2017-06-28 09:29:04 +00:00
|
|
|
require 'spec_helper'
|
|
|
|
require Rails.root.join('db', 'post_migrate', '20170628080858_migrate_stage_id_reference_in_background')
|
|
|
|
|
2017-06-29 10:10:29 +00:00
|
|
|
describe MigrateStageIdReferenceInBackground, :migration, :sidekiq do
|
2017-06-28 09:29:04 +00:00
|
|
|
let(:jobs) { table(:ci_builds) }
|
|
|
|
let(:stages) { table(:ci_stages) }
|
|
|
|
let(:pipelines) { table(:ci_pipelines) }
|
|
|
|
let(:projects) { table(:projects) }
|
|
|
|
|
|
|
|
before do
|
2017-07-07 13:44:47 +00:00
|
|
|
stub_const("#{described_class.name}::BATCH_SIZE", 3)
|
|
|
|
stub_const("#{described_class.name}::RANGE_SIZE", 2)
|
2017-06-28 10:21:25 +00:00
|
|
|
|
2017-06-28 09:29:04 +00:00
|
|
|
projects.create!(id: 123, name: 'gitlab1', path: 'gitlab1')
|
2017-06-29 10:26:37 +00:00
|
|
|
projects.create!(id: 345, name: 'gitlab2', path: 'gitlab2')
|
|
|
|
|
2017-06-28 09:29:04 +00:00
|
|
|
pipelines.create!(id: 1, project_id: 123, ref: 'master', sha: 'adf43c3a')
|
2017-06-29 10:26:37 +00:00
|
|
|
pipelines.create!(id: 2, project_id: 345, ref: 'feature', sha: 'cdf43c3c')
|
2017-06-28 09:29:04 +00:00
|
|
|
|
|
|
|
jobs.create!(id: 1, commit_id: 1, project_id: 123, stage_idx: 2, stage: 'build')
|
|
|
|
jobs.create!(id: 2, commit_id: 1, project_id: 123, stage_idx: 2, stage: 'build')
|
|
|
|
jobs.create!(id: 3, commit_id: 1, project_id: 123, stage_idx: 1, stage: 'test')
|
|
|
|
jobs.create!(id: 4, commit_id: 1, project_id: 123, stage_idx: 3, stage: 'deploy')
|
2017-06-29 10:26:37 +00:00
|
|
|
jobs.create!(id: 5, commit_id: 2, project_id: 345, stage_idx: 1, stage: 'test')
|
2017-06-28 09:29:04 +00:00
|
|
|
|
|
|
|
stages.create(id: 101, pipeline_id: 1, project_id: 123, name: 'test')
|
|
|
|
stages.create(id: 102, pipeline_id: 1, project_id: 123, name: 'build')
|
|
|
|
stages.create(id: 103, pipeline_id: 1, project_id: 123, name: 'deploy')
|
2017-06-29 10:26:37 +00:00
|
|
|
|
|
|
|
jobs.create!(id: 6, commit_id: 2, project_id: 345, stage_id: 101, stage_idx: 1, stage: 'test')
|
2017-06-28 09:29:04 +00:00
|
|
|
end
|
|
|
|
|
2017-06-28 13:24:53 +00:00
|
|
|
it 'correctly schedules background migrations' do
|
|
|
|
Sidekiq::Testing.fake! do
|
2017-06-29 10:10:29 +00:00
|
|
|
Timecop.freeze do
|
|
|
|
migrate!
|
2017-06-28 13:24:53 +00:00
|
|
|
|
2018-01-05 09:15:03 +00:00
|
|
|
expect(described_class::MIGRATION).to be_scheduled_delayed_migration(2.minutes, 1, 2)
|
|
|
|
expect(described_class::MIGRATION).to be_scheduled_delayed_migration(2.minutes, 3, 3)
|
|
|
|
expect(described_class::MIGRATION).to be_scheduled_delayed_migration(4.minutes, 4, 5)
|
2017-07-07 13:50:33 +00:00
|
|
|
expect(BackgroundMigrationWorker.jobs.size).to eq 3
|
2017-06-29 10:10:29 +00:00
|
|
|
end
|
2017-06-28 13:24:53 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-06-28 09:29:04 +00:00
|
|
|
it 'schedules background migrations' do
|
2018-07-23 04:34:54 +00:00
|
|
|
perform_enqueued_jobs do
|
2017-06-29 13:26:47 +00:00
|
|
|
expect(jobs.where(stage_id: nil).count).to eq 5
|
2017-06-28 10:01:52 +00:00
|
|
|
|
2017-06-28 13:24:53 +00:00
|
|
|
migrate!
|
2017-06-28 10:01:52 +00:00
|
|
|
|
2017-06-29 13:26:47 +00:00
|
|
|
expect(jobs.where(stage_id: nil).count).to eq 1
|
2017-06-28 13:24:53 +00:00
|
|
|
end
|
2017-06-28 09:29:04 +00:00
|
|
|
end
|
|
|
|
end
|