1
0
Fork 0
mirror of https://github.com/actix/actix-web.git synced 2025-01-10 17:25:36 +00:00

allow to handle empty path for application with prefix

This commit is contained in:
Nikolay Kim 2018-07-24 14:51:48 -07:00
parent b79a9aaec7
commit d6abd2fe22
3 changed files with 43 additions and 14 deletions

View file

@ -6,6 +6,12 @@
* Add implementation of `FromRequest<S>` for `Option<T>` and `Result<T, Error>` * Add implementation of `FromRequest<S>` for `Option<T>` and `Result<T, Error>`
* Allow to handle application prefix, i.e. allow to handle `/app` path
for application with `/app` prefix.
Check [`App::prefix()`](https://actix.rs/actix-web/actix_web/struct.App.html#method.prefix)
api doc.
### Fixed ### Fixed
* removed the timestamp from the default logger middleware * removed the timestamp from the default logger middleware

View file

@ -171,7 +171,9 @@ where
/// In the following example only requests with an `/app/` path /// In the following example only requests with an `/app/` path
/// prefix get handled. Requests with path `/app/test/` would be /// prefix get handled. Requests with path `/app/test/` would be
/// handled, while requests with the paths `/application` or /// handled, while requests with the paths `/application` or
/// `/other/...` would return `NOT FOUND`. /// `/other/...` would return `NOT FOUND`. It is also possible to
/// handle `/app` path, to do this you can register resource for
/// empty string `""`
/// ///
/// ```rust /// ```rust
/// # extern crate actix_web; /// # extern crate actix_web;
@ -180,6 +182,8 @@ where
/// fn main() { /// fn main() {
/// let app = App::new() /// let app = App::new()
/// .prefix("/app") /// .prefix("/app")
/// .resource("", |r| r.f(|_| HttpResponse::Ok())) // <- handle `/app` path
/// .resource("/", |r| r.f(|_| HttpResponse::Ok())) // <- handle `/app/` path
/// .resource("/test", |r| { /// .resource("/test", |r| {
/// r.get().f(|_| HttpResponse::Ok()); /// r.get().f(|_| HttpResponse::Ok());
/// r.head().f(|_| HttpResponse::MethodNotAllowed()); /// r.head().f(|_| HttpResponse::MethodNotAllowed());
@ -822,6 +826,23 @@ mod tests {
assert_eq!(resp.as_msg().status(), StatusCode::NOT_FOUND); assert_eq!(resp.as_msg().status(), StatusCode::NOT_FOUND);
} }
#[test]
fn test_option_responder() {
let app = App::new()
.resource("/none", |r| r.f(|_| -> Option<&'static str> { None }))
.resource("/some", |r| r.f(|_| Some("some")))
.finish();
let req = TestRequest::with_uri("/none").request();
let resp = app.run(req);
assert_eq!(resp.as_msg().status(), StatusCode::NOT_FOUND);
let req = TestRequest::with_uri("/some").request();
let resp = app.run(req);
assert_eq!(resp.as_msg().status(), StatusCode::OK);
assert_eq!(resp.as_msg().body(), &Body::Binary(Binary::Slice(b"some")));
}
#[test] #[test]
fn test_filter() { fn test_filter() {
let mut srv = TestServer::with_factory(|| { let mut srv = TestServer::with_factory(|| {
@ -840,19 +861,21 @@ mod tests {
} }
#[test] #[test]
fn test_option_responder() { fn test_prefix_root() {
let app = App::new() let mut srv = TestServer::with_factory(|| {
.resource("/none", |r| r.f(|_| -> Option<&'static str> { None })) App::new()
.resource("/some", |r| r.f(|_| Some("some"))) .prefix("/test")
.finish(); .resource("/", |r| r.f(|_| HttpResponse::Ok()))
.resource("", |r| r.f(|_| HttpResponse::Created()))
});
let req = TestRequest::with_uri("/none").request(); let request = srv.get().uri(srv.url("/test/")).finish().unwrap();
let resp = app.run(req); let response = srv.execute(request.send()).unwrap();
assert_eq!(resp.as_msg().status(), StatusCode::NOT_FOUND); assert_eq!(response.status(), StatusCode::OK);
let req = TestRequest::with_uri("/some").request(); let request = srv.get().uri(srv.url("/test")).finish().unwrap();
let resp = app.run(req); let response = srv.execute(request.send()).unwrap();
assert_eq!(resp.as_msg().status(), StatusCode::OK); assert_eq!(response.status(), StatusCode::CREATED);
assert_eq!(resp.as_msg().body(), &Body::Binary(Binary::Slice(b"some")));
} }
} }

View file

@ -463,7 +463,7 @@ impl ResourceDef {
/// ///
/// Panics if path pattern is wrong. /// Panics if path pattern is wrong.
pub fn new(path: &str) -> Self { pub fn new(path: &str) -> Self {
ResourceDef::with_prefix(path, "/", false) ResourceDef::with_prefix(path, if path.is_empty() { "" } else { "/" }, false)
} }
/// Parse path pattern and create new `Resource` instance. /// Parse path pattern and create new `Resource` instance.