From e88250706de78885e88cfa8bc42381f920369784 Mon Sep 17 00:00:00 2001 From: Oliver Browne Date: Tue, 13 Aug 2024 17:40:39 +0300 Subject: [PATCH] fix: return body to hog if we get a bad response code (#24287) --- rust/hook-worker/src/worker.rs | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/rust/hook-worker/src/worker.rs b/rust/hook-worker/src/worker.rs index cfa7523883c69..f59f2dec62713 100644 --- a/rust/hook-worker/src/worker.rs +++ b/rust/hook-worker/src/worker.rs @@ -588,7 +588,10 @@ async fn process_webhook_job( match request_error { WebhookRequestError::RetryableRequestError { - error, retry_after, .. + error, + retry_after, + response, // Grab the response so we can send it back to hog for debug + .. } => { let retry_interval = retry_policy.retry_interval(webhook_job.attempt() as u32, retry_after); @@ -623,7 +626,7 @@ async fn process_webhook_job( Some(status) => Ok(WebhookResult::BadResponse(WebhookResponse { duration: now.elapsed(), status_code: status, - body: None, + body: response, })), None => Ok(WebhookResult::Error(error.to_string())), } @@ -634,7 +637,9 @@ async fn process_webhook_job( } } } - WebhookRequestError::NonRetryableRetryableRequestError { error, .. } => { + WebhookRequestError::NonRetryableRetryableRequestError { + error, response, .. + } => { webhook_job .fail(webhook_job_error) .await @@ -649,7 +654,7 @@ async fn process_webhook_job( Some(status) => Ok(WebhookResult::BadResponse(WebhookResponse { duration: now.elapsed(), status_code: status, - body: None, + body: response, })), None => Ok(WebhookResult::Error(error.to_string())), } @@ -1126,7 +1131,7 @@ mod tests { let received_response = async_function_response.get("response").unwrap(); assert_eq!( json!({ - "body": None::, // TODO: We should still return the response. + "body": Some("{\"message\": \"bad response\"}"), "status": 500 }), *received_response