Add variables on pipeline webhook
This commit is contained in:
parent
34d24c1ff5
commit
57a4ee88ae
6 changed files with 59 additions and 17 deletions
|
@ -10,5 +10,9 @@ module Ci
|
|||
alias_attribute :secret_value, :value
|
||||
|
||||
validates :key, uniqueness: { scope: :pipeline_id }
|
||||
|
||||
def hook_attrs
|
||||
{ key: key, value: value }
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
5
changelogs/unreleased/pipeline-event-variables.yml
Normal file
5
changelogs/unreleased/pipeline-event-variables.yml
Normal file
|
@ -0,0 +1,5 @@
|
|||
---
|
||||
title: pipeline webhook event now contain pipeline variables
|
||||
merge_request: 18171
|
||||
author: Pierre Tardy
|
||||
type: added
|
|
@ -943,7 +943,13 @@ X-Gitlab-Event: Pipeline Hook
|
|||
],
|
||||
"created_at": "2016-08-12 15:23:28 UTC",
|
||||
"finished_at": "2016-08-12 15:26:29 UTC",
|
||||
"duration": 63
|
||||
"duration": 63,
|
||||
"variables": [
|
||||
{
|
||||
"key": "NESTOR_PROD_ENVIRONMENT",
|
||||
"value": "us-west-1"
|
||||
}
|
||||
]
|
||||
},
|
||||
"user":{
|
||||
"name": "Administrator",
|
||||
|
|
|
@ -26,7 +26,8 @@ module Gitlab
|
|||
stages: pipeline.stages_names,
|
||||
created_at: pipeline.created_at,
|
||||
finished_at: pipeline.finished_at,
|
||||
duration: pipeline.duration
|
||||
duration: pipeline.duration,
|
||||
variables: pipeline.variables.map(&:hook_attrs)
|
||||
}
|
||||
end
|
||||
|
||||
|
|
|
@ -6,10 +6,10 @@ describe Gitlab::DataBuilder::Pipeline do
|
|||
|
||||
let(:pipeline) do
|
||||
create(:ci_pipeline,
|
||||
project: project,
|
||||
status: 'success',
|
||||
sha: project.commit.sha,
|
||||
ref: project.default_branch)
|
||||
project: project,
|
||||
status: 'success',
|
||||
sha: project.commit.sha,
|
||||
ref: project.default_branch)
|
||||
end
|
||||
|
||||
let!(:build) { create(:ci_build, pipeline: pipeline) }
|
||||
|
@ -20,18 +20,35 @@ describe Gitlab::DataBuilder::Pipeline do
|
|||
let(:build_data) { data[:builds].first }
|
||||
let(:project_data) { data[:project] }
|
||||
|
||||
it { expect(attributes).to be_a(Hash) }
|
||||
it { expect(attributes[:ref]).to eq(pipeline.ref) }
|
||||
it { expect(attributes[:sha]).to eq(pipeline.sha) }
|
||||
it { expect(attributes[:tag]).to eq(pipeline.tag) }
|
||||
it { expect(attributes[:id]).to eq(pipeline.id) }
|
||||
it { expect(attributes[:status]).to eq(pipeline.status) }
|
||||
it { expect(attributes[:detailed_status]).to eq('passed') }
|
||||
it 'has correct attributes' do
|
||||
expect(attributes).to be_a(Hash)
|
||||
expect(attributes[:ref]).to eq(pipeline.ref)
|
||||
expect(attributes[:sha]).to eq(pipeline.sha)
|
||||
expect(attributes[:tag]).to eq(pipeline.tag)
|
||||
expect(attributes[:id]).to eq(pipeline.id)
|
||||
expect(attributes[:status]).to eq(pipeline.status)
|
||||
expect(attributes[:detailed_status]).to eq('passed')
|
||||
expect(build_data).to be_a(Hash)
|
||||
expect(build_data[:id]).to eq(build.id)
|
||||
expect(build_data[:status]).to eq(build.status)
|
||||
expect(project_data).to eq(project.hook_attrs(backward: false))
|
||||
end
|
||||
|
||||
it { expect(build_data).to be_a(Hash) }
|
||||
it { expect(build_data[:id]).to eq(build.id) }
|
||||
it { expect(build_data[:status]).to eq(build.status) }
|
||||
context 'pipeline without variables' do
|
||||
it 'has empty variables hash' do
|
||||
expect(attributes[:variables]).to be_a(Array)
|
||||
expect(attributes[:variables]).to be_empty()
|
||||
end
|
||||
end
|
||||
|
||||
it { expect(project_data).to eq(project.hook_attrs(backward: false)) }
|
||||
context 'pipeline with variables' do
|
||||
let(:build) { create(:ci_build, pipeline: pipeline) }
|
||||
let(:data) { described_class.build(pipeline) }
|
||||
let(:attributes) { data[:object_attributes] }
|
||||
let!(:pipeline_variable) { create(:ci_pipeline_variable, pipeline: pipeline, key: 'TRIGGER_KEY_1', value: 'TRIGGER_VALUE_1') }
|
||||
|
||||
it { expect(attributes[:variables]).to be_a(Array) }
|
||||
it { expect(attributes[:variables]).to contain_exactly({ key: 'TRIGGER_KEY_1', value: 'TRIGGER_VALUE_1' }) }
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -5,4 +5,13 @@ describe Ci::PipelineVariable do
|
|||
|
||||
it { is_expected.to include_module(HasVariable) }
|
||||
it { is_expected.to validate_uniqueness_of(:key).scoped_to(:pipeline_id) }
|
||||
|
||||
describe '#hook_attrs' do
|
||||
let(:variable) { create(:ci_pipeline_variable, key: 'foo', value: 'bar') }
|
||||
|
||||
subject { variable.hook_attrs }
|
||||
|
||||
it { is_expected.to be_a(Hash) }
|
||||
it { is_expected.to eq({ key: 'foo', value: 'bar' }) }
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue