miniserve/tests/tls.rs

60 lines
1.7 KiB
Rust
Raw Normal View History

2021-08-27 02:11:10 +00:00
mod fixtures;
use assert_cmd::Command;
use fixtures::{server, Error, TestServer, FILES};
use predicates::str::contains;
use reqwest::blocking::ClientBuilder;
use rstest::rstest;
use select::{document::Document, node::Node};
/// Can start the server with TLS and receive encrypted responses.
#[rstest]
2022-02-05 20:30:47 +00:00
#[case(server(&[
2023-04-16 14:02:26 +00:00
"--tls-cert", "tests/data/cert_rsa.pem",
2022-02-05 20:30:47 +00:00
"--tls-key", "tests/data/key_pkcs8.pem",
]))]
#[case(server(&[
2023-04-16 14:02:26 +00:00
"--tls-cert", "tests/data/cert_rsa.pem",
2022-02-05 20:30:47 +00:00
"--tls-key", "tests/data/key_pkcs1.pem",
]))]
2023-04-16 14:02:26 +00:00
#[case(server(&[
"--tls-cert", "tests/data/cert_ec.pem",
"--tls-key", "tests/data/key_ec.pem",
]))]
2022-02-05 20:30:47 +00:00
fn tls_works(#[case] server: TestServer) -> Result<(), Error> {
2021-08-27 02:11:10 +00:00
let client = ClientBuilder::new()
.danger_accept_invalid_certs(true)
.build()?;
let body = client.get(server.url()).send()?.error_for_status()?;
let parsed = Document::from_read(body)?;
for &file in FILES {
assert!(parsed.find(|x: &Node| x.text() == file).next().is_some());
}
Ok(())
}
/// Wrong path for cert throws error.
#[rstest]
fn wrong_path_cert() -> Result<(), Error> {
Command::cargo_bin("miniserve")?
2022-12-19 11:49:59 +00:00
.args(["--tls-cert", "wrong", "--tls-key", "tests/data/key.pem"])
2021-08-27 02:11:10 +00:00
.assert()
.failure()
.stderr(contains("Error: Couldn't access TLS certificate \"wrong\""));
Ok(())
}
/// Wrong paths for key throws errors.
#[rstest]
fn wrong_path_key() -> Result<(), Error> {
Command::cargo_bin("miniserve")?
2022-12-19 11:49:59 +00:00
.args(["--tls-cert", "tests/data/cert.pem", "--tls-key", "wrong"])
2021-08-27 02:11:10 +00:00
.assert()
.failure()
.stderr(contains("Error: Couldn't access TLS key \"wrong\""));
Ok(())
}