mirror of
https://github.com/rwf2/Rocket.git
synced 2025-01-17 23:19:06 +00:00
parent
58445be4ff
commit
05a8a93eec
@ -4,6 +4,8 @@
|
||||
extern crate rocket_contrib;
|
||||
extern crate rocket;
|
||||
|
||||
#[cfg(test)] mod tests;
|
||||
|
||||
use std::collections::HashMap;
|
||||
|
||||
use rocket::outcome::IntoOutcome;
|
||||
@ -76,9 +78,12 @@ fn index() -> Redirect {
|
||||
Redirect::to("/login")
|
||||
}
|
||||
|
||||
fn main() {
|
||||
fn rocket() -> rocket::Rocket {
|
||||
rocket::ignite()
|
||||
.attach(Template::fairing())
|
||||
.mount("/", routes![index, user_index, login, logout, login_user, login_page])
|
||||
.launch();
|
||||
}
|
||||
|
||||
fn main() {
|
||||
rocket().launch();
|
||||
}
|
||||
|
70
examples/session/src/tests.rs
Normal file
70
examples/session/src/tests.rs
Normal file
@ -0,0 +1,70 @@
|
||||
use super::rocket;
|
||||
use rocket::Response;
|
||||
use rocket::local::Client;
|
||||
use rocket::http::{Status, Cookie, ContentType};
|
||||
|
||||
fn user_id_cookie(response: &Response) -> Option<Cookie<'static>> {
|
||||
let cookie = response.headers()
|
||||
.get("Set-Cookie")
|
||||
.filter(|v| v.starts_with("user_id"))
|
||||
.nth(0)
|
||||
.and_then(|val| Cookie::parse_encoded(val).ok());
|
||||
|
||||
cookie.map(|c| c.into_owned())
|
||||
}
|
||||
|
||||
fn login(client: &Client, user: &str, pass: &str) -> Option<Cookie<'static>> {
|
||||
let response = client.post("/login")
|
||||
.header(ContentType::Form)
|
||||
.body(format!("username={}&password={}", user, pass))
|
||||
.dispatch();
|
||||
|
||||
user_id_cookie(&response)
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn redirect_on_index() {
|
||||
let client = Client::new(rocket()).unwrap();
|
||||
let response = client.get("/").dispatch();
|
||||
assert_eq!(response.status(), Status::SeeOther);
|
||||
assert_eq!(response.headers().get_one("Location"), Some("/login"));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn can_login() {
|
||||
let client = Client::new(rocket()).unwrap();
|
||||
|
||||
let mut response = client.get("/login").dispatch();
|
||||
let body = response.body_string().unwrap();
|
||||
assert_eq!(response.status(), Status::Ok);
|
||||
assert!(body.contains("Please login to continue."));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn login_fails() {
|
||||
let client = Client::new(rocket()).unwrap();
|
||||
assert!(login(&client, "Seergio", "password").is_none());
|
||||
assert!(login(&client, "Sergio", "idontknow").is_none());
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn login_logout_succeeds() {
|
||||
let client = Client::new(rocket()).unwrap();
|
||||
let login_cookie = login(&client, "Sergio", "password").expect("logged in");
|
||||
|
||||
// Ensure we're logged in.
|
||||
let mut response = client.get("/").cookie(login_cookie.clone()).dispatch();
|
||||
let body = response.body_string().unwrap();
|
||||
assert_eq!(response.status(), Status::Ok);
|
||||
assert!(body.contains("Logged in with user ID 1"));
|
||||
|
||||
// One more.
|
||||
let response = client.get("/login").cookie(login_cookie.clone()).dispatch();
|
||||
assert_eq!(response.status(), Status::SeeOther);
|
||||
assert_eq!(response.headers().get_one("Location"), Some("/"));
|
||||
|
||||
// Logout.
|
||||
let response = client.post("/logout").cookie(login_cookie).dispatch();
|
||||
let cookie = user_id_cookie(&response).expect("logout cookie");
|
||||
assert!(cookie.value().is_empty());
|
||||
}
|
Loading…
Reference in New Issue
Block a user