Commit e7e4cf00 authored by Robert Speicher's avatar Robert Speicher

Merge branch '534-jenkins-ci-service-doesn-t-send-x-gitlab-event-header' into 'master'

Add standard web hook headers to Jenkins CI post

Closes #534

The Jenkins web hook was not sending the standard web hook headers.
Specifically, the `gitlab-plugin` for Jenkins needs to use the
`X-GitLab-Event` header. This makes our EE service unable to work with
the newer GitLab Plugin for Jenkins.

See https://github.com/jenkinsci/gitlab-plugin/issues/272

See merge request !374
parents a25d6e72 69472849
class ServiceHook < WebHook class ServiceHook < WebHook
belongs_to :service belongs_to :service
def execute(data) def execute(data, hook_name = 'service_hook')
super(data, 'service_hook') super(data, hook_name)
end end
end end
...@@ -46,14 +46,9 @@ class JenkinsService < CiService ...@@ -46,14 +46,9 @@ class JenkinsService < CiService
end end
def execute(data) def execute(data)
self.class.post( return unless supported_events.include?(data[:object_kind])
hook_url,
body: data.to_json, service_hook.execute(data, "#{data[:object_kind]}_hook")
headers: {
'Content-Type' => 'application/json',
'Authorization' => "Basic #{auth}"
}
)
end end
def test(data) def test(data)
......
...@@ -74,6 +74,30 @@ describe JenkinsService do ...@@ -74,6 +74,30 @@ describe JenkinsService do
end end
end end
describe '#execute' do
it 'adds default web hook headers to the request' do
user = create(:user, username: 'username')
project = create(:project, name: 'project')
push_sample_data = Gitlab::PushDataBuilder.build_sample(project, user)
jenkins_service = described_class.create(
active: true,
project: project,
properties: {
jenkins_url: 'http://jenkins.example.com/',
project_name: 'my_project'
}
)
stub_request(:post, jenkins_service.hook_url)
jenkins_service.execute(push_sample_data)
expect(
a_request(:post, jenkins_service.hook_url)
.with(headers: { 'X-Gitlab-Event' => 'Push Hook' })
).to have_been_made.once
end
end
describe 'Stored password invalidation' do describe 'Stored password invalidation' do
let(:project) { create(:project) } let(:project) { create(:project) }
......
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