Commit e3d2fa89 authored by Furkan Ayhan's avatar Furkan Ayhan

Fix retried value for commit statuses

We are trying to remove ProcessPipelineService#update_retried method.
When doing this, we found that this method is still used for some
cases. This commit fixes those usages.
parent d7c2ed24
...@@ -84,6 +84,8 @@ class CommitStatus < ApplicationRecord ...@@ -84,6 +84,8 @@ class CommitStatus < ApplicationRecord
# extend this `Hash` with new values. # extend this `Hash` with new values.
enum_with_nil failure_reason: Enums::Ci::CommitStatus.failure_reasons enum_with_nil failure_reason: Enums::Ci::CommitStatus.failure_reasons
default_value_for :retried, false
## ##
# We still create some CommitStatuses outside of CreatePipelineService. # We still create some CommitStatuses outside of CreatePipelineService.
# #
...@@ -290,6 +292,14 @@ class CommitStatus < ApplicationRecord ...@@ -290,6 +292,14 @@ class CommitStatus < ApplicationRecord
failed? && !unrecoverable_failure? failed? && !unrecoverable_failure?
end end
def update_older_statuses_retried!
self.class
.latest
.where(name: name)
.where.not(id: id)
.update_all(retried: true, processed: true)
end
private private
def unrecoverable_failure? def unrecoverable_failure?
......
...@@ -30,6 +30,8 @@ module Ci ...@@ -30,6 +30,8 @@ module Ci
# this updates only when there are data that needs to be updated, there are two groups with no retried flag # this updates only when there are data that needs to be updated, there are two groups with no retried flag
# rubocop: disable CodeReuse/ActiveRecord # rubocop: disable CodeReuse/ActiveRecord
def update_retried def update_retried
return if Feature.enabled?(:ci_remove_update_retried_from_process_pipeline, pipeline.project, default_enabled: :yaml)
# find the latest builds for each name # find the latest builds for each name
latest_statuses = pipeline.latest_statuses latest_statuses = pipeline.latest_statuses
.group(:name) .group(:name)
......
...@@ -33,6 +33,7 @@ module Projects ...@@ -33,6 +33,7 @@ module Projects
@status = create_status @status = create_status
@status.enqueue! @status.enqueue!
@status.run! @status.run!
@status.update_older_statuses_retried! if Feature.enabled?(:ci_fix_commit_status_retried, project, default_enabled: :yaml)
raise InvalidStateError, 'missing pages artifacts' unless build.artifacts? raise InvalidStateError, 'missing pages artifacts' unless build.artifacts?
raise InvalidStateError, 'build SHA is outdated for this ref' unless latest? raise InvalidStateError, 'build SHA is outdated for this ref' unless latest?
......
---
name: ci_fix_commit_status_retried
introduced_by_url: https://gitlab.com/gitlab-org/gitlab/-/merge_requests/54300
rollout_issue_url: https://gitlab.com/gitlab-org/gitlab/-/issues/321631
milestone: '13.9'
type: development
group: group::pipeline authoring
default_enabled: false
---
name: ci_remove_update_retried_from_process_pipeline
introduced_by_url: https://gitlab.com/gitlab-org/gitlab/-/merge_requests/54300
rollout_issue_url: https://gitlab.com/gitlab-org/gitlab/-/issues/321630
milestone: '13.9'
type: development
group: group::pipeline authoring
default_enabled: false
...@@ -100,7 +100,12 @@ module API ...@@ -100,7 +100,12 @@ module API
attributes_for_keys(%w[target_url description coverage]) attributes_for_keys(%w[target_url description coverage])
status.update(optional_attributes) if optional_attributes.any? status.update(optional_attributes) if optional_attributes.any?
render_validation_error!(status) if status.invalid?
if status.valid?
status.update_older_statuses_retried! if Feature.enabled?(:ci_fix_commit_status_retried, user_project, default_enabled: :yaml)
else
render_validation_error!(status)
end
begin begin
case params[:state] case params[:state]
......
...@@ -1132,12 +1132,17 @@ RSpec.describe Ci::Pipeline, :mailer, factory_default: :keep do ...@@ -1132,12 +1132,17 @@ RSpec.describe Ci::Pipeline, :mailer, factory_default: :keep do
end end
context 'when commit status is retried' do context 'when commit status is retried' do
before do let!(:old_commit_status) do
create(:commit_status, pipeline: pipeline, create(:commit_status, pipeline: pipeline,
stage: 'build', stage: 'build',
name: 'mac', name: 'mac',
stage_idx: 0, stage_idx: 0,
status: 'success') status: 'success')
end
context 'when FF ci_remove_update_retried_from_process_pipeline is disabled' do
before do
stub_feature_flags(ci_remove_update_retried_from_process_pipeline: false)
Ci::ProcessPipelineService Ci::ProcessPipelineService
.new(pipeline) .new(pipeline)
...@@ -1151,6 +1156,7 @@ RSpec.describe Ci::Pipeline, :mailer, factory_default: :keep do ...@@ -1151,6 +1156,7 @@ RSpec.describe Ci::Pipeline, :mailer, factory_default: :keep do
end end
end end
end end
end
context 'when there is a stage with warnings' do context 'when there is a stage with warnings' do
before do before do
......
...@@ -291,7 +291,7 @@ RSpec.describe API::CommitStatuses do ...@@ -291,7 +291,7 @@ RSpec.describe API::CommitStatuses do
end end
context 'when retrying a commit status' do context 'when retrying a commit status' do
before do subject(:post_request) do
post api(post_url, developer), post api(post_url, developer),
params: { state: 'failed', name: 'test', ref: 'master' } params: { state: 'failed', name: 'test', ref: 'master' }
...@@ -300,15 +300,45 @@ RSpec.describe API::CommitStatuses do ...@@ -300,15 +300,45 @@ RSpec.describe API::CommitStatuses do
end end
it 'correctly posts a new commit status' do it 'correctly posts a new commit status' do
post_request
expect(response).to have_gitlab_http_status(:created) expect(response).to have_gitlab_http_status(:created)
expect(json_response['sha']).to eq(commit.id) expect(json_response['sha']).to eq(commit.id)
expect(json_response['status']).to eq('success') expect(json_response['status']).to eq('success')
end end
context 'feature flags' do
using RSpec::Parameterized::TableSyntax
where(:ci_fix_commit_status_retried, :ci_remove_update_retried_from_process_pipeline, :previous_statuses_retried) do
true | true | true
true | false | true
false | true | false
false | false | true
end
with_them do
before do
stub_feature_flags(
ci_fix_commit_status_retried: ci_fix_commit_status_retried,
ci_remove_update_retried_from_process_pipeline: ci_remove_update_retried_from_process_pipeline
)
end
it 'retries a commit status', :sidekiq_might_not_need_inline do it 'retries a commit status', :sidekiq_might_not_need_inline do
post_request
expect(CommitStatus.count).to eq 2 expect(CommitStatus.count).to eq 2
if previous_statuses_retried
expect(CommitStatus.first).to be_retried expect(CommitStatus.first).to be_retried
expect(CommitStatus.last.pipeline).to be_success expect(CommitStatus.last.pipeline).to be_success
else
expect(CommitStatus.first).not_to be_retried
expect(CommitStatus.last.pipeline).to be_failed
end
end
end
end end
end end
......
...@@ -43,6 +43,20 @@ RSpec.describe Ci::ProcessPipelineService do ...@@ -43,6 +43,20 @@ RSpec.describe Ci::ProcessPipelineService do
let!(:build) { create_build('build') } let!(:build) { create_build('build') }
let!(:test) { create_build('test') } let!(:test) { create_build('test') }
context 'when FF ci_remove_update_retried_from_process_pipeline is enabled' do
it 'does not update older builds as retried' do
subject.execute
expect(all_builds.latest).to contain_exactly(build, build_retried, test)
expect(all_builds.retried).to be_empty
end
end
context 'when FF ci_remove_update_retried_from_process_pipeline is disabled' do
before do
stub_feature_flags(ci_remove_update_retried_from_process_pipeline: false)
end
it 'returns unique statuses' do it 'returns unique statuses' do
subject.execute subject.execute
...@@ -78,6 +92,9 @@ RSpec.describe Ci::ProcessPipelineService do ...@@ -78,6 +92,9 @@ RSpec.describe Ci::ProcessPipelineService do
end end
end end
end end
end
private
def create_build(name, **opts) def create_build(name, **opts)
create(:ci_build, :created, pipeline: pipeline, name: name, **opts) create(:ci_build, :created, pipeline: pipeline, name: name, **opts)
......
...@@ -335,6 +335,41 @@ RSpec.describe Projects::UpdatePagesService do ...@@ -335,6 +335,41 @@ RSpec.describe Projects::UpdatePagesService do
end end
end end
context 'when retrying the job' do
let!(:older_deploy_job) do
create(:generic_commit_status, :failed, pipeline: pipeline,
ref: build.ref,
stage: 'deploy',
name: 'pages:deploy')
end
before do
create(:ci_job_artifact, :correct_checksum, file: file, job: build)
create(:ci_job_artifact, file_type: :metadata, file_format: :gzip, file: metadata, job: build)
build.reload
end
it 'marks older pages:deploy jobs retried' do
expect(execute).to eq(:success)
expect(older_deploy_job.reload).to be_retried
end
context 'when FF ci_fix_commit_status_retried is disabled' do
before do
stub_feature_flags(ci_fix_commit_status_retried: false)
end
it 'does not mark older pages:deploy jobs retried' do
expect(execute).to eq(:success)
expect(older_deploy_job.reload).not_to be_retried
end
end
end
private
def deploy_status def deploy_status
GenericCommitStatus.find_by(name: 'pages:deploy') GenericCommitStatus.find_by(name: 'pages:deploy')
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