diff --git a/app/jobs/web_hook_job.rb b/app/jobs/web_hook_job.rb index 731e7a9c113..4107d714aad 100644 --- a/app/jobs/web_hook_job.rb +++ b/app/jobs/web_hook_job.rb @@ -10,7 +10,15 @@ def perform(procedure_id, dossier_id, state, updated_at) state: state, updated_at: updated_at } + procedure = Procedure.find(procedure_id) - Typhoeus.post(procedure.web_hook_url, body: body, timeout: TIMEOUT) + + response = Typhoeus.post(procedure.web_hook_url, body: body, timeout: TIMEOUT) + + if !response.success? + Sentry.set_tags(procedure: procedure_id, dossier: dossier_id) + Sentry.set_extras(web_hook_url: procedure.web_hook_url) + Sentry.capture_message("Webhook error: #{response.status} // Response: #{response.body}") + end end end diff --git a/spec/jobs/web_hook_job_spec.rb b/spec/jobs/web_hook_job_spec.rb new file mode 100644 index 00000000000..b18ae088bfe --- /dev/null +++ b/spec/jobs/web_hook_job_spec.rb @@ -0,0 +1,22 @@ +describe WebHookJob, type: :job do + describe 'perform' do + let(:procedure) { create(:procedure, web_hook_url:) } + let(:dossier) { create(:dossier, procedure:) } + let(:web_hook_url) { "https://domaine.fr/callback_url" } + let(:job) { WebHookJob.new(procedure.id, dossier.id, dossier.state, dossier.updated_at) } + + context 'with success on webhook' do + it 'calls webhook' do + stub_request(:post, web_hook_url).to_return(status: 200, body: "success") + expect { job.perform_now }.not_to raise_error + end + end + + context 'with error on webhook' do + it 'raises' do + stub_request(:post, web_hook_url).to_return(status: 500, body: "error") + expect { job.perform_now }.to raise_error + end + end + end +end