From 8d52e2bbd9ff16ec27c609264c326279c26da4ed Mon Sep 17 00:00:00 2001 From: Nikolay Kim Date: Wed, 6 Dec 2017 13:02:53 -0800 Subject: [PATCH] tests for default resource --- src/application.rs | 50 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) diff --git a/src/application.rs b/src/application.rs index 7dc811095..f0833e416 100644 --- a/src/application.rs +++ b/src/application.rs @@ -257,3 +257,53 @@ impl Iterator for Application { } } } + + +#[cfg(test)] +mod tests { + use std::str::FromStr; + use http::{Method, Version, Uri, HeaderMap, StatusCode}; + use super::*; + use handler::ReplyItem; + use httprequest::HttpRequest; + use httpresponse::HttpResponse; + use payload::Payload; + use httpcodes; + + impl Reply { + fn msg(self) -> Option { + match self.into() { + ReplyItem::Message(resp) => Some(resp), + _ => None, + } + } + } + + #[test] + fn test_default_resource() { + let app = Application::new("/") + .resource("/test", |r| r.h(httpcodes::HTTPOk)) + .finish(); + + let req = HttpRequest::new( + Method::GET, Uri::from_str("/test").unwrap(), + Version::HTTP_11, HeaderMap::new(), Payload::empty()); + let resp = app.run(req).msg().unwrap(); + assert_eq!(resp.status(), StatusCode::OK); + + let req = HttpRequest::new( + Method::GET, Uri::from_str("/blah").unwrap(), + Version::HTTP_11, HeaderMap::new(), Payload::empty()); + let resp = app.run(req).msg().unwrap(); + assert_eq!(resp.status(), StatusCode::NOT_FOUND); + + let app = Application::new("/") + .default_resource(|r| r.h(httpcodes::HTTPMethodNotAllowed)) + .finish(); + let req = HttpRequest::new( + Method::GET, Uri::from_str("/blah").unwrap(), + Version::HTTP_11, HeaderMap::new(), Payload::empty()); + let resp = app.run(req).msg().unwrap(); + assert_eq!(resp.status(), StatusCode::METHOD_NOT_ALLOWED); + } +}