summaryrefslogtreecommitdiff
path: root/spec/workers/build_hooks_worker_spec.rb
blob: 426eb03638c22689a127e6442528cb908d63df81 (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
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe BuildHooksWorker do
  describe '#perform' do
    context 'when build exists' do
      let!(:build) { create(:ci_build) }

      it 'calls build hooks' do
        expect_any_instance_of(Ci::Build)
          .to receive(:execute_hooks)

        described_class.new.perform(build.id)
      end
    end

    context 'when build does not exist' do
      it 'does not raise exception' do
        expect { described_class.new.perform(123) }
          .not_to raise_error
      end
    end
  end

  describe '.perform_async' do
    it 'sends a message to the application logger, before performing', :sidekiq_inline do
      build = create(:ci_build)

      expect(Gitlab::AppLogger).to receive(:info).with(
        message: include('Enqueuing hooks for Build'),
        class: described_class.name,
        build_id: build.id,
        pipeline_id: build.pipeline_id,
        project_id: build.project_id,
        build_status: build.status
      )

      expect_any_instance_of(Ci::Build).to receive(:execute_hooks)

      described_class.perform_async(build)
    end
  end

  it_behaves_like 'worker with data consistency',
                  described_class,
                  data_consistency: :delayed
end