Commit 9b203698 authored by Bob Van Landuyt's avatar Bob Van Landuyt

Merge branch '25344-fire-webhook-on-new-deployment' into 'master'

Fire webhook on new deployment

See merge request gitlab-org/gitlab!38874
parents c7f7cdab 3ffbf03c
...@@ -12,7 +12,8 @@ module TriggerableHooks ...@@ -12,7 +12,8 @@ module TriggerableHooks
merge_request_hooks: :merge_requests_events, merge_request_hooks: :merge_requests_events,
job_hooks: :job_events, job_hooks: :job_events,
pipeline_hooks: :pipeline_events, pipeline_hooks: :pipeline_events,
wiki_page_hooks: :wiki_page_events wiki_page_hooks: :wiki_page_events,
deployment_hooks: :deployment_events
}.freeze }.freeze
extend ActiveSupport::Concern extend ActiveSupport::Concern
......
...@@ -148,6 +148,7 @@ class Deployment < ApplicationRecord ...@@ -148,6 +148,7 @@ class Deployment < ApplicationRecord
def execute_hooks def execute_hooks
deployment_data = Gitlab::DataBuilder::Deployment.build(self) deployment_data = Gitlab::DataBuilder::Deployment.build(self)
project.execute_hooks(deployment_data, :deployment_hooks) if Feature.enabled?(:deployment_webhooks, project)
project.execute_services(deployment_data, :deployment_hooks) project.execute_services(deployment_data, :deployment_hooks)
end end
......
...@@ -17,7 +17,8 @@ class ProjectHook < WebHook ...@@ -17,7 +17,8 @@ class ProjectHook < WebHook
:merge_request_hooks, :merge_request_hooks,
:job_hooks, :job_hooks,
:pipeline_hooks, :pipeline_hooks,
:wiki_page_hooks :wiki_page_hooks,
:deployment_hooks
] ]
belongs_to :project belongs_to :project
......
...@@ -49,5 +49,29 @@ RSpec.describe Deployments::FinishedWorker do ...@@ -49,5 +49,29 @@ RSpec.describe Deployments::FinishedWorker do
expect(ProjectServiceWorker).not_to have_received(:perform_async) expect(ProjectServiceWorker).not_to have_received(:perform_async)
end end
it 'execute webhooks' do
deployment = create(:deployment)
project = deployment.project
web_hook = create(:project_hook, deployment_events: true, project: project)
expect_next_instance_of(WebHookService, web_hook, an_instance_of(Hash), "deployment_hooks") do |service|
expect(service).to receive(:async_execute)
end
worker.perform(deployment.id)
end
it 'does not execute webhooks if feature flag is disabled' do
stub_feature_flags(deployment_webhooks: false)
deployment = create(:deployment)
project = deployment.project
create(:project_hook, deployment_events: true, project: project)
expect(WebHookService).not_to receive(:new)
worker.perform(deployment.id)
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