diff options
Diffstat (limited to 'spec/migrations/schedule_populate_requirements_issue_id_spec.rb')
-rw-r--r-- | spec/migrations/schedule_populate_requirements_issue_id_spec.rb | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/spec/migrations/schedule_populate_requirements_issue_id_spec.rb b/spec/migrations/schedule_populate_requirements_issue_id_spec.rb new file mode 100644 index 00000000000..2702c000b60 --- /dev/null +++ b/spec/migrations/schedule_populate_requirements_issue_id_spec.rb @@ -0,0 +1,79 @@ +# frozen_string_literal: true + +require 'spec_helper' +require_migration! + +RSpec.describe SchedulePopulateRequirementsIssueId do + include MigrationHelpers::WorkItemTypesHelper + + let(:issues) { table(:issues) } + let(:requirements) { table(:requirements) } + let(:namespaces) { table(:namespaces) } + let(:projects) { table(:projects) } + let(:users) { table(:users) } + let!(:group) { namespaces.create!(name: 'gitlab', path: 'gitlab-org') } + let!(:project_namespace) { namespaces.create!(name: 'project-namespace', path: 'project-namespace') } + + let!(:project) do + projects.create!(namespace_id: group.id, project_namespace_id: project_namespace.id, name: 'gitlab', path: 'gitlab') + end + + let(:migration) { described_class::MIGRATION } + + let!(:author) do + users.create!( + email: 'author@example.com', + notification_email: 'author@example.com', + name: 'author', + username: 'author', + projects_limit: 10, + state: 'active') + end + + before do + stub_const("#{described_class.name}::BATCH_SIZE", 2) + end + + it 'schedules jobs for all requirements without issues in sync' do + Sidekiq::Testing.fake! do + freeze_time do + migrate! + + # Restores the previous schema so we do not have a NOT NULL + # constraint on requirements.issue_id column, which would + # prevent us to create invalid requirement records. + migration_context.down(previous_migration(3).version) + + requirement_1 = create_requirement(iid: 1, title: 'r 1') + + # Create one requirement with issue_id present, to make + # sure a job won't be scheduled for it + work_item_type_id = work_item_types_table.find_by(namespace_id: nil, name: 'Issue').id + issue = issues.create!(state_id: 1, work_item_type_id: work_item_type_id) + create_requirement(iid: 2, title: 'r 2', issue_id: issue.id) + + requirement_3 = create_requirement(iid: 3, title: 'r 3') + requirement_4 = create_requirement(iid: 4, title: 'r 4') + requirement_5 = create_requirement(iid: 5, title: 'r 5') + + migrate! + + expect(migration).to be_scheduled_delayed_migration(120.seconds, requirement_1.id, requirement_3.id) + expect(migration).to be_scheduled_delayed_migration(240.seconds, requirement_4.id, requirement_5.id) + expect(BackgroundMigrationWorker.jobs.size).to eq(2) + end + end + end + + def create_requirement(iid:, title:, issue_id: nil) + requirements.create!( + iid: iid, + project_id: project.id, + issue_id: issue_id, + title: title, + state: 1, + created_at: Time.now, + updated_at: Time.now, + author_id: author.id) + end +end |