Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/migrations/schedule_populate_requirements_issue_id_spec.rb')
-rw-r--r--spec/migrations/schedule_populate_requirements_issue_id_spec.rb79
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