summaryrefslogtreecommitdiff
path: root/spec/migrations/schedule_backfill_draft_status_on_merge_requests_corrected_regex_spec.rb
blob: 8a14bf586989494eacdf590c7771962e7268cf9f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
# frozen_string_literal: true

require 'spec_helper'

require_migration!

RSpec.describe ScheduleBackfillDraftStatusOnMergeRequestsCorrectedRegex, :sidekiq, feature_category: :code_review do
  let(:namespaces)     { table(:namespaces) }
  let(:projects)       { table(:projects) }
  let(:merge_requests) { table(:merge_requests) }

  let!(:namespace) { namespaces.create!(name: 'namespace', path: 'namespace') }
  let(:proj_namespace) { namespaces.create!(name: 'proj1', path: 'proj1', type: 'Project', parent_id: namespace.id) }
  let!(:project) { projects.create!(namespace_id: namespace.id, project_namespace_id: proj_namespace.id) }

  let(:draft_prefixes) { ["[Draft]", "(Draft)", "Draft:", "Draft", "[WIP]", "WIP:", "WIP"] }

  def create_merge_request(params)
    common_params = {
      target_project_id: project.id,
      target_branch: 'feature1',
      source_branch: 'master'
    }

    merge_requests.create!(common_params.merge(params))
  end

  before do
    draft_prefixes.each do |prefix|
      (1..4).each do |n|
        create_merge_request(
          title: "#{prefix} This is a title",
          draft: false,
          state_id: n
        )

        create_merge_request(
          title: "This is a title with the #{prefix} in a weird spot",
          draft: false,
          state_id: n
        )
      end
    end

    stub_const("#{described_class}::BATCH_SIZE", 1)
  end

  it 'schedules BackfillDraftStatusOnMergeRequests background jobs' do
    Sidekiq::Testing.fake! do
      draft_mrs = MergeRequest.where(state_id: 1)
        .where(draft: false)
        .where("title ~* ?", described_class::CORRECTED_REGEXP_STR)

      first_mr_id = draft_mrs.first.id
      second_mr_id = draft_mrs.second.id

      freeze_time do
        migrate!

        expect(BackgroundMigrationWorker.jobs.size).to eq(7)
        expect(described_class::MIGRATION)
          .to be_scheduled_delayed_migration(2.minutes, first_mr_id, first_mr_id)
        expect(described_class::MIGRATION)
          .to be_scheduled_delayed_migration(4.minutes, second_mr_id, second_mr_id)
      end
    end
  end
end