Commit 10e8074a authored by Markus Koller's avatar Markus Koller

Merge branch 'mc/feature/rename-create-downstream-pipeline-worker' into 'master'

Rename CreateCrossProjectPipeline worker

See merge request gitlab-org/gitlab!70816
parents cbd8a04d cc979a1b
...@@ -31,9 +31,13 @@ module Ci ...@@ -31,9 +31,13 @@ module Ci
next unless bridge.triggers_downstream_pipeline? next unless bridge.triggers_downstream_pipeline?
bridge.run_after_commit do bridge.run_after_commit do
if ::Feature.enabled?(:create_cross_project_pipeline_worker_rename, default_enabled: :yaml)
::Ci::CreateDownstreamPipelineWorker.perform_async(bridge.id)
else
::Ci::CreateCrossProjectPipelineWorker.perform_async(bridge.id) ::Ci::CreateCrossProjectPipelineWorker.perform_async(bridge.id)
end end
end end
end
event :pending do event :pending do
transition all => :pending transition all => :pending
......
...@@ -1474,6 +1474,15 @@ ...@@ -1474,6 +1474,15 @@
:weight: 3 :weight: 3
:idempotent: :idempotent:
:tags: [] :tags: []
- :name: pipeline_default:ci_create_downstream_pipeline
:worker_name: Ci::CreateDownstreamPipelineWorker
:feature_category: :continuous_integration
:has_external_dependencies:
:urgency: :low
:resource_boundary: :cpu
:weight: 3
:idempotent:
:tags: []
- :name: pipeline_default:ci_drop_pipeline - :name: pipeline_default:ci_drop_pipeline
:worker_name: Ci::DropPipelineWorker :worker_name: Ci::DropPipelineWorker
:feature_category: :continuous_integration :feature_category: :continuous_integration
......
# frozen_string_literal: true
module Ci
class CreateDownstreamPipelineWorker # rubocop:disable Scalability/IdempotentWorker
include ::ApplicationWorker
include ::PipelineQueue
sidekiq_options retry: 3
worker_resource_boundary :cpu
def perform(bridge_id)
::Ci::Bridge.find_by_id(bridge_id).try do |bridge|
::Ci::CreateDownstreamPipelineService
.new(bridge.project, bridge.user)
.execute(bridge)
end
end
end
end
---
name: create_cross_project_pipeline_worker_rename
introduced_by_url: https://gitlab.com/gitlab-org/gitlab/-/merge_requests/70816
rollout_issue_url: https://gitlab.com/gitlab-org/gitlab/-/issues/341410
milestone: '14.4'
type: development
group: group::pipeline authoring
default_enabled: false
...@@ -41,6 +41,23 @@ RSpec.describe Ci::Bridge do ...@@ -41,6 +41,23 @@ RSpec.describe Ci::Bridge do
bridge.enqueue! bridge.enqueue!
end end
context 'when the create_cross_project_pipeline_worker_rename feature is enabled' do
before do
stub_feature_flags(create_cross_project_pipeline_worker_rename: true)
end
it 'does not schedule downstream pipeline creation' do
bridge.enqueue!
expect(::Ci::CreateDownstreamPipelineWorker.jobs).to be_empty
end
end
context 'when the create_cross_project_pipeline_worker_rename feature is not enabled' do
before do
stub_feature_flags(create_cross_project_pipeline_worker_rename: false)
end
it 'does not schedule downstream pipeline creation' do it 'does not schedule downstream pipeline creation' do
bridge.enqueue! bridge.enqueue!
...@@ -48,6 +65,7 @@ RSpec.describe Ci::Bridge do ...@@ -48,6 +65,7 @@ RSpec.describe Ci::Bridge do
end end
end end
end end
end
describe '#inherit_status_from_upstream!' do describe '#inherit_status_from_upstream!' do
before do before do
......
...@@ -73,6 +73,25 @@ RSpec.describe Ci::Bridge do ...@@ -73,6 +73,25 @@ RSpec.describe Ci::Bridge do
describe 'state machine transitions' do describe 'state machine transitions' do
context 'when bridge points towards downstream' do context 'when bridge points towards downstream' do
%i[created manual].each do |status| %i[created manual].each do |status|
context 'when the create_cross_project_pipeline_worker_rename feature is enabled' do
before do
stub_feature_flags(create_cross_project_pipeline_worker_rename: true)
end
it "schedules downstream pipeline creation when the status is #{status}" do
bridge.status = status
bridge.enqueue!
expect(::Ci::CreateDownstreamPipelineWorker.jobs.last['args']).to eq([bridge.id])
end
end
context 'when the create_cross_project_pipeline_worker_rename feature is not enabled' do
before do
stub_feature_flags(create_cross_project_pipeline_worker_rename: false)
end
it "schedules downstream pipeline creation when the status is #{status}" do it "schedules downstream pipeline creation when the status is #{status}" do
bridge.status = status bridge.status = status
...@@ -81,6 +100,26 @@ RSpec.describe Ci::Bridge do ...@@ -81,6 +100,26 @@ RSpec.describe Ci::Bridge do
expect(::Ci::CreateCrossProjectPipelineWorker.jobs.last['args']).to eq([bridge.id]) expect(::Ci::CreateCrossProjectPipelineWorker.jobs.last['args']).to eq([bridge.id])
end end
end end
end
context 'when the create_cross_project_pipeline_worker_rename feature is enabled' do
before do
stub_feature_flags(create_cross_project_pipeline_worker_rename: true)
end
it "schedules downstream pipeline creation when the status is waiting for resource" do
bridge.status = :waiting_for_resource
bridge.enqueue_waiting_for_resource!
expect(::Ci::CreateDownstreamPipelineWorker.jobs.last['args']).to eq([bridge.id])
end
end
context 'when the create_cross_project_pipeline_worker_rename feature is not enabled' do
before do
stub_feature_flags(create_cross_project_pipeline_worker_rename: false)
end
it "schedules downstream pipeline creation when the status is waiting for resource" do it "schedules downstream pipeline creation when the status is waiting for resource" do
bridge.status = :waiting_for_resource bridge.status = :waiting_for_resource
...@@ -89,6 +128,7 @@ RSpec.describe Ci::Bridge do ...@@ -89,6 +128,7 @@ RSpec.describe Ci::Bridge do
expect(::Ci::CreateCrossProjectPipelineWorker.jobs.last['args']).to eq([bridge.id]) expect(::Ci::CreateCrossProjectPipelineWorker.jobs.last['args']).to eq([bridge.id])
end end
end
it 'raises error when the status is failed' do it 'raises error when the status is failed' do
bridge.status = :failed bridge.status = :failed
......
...@@ -23,16 +23,34 @@ RSpec.describe Ci::PlayBridgeService, '#execute' do ...@@ -23,16 +23,34 @@ RSpec.describe Ci::PlayBridgeService, '#execute' do
expect(bridge.reload).to be_pending expect(bridge.reload).to be_pending
end end
it 'enqueues Ci::CreateCrossProjectPipelineWorker' do it "updates bridge's user" do
expect(::Ci::CreateCrossProjectPipelineWorker).to receive(:perform_async).with(bridge.id)
execute_service execute_service
expect(bridge.reload.user).to eq(user)
end end
it "updates bridge's user" do context 'when the create_cross_project_pipeline_worker_rename feature is enabled' do
before do
stub_feature_flags(create_cross_project_pipeline_worker_rename: true)
end
it 'enqueues Ci::CreateDownstreamPipelineWorker' do
expect(::Ci::CreateDownstreamPipelineWorker).to receive(:perform_async).with(bridge.id)
execute_service execute_service
end
end
expect(bridge.reload.user).to eq(user) context 'when the create_cross_project_pipeline_worker_rename feature is not enabled' do
before do
stub_feature_flags(create_cross_project_pipeline_worker_rename: false)
end
it 'enqueues Ci::CreateCrossProjectPipelineWorker' do
expect(::Ci::CreateCrossProjectPipelineWorker).to receive(:perform_async).with(bridge.id)
execute_service
end
end end
context 'when a subsequent job is skipped' do context 'when a subsequent job is skipped' do
......
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Ci::CreateDownstreamPipelineWorker do
let_it_be(:user) { create(:user) }
let_it_be(:project) { create(:project) }
let_it_be(:pipeline) { create(:ci_pipeline, project: project) }
let(:bridge) { create(:ci_bridge, user: user, pipeline: pipeline) }
let(:service) { double('pipeline creation service') }
describe '#perform' do
context 'when bridge exists' do
it 'calls cross project pipeline creation service' do
expect(Ci::CreateDownstreamPipelineService)
.to receive(:new)
.with(project, user)
.and_return(service)
expect(service).to receive(:execute).with(bridge)
described_class.new.perform(bridge.id)
end
end
context 'when bridge does not exist' do
it 'does nothing' do
expect(Ci::CreateDownstreamPipelineService)
.not_to receive(:new)
described_class.new.perform(non_existing_record_id)
end
end
end
end
...@@ -155,6 +155,7 @@ RSpec.describe 'Every Sidekiq worker' do ...@@ -155,6 +155,7 @@ RSpec.describe 'Every Sidekiq worker' do
'Ci::BuildScheduleWorker' => 3, 'Ci::BuildScheduleWorker' => 3,
'Ci::BuildTraceChunkFlushWorker' => 3, 'Ci::BuildTraceChunkFlushWorker' => 3,
'Ci::CreateCrossProjectPipelineWorker' => 3, 'Ci::CreateCrossProjectPipelineWorker' => 3,
'Ci::CreateDownstreamPipelineWorker' => 3,
'Ci::DailyBuildGroupReportResultsWorker' => 3, 'Ci::DailyBuildGroupReportResultsWorker' => 3,
'Ci::DeleteObjectsWorker' => 0, 'Ci::DeleteObjectsWorker' => 0,
'Ci::DropPipelineWorker' => 3, 'Ci::DropPipelineWorker' => 3,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment