File: drop_pipeline_worker_spec.rb

package info (click to toggle)
gitlab 17.6.5-19
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 629,368 kB
  • sloc: ruby: 1,915,304; javascript: 557,307; sql: 60,639; xml: 6,509; sh: 4,567; makefile: 1,239; python: 406
file content (36 lines) | stat: -rw-r--r-- 1,057 bytes parent folder | download
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
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Ci::DropPipelineWorker, feature_category: :continuous_integration do
  include AfterNextHelpers

  let(:pipeline) { create(:ci_pipeline, :running) }
  let(:failure_reason) { :user_blocked }

  describe '#perform' do
    subject { described_class.new.perform(pipeline.id, failure_reason) }

    it 'calls delegates to the service' do
      expect_next(Ci::DropPipelineService).to receive(:execute).with(pipeline, failure_reason)

      subject
    end

    it_behaves_like 'an idempotent worker' do
      let!(:running_build) { create(:ci_build, :running, pipeline: pipeline) }
      let!(:success_build) { create(:ci_build, :success, pipeline: pipeline) }

      let(:job_args) { [pipeline.id, failure_reason] }

      it 'executes the service', :aggregate_failures do
        subject

        expect(running_build.reload).to be_failed
        expect(running_build.failure_reason).to eq(failure_reason.to_s)

        expect(success_build.reload).to be_success
      end
    end
  end
end