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

merge_request_cleanup_refs_worker_spec.rb « workers « spec - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 6c87b6827a80b0a9f06bf7bdb57ac4122b5587af (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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe MergeRequestCleanupRefsWorker, feature_category: :code_review_workflow do
  let(:worker) { described_class.new }

  describe '#perform_work' do
    context 'when next cleanup schedule is found' do
      let(:failed_count) { 0 }
      let!(:cleanup_schedule) { create(:merge_request_cleanup_schedule, failed_count: failed_count) }

      it 'marks the cleanup schedule as completed on success' do
        stub_cleanup_service(status: :success)
        worker.perform_work

        expect(cleanup_schedule.reload).to be_completed
        expect(cleanup_schedule.completed_at).to be_present
      end

      context 'when service fails' do
        before do
          stub_cleanup_service(status: :error)
          worker.perform_work
        end

        it 'marks the cleanup schedule as unstarted and track the failure' do
          expect(cleanup_schedule.reload).to be_unstarted
          expect(cleanup_schedule.failed_count).to eq(1)
          expect(cleanup_schedule.completed_at).to be_nil
        end

        context "and cleanup schedule has already failed #{WebHooks::AutoDisabling::FAILURE_THRESHOLD} times" do
          let(:failed_count) { WebHooks::AutoDisabling::FAILURE_THRESHOLD }

          it 'marks the cleanup schedule as failed and track the failure' do
            expect(cleanup_schedule.reload).to be_failed
            expect(cleanup_schedule.failed_count).to eq(failed_count + 1)
            expect(cleanup_schedule.completed_at).to be_nil
          end
        end
      end
    end

    context 'when there is no next cleanup schedule found' do
      it 'does nothing' do
        expect(MergeRequests::CleanupRefsService).not_to receive(:new)

        worker.perform_work
      end
    end
  end

  describe '#remaining_work_count' do
    let_it_be(:unstarted) { create_list(:merge_request_cleanup_schedule, 2) }
    let_it_be(:running) { create_list(:merge_request_cleanup_schedule, 2, :running) }
    let_it_be(:completed) { create_list(:merge_request_cleanup_schedule, 2, :completed) }

    it 'returns number of scheduled and unstarted cleanup schedule records' do
      expect(worker.remaining_work_count).to eq(unstarted.count)
    end

    context 'when count exceeds max_running_jobs' do
      before do
        create_list(:merge_request_cleanup_schedule, worker.max_running_jobs)
      end

      it 'gets capped at max_running_jobs' do
        expect(worker.remaining_work_count).to eq(worker.max_running_jobs)
      end
    end
  end

  describe '#max_running_jobs' do
    it 'returns the value of MAX_RUNNING_JOBS' do
      expect(worker.max_running_jobs).to eq(described_class::MAX_RUNNING_JOBS)
    end
  end

  def stub_cleanup_service(result)
    expect_next_instance_of(MergeRequests::CleanupRefsService, cleanup_schedule.merge_request) do |svc|
      expect(svc).to receive(:execute).and_return(result)
    end
  end
end