mirror of
https://github.com/rwf2/Rocket.git
synced 2025-01-09 03:02:45 +00:00
02011a1307
This commit is a codebase-wide cleanup driven by clippy warnings. In addition to fixing every reasonable warning, the following new functionality was introduced: * `Accept::new()` now takes any `T: Into<QMediaType>` iterator. * `TempFile::is_empty()` was added. * `HeaderMap` now implements `IntoIterator`. This commit makes the following breaking changes: * The `IntoCollection` trait is gone. Generics previously bound by the trait are now bound by `IntoIterator`. This affects: - `Accept::new()` - `ContentType::with_params()` - `Permission::{allow, allowed}()` * `MediaType`, `QMediaType`, and `Allow` implement `IntoIterator`, enabling most existing code to continue working without change. * The inherent `HeaderMap::into_iter()` method was removed. * The `Ok` variant in ErrorKind::Liftoff` is now `Box<Rocket<Orbit>>`.
101 lines
3.5 KiB
Rust
101 lines
3.5 KiB
Rust
#[macro_use] extern crate rocket;
|
|
|
|
#[get("/")]
|
|
fn inspect_proto(proto: rocket::http::ProxyProto<'_>) -> String {
|
|
proto.to_string()
|
|
}
|
|
|
|
mod tests {
|
|
use rocket::{Rocket, Build, Route};
|
|
use rocket::http::{Header, Status};
|
|
use rocket::local::blocking::Client;
|
|
use rocket::figment::Figment;
|
|
|
|
fn routes() -> Vec<Route> {
|
|
routes![super::inspect_proto]
|
|
}
|
|
|
|
fn rocket_with_proto_header(header: Option<&'static str>) -> Rocket<Build> {
|
|
let mut config = rocket::Config::debug_default();
|
|
config.proxy_proto_header = header.map(|h| h.into());
|
|
rocket::custom(config).mount("/", routes())
|
|
}
|
|
|
|
#[test]
|
|
fn check_proxy_proto_header_works() {
|
|
let client = Client::debug(rocket_with_proto_header(Some("X-Url-Scheme"))).unwrap();
|
|
let response = client.get("/")
|
|
.header(Header::new("X-Forwarded-Proto", "https"))
|
|
.header(Header::new("X-Url-Scheme", "http"))
|
|
.dispatch();
|
|
|
|
assert_eq!(response.into_string().unwrap(), "http");
|
|
|
|
let response = client.get("/").header(Header::new("X-Url-Scheme", "https")).dispatch();
|
|
assert_eq!(response.into_string().unwrap(), "https");
|
|
|
|
let response = client.get("/").dispatch();
|
|
assert_eq!(response.status(), Status::InternalServerError);
|
|
}
|
|
|
|
#[test]
|
|
fn check_proxy_proto_header_works_again() {
|
|
let client = Client::debug(rocket_with_proto_header(Some("x-url-scheme"))).unwrap();
|
|
let response = client.get("/")
|
|
.header(Header::new("X-Url-Scheme", "hTTpS"))
|
|
.dispatch();
|
|
|
|
assert_eq!(response.into_string().unwrap(), "https");
|
|
|
|
let config = Figment::from(rocket::Config::debug_default())
|
|
.merge(("proxy_proto_header", "x-url-scheme"));
|
|
|
|
let client = Client::debug(rocket::custom(config).mount("/", routes())).unwrap();
|
|
let response = client.get("/")
|
|
.header(Header::new("X-url-Scheme", "HTTPS"))
|
|
.dispatch();
|
|
|
|
assert_eq!(response.into_string().unwrap(), "https");
|
|
}
|
|
|
|
#[test]
|
|
fn check_default_proxy_proto_header_works() {
|
|
let client = Client::debug_with(routes()).unwrap();
|
|
let response = client.get("/")
|
|
.header(Header::new("X-Forwarded-Proto", "https"))
|
|
.dispatch();
|
|
|
|
assert_eq!(response.status(), Status::InternalServerError);
|
|
}
|
|
|
|
#[test]
|
|
fn check_no_proxy_proto_header_works() {
|
|
let client = Client::debug(rocket_with_proto_header(None)).unwrap();
|
|
let response = client.get("/")
|
|
.header(Header::new("X-Forwarded-Proto", "https"))
|
|
.dispatch();
|
|
|
|
assert_eq!(response.status(), Status::InternalServerError);
|
|
|
|
let config =
|
|
Figment::from(rocket::Config::debug_default()).merge(("proxy_proto_header", false));
|
|
|
|
let client = Client::debug(rocket::custom(config).mount("/", routes())).unwrap();
|
|
let response = client.get("/")
|
|
.header(Header::new("X-Forwarded-Proto", "https"))
|
|
.dispatch();
|
|
|
|
assert_eq!(response.status(), Status::InternalServerError);
|
|
|
|
let config = Figment::from(rocket::Config::debug_default())
|
|
.merge(("proxy_proto_header", "x-forwarded-proto"));
|
|
|
|
let client = Client::debug(rocket::custom(config).mount("/", routes())).unwrap();
|
|
let response = client.get("/")
|
|
.header(Header::new("x-Forwarded-Proto", "https"))
|
|
.dispatch();
|
|
|
|
assert_eq!(response.into_string(), Some("https".into()));
|
|
}
|
|
}
|