# 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