Commit c70e9f2e authored by Tomasz Maczukin's avatar Tomasz Maczukin

Send new configuration options with job's payload

parent 8c6e2bad
...@@ -804,7 +804,11 @@ module API ...@@ -804,7 +804,11 @@ module API
end end
class Image < Grape::Entity class Image < Grape::Entity
expose :name expose :name, :entrypoint
end
class ServiceImage < Image
expose :alias, :command
end end
class Artifacts < Grape::Entity class Artifacts < Grape::Entity
...@@ -848,7 +852,7 @@ module API ...@@ -848,7 +852,7 @@ module API
expose :variables expose :variables
expose :steps, using: Step expose :steps, using: Step
expose :image, using: Image expose :image, using: Image
expose :services, using: Image expose :services, using: ServiceImage
expose :artifacts, using: Artifacts expose :artifacts, using: Artifacts
expose :cache, using: Cache expose :cache, using: Cache
expose :credentials, using: Credentials expose :credentials, using: Credentials
......
...@@ -2,7 +2,7 @@ module Gitlab ...@@ -2,7 +2,7 @@ module Gitlab
module Ci module Ci
module Build module Build
class Image class Image
attr_reader :name attr_reader :alias, :command, :entrypoint, :name
class << self class << self
def from_image(job) def from_image(job)
...@@ -21,7 +21,14 @@ module Gitlab ...@@ -21,7 +21,14 @@ module Gitlab
end end
def initialize(image) def initialize(image)
if image.is_a?(String)
@name = image @name = image
elsif image.is_a?(Hash)
@alias = image[:alias]
@command = image[:command]
@entrypoint = image[:entrypoint]
@name = image[:name]
end
end end
def valid? def valid?
......
...@@ -194,8 +194,8 @@ FactoryGirl.define do ...@@ -194,8 +194,8 @@ FactoryGirl.define do
trait :extended_options do trait :extended_options do
options do options do
{ {
image: 'ruby:2.1', image: { name: 'ruby:2.1', entrypoint: '/bin/sh' },
services: ['postgres'], services: ['postgres', { name: 'docker:dind', entrypoint: '/bin/sh', command: 'sleep 30', alias: 'docker' }],
after_script: %w(ls date), after_script: %w(ls date),
artifacts: { artifacts: {
name: 'artifacts_file', name: 'artifacts_file',
......
...@@ -10,6 +10,7 @@ describe Gitlab::Ci::Build::Image do ...@@ -10,6 +10,7 @@ describe Gitlab::Ci::Build::Image do
let(:image_name) { 'ruby:2.1' } let(:image_name) { 'ruby:2.1' }
let(:job) { create(:ci_build, options: { image: image_name } ) } let(:job) { create(:ci_build, options: { image: image_name } ) }
context 'when image is defined as string' do
it 'fabricates an object of the proper class' do it 'fabricates an object of the proper class' do
is_expected.to be_kind_of(described_class) is_expected.to be_kind_of(described_class)
end end
...@@ -17,6 +18,21 @@ describe Gitlab::Ci::Build::Image do ...@@ -17,6 +18,21 @@ describe Gitlab::Ci::Build::Image do
it 'populates fabricated object with the proper name attribute' do it 'populates fabricated object with the proper name attribute' do
expect(subject.name).to eq(image_name) expect(subject.name).to eq(image_name)
end end
end
context 'when image is defined as hash' do
let(:entrypoint) { '/bin/sh' }
let(:job) { create(:ci_build, options: { image: { name: image_name, entrypoint: entrypoint } } ) }
it 'fabricates an object of the proper class' do
is_expected.to be_kind_of(described_class)
end
it 'populates fabricated object with the proper attributes' do
expect(subject.name).to eq(image_name)
expect(subject.entrypoint).to eq(entrypoint)
end
end
context 'when image name is empty' do context 'when image name is empty' do
let(:image_name) { '' } let(:image_name) { '' }
...@@ -41,10 +57,39 @@ describe Gitlab::Ci::Build::Image do ...@@ -41,10 +57,39 @@ describe Gitlab::Ci::Build::Image do
let(:service_image_name) { 'postgres' } let(:service_image_name) { 'postgres' }
let(:job) { create(:ci_build, options: { services: [service_image_name] }) } let(:job) { create(:ci_build, options: { services: [service_image_name] }) }
context 'when service is defined as string' do
it 'fabricates an non-empty array of objects' do
is_expected.to be_kind_of(Array)
is_expected.not_to be_empty
end
it 'populates fabricated objects with the proper name attributes' do
expect(subject.first).to be_kind_of(described_class)
expect(subject.first.name).to eq(service_image_name)
end
end
context 'when service is defined as hash' do
let(:service_entrypoint) { '/bin/sh' }
let(:service_alias) { 'db' }
let(:service_command) { 'sleep 30' }
let(:job) do
create(:ci_build, options: { services: [{ name: service_image_name, entrypoint: service_entrypoint,
alias: service_alias, command: service_command }] })
end
it 'fabricates an non-empty array of objects' do it 'fabricates an non-empty array of objects' do
is_expected.to be_kind_of(Array) is_expected.to be_kind_of(Array)
is_expected.not_to be_empty is_expected.not_to be_empty
expect(subject.first).to be_kind_of(described_class)
end
it 'populates fabricated objects with the proper attributes' do
expect(subject.first.name).to eq(service_image_name) expect(subject.first.name).to eq(service_image_name)
expect(subject.first.entrypoint).to eq(service_entrypoint)
expect(subject.first.alias).to eq(service_alias)
expect(subject.first.command).to eq(service_command)
end
end end
context 'when service image name is empty' do context 'when service image name is empty' do
......
...@@ -356,8 +356,11 @@ describe API::Runner do ...@@ -356,8 +356,11 @@ describe API::Runner do
expect(json_response['token']).to eq(job.token) expect(json_response['token']).to eq(job.token)
expect(json_response['job_info']).to eq(expected_job_info) expect(json_response['job_info']).to eq(expected_job_info)
expect(json_response['git_info']).to eq(expected_git_info) expect(json_response['git_info']).to eq(expected_git_info)
expect(json_response['image']).to eq({ 'name' => 'ruby:2.1' }) expect(json_response['image']).to eq({ 'name' => 'ruby:2.1', 'entrypoint' => '/bin/sh' })
expect(json_response['services']).to eq([{ 'name' => 'postgres' }]) expect(json_response['services']).to eq([{ 'name' => 'postgres', 'entrypoint' => nil,
'alias' => nil, 'command' => nil },
{ 'name' => 'docker:dind', 'entrypoint' => '/bin/sh',
'alias' => 'docker', 'command' => 'sleep 30' }])
expect(json_response['steps']).to eq(expected_steps) expect(json_response['steps']).to eq(expected_steps)
expect(json_response['artifacts']).to eq(expected_artifacts) expect(json_response['artifacts']).to eq(expected_artifacts)
expect(json_response['cache']).to eq(expected_cache) expect(json_response['cache']).to eq(expected_cache)
......
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