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

20230530012406_finalize_backfill_resource_link_events_spec.rb « migrations « spec - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 0298b470ac8c4c860a112fe2514eed5d04f05a95 (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 FinalizeBackfillResourceLinkEvents, feature_category: :team_planning do
  let(:batched_migrations) { table(:batched_background_migrations) }

  context 'when migration is missing' do
    before do
      batched_migrations.where(job_class_name: described_class::MIGRATION).delete_all
    end

    it 'warns migration not found' do
      expect(Gitlab::AppLogger)
        .to receive(:warn).with(/Could not find batched background migration for the given configuration:/)
                          .once

      migrate!
    end
  end

  context 'with migration present' do
    let!(:batched_migration) do
      batched_migrations.create!(
        job_class_name: described_class::MIGRATION,
        table_name: :system_note_metadata,
        column_name: :id,
        interval: 2.minutes,
        min_value: 1,
        max_value: 5,
        batch_size: 5,
        sub_batch_size: 5,
        gitlab_schema: :gitlab_main,
        status: status
      )
    end

    context 'when migrations have finished' do
      let(:status) { 3 } # finished enum value

      it 'does not raise an error' do
        expect { migrate! }.not_to raise_error
      end
    end

    context 'with different migration statuses' do
      using RSpec::Parameterized::TableSyntax

      where(:status, :description) do
        0 | 'paused'
        1 | 'active'
        4 | 'failed'
        5 | 'finalizing'
      end

      with_them do
        it 'finalizes the migration' do
          expect do
            migrate!

            batched_migration.reload
          end.to change { batched_migration.status }.from(status).to(3)
        end
      end
    end
  end
end