summaryrefslogtreecommitdiff
path: root/spec/lib/gitlab/background_migration/add_merge_request_diff_commits_count_spec.rb
blob: c43ed72038eab9bc99566b8d00d9ef2755b9bee7 (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
require 'spec_helper'

describe Gitlab::BackgroundMigration::AddMergeRequestDiffCommitsCount, :migration, schema: 20180105212544 do
  let(:projects_table) { table(:projects) }
  let(:merge_requests_table) { table(:merge_requests) }
  let(:merge_request_diffs_table) { table(:merge_request_diffs) }
  let(:merge_request_diff_commits_table) { table(:merge_request_diff_commits) }

  let(:project) { projects_table.create!(name: 'gitlab', path: 'gitlab-org/gitlab-ce') }
  let(:merge_request) do
    merge_requests_table.create!(target_project_id: project.id,
                                 target_branch: 'master',
                                 source_project_id: project.id,
                                 source_branch: 'mr name',
                                 title: 'mr name')
  end

  def create_diff!(name, commits: 0)
    mr_diff = merge_request_diffs_table.create!(
      merge_request_id: merge_request.id)

    commits.times do |i|
      merge_request_diff_commits_table.create!(
        merge_request_diff_id: mr_diff.id,
        relative_order: i, sha: i)
    end

    mr_diff
  end

  describe '#perform' do
    it 'migrates diffs that have no commits' do
      diff = create_diff!('with_multiple_commits', commits: 0)

      subject.perform(diff.id, diff.id)

      expect(diff.reload.commits_count).to eq(0)
    end

    it 'skips diffs that have commits_count already set' do
      timestamp = 2.days.ago
      diff = merge_request_diffs_table.create!(
        merge_request_id: merge_request.id,
        commits_count: 0,
        updated_at: timestamp)

      subject.perform(diff.id, diff.id)

      expect(diff.reload.updated_at).to be_within(1.second).of(timestamp)
    end

    it 'migrates multiple diffs to the correct values' do
      diffs = Array.new(3).map.with_index { |_, i| create_diff!(i, commits: 3) }

      subject.perform(diffs.first.id, diffs.last.id)

      diffs.each do |diff|
        expect(diff.reload.commits_count).to eq(3)
      end
    end
  end
end