Commit 8b3ba6f3 authored by Fabio Pitino's avatar Fabio Pitino

Ensure current user and variables are updated when playing a job

Use `update!` instead of `update` to ensure that the job attributes
are updated successfully when playing a manual job.

Changelog: fixed
parent d178b976
...@@ -9,7 +9,7 @@ module Ci ...@@ -9,7 +9,7 @@ module Ci
# #
if build.enqueue if build.enqueue
build.tap do |build| build.tap do |build|
build.update(user: current_user, job_variables_attributes: job_variables_attributes || []) build.update!(user: current_user, job_variables_attributes: job_variables_attributes || [])
AfterRequeueJobService.new(project, current_user).execute(build) AfterRequeueJobService.new(project, current_user).execute(build)
end end
......
...@@ -79,12 +79,22 @@ RSpec.describe Ci::PlayBuildService, '#execute' do ...@@ -79,12 +79,22 @@ RSpec.describe Ci::PlayBuildService, '#execute' do
{ key: 'second', secret_value: 'second' }] { key: 'second', secret_value: 'second' }]
end end
subject { service.execute(build, job_variables) }
it 'assigns the variables to the build' do it 'assigns the variables to the build' do
service.execute(build, job_variables) subject
expect(build.reload.job_variables.map(&:key)).to contain_exactly('first', 'second') expect(build.reload.job_variables.map(&:key)).to contain_exactly('first', 'second')
end end
context 'when variables are invalid' do
let(:job_variables) { [{}] }
it 'raises an error' do
expect { subject }.to raise_error(ActiveRecord::RecordInvalid)
end
end
context 'when user defined variables are restricted' do context 'when user defined variables are restricted' do
before do before do
project.update!(restrict_user_defined_variables: true) project.update!(restrict_user_defined_variables: true)
...@@ -96,7 +106,7 @@ RSpec.describe Ci::PlayBuildService, '#execute' do ...@@ -96,7 +106,7 @@ RSpec.describe Ci::PlayBuildService, '#execute' do
end end
it 'assigns the variables to the build' do it 'assigns the variables to the build' do
service.execute(build, job_variables) subject
expect(build.reload.job_variables.map(&:key)).to contain_exactly('first', 'second') expect(build.reload.job_variables.map(&:key)).to contain_exactly('first', 'second')
end end
...@@ -104,8 +114,7 @@ RSpec.describe Ci::PlayBuildService, '#execute' do ...@@ -104,8 +114,7 @@ RSpec.describe Ci::PlayBuildService, '#execute' do
context 'when user is developer' do context 'when user is developer' do
it 'raises an error' do it 'raises an error' do
expect { service.execute(build, job_variables) } expect { subject }.to raise_error Gitlab::Access::AccessDeniedError
.to raise_error Gitlab::Access::AccessDeniedError
end end
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