From 270c857bc6a821565ba101268e27c21f66b42551 Mon Sep 17 00:00:00 2001 From: James Lucas Date: Thu, 1 Feb 2024 14:43:12 -0600 Subject: [PATCH] http: surface errors based on status code (#1484) Co-authored-by: Cijo Thomas --- opentelemetry-http/CHANGELOG.md | 5 +++++ opentelemetry-http/src/lib.rs | 25 +++++++++++++------------ 2 files changed, 18 insertions(+), 12 deletions(-) diff --git a/opentelemetry-http/CHANGELOG.md b/opentelemetry-http/CHANGELOG.md index 8562d343f4..32eb36bbff 100644 --- a/opentelemetry-http/CHANGELOG.md +++ b/opentelemetry-http/CHANGELOG.md @@ -2,6 +2,11 @@ ## vNext +### Changed + +- **Breaking** Surface non-2xx status codes as errors; change `ResponseExt` trait to return `HttpError` instead of `TraceError`[#1484](https://github.com/open-telemetry/opentelemetry-rust/pull/1484) + + ## v0.10.0 ### Changed diff --git a/opentelemetry-http/src/lib.rs b/opentelemetry-http/src/lib.rs index c0a6145b20..67d2c7b11a 100644 --- a/opentelemetry-http/src/lib.rs +++ b/opentelemetry-http/src/lib.rs @@ -5,10 +5,7 @@ use std::fmt::Debug; pub use bytes::Bytes; #[doc(no_inline)] pub use http::{Request, Response}; -use opentelemetry::{ - propagation::{Extractor, Injector}, - trace::TraceError, -}; +use opentelemetry::propagation::{Extractor, Injector}; pub struct HeaderInjector<'a>(pub &'a mut http::HeaderMap); @@ -66,7 +63,7 @@ mod reqwest { impl HttpClient for reqwest::Client { async fn send(&self, request: Request>) -> Result, HttpError> { let request = request.try_into()?; - let mut response = self.execute(request).await?; + let mut response = self.execute(request).await?.error_for_status()?; let headers = std::mem::take(response.headers_mut()); let mut http_response = Response::builder() .status(response.status()) @@ -81,7 +78,7 @@ mod reqwest { impl HttpClient for reqwest::blocking::Client { async fn send(&self, request: Request>) -> Result, HttpError> { let request = request.try_into()?; - let mut response = self.execute(request)?; + let mut response = self.execute(request)?.error_for_status()?; let headers = std::mem::take(response.headers_mut()); let mut http_response = Response::builder() .status(response.status()) @@ -99,7 +96,7 @@ pub mod surf { use http::{header::HeaderName, HeaderMap, HeaderValue}; - use super::{async_trait, Bytes, HttpClient, HttpError, Request, Response}; + use super::{async_trait, Bytes, HttpClient, HttpError, Request, Response, ResponseExt}; #[derive(Debug)] pub struct BasicAuthMiddleware(pub surf::http::auth::BasicAuth); @@ -148,13 +145,15 @@ pub mod surf { *http_response.headers_mut() = headers; - Ok(http_response) + Ok(http_response.error_for_status()?) } } } #[cfg(feature = "isahc")] mod isahc { + use crate::ResponseExt; + use super::{async_trait, Bytes, HttpClient, HttpError, Request, Response}; use isahc::AsyncReadResponseExt; use std::convert::TryInto as _; @@ -172,13 +171,15 @@ mod isahc { .body(bytes.into())?; *http_response.headers_mut() = headers; - Ok(http_response) + Ok(http_response.error_for_status()?) } } } #[cfg(any(feature = "hyper", feature = "hyper_tls"))] pub mod hyper { + use crate::ResponseExt; + use super::{async_trait, Bytes, HttpClient, HttpError, Request, Response}; use http::HeaderValue; use hyper::client::connect::Connect; @@ -236,7 +237,7 @@ pub mod hyper { .body(hyper::body::to_bytes(response.into_body()).await?)?; *http_response.headers_mut() = headers; - Ok(http_response) + Ok(http_response.error_for_status()?) } } } @@ -244,11 +245,11 @@ pub mod hyper { /// Methods to make working with responses from the [`HttpClient`] trait easier. pub trait ResponseExt: Sized { /// Turn a response into an error if the HTTP status does not indicate success (200 - 299). - fn error_for_status(self) -> Result; + fn error_for_status(self) -> Result; } impl ResponseExt for Response { - fn error_for_status(self) -> Result { + fn error_for_status(self) -> Result { if self.status().is_success() { Ok(self) } else {