summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--spec/migrations/clean_stage_id_reference_migration_spec.rb22
1 files changed, 13 insertions, 9 deletions
diff --git a/spec/migrations/clean_stage_id_reference_migration_spec.rb b/spec/migrations/clean_stage_id_reference_migration_spec.rb
index c2072f2672d..9a581df28a2 100644
--- a/spec/migrations/clean_stage_id_reference_migration_spec.rb
+++ b/spec/migrations/clean_stage_id_reference_migration_spec.rb
@@ -2,28 +2,32 @@ require 'spec_helper'
require Rails.root.join('db', 'migrate', '20170710083355_clean_stage_id_reference_migration.rb')
describe CleanStageIdReferenceMigration, :migration, :sidekiq, :redis do
- let(:migration) { 'MigrateBuildStageIdReference' }
+ let(:migration_class) { 'MigrateBuildStageIdReference' }
+ let(:migration) { spy('migration') }
+
+ before do
+ allow(Gitlab::BackgroundMigration.const_get(migration_class))
+ .to receive(:new).and_return(migration)
+ end
context 'when there are pending background migrations' do
it 'processes pending jobs synchronously' do
Sidekiq::Testing.disable! do
- BackgroundMigrationWorker.perform_in(2.minutes, migration, [1, 1])
- BackgroundMigrationWorker.perform_async(migration, [1, 1])
-
- expect(Gitlab::BackgroundMigration)
- .to receive(:perform).twice.and_call_original
+ BackgroundMigrationWorker.perform_in(2.minutes, migration_class, [1, 1])
+ BackgroundMigrationWorker.perform_async(migration_class, [1, 1])
migrate!
+
+ expect(migration).to have_received(:perform).with(1, 1).twice
end
end
end
-
context 'when there are no background migrations pending' do
it 'does nothing' do
Sidekiq::Testing.disable! do
- expect(Gitlab::BackgroundMigration).not_to receive(:perform)
-
migrate!
+
+ expect(migration).not_to have_received(:perform)
end
end
end