1
0
mirror of https://github.com/actix/actix-extras.git synced 2024-12-24 11:55:23 +01:00
actix-extras/tests/test_httpserver.rs

150 lines
4.1 KiB
Rust
Raw Normal View History

2019-03-13 06:57:09 +01:00
use net2::TcpBuilder;
use std::sync::mpsc;
use std::{net, thread, time::Duration};
2019-11-20 18:33:22 +01:00
#[cfg(feature = "openssl")]
use open_ssl::ssl::SslAcceptorBuilder;
2019-04-01 05:43:00 +02:00
2019-03-28 22:27:07 +01:00
use actix_http::Response;
2019-04-01 05:43:00 +02:00
use actix_web::{test, web, App, HttpServer};
2019-03-13 06:57:09 +01:00
fn unused_addr() -> net::SocketAddr {
let addr: net::SocketAddr = "127.0.0.1:0".parse().unwrap();
let socket = TcpBuilder::new_v4().unwrap();
socket.bind(&addr).unwrap();
socket.reuse_address(true).unwrap();
let tcp = socket.to_tcp_listener().unwrap();
tcp.local_addr().unwrap()
}
#[test]
#[cfg(unix)]
fn test_start() {
let addr = unused_addr();
let (tx, rx) = mpsc::channel();
thread::spawn(move || {
let sys = actix_rt::System::new("test");
let srv = HttpServer::new(|| {
App::new().service(
web::resource("/").route(web::to(|| Response::Ok().body("test"))),
)
})
.workers(1)
.backlog(1)
.maxconn(10)
.maxconnrate(10)
.keep_alive(10)
.client_timeout(5000)
.client_shutdown(0)
.server_hostname("localhost")
.system_exit()
.disable_signals()
.bind(format!("{}", addr))
.unwrap()
.start();
let _ = tx.send((srv, actix_rt::System::current()));
let _ = sys.run();
});
let (srv, sys) = rx.recv().unwrap();
2019-03-28 22:27:07 +01:00
#[cfg(feature = "client")]
{
use actix_http::client;
use actix_web::test;
2019-11-20 18:33:22 +01:00
test::block_on(async {
let client = awc::Client::build()
.connector(
client::Connector::new()
.timeout(Duration::from_millis(100))
.finish(),
)
.finish();
2019-03-13 06:57:09 +01:00
2019-11-20 18:33:22 +01:00
let host = format!("http://{}", addr);
let response = client.get(host.clone()).send().await.unwrap();
assert!(response.status().is_success());
});
2019-03-28 22:27:07 +01:00
}
2019-03-13 06:57:09 +01:00
// stop
let _ = srv.stop(false);
thread::sleep(Duration::from_millis(100));
let _ = sys.stop();
}
2019-04-01 05:43:00 +02:00
2019-11-20 18:33:22 +01:00
#[cfg(feature = "openssl")]
2019-04-01 05:43:00 +02:00
fn ssl_acceptor() -> std::io::Result<SslAcceptorBuilder> {
2019-11-20 18:33:22 +01:00
use open_ssl::ssl::{SslAcceptor, SslFiletype, SslMethod};
2019-04-01 05:43:00 +02:00
// load ssl keys
let mut builder = SslAcceptor::mozilla_intermediate(SslMethod::tls()).unwrap();
builder
.set_private_key_file("tests/key.pem", SslFiletype::PEM)
.unwrap();
builder
.set_certificate_chain_file("tests/cert.pem")
.unwrap();
Ok(builder)
}
#[test]
2019-11-20 18:33:22 +01:00
#[cfg(feature = "openssl")]
2019-04-01 05:43:00 +02:00
fn test_start_ssl() {
let addr = unused_addr();
let (tx, rx) = mpsc::channel();
thread::spawn(move || {
let sys = actix_rt::System::new("test");
let builder = ssl_acceptor().unwrap();
let srv = HttpServer::new(|| {
App::new().service(
web::resource("/").route(web::to(|| Response::Ok().body("test"))),
)
})
.workers(1)
.shutdown_timeout(1)
.system_exit()
.disable_signals()
2019-11-20 18:33:22 +01:00
.bind_openssl(format!("{}", addr), builder)
2019-04-01 05:43:00 +02:00
.unwrap()
.start();
let _ = tx.send((srv, actix_rt::System::current()));
let _ = sys.run();
});
let (srv, sys) = rx.recv().unwrap();
2019-11-20 18:33:22 +01:00
test::block_on(async move {
use open_ssl::ssl::{SslConnector, SslMethod, SslVerifyMode};
2019-04-01 05:43:00 +02:00
let mut builder = SslConnector::builder(SslMethod::tls()).unwrap();
builder.set_verify(SslVerifyMode::NONE);
let _ = builder
.set_alpn_protos(b"\x02h2\x08http/1.1")
.map_err(|e| log::error!("Can not set alpn protocol: {:?}", e));
2019-11-20 18:33:22 +01:00
let client = awc::Client::build()
.connector(
awc::Connector::new()
.ssl(builder.build())
.timeout(Duration::from_millis(100))
.finish(),
)
.finish();
let host = format!("https://{}", addr);
let response = client.get(host.clone()).send().await.unwrap();
assert!(response.status().is_success());
});
2019-04-01 05:43:00 +02:00
// stop
let _ = srv.stop(false);
thread::sleep(Duration::from_millis(100));
let _ = sys.stop();
}