2021-04-29 21:17:54 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
RSpec.describe Ci::DropPipelineService do
|
|
|
|
let_it_be(:user) { create(:user) }
|
|
|
|
|
|
|
|
let(:failure_reason) { :user_blocked }
|
|
|
|
|
|
|
|
let!(:cancelable_pipeline) { create(:ci_pipeline, :running, user: user) }
|
|
|
|
let!(:running_build) { create(:ci_build, :running, pipeline: cancelable_pipeline) }
|
2021-10-27 15:23:28 +05:30
|
|
|
let!(:commit_status_running) { create(:commit_status, :running, pipeline: cancelable_pipeline) }
|
2021-04-29 21:17:54 +05:30
|
|
|
let!(:success_pipeline) { create(:ci_pipeline, :success, user: user) }
|
|
|
|
let!(:success_build) { create(:ci_build, :success, pipeline: success_pipeline) }
|
2021-10-27 15:23:28 +05:30
|
|
|
let!(:commit_status_success) { create(:commit_status, :success, pipeline: cancelable_pipeline) }
|
2021-04-29 21:17:54 +05:30
|
|
|
|
|
|
|
describe '#execute_async_for_all' do
|
|
|
|
subject { described_class.new.execute_async_for_all(user.pipelines, failure_reason, user) }
|
|
|
|
|
|
|
|
it 'drops only cancelable pipelines asynchronously', :sidekiq_inline do
|
|
|
|
subject
|
|
|
|
|
|
|
|
expect(cancelable_pipeline.reload).to be_failed
|
|
|
|
expect(running_build.reload).to be_failed
|
|
|
|
|
|
|
|
expect(success_pipeline.reload).to be_success
|
|
|
|
expect(success_build.reload).to be_success
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#execute' do
|
|
|
|
subject { described_class.new.execute(cancelable_pipeline.id, failure_reason) }
|
|
|
|
|
|
|
|
def drop_pipeline!(pipeline)
|
|
|
|
described_class.new.execute(pipeline, failure_reason)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'drops each cancelable build in the pipeline', :aggregate_failures do
|
|
|
|
drop_pipeline!(cancelable_pipeline)
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
it 'avoids N+1 queries when reading data' do
|
|
|
|
control_count = ActiveRecord::QueryRecorder.new do
|
|
|
|
drop_pipeline!(cancelable_pipeline)
|
|
|
|
end.count
|
|
|
|
|
|
|
|
writes_per_build = 2
|
|
|
|
expected_reads_count = control_count - writes_per_build
|
|
|
|
|
|
|
|
create_list(:ci_build, 5, :running, pipeline: cancelable_pipeline)
|
|
|
|
|
|
|
|
expect do
|
|
|
|
drop_pipeline!(cancelable_pipeline)
|
|
|
|
end.not_to exceed_query_limit(expected_reads_count + (5 * writes_per_build))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|