Commit bb9e1008 authored by Luke Duncalfe's avatar Luke Duncalfe

Migrate WebHookWorker to use params: step 2

This change represents `Release M+1` in:
https://gitlab.com/gitlab-org/gitlab/-/issues/347389

There should be no noticable changes.
parent 6d4d3531
...@@ -102,9 +102,11 @@ class WebHookService ...@@ -102,9 +102,11 @@ class WebHookService
break log_rate_limited if rate_limited? break log_rate_limited if rate_limited?
break log_recursion_blocked if recursion_blocked? break log_recursion_blocked if recursion_blocked?
data[:_gitlab_recursion_detection_request_uuid] = Gitlab::WebHooks::RecursionDetection::UUID.instance.request_uuid params = {
recursion_detection_request_uuid: Gitlab::WebHooks::RecursionDetection::UUID.instance.request_uuid
}.compact
WebHookWorker.perform_async(hook.id, data, hook_name) WebHookWorker.perform_async(hook.id, data, hook_name, params)
end end
end end
......
...@@ -6,14 +6,14 @@ class WebHookWorker ...@@ -6,14 +6,14 @@ class WebHookWorker
include ApplicationWorker include ApplicationWorker
feature_category :integrations feature_category :integrations
loggable_arguments 2 loggable_arguments 2, 3
data_consistency :delayed data_consistency :delayed
sidekiq_options retry: 4, dead: false sidekiq_options retry: 4, dead: false
urgency :low urgency :low
worker_has_external_dependencies! worker_has_external_dependencies!
# Webhook recursion detection properties are passed through the `data` arg. # Webhook recursion detection properties may be passed through the `data` arg.
# This will be migrated to the `params` arg over the next few releases. # This will be migrated to the `params` arg over the next few releases.
# See https://gitlab.com/gitlab-org/gitlab/-/issues/347389. # See https://gitlab.com/gitlab-org/gitlab/-/issues/347389.
def perform(hook_id, data, hook_name, params = {}) def perform(hook_id, data, hook_name, params = {})
...@@ -21,12 +21,14 @@ class WebHookWorker ...@@ -21,12 +21,14 @@ class WebHookWorker
return unless hook return unless hook
data = data.with_indifferent_access data = data.with_indifferent_access
params.symbolize_keys!
# Before executing the hook, reapply any recursion detection UUID that was # TODO: Remove in 14.9 https://gitlab.com/gitlab-org/gitlab/-/issues/347389
# initially present in the request header so the hook can pass this same header params[:recursion_detection_request_uuid] ||= data.delete(:_gitlab_recursion_detection_request_uuid)
# value in its request.
recursion_detection_uuid = data.delete(:_gitlab_recursion_detection_request_uuid) # Before executing the hook, reapply any recursion detection UUID that was initially
Gitlab::WebHooks::RecursionDetection.set_request_uuid(recursion_detection_uuid) # present in the request header so the hook can pass this same header value in its request.
Gitlab::WebHooks::RecursionDetection.set_request_uuid(params[:recursion_detection_request_uuid])
WebHookService.new(hook, data, hook_name, jid).execute WebHookService.new(hook, data, hook_name, jid).execute
end end
......
...@@ -130,7 +130,7 @@ RSpec.describe FeatureFlags::UpdateService do ...@@ -130,7 +130,7 @@ RSpec.describe FeatureFlags::UpdateService do
it 'executes hooks' do it 'executes hooks' do
hook = create(:project_hook, :all_events_enabled, project: project) hook = create(:project_hook, :all_events_enabled, project: project)
expect(WebHookWorker).to receive(:perform_async).with(hook.id, an_instance_of(Hash), 'feature_flag_hooks') expect(WebHookWorker).to receive(:perform_async).with(hook.id, an_instance_of(Hash), 'feature_flag_hooks', an_instance_of(Hash))
subject subject
end end
......
...@@ -404,7 +404,7 @@ RSpec.describe WebHookService, :request_store, :clean_gitlab_redis_shared_state ...@@ -404,7 +404,7 @@ RSpec.describe WebHookService, :request_store, :clean_gitlab_redis_shared_state
describe '#async_execute' do describe '#async_execute' do
def expect_to_perform_worker(hook) def expect_to_perform_worker(hook)
expect(WebHookWorker).to receive(:perform_async).with(hook.id, data, 'push_hooks') expect(WebHookWorker).to receive(:perform_async).with(hook.id, data, 'push_hooks', an_instance_of(Hash))
end end
def expect_to_rate_limit(hook, threshold:, throttled: false) def expect_to_rate_limit(hook, threshold:, throttled: false)
......
...@@ -19,7 +19,16 @@ RSpec.describe WebHookWorker do ...@@ -19,7 +19,16 @@ RSpec.describe WebHookWorker do
expect { subject.perform(non_existing_record_id, data, hook_name) }.not_to raise_error expect { subject.perform(non_existing_record_id, data, hook_name) }.not_to raise_error
end end
it 'retrieves recursion detection data, reinstates it, and cleans it from payload', :request_store, :aggregate_failures do it 'retrieves recursion detection data and reinstates it', :request_store, :aggregate_failures do
uuid = SecureRandom.uuid
params = { recursion_detection_request_uuid: uuid }
expect_next(WebHookService, project_hook, data.with_indifferent_access, hook_name, anything).to receive(:execute)
expect { subject.perform(project_hook.id, data, hook_name, params) }
.to change { Gitlab::WebHooks::RecursionDetection::UUID.instance.request_uuid }.to(uuid)
end
it 'retrieves recursion detection data, reinstates it, and cleans it from payload when passed through as data', :request_store, :aggregate_failures do
uuid = SecureRandom.uuid uuid = SecureRandom.uuid
full_data = data.merge({ _gitlab_recursion_detection_request_uuid: uuid }) full_data = data.merge({ _gitlab_recursion_detection_request_uuid: uuid })
......
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