Commit 75dab5a1 authored by Stan Hu's avatar Stan Hu

Fix error in updating runner session

If a runner attempted to pass along `session` parameters, an error in
`Ci::RegisterJobService` would be encountered if an existing session
were present. This occurred because the `id` field did not exist in the
parameters, so Rails would signal an error:

```
Failed to remove the existing associated runner_session. The record
failed to save after its foreign key was set to nil.
```

By adding the `update_only: true`, we allow Rails to update an existing
session.

Closes https://gitlab.com/gitlab-org/gitlab/issues/34366
parent f8f3bcc6
...@@ -53,7 +53,7 @@ module Ci ...@@ -53,7 +53,7 @@ module Ci
has_one :runner_session, class_name: 'Ci::BuildRunnerSession', validate: true, inverse_of: :build has_one :runner_session, class_name: 'Ci::BuildRunnerSession', validate: true, inverse_of: :build
accepts_nested_attributes_for :runner_session accepts_nested_attributes_for :runner_session, update_only: true
accepts_nested_attributes_for :job_variables accepts_nested_attributes_for :job_variables
delegate :url, to: :runner_session, prefix: true, allow_nil: true delegate :url, to: :runner_session, prefix: true, allow_nil: true
......
---
title: Fix error in updating runner session
merge_request: 20902
author:
type: fixed
...@@ -4,6 +4,7 @@ require 'spec_helper' ...@@ -4,6 +4,7 @@ require 'spec_helper'
describe Ci::BuildRunnerSession, model: true do describe Ci::BuildRunnerSession, model: true do
let!(:build) { create(:ci_build, :with_runner_session) } let!(:build) { create(:ci_build, :with_runner_session) }
let(:url) { 'https://new.example.com' }
subject { build.runner_session } subject { build.runner_session }
...@@ -12,6 +13,25 @@ describe Ci::BuildRunnerSession, model: true do ...@@ -12,6 +13,25 @@ describe Ci::BuildRunnerSession, model: true do
it { is_expected.to validate_presence_of(:build) } it { is_expected.to validate_presence_of(:build) }
it { is_expected.to validate_presence_of(:url).with_message('must be a valid URL') } it { is_expected.to validate_presence_of(:url).with_message('must be a valid URL') }
context 'nested attribute assignment' do
it 'creates a new session' do
simple_build = create(:ci_build)
simple_build.runner_session_attributes = { url: url }
simple_build.save!
session = simple_build.reload.runner_session
expect(session).to be_a(Ci::BuildRunnerSession)
expect(session.url).to eq(url)
end
it 'updates session with new attributes' do
build.runner_session_attributes = { url: url }
build.save!
expect(build.reload.runner_session.url).to eq(url)
end
end
describe '#terminal_specification' do describe '#terminal_specification' do
let(:specification) { subject.terminal_specification } let(:specification) { subject.terminal_specification }
......
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