use fatcat::auth::AuthConfectionary; use fatcat::identifiers::FatcatId; use fatcat::{auth, server}; use std::str::FromStr; #[test] fn test_macaroons() { // Test everything we can without connecting to database let c = AuthConfectionary::new_dummy(); let editor_id = FatcatId::from_str("q3nouwy3nnbsvo3h5klxsx4a7y").unwrap(); // create token w/o expiration c.create_token(editor_id, None).unwrap(); // create token w/ expiration c.create_token(editor_id, Some(chrono::Duration::days(1))) .unwrap(); } #[test] fn test_auth_db() { // Test things that require database let server = server::create_test_server().unwrap(); let conn = server.db_pool.get().expect("db_pool error"); let c = AuthConfectionary::new_dummy(); let editor_id = FatcatId::from_str("aaaaaaaaaaaabkvkaaaaaaaaae").unwrap(); // create token let token = c.create_token(editor_id, None).unwrap(); // verify token let editor_row = c.parse_macaroon_token(&conn, &token, None).unwrap(); assert_eq!(editor_row.id, editor_id.to_uuid()); // create token w/ expiration let token = c.create_token(editor_id, Some(chrono::Duration::days(1))).unwrap(); // verify token w/ expiration let editor_row = c.parse_macaroon_token(&conn, &token, None).unwrap(); assert_eq!(editor_row.id, editor_id.to_uuid()); // revoke token auth::revoke_tokens(&conn, editor_id).unwrap(); // verification should fail // XXX: one-second slop breaks this //assert!(c.parse_macaroon_token(&conn, &token, None).is_err()); }