mirror of
https://github.com/rwf2/Rocket.git
synced 2025-01-17 23:19:06 +00:00
parent
aa154be51d
commit
0a978fdb5d
@ -216,9 +216,12 @@ impl Rocket {
|
|||||||
// Route the request and run the user's handlers.
|
// Route the request and run the user's handlers.
|
||||||
let mut response = self.route_and_process(request, data);
|
let mut response = self.route_and_process(request, data);
|
||||||
|
|
||||||
// Add the 'rocket' server header to the response and run fairings.
|
// Add the 'rocket' server header to the response and run fairings only if the header
|
||||||
|
// doesn't already exist.
|
||||||
// TODO: If removing Hyper, write out `Date` header too.
|
// TODO: If removing Hyper, write out `Date` header too.
|
||||||
response.set_header(Header::new("Server", "Rocket"));
|
if !response.headers().contains("Server") {
|
||||||
|
response.set_header(Header::new("Server", "Rocket"));
|
||||||
|
}
|
||||||
self.fairings.handle_response(request, &mut response);
|
self.fairings.handle_response(request, &mut response);
|
||||||
|
|
||||||
// Strip the body if this is a `HEAD` request.
|
// Strip the body if this is a `HEAD` request.
|
||||||
|
43
core/lib/tests/conditionally-set-server-header-997.rs
Normal file
43
core/lib/tests/conditionally-set-server-header-997.rs
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
#![feature(proc_macro_hygiene, decl_macro)]
|
||||||
|
|
||||||
|
#[macro_use]
|
||||||
|
extern crate rocket;
|
||||||
|
extern crate rocket_http;
|
||||||
|
|
||||||
|
use rocket::response::Redirect;
|
||||||
|
use rocket::Response;
|
||||||
|
use rocket_http::{Header, Status};
|
||||||
|
|
||||||
|
#[get("/do_not_overwrite")]
|
||||||
|
fn do_not_overwrite<'r>() -> Result<Response<'r>, ()> {
|
||||||
|
let header = Header::new("Server", "Test");
|
||||||
|
|
||||||
|
Response::build()
|
||||||
|
.header(header)
|
||||||
|
.ok()
|
||||||
|
}
|
||||||
|
|
||||||
|
#[get("/use_default")]
|
||||||
|
fn use_default<'r>() -> Result<Response<'r>, ()> {
|
||||||
|
Response::build()
|
||||||
|
.ok()
|
||||||
|
}
|
||||||
|
|
||||||
|
mod conditionally_set_server_header {
|
||||||
|
use super::*;
|
||||||
|
use rocket::local::Client;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn do_not_overwrite_server_header() {
|
||||||
|
let rocket = rocket::ignite().mount("/", routes![do_not_overwrite, use_default]);
|
||||||
|
let client = Client::new(rocket).unwrap();
|
||||||
|
|
||||||
|
let response = client.get("/do_not_overwrite").dispatch();
|
||||||
|
let server = response.headers().get_one("Server");
|
||||||
|
assert_eq!(server, Some("Test"));
|
||||||
|
|
||||||
|
let response = client.get("/use_default").dispatch();
|
||||||
|
let server = response.headers().get_one("Server");
|
||||||
|
assert_eq!(server, Some("Rocket"));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user