1
0
Fork 0
mirror of https://github.com/actix/actix-web.git synced 2024-06-02 21:39:26 +00:00
actix-web/actix-web/tests/test_httpserver.rs

138 lines
4.1 KiB
Rust
Raw Permalink Normal View History

2019-11-20 17:33:22 +00:00
#[cfg(feature = "openssl")]
2021-02-07 03:54:58 +00:00
extern crate tls_openssl as openssl;
2019-04-01 03:43:00 +00:00
#[cfg(any(unix, feature = "openssl"))]
use {
actix_web::{web, App, HttpResponse, HttpServer},
std::{sync::mpsc, thread, time::Duration},
};
2019-03-13 05:57:09 +00:00
#[cfg(unix)]
2019-11-26 05:25:50 +00:00
#[actix_rt::test]
async fn test_start() {
let addr = actix_test::unused_addr();
2019-03-13 05:57:09 +00:00
let (tx, rx) = mpsc::channel();
thread::spawn(move || {
2021-11-15 04:03:33 +00:00
actix_rt::System::new()
.block_on(async {
let srv = HttpServer::new(|| {
App::new().service(
web::resource("/")
.route(web::to(|| async { HttpResponse::Ok().body("test") })),
2021-11-15 04:03:33 +00:00
)
})
.workers(1)
.backlog(1)
.max_connections(10)
.max_connection_rate(10)
2022-01-31 17:30:34 +00:00
.keep_alive(Duration::from_secs(10))
.client_request_timeout(Duration::from_secs(5))
.client_disconnect_timeout(Duration::ZERO)
2021-11-15 04:03:33 +00:00
.server_hostname("localhost")
.system_exit()
.disable_signals()
.bind(format!("{}", addr))
.unwrap()
.run();
tx.send(srv.handle()).unwrap();
srv.await
})
2021-11-15 04:03:33 +00:00
.unwrap();
});
2021-11-15 04:03:33 +00:00
let srv = rx.recv().unwrap();
2019-03-13 05:57:09 +00:00
2021-11-15 04:03:33 +00:00
let client = awc::Client::builder()
.connector(awc::Connector::new().timeout(Duration::from_millis(100)))
.finish();
let host = format!("http://{}", addr);
let response = client.get(host.clone()).send().await.unwrap();
assert!(response.status().is_success());
srv.stop(false).await;
2019-03-13 05:57:09 +00:00
}
2019-04-01 03:43:00 +00:00
2019-11-20 17:33:22 +00:00
#[cfg(feature = "openssl")]
fn ssl_acceptor() -> openssl::ssl::SslAcceptorBuilder {
use openssl::{
pkey::PKey,
ssl::{SslAcceptor, SslMethod},
x509::X509,
};
2024-05-19 09:12:32 +00:00
let rcgen::CertifiedKey { cert, key_pair } =
rcgen::generate_simple_self_signed(["localhost".to_owned()]).unwrap();
let cert_file = cert.pem();
let key_file = key_pair.serialize_pem();
let cert = X509::from_pem(cert_file.as_bytes()).unwrap();
let key = PKey::private_key_from_pem(key_file.as_bytes()).unwrap();
2019-04-01 03:43:00 +00:00
let mut builder = SslAcceptor::mozilla_intermediate(SslMethod::tls()).unwrap();
builder.set_certificate(&cert).unwrap();
builder.set_private_key(&key).unwrap();
2021-03-08 20:51:50 +00:00
builder
2019-04-01 03:43:00 +00:00
}
2019-11-26 05:25:50 +00:00
#[actix_rt::test]
2019-11-20 17:33:22 +00:00
#[cfg(feature = "openssl")]
2019-11-26 05:25:50 +00:00
async fn test_start_ssl() {
use actix_web::HttpRequest;
2021-11-15 04:03:33 +00:00
use openssl::ssl::{SslConnector, SslMethod, SslVerifyMode};
let addr = actix_test::unused_addr();
2019-04-01 03:43:00 +00:00
let (tx, rx) = mpsc::channel();
thread::spawn(move || {
2021-11-15 04:03:33 +00:00
actix_rt::System::new()
.block_on(async {
let builder = ssl_acceptor();
let srv = HttpServer::new(|| {
App::new().service(web::resource("/").route(web::to(|req: HttpRequest| {
assert!(req.app_config().secure());
async { HttpResponse::Ok().body("test") }
2021-11-15 04:03:33 +00:00
})))
})
.workers(1)
.shutdown_timeout(1)
.system_exit()
.disable_signals()
.bind_openssl(format!("{}", addr), builder)
.unwrap();
let srv = srv.run();
tx.send(srv.handle()).unwrap();
srv.await
})
.unwrap()
2019-04-01 03:43:00 +00:00
});
2021-11-15 04:03:33 +00:00
let srv = rx.recv().unwrap();
2019-04-01 03:43:00 +00:00
2019-11-26 05:25:50 +00: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));
let client = awc::Client::builder()
2019-11-26 05:25:50 +00:00
.connector(
awc::Connector::new()
.openssl(builder.build())
2021-02-18 12:30:09 +00:00
.timeout(Duration::from_millis(100)),
2019-11-26 05:25:50 +00:00
)
.finish();
let host = format!("https://{}", addr);
let response = client.get(host.clone()).send().await.unwrap();
assert!(response.status().is_success());
2019-04-01 03:43:00 +00:00
2021-11-15 04:03:33 +00:00
srv.stop(false).await;
2019-04-01 03:43:00 +00:00
}