Annotate panicking functions with #[track_caller] (#1248)

This commit is contained in:
David Pedersen 2022-08-11 12:45:42 +02:00 committed by GitHub
parent 50a4be999d
commit 6cd356690d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 17 additions and 1 deletions

View file

@ -42,8 +42,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
relaxed so the response type must implement `IntoResponse` rather than being a relaxed so the response type must implement `IntoResponse` rather than being a
literal `Response` literal `Response`
- **change:** axum's MSRV is now 1.60 ([#1239]) - **change:** axum's MSRV is now 1.60 ([#1239])
- **fixed:** Annotate panicking functions with `#[track_caller]` so the error
message points to where the user added the invalid router, rather than
somewhere internally in axum ([#1248])
[#1171]: https://github.com/tokio-rs/axum/pull/1171
[#1077]: https://github.com/tokio-rs/axum/pull/1077 [#1077]: https://github.com/tokio-rs/axum/pull/1077
[#1086]: https://github.com/tokio-rs/axum/pull/1086 [#1086]: https://github.com/tokio-rs/axum/pull/1086
[#1088]: https://github.com/tokio-rs/axum/pull/1088 [#1088]: https://github.com/tokio-rs/axum/pull/1088
@ -52,7 +54,9 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
[#1130]: https://github.com/tokio-rs/axum/pull/1130 [#1130]: https://github.com/tokio-rs/axum/pull/1130
[#1135]: https://github.com/tokio-rs/axum/pull/1135 [#1135]: https://github.com/tokio-rs/axum/pull/1135
[#1152]: https://github.com/tokio-rs/axum/pull/1152 [#1152]: https://github.com/tokio-rs/axum/pull/1152
[#1171]: https://github.com/tokio-rs/axum/pull/1171
[#1239]: https://github.com/tokio-rs/axum/pull/1239 [#1239]: https://github.com/tokio-rs/axum/pull/1239
[#1248]: https://github.com/tokio-rs/axum/pull/1248
[#924]: https://github.com/tokio-rs/axum/pull/924 [#924]: https://github.com/tokio-rs/axum/pull/924
# 0.5.10 (28. June, 2022) # 0.5.10 (28. June, 2022)

View file

@ -205,6 +205,7 @@ macro_rules! chained_service_fn {
$name:ident, $method:ident $name:ident, $method:ident
) => { ) => {
$(#[$m])+ $(#[$m])+
#[track_caller]
pub fn $name<S>(self, svc: S) -> Self pub fn $name<S>(self, svc: S) -> Self
where where
S: Service<Request<ReqBody>, Error = E> S: Service<Request<ReqBody>, Error = E>
@ -268,6 +269,7 @@ macro_rules! chained_handler_fn {
$name:ident, $method:ident $name:ident, $method:ident
) => { ) => {
$(#[$m])+ $(#[$m])+
#[track_caller]
pub fn $name<H, T>(self, handler: H) -> Self pub fn $name<H, T>(self, handler: H) -> Self
where where
H: Handler<T, B>, H: Handler<T, B>,
@ -577,6 +579,7 @@ where
/// # axum::Server::bind(&"".parse().unwrap()).serve(app.into_make_service()).await.unwrap(); /// # axum::Server::bind(&"".parse().unwrap()).serve(app.into_make_service()).await.unwrap();
/// # }; /// # };
/// ``` /// ```
#[track_caller]
pub fn on<H, T>(self, filter: MethodFilter, handler: H) -> Self pub fn on<H, T>(self, filter: MethodFilter, handler: H) -> Self
where where
H: Handler<T, B>, H: Handler<T, B>,
@ -689,6 +692,7 @@ impl<ReqBody, E> MethodRouter<ReqBody, E> {
/// # axum::Server::bind(&"".parse().unwrap()).serve(app.into_make_service()).await.unwrap(); /// # axum::Server::bind(&"".parse().unwrap()).serve(app.into_make_service()).await.unwrap();
/// # }; /// # };
/// ``` /// ```
#[track_caller]
pub fn on_service<S>(self, filter: MethodFilter, svc: S) -> Self pub fn on_service<S>(self, filter: MethodFilter, svc: S) -> Self
where where
S: Service<Request<ReqBody>, Error = E> + Clone + Send + 'static, S: Service<Request<ReqBody>, Error = E> + Clone + Send + 'static,
@ -783,8 +787,10 @@ impl<ReqBody, E> MethodRouter<ReqBody, E> {
} }
#[doc = include_str!("../docs/method_routing/merge.md")] #[doc = include_str!("../docs/method_routing/merge.md")]
#[track_caller]
pub fn merge(mut self, other: MethodRouter<ReqBody, E>) -> Self { pub fn merge(mut self, other: MethodRouter<ReqBody, E>) -> Self {
// written using inner functions to generate less IR // written using inner functions to generate less IR
#[track_caller]
fn merge_inner<T>(name: &str, first: Option<T>, second: Option<T>) -> Option<T> { fn merge_inner<T>(name: &str, first: Option<T>, second: Option<T>) -> Option<T> {
match (first, second) { match (first, second) {
(Some(_), Some(_)) => panic!( (Some(_), Some(_)) => panic!(
@ -796,6 +802,7 @@ impl<ReqBody, E> MethodRouter<ReqBody, E> {
} }
} }
#[track_caller]
fn merge_fallback<B, E>( fn merge_fallback<B, E>(
fallback: Fallback<B, E>, fallback: Fallback<B, E>,
fallback_other: Fallback<B, E>, fallback_other: Fallback<B, E>,
@ -843,6 +850,7 @@ impl<ReqBody, E> MethodRouter<ReqBody, E> {
self.layer(HandleErrorLayer::new(f)) self.layer(HandleErrorLayer::new(f))
} }
#[track_caller]
fn on_service_boxed_response_body<S>(mut self, filter: MethodFilter, svc: S) -> Self fn on_service_boxed_response_body<S>(mut self, filter: MethodFilter, svc: S) -> Self
where where
S: Service<Request<ReqBody>, Error = E> + Clone + Send + 'static, S: Service<Request<ReqBody>, Error = E> + Clone + Send + 'static,

View file

@ -114,6 +114,7 @@ where
} }
#[doc = include_str!("../docs/routing/route.md")] #[doc = include_str!("../docs/routing/route.md")]
#[track_caller]
pub fn route<T>(mut self, path: &str, service: T) -> Self pub fn route<T>(mut self, path: &str, service: T) -> Self
where where
T: Service<Request<B>, Error = Infallible> + Clone + Send + 'static, T: Service<Request<B>, Error = Infallible> + Clone + Send + 'static,
@ -167,6 +168,7 @@ where
self self
} }
#[track_caller]
fn set_node(&mut self, path: &str, id: RouteId) { fn set_node(&mut self, path: &str, id: RouteId) {
let mut node = let mut node =
Arc::try_unwrap(Arc::clone(&self.node)).unwrap_or_else(|node| (*node).clone()); Arc::try_unwrap(Arc::clone(&self.node)).unwrap_or_else(|node| (*node).clone());
@ -177,6 +179,7 @@ where
} }
#[doc = include_str!("../docs/routing/nest.md")] #[doc = include_str!("../docs/routing/nest.md")]
#[track_caller]
pub fn nest<T>(mut self, mut path: &str, svc: T) -> Self pub fn nest<T>(mut self, mut path: &str, svc: T) -> Self
where where
T: Service<Request<B>, Error = Infallible> + Clone + Send + 'static, T: Service<Request<B>, Error = Infallible> + Clone + Send + 'static,
@ -216,6 +219,7 @@ where
} }
#[doc = include_str!("../docs/routing/merge.md")] #[doc = include_str!("../docs/routing/merge.md")]
#[track_caller]
pub fn merge<R>(mut self, other: R) -> Self pub fn merge<R>(mut self, other: R) -> Self
where where
R: Into<Router<B>>, R: Into<Router<B>>,