1
0
Fork 0
mirror of https://github.com/actix/actix-web.git synced 2024-10-12 05:02:27 +00:00
actix-web/tests/test_server.rs

138 lines
4.3 KiB
Rust
Raw Normal View History

2018-10-07 04:07:32 +00:00
extern crate actix;
extern crate actix_http;
extern crate actix_net;
extern crate actix_web;
extern crate futures;
use std::{io::Read, io::Write, net, thread, time};
use actix::System;
use actix_net::server::Server;
2018-10-07 04:32:01 +00:00
use actix_web::{client, test, HttpMessage};
2018-10-07 04:07:32 +00:00
use futures::future;
2018-10-07 16:48:53 +00:00
use actix_http::{h1, KeepAlive, Request, Response};
2018-10-07 04:07:32 +00:00
#[test]
fn test_h1_v2() {
let addr = test::TestServer::unused_addr();
thread::spawn(move || {
Server::new()
.bind("test", addr, move || {
2018-10-07 15:28:38 +00:00
h1::H1Service::build()
2018-10-07 04:07:32 +00:00
.keep_alive(KeepAlive::Disabled)
.client_timeout(1000)
.client_disconnect(1000)
.server_hostname("localhost")
.server_address(addr)
2018-10-07 16:48:53 +00:00
.finish(|_| future::ok::<_, ()>(Response::Ok().finish()))
2018-10-07 04:07:32 +00:00
}).unwrap()
.run();
});
2018-10-07 16:48:53 +00:00
thread::sleep(time::Duration::from_millis(100));
2018-10-07 04:07:32 +00:00
let mut sys = System::new("test");
{
let req = client::ClientRequest::get(format!("http://{}/", addr).as_str())
.finish()
.unwrap();
let response = sys.block_on(req.send()).unwrap();
assert!(response.status().is_success());
}
}
#[test]
fn test_slow_request() {
let addr = test::TestServer::unused_addr();
thread::spawn(move || {
Server::new()
.bind("test", addr, move || {
2018-10-07 15:28:38 +00:00
h1::H1Service::build()
.client_timeout(100)
2018-10-07 16:48:53 +00:00
.finish(|_| future::ok::<_, ()>(Response::Ok().finish()))
2018-10-07 04:07:32 +00:00
}).unwrap()
.run();
});
thread::sleep(time::Duration::from_millis(100));
let mut stream = net::TcpStream::connect(addr).unwrap();
let _ = stream.write_all(b"GET /test/tests/test HTTP/1.1\r\n");
let mut data = String::new();
let _ = stream.read_to_string(&mut data);
assert!(data.starts_with("HTTP/1.1 408 Request Timeout"));
}
#[test]
fn test_malformed_request() {
let addr = test::TestServer::unused_addr();
thread::spawn(move || {
Server::new()
.bind("test", addr, move || {
2018-10-07 15:28:38 +00:00
h1::H1Service::build()
.client_timeout(100)
2018-10-07 16:48:53 +00:00
.finish(|_| future::ok::<_, ()>(Response::Ok().finish()))
2018-10-07 04:07:32 +00:00
}).unwrap()
.run();
});
thread::sleep(time::Duration::from_millis(100));
let mut stream = net::TcpStream::connect(addr).unwrap();
let _ = stream.write_all(b"GET /test/tests/test HTTP1.1\r\n");
let mut data = String::new();
let _ = stream.read_to_string(&mut data);
assert!(data.starts_with("HTTP/1.1 400 Bad Request"));
}
2018-10-07 04:32:01 +00:00
#[test]
fn test_content_length() {
use actix_http::http::{
header::{HeaderName, HeaderValue},
StatusCode,
};
let addr = test::TestServer::unused_addr();
thread::spawn(move || {
Server::new()
.bind("test", addr, move || {
2018-10-07 15:28:38 +00:00
h1::H1Service::new(|req: Request| {
2018-10-07 04:32:01 +00:00
let indx: usize = req.uri().path()[1..].parse().unwrap();
let statuses = [
StatusCode::NO_CONTENT,
StatusCode::CONTINUE,
StatusCode::SWITCHING_PROTOCOLS,
StatusCode::PROCESSING,
StatusCode::OK,
StatusCode::NOT_FOUND,
];
2018-10-07 16:48:53 +00:00
future::ok::<_, ()>(Response::new(statuses[indx]))
2018-10-07 04:32:01 +00:00
})
}).unwrap()
.run();
});
thread::sleep(time::Duration::from_millis(100));
let header = HeaderName::from_static("content-length");
let value = HeaderValue::from_static("0");
let mut sys = System::new("test");
{
for i in 0..4 {
let req =
client::ClientRequest::get(format!("http://{}/{}", addr, i).as_str())
.finish()
.unwrap();
let response = sys.block_on(req.send()).unwrap();
assert_eq!(response.headers().get(&header), None);
}
for i in 4..6 {
let req =
client::ClientRequest::get(format!("http://{}/{}", addr, i).as_str())
.finish()
.unwrap();
let response = sys.block_on(req.send()).unwrap();
assert_eq!(response.headers().get(&header), Some(&value));
}
}
}