Skip to content

Commit

Permalink
Fix TSR redirecting to top-level inside nested Router (#2993)
Browse files Browse the repository at this point in the history
Co-authored-by: David Mládek <[email protected]>
  • Loading branch information
2 people authored and jplatte committed Nov 14, 2024
1 parent eb6bea3 commit 43814c1
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 3 deletions.
2 changes: 1 addition & 1 deletion axum-extra/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ typed-header = ["dep:headers"]
typed-routing = ["dep:axum-macros", "dep:percent-encoding", "dep:serde_html_form", "dep:form_urlencoded"]

[dependencies]
axum = { path = "../axum", version = "0.7.7", default-features = false }
axum = { path = "../axum", version = "0.7.7", default-features = false, features = ["original-uri"] }
axum-core = { path = "../axum-core", version = "0.4.5" }
bytes = "1.1.0"
futures-util = { version = "0.3", default-features = false, features = ["alloc"] }
Expand Down
20 changes: 18 additions & 2 deletions axum-extra/src/routing/mod.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
//! Additional types for defining routes.
use axum::{
extract::Request,
extract::{OriginalUri, Request},
response::{IntoResponse, Redirect, Response},
routing::{any, MethodRouter},
Router,
Expand Down Expand Up @@ -313,7 +313,7 @@ fn add_tsr_redirect_route<S>(router: Router<S>, path: &str) -> Router<S>
where
S: Clone + Send + Sync + 'static,
{
async fn redirect_handler(uri: Uri) -> Response {
async fn redirect_handler(OriginalUri(uri): OriginalUri) -> Response {
let new_uri = map_path(uri, |path| {
path.strip_suffix('/')
.map(Cow::Borrowed)
Expand Down Expand Up @@ -432,6 +432,22 @@ mod tests {
assert_eq!(res.headers()["location"], "/foo?a=a");
}

#[tokio::test]
async fn tsr_works_in_nested_router() {
let app = Router::new().nest(
"/neko",
Router::new().route_with_tsr("/nyan/", get(|| async {})),
);

let client = TestClient::new(app);
let res = client.get("/neko/nyan/").await;
assert_eq!(res.status(), StatusCode::OK);

let res = client.get("/neko/nyan").await;
assert_eq!(res.status(), StatusCode::PERMANENT_REDIRECT);
assert_eq!(res.headers()["location"], "/neko/nyan/");
}

#[test]
#[should_panic = "Cannot add a trailing slash redirect route for `/`"]
fn tsr_at_root() {
Expand Down

0 comments on commit 43814c1

Please sign in to comment.