mirror of
https://github.com/actix/actix-web.git
synced 2025-01-05 14:58:44 +00:00
tests for default predicates
This commit is contained in:
parent
3e91b06241
commit
9043e7286d
3 changed files with 106 additions and 11 deletions
12
README.md
12
README.md
|
@ -5,16 +5,14 @@ Actix web is a small, fast, down-to-earth, open source rust web framework.
|
||||||
```rust,ignore
|
```rust,ignore
|
||||||
use actix_web::*;
|
use actix_web::*;
|
||||||
|
|
||||||
fn index(req: HttpRequest) -> String
|
fn index(req: HttpRequest) -> String {
|
||||||
{
|
format!("Hello {}!", &req.match_info()["name"])
|
||||||
format!("Hello {}!",
|
|
||||||
&req.match_info()["name"])
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
HttpServer::new(Application::new("/")
|
HttpServer::new(
|
||||||
.resource("/{name}",
|
Application::new("/")
|
||||||
|r| r.method(Method::GET).f(index)))
|
.resource("/{name}", |r| r.method(Method::GET).f(index)))
|
||||||
.serve::<_, ()>("127.0.0.1:8080");
|
.serve::<_, ()>("127.0.0.1:8080");
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
|
@ -65,7 +65,7 @@ impl<'a> ConnectionInfo<'a> {
|
||||||
if scheme.is_none() {
|
if scheme.is_none() {
|
||||||
scheme = req.uri().scheme_part().map(|a| a.as_str());
|
scheme = req.uri().scheme_part().map(|a| a.as_str());
|
||||||
if scheme.is_none() {
|
if scheme.is_none() {
|
||||||
if let Some(ref router) = req.router() {
|
if let Some(router) = req.router() {
|
||||||
if router.server_settings().secure() {
|
if router.server_settings().secure() {
|
||||||
scheme = Some("https")
|
scheme = Some("https")
|
||||||
}
|
}
|
||||||
|
@ -88,7 +88,7 @@ impl<'a> ConnectionInfo<'a> {
|
||||||
if host.is_none() {
|
if host.is_none() {
|
||||||
host = req.uri().authority_part().map(|a| a.as_str());
|
host = req.uri().authority_part().map(|a| a.as_str());
|
||||||
if host.is_none() {
|
if host.is_none() {
|
||||||
if let Some(ref router) = req.router() {
|
if let Some(router) = req.router() {
|
||||||
host = Some(router.server_settings().host());
|
host = Some(router.server_settings().host());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -104,8 +104,7 @@ impl<'a> ConnectionInfo<'a> {
|
||||||
remote = h.split(',').next().map(|v| v.trim());
|
remote = h.split(',').next().map(|v| v.trim());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if remote.is_none() {
|
if remote.is_none() { // get peeraddr from socketaddr
|
||||||
// get peeraddr from socketaddr
|
|
||||||
peer = req.peer_addr().map(|addr| format!("{}", addr));
|
peer = req.peer_addr().map(|addr| format!("{}", addr));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
98
src/pred.rs
98
src/pred.rs
|
@ -146,3 +146,101 @@ impl<S: 'static> Predicate<S> for HeaderPredicate<S> {
|
||||||
false
|
false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use super::*;
|
||||||
|
use std::str::FromStr;
|
||||||
|
use http::{Uri, Version, Method};
|
||||||
|
use http::header::{self, HeaderMap};
|
||||||
|
use payload::Payload;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_header() {
|
||||||
|
let mut headers = HeaderMap::new();
|
||||||
|
headers.insert(header::TRANSFER_ENCODING,
|
||||||
|
header::HeaderValue::from_static("chunked"));
|
||||||
|
let mut req = HttpRequest::new(
|
||||||
|
Method::GET, Uri::from_str("/").unwrap(),
|
||||||
|
Version::HTTP_11, headers, Payload::empty());
|
||||||
|
|
||||||
|
let pred = Header("transfer-encoding", "chunked");
|
||||||
|
assert!(pred.check(&mut req));
|
||||||
|
|
||||||
|
let pred = Header("transfer-encoding", "other");
|
||||||
|
assert!(!pred.check(&mut req));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_methods() {
|
||||||
|
let mut req = HttpRequest::new(
|
||||||
|
Method::GET, Uri::from_str("/").unwrap(),
|
||||||
|
Version::HTTP_11, HeaderMap::new(), Payload::empty());
|
||||||
|
let mut req2 = HttpRequest::new(
|
||||||
|
Method::POST, Uri::from_str("/").unwrap(),
|
||||||
|
Version::HTTP_11, HeaderMap::new(), Payload::empty());
|
||||||
|
|
||||||
|
assert!(Get().check(&mut req));
|
||||||
|
assert!(!Get().check(&mut req2));
|
||||||
|
assert!(Post().check(&mut req2));
|
||||||
|
assert!(!Post().check(&mut req));
|
||||||
|
|
||||||
|
let mut r = HttpRequest::new(
|
||||||
|
Method::PUT, Uri::from_str("/").unwrap(),
|
||||||
|
Version::HTTP_11, HeaderMap::new(), Payload::empty());
|
||||||
|
assert!(Put().check(&mut r));
|
||||||
|
assert!(!Put().check(&mut req));
|
||||||
|
|
||||||
|
let mut r = HttpRequest::new(
|
||||||
|
Method::DELETE, Uri::from_str("/").unwrap(),
|
||||||
|
Version::HTTP_11, HeaderMap::new(), Payload::empty());
|
||||||
|
assert!(Delete().check(&mut r));
|
||||||
|
assert!(!Delete().check(&mut req));
|
||||||
|
|
||||||
|
let mut r = HttpRequest::new(
|
||||||
|
Method::HEAD, Uri::from_str("/").unwrap(),
|
||||||
|
Version::HTTP_11, HeaderMap::new(), Payload::empty());
|
||||||
|
assert!(Head().check(&mut r));
|
||||||
|
assert!(!Head().check(&mut req));
|
||||||
|
|
||||||
|
let mut r = HttpRequest::new(
|
||||||
|
Method::OPTIONS, Uri::from_str("/").unwrap(),
|
||||||
|
Version::HTTP_11, HeaderMap::new(), Payload::empty());
|
||||||
|
assert!(Options().check(&mut r));
|
||||||
|
assert!(!Options().check(&mut req));
|
||||||
|
|
||||||
|
let mut r = HttpRequest::new(
|
||||||
|
Method::CONNECT, Uri::from_str("/").unwrap(),
|
||||||
|
Version::HTTP_11, HeaderMap::new(), Payload::empty());
|
||||||
|
assert!(Connect().check(&mut r));
|
||||||
|
assert!(!Connect().check(&mut req));
|
||||||
|
|
||||||
|
let mut r = HttpRequest::new(
|
||||||
|
Method::PATCH, Uri::from_str("/").unwrap(),
|
||||||
|
Version::HTTP_11, HeaderMap::new(), Payload::empty());
|
||||||
|
assert!(Patch().check(&mut r));
|
||||||
|
assert!(!Patch().check(&mut req));
|
||||||
|
|
||||||
|
let mut r = HttpRequest::new(
|
||||||
|
Method::TRACE, Uri::from_str("/").unwrap(),
|
||||||
|
Version::HTTP_11, HeaderMap::new(), Payload::empty());
|
||||||
|
assert!(Trace().check(&mut r));
|
||||||
|
assert!(!Trace().check(&mut req));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_preds() {
|
||||||
|
let mut r = HttpRequest::new(
|
||||||
|
Method::TRACE, Uri::from_str("/").unwrap(),
|
||||||
|
Version::HTTP_11, HeaderMap::new(), Payload::empty());
|
||||||
|
|
||||||
|
assert!(Not(Get()).check(&mut r));
|
||||||
|
assert!(!Not(Trace()).check(&mut r));
|
||||||
|
|
||||||
|
assert!(All(vec![Trace(), Trace()]).check(&mut r));
|
||||||
|
assert!(!All(vec![Get(), Trace()]).check(&mut r));
|
||||||
|
|
||||||
|
assert!(Any(vec![Get(), Trace()]).check(&mut r));
|
||||||
|
assert!(!Any(vec![Get(), Get()]).check(&mut r));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue