Commit 8c77a798 authored by Douglas Barbosa Alexandre's avatar Douglas Barbosa Alexandre

Merge branch 'mc/backstage/make-pipeline-retry-async' into 'master'

Move pipeline retry to worker [RUN ALL RSPEC] [RUN AS-IF-FOSS]

See merge request gitlab-org/gitlab!61270
parents 3e38b6b5 d7be9c37
...@@ -176,7 +176,11 @@ class Projects::PipelinesController < Projects::ApplicationController ...@@ -176,7 +176,11 @@ class Projects::PipelinesController < Projects::ApplicationController
end end
def retry def retry
pipeline.retry_failed(current_user) if Gitlab::Ci::Features.background_pipeline_retry_endpoint?(@project)
::Ci::RetryPipelineWorker.perform_async(pipeline.id, current_user.id) # rubocop:disable CodeReuse/Worker
else
pipeline.retry_failed(current_user)
end
respond_to do |format| respond_to do |format|
format.html do format.html do
......
...@@ -1515,6 +1515,15 @@ ...@@ -1515,6 +1515,15 @@
:weight: 3 :weight: 3
:idempotent: :idempotent:
:tags: [] :tags: []
- :name: pipeline_default:ci_retry_pipeline
:worker_name: Ci::RetryPipelineWorker
:feature_category: :continuous_integration
:has_external_dependencies:
:urgency: :high
:resource_boundary: :cpu
:weight: 3
:idempotent:
:tags: []
- :name: pipeline_default:pipeline_metrics - :name: pipeline_default:pipeline_metrics
:worker_name: PipelineMetricsWorker :worker_name: PipelineMetricsWorker
:feature_category: :continuous_integration :feature_category: :continuous_integration
......
# frozen_string_literal: true
module Ci
class RetryPipelineWorker # rubocop:disable Scalability/IdempotentWorker
include ::ApplicationWorker
include ::PipelineQueue
urgency :high
worker_resource_boundary :cpu
def perform(pipeline_id, user_id)
::Ci::Pipeline.find_by_id(pipeline_id).try do |pipeline|
::User.find_by_id(user_id).try do |user|
pipeline.retry_failed(user)
end
end
end
end
end
---
title: Make pipeline retry endpoint async.
merge_request: 61270
author:
type: changed
---
name: background_pipeline_retry_endpoint
introduced_by_url: https://gitlab.com/gitlab-org/gitlab/-/merge_requests/61270
rollout_issue_url: https://gitlab.com/gitlab-org/gitlab/-/issues/330915
milestone: '13.12'
type: development
group: group::pipeline authoring
default_enabled: false
...@@ -54,6 +54,10 @@ module Gitlab ...@@ -54,6 +54,10 @@ module Gitlab
def self.gldropdown_tags_enabled? def self.gldropdown_tags_enabled?
::Feature.enabled?(:gldropdown_tags, default_enabled: :yaml) ::Feature.enabled?(:gldropdown_tags, default_enabled: :yaml)
end end
def self.background_pipeline_retry_endpoint?(project)
::Feature.enabled?(:background_pipeline_retry_endpoint, project)
end
end end
end end
end end
...@@ -853,10 +853,7 @@ RSpec.describe Projects::PipelinesController do ...@@ -853,10 +853,7 @@ RSpec.describe Projects::PipelinesController do
end end
describe 'POST retry.json' do describe 'POST retry.json' do
let!(:pipeline) { create(:ci_pipeline, :failed, project: project) } subject(:post_retry) do
let!(:build) { create(:ci_build, :failed, pipeline: pipeline) }
before do
post :retry, params: { post :retry, params: {
namespace_id: project.namespace, namespace_id: project.namespace,
project_id: project, project_id: project,
...@@ -865,15 +862,41 @@ RSpec.describe Projects::PipelinesController do ...@@ -865,15 +862,41 @@ RSpec.describe Projects::PipelinesController do
format: :json format: :json
end end
it 'retries a pipeline without returning any content' do let!(:pipeline) { create(:ci_pipeline, :failed, project: project) }
let!(:build) { create(:ci_build, :failed, pipeline: pipeline) }
let(:worker_spy) { class_spy(::Ci::RetryPipelineWorker) }
before do
stub_const('::Ci::RetryPipelineWorker', worker_spy)
end
it 'retries a pipeline in the background without returning any content' do
post_retry
expect(response).to have_gitlab_http_status(:no_content) expect(response).to have_gitlab_http_status(:no_content)
expect(build.reload).to be_retried expect(::Ci::RetryPipelineWorker).to have_received(:perform_async).with(pipeline.id, user.id)
end
context 'when feature flag is disabled' do
before do
stub_feature_flags(background_pipeline_retry_endpoint: false)
end
it 'retries the pipeline without returning any content' do
post_retry
expect(response).to have_gitlab_http_status(:no_content)
expect(build.reload).to be_retried
end
end end
context 'when builds are disabled' do context 'when builds are disabled' do
let(:feature) { ProjectFeature::DISABLED } let(:feature) { ProjectFeature::DISABLED }
it 'fails to retry pipeline' do it 'fails to retry pipeline' do
post_retry
expect(response).to have_gitlab_http_status(:not_found) expect(response).to have_gitlab_http_status(:not_found)
end end
end end
......
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Ci::RetryPipelineWorker do
describe '#perform' do
subject(:perform) { described_class.new.perform(pipeline_id, user_id) }
let(:pipeline) { create(:ci_pipeline) }
context 'when pipeline exists' do
let(:pipeline_id) { pipeline.id }
context 'when user exists' do
let(:user) { create(:user) }
let(:user_id) { user.id }
before do
pipeline.project.add_maintainer(user)
end
it 'retries the pipeline' do
expect(::Ci::Pipeline).to receive(:find_by_id).with(pipeline.id).and_return(pipeline)
expect(pipeline).to receive(:retry_failed).with(having_attributes(id: user_id))
perform
end
end
context 'when user does not exist' do
let(:user_id) { 1234 }
it 'does not retry the pipeline' do
expect(::Ci::Pipeline).to receive(:find_by_id).with(pipeline_id).and_return(pipeline)
expect(pipeline).not_to receive(:retry_failed).with(having_attributes(id: user_id))
perform
end
end
end
context 'when pipeline does not exist' do
let(:pipeline_id) { 1234 }
let(:user_id) { 1234 }
it 'returns nil' do
expect(perform).to be_nil
end
end
end
end
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