Commit c40d8005 authored by Kamil Trzciński's avatar Kamil Trzciński

Merge branch '218746-copy-secrets-on-retry' into 'master'

Copy CI secrets when retrying a job [RUN AS-IF-FOSS]

Closes #218746

See merge request gitlab-org/gitlab!40458
parents 7bda030d 53fed0b4
...@@ -2,11 +2,13 @@ ...@@ -2,11 +2,13 @@
module Ci module Ci
class RetryBuildService < ::BaseService class RetryBuildService < ::BaseService
CLONE_ACCESSORS = %i[pipeline project ref tag options name def self.clone_accessors
%i[pipeline project ref tag options name
allow_failure stage stage_id stage_idx trigger_request allow_failure stage stage_id stage_idx trigger_request
yaml_variables when environment coverage_regex yaml_variables when environment coverage_regex
description tag_list protected needs_attributes description tag_list protected needs_attributes
resource_group scheduling_type].freeze resource_group scheduling_type].freeze
end
def execute(build) def execute(build)
build.ensure_scheduling_type! build.ensure_scheduling_type!
...@@ -28,7 +30,7 @@ module Ci ...@@ -28,7 +30,7 @@ module Ci
raise Gitlab::Access::AccessDeniedError raise Gitlab::Access::AccessDeniedError
end end
attributes = CLONE_ACCESSORS.map do |attribute| attributes = self.class.clone_accessors.map do |attribute|
[attribute, build.public_send(attribute)] # rubocop:disable GitlabSecurity/PublicSend [attribute, build.public_send(attribute)] # rubocop:disable GitlabSecurity/PublicSend
end.to_h end.to_h
...@@ -68,3 +70,5 @@ module Ci ...@@ -68,3 +70,5 @@ module Ci
end end
end end
end end
Ci::RetryBuildService.prepend_if_ee('EE::Ci::RetryBuildService')
# frozen_string_literal: true
module EE
module Ci
module RetryBuildService
extend ActiveSupport::Concern
class_methods do
extend ::Gitlab::Utils::Override
override :clone_accessors
def clone_accessors
(super + %i[secrets]).freeze
end
end
end
end
end
...@@ -3,4 +3,48 @@ require 'spec_helper' ...@@ -3,4 +3,48 @@ require 'spec_helper'
RSpec.describe Ci::RetryBuildService do RSpec.describe Ci::RetryBuildService do
it_behaves_like 'restricts access to protected environments' it_behaves_like 'restricts access to protected environments'
describe '#reprocess' do
context 'when user has ability to execute build' do
let(:user) { create(:user) }
let(:build) { create(:ci_build) }
let(:project) { build.project }
subject(:service) { described_class.new(project, user) }
let(:new_build) do
Timecop.freeze(1.second.from_now) do
service.reprocess!(build)
end
end
before do
stub_not_protect_default_branch
project.add_developer(user)
end
context 'when build has secrets' do
let(:secrets) do
{
'DATABASE_PASSWORD' => {
'vault' => {
'engine' => { 'name' => 'kv-v2', 'path' => 'kv-v2' },
'path' => 'production/db',
'field' => 'password'
}
}
}
end
before do
build.update!(secrets: secrets)
end
it 'clones secrets' do
expect(new_build.secrets).to eq(secrets)
end
end
end
end
end end
...@@ -22,7 +22,7 @@ RSpec.describe Ci::RetryBuildService do ...@@ -22,7 +22,7 @@ RSpec.describe Ci::RetryBuildService do
described_class.new(project, user) described_class.new(project, user)
end end
clone_accessors = described_class::CLONE_ACCESSORS clone_accessors = described_class.clone_accessors
reject_accessors = reject_accessors =
%i[id status user token token_encrypted coverage trace runner %i[id status user token token_encrypted coverage trace runner
...@@ -143,6 +143,8 @@ RSpec.describe Ci::RetryBuildService do ...@@ -143,6 +143,8 @@ RSpec.describe Ci::RetryBuildService do
Ci::Build.reflect_on_all_associations.map(&:name) + Ci::Build.reflect_on_all_associations.map(&:name) +
[:tag_list, :needs_attributes] [:tag_list, :needs_attributes]
current_accessors << :secrets if Gitlab.ee?
current_accessors.uniq! current_accessors.uniq!
expect(current_accessors).to include(*processed_accessors) expect(current_accessors).to include(*processed_accessors)
......
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