2019-04-11 08:17:24 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-08-11 09:22:35 -04:00
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-06-24 02:09:01 -04:00
|
|
|
RSpec.describe Ci::ProcessPipelineService do
|
2016-08-11 09:22:35 -04:00
|
|
|
let(:user) { create(:user) }
|
2017-08-02 15:55:11 -04:00
|
|
|
let(:project) { create(:project) }
|
2017-02-13 07:19:23 -05:00
|
|
|
|
|
|
|
let(:pipeline) do
|
|
|
|
create(:ci_empty_pipeline, ref: 'master', project: project)
|
|
|
|
end
|
|
|
|
|
2020-07-15 08:09:26 -04:00
|
|
|
subject { described_class.new(pipeline) }
|
|
|
|
|
2017-02-13 07:19:23 -05:00
|
|
|
before do
|
2018-02-27 21:56:18 -05:00
|
|
|
stub_ci_pipeline_to_return_yaml_file
|
2017-07-18 10:32:34 -04:00
|
|
|
stub_not_protect_default_branch
|
|
|
|
|
|
|
|
project.add_developer(user)
|
2017-02-13 07:19:23 -05:00
|
|
|
end
|
2016-08-11 09:22:35 -04:00
|
|
|
|
2020-07-15 08:09:26 -04:00
|
|
|
describe 'processing events counter' do
|
|
|
|
let(:metrics) { double('pipeline metrics') }
|
|
|
|
let(:counter) { double('events counter') }
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(subject)
|
|
|
|
.to receive(:metrics).and_return(metrics)
|
|
|
|
allow(metrics)
|
|
|
|
.to receive(:pipeline_processing_events_counter)
|
|
|
|
.and_return(counter)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'increments processing events counter' do
|
|
|
|
expect(counter).to receive(:increment)
|
|
|
|
|
|
|
|
subject.execute
|
|
|
|
end
|
|
|
|
end
|
2017-04-16 07:14:39 -04:00
|
|
|
|
2020-07-15 08:09:26 -04:00
|
|
|
describe 'updating a list of retried builds' do
|
2017-04-16 07:14:39 -04:00
|
|
|
let!(:build_retried) { create_build('build') }
|
|
|
|
let!(:build) { create_build('build') }
|
|
|
|
let!(:test) { create_build('test') }
|
|
|
|
|
2021-03-09 07:08:52 -05:00
|
|
|
context 'when FF ci_remove_update_retried_from_process_pipeline is enabled' do
|
|
|
|
it 'does not update older builds as retried' do
|
|
|
|
subject.execute
|
2017-04-16 07:14:39 -04:00
|
|
|
|
2021-03-09 07:08:52 -05:00
|
|
|
expect(all_builds.latest).to contain_exactly(build, build_retried, test)
|
|
|
|
expect(all_builds.retried).to be_empty
|
|
|
|
end
|
2017-04-16 07:14:39 -04:00
|
|
|
end
|
2017-03-03 06:51:23 -05:00
|
|
|
|
2021-03-09 07:08:52 -05:00
|
|
|
context 'when FF ci_remove_update_retried_from_process_pipeline is disabled' do
|
2021-02-04 13:09:22 -05:00
|
|
|
before do
|
2021-03-09 07:08:52 -05:00
|
|
|
stub_feature_flags(ci_remove_update_retried_from_process_pipeline: false)
|
2021-02-04 13:09:22 -05:00
|
|
|
end
|
|
|
|
|
2021-03-09 07:08:52 -05:00
|
|
|
it 'returns unique statuses' do
|
2021-02-04 13:09:22 -05:00
|
|
|
subject.execute
|
2021-03-09 07:08:52 -05:00
|
|
|
|
|
|
|
expect(all_builds.latest).to contain_exactly(build, test)
|
|
|
|
expect(all_builds.retried).to contain_exactly(build_retried)
|
2021-02-04 13:09:22 -05:00
|
|
|
end
|
|
|
|
|
2021-03-09 07:08:52 -05:00
|
|
|
context 'counter ci_legacy_update_jobs_as_retried_total' do
|
|
|
|
let(:counter) { double(increment: true) }
|
|
|
|
|
2021-02-04 13:09:22 -05:00
|
|
|
before do
|
2021-03-09 07:08:52 -05:00
|
|
|
allow(Gitlab::Metrics).to receive(:counter).and_call_original
|
|
|
|
allow(Gitlab::Metrics).to receive(:counter)
|
|
|
|
.with(:ci_legacy_update_jobs_as_retried_total, anything)
|
|
|
|
.and_return(counter)
|
2021-02-04 13:09:22 -05:00
|
|
|
end
|
|
|
|
|
2021-03-09 07:08:52 -05:00
|
|
|
it 'increments the counter' do
|
|
|
|
expect(counter).to receive(:increment)
|
2021-02-04 13:09:22 -05:00
|
|
|
|
|
|
|
subject.execute
|
|
|
|
end
|
2021-03-09 07:08:52 -05:00
|
|
|
|
|
|
|
context 'when the previous build has already retried column true' do
|
|
|
|
before do
|
|
|
|
build_retried.update_columns(retried: true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not increment the counter' do
|
|
|
|
expect(counter).not_to receive(:increment)
|
|
|
|
|
|
|
|
subject.execute
|
|
|
|
end
|
|
|
|
end
|
2021-02-04 13:09:22 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2021-03-09 07:08:52 -05:00
|
|
|
private
|
|
|
|
|
2020-07-15 08:09:26 -04:00
|
|
|
def create_build(name, **opts)
|
|
|
|
create(:ci_build, :created, pipeline: pipeline, name: name, **opts)
|
|
|
|
end
|
2018-09-27 03:10:55 -04:00
|
|
|
|
2020-07-15 08:09:26 -04:00
|
|
|
def all_builds
|
|
|
|
pipeline.builds.order(:stage_idx, :id)
|
|
|
|
end
|
2018-09-27 03:10:55 -04:00
|
|
|
end
|
2016-08-11 09:22:35 -04:00
|
|
|
end
|