mirror of
https://github.com/rwf2/Rocket.git
synced 2025-01-07 10:12:36 +00:00
1e5a1b8940
This is a breaking change. The `testing` feature no longer exists. Testing structures can now be accessed without any features enabled. Prior to this change, Rocket would panic when draining from a network stream failed. With this change, Rocket force closes the stream on any error. This change also ensures that the `Fairings` launch output only prints if at least one fairing has been attached.
112 lines
2.9 KiB
Rust
112 lines
2.9 KiB
Rust
#![feature(test, plugin)]
|
|
#![plugin(rocket_codegen)]
|
|
|
|
extern crate rocket;
|
|
|
|
use rocket::config::{Environment, Config};
|
|
use rocket::http::RawStr;
|
|
|
|
#[get("/")]
|
|
fn get_index() -> &'static str { "index" }
|
|
|
|
#[put("/")]
|
|
fn put_index() -> &'static str { "index" }
|
|
|
|
#[post("/")]
|
|
fn post_index() -> &'static str { "index" }
|
|
|
|
#[get("/a")]
|
|
fn index_a() -> &'static str { "index" }
|
|
|
|
#[get("/b")]
|
|
fn index_b() -> &'static str { "index" }
|
|
|
|
#[get("/c")]
|
|
fn index_c() -> &'static str { "index" }
|
|
|
|
#[get("/<a>")]
|
|
fn index_dyn_a(a: &RawStr) -> &'static str { "index" }
|
|
|
|
fn rocket() -> rocket::Rocket {
|
|
let config = Config::new(Environment::Production).unwrap();
|
|
rocket::custom(config, false)
|
|
.mount("/", routes![get_index, put_index, post_index, index_a,
|
|
index_b, index_c, index_dyn_a])
|
|
}
|
|
|
|
mod benches {
|
|
extern crate test;
|
|
|
|
use super::rocket;
|
|
use self::test::Bencher;
|
|
use rocket::testing::MockRequest;
|
|
use rocket::http::Method::*;
|
|
|
|
#[bench]
|
|
fn bench_single_get_index(b: &mut Bencher) {
|
|
let rocket = rocket();
|
|
let mut request = MockRequest::new(Get, "/");
|
|
|
|
b.iter(|| {
|
|
request.dispatch_with(&rocket);
|
|
});
|
|
}
|
|
|
|
#[bench]
|
|
fn bench_get_put_post_index(b: &mut Bencher) {
|
|
let rocket = rocket();
|
|
|
|
// Hold all of the requests we're going to make during the benchmark.
|
|
let mut requests = vec![];
|
|
requests.push(MockRequest::new(Get, "/"));
|
|
requests.push(MockRequest::new(Put, "/"));
|
|
requests.push(MockRequest::new(Post, "/"));
|
|
|
|
b.iter(|| {
|
|
for request in requests.iter_mut() {
|
|
request.dispatch_with(&rocket);
|
|
}
|
|
});
|
|
}
|
|
|
|
#[bench]
|
|
fn bench_dynamic(b: &mut Bencher) {
|
|
let rocket = rocket();
|
|
|
|
// Hold all of the requests we're going to make during the benchmark.
|
|
let mut requests = vec![];
|
|
requests.push(MockRequest::new(Get, "/abc"));
|
|
requests.push(MockRequest::new(Get, "/abcdefg"));
|
|
requests.push(MockRequest::new(Get, "/123"));
|
|
|
|
b.iter(|| {
|
|
for request in requests.iter_mut() {
|
|
request.dispatch_with(&rocket);
|
|
}
|
|
});
|
|
}
|
|
|
|
#[bench]
|
|
fn bench_simple_routing(b: &mut Bencher) {
|
|
let rocket = rocket();
|
|
|
|
// Hold all of the requests we're going to make during the benchmark.
|
|
let mut requests = vec![];
|
|
for route in rocket.routes() {
|
|
let request = MockRequest::new(route.method, route.path.path());
|
|
requests.push(request);
|
|
}
|
|
|
|
// A few more for the dynamic route.
|
|
requests.push(MockRequest::new(Get, "/abc"));
|
|
requests.push(MockRequest::new(Get, "/abcdefg"));
|
|
requests.push(MockRequest::new(Get, "/123"));
|
|
|
|
b.iter(|| {
|
|
for request in requests.iter_mut() {
|
|
request.dispatch_with(&rocket);
|
|
}
|
|
});
|
|
}
|
|
}
|