mirror of
https://github.com/creating2morrow/neveko.git
synced 2025-01-03 17:39:55 +00:00
add auth.rs unit tests
This commit is contained in:
parent
d83fa927c3
commit
6fa26eeb47
3 changed files with 107 additions and 10 deletions
|
@ -13,7 +13,6 @@ use log::{
|
||||||
error,
|
error,
|
||||||
info,
|
info,
|
||||||
};
|
};
|
||||||
|
|
||||||
use rocket::{
|
use rocket::{
|
||||||
http::Status,
|
http::Status,
|
||||||
outcome::Outcome,
|
outcome::Outcome,
|
||||||
|
@ -65,7 +64,7 @@ pub fn find(aid: &String) -> Authorization {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Update new authorization creation time
|
/// Update new authorization creation time
|
||||||
fn update_expiration(f_auth: Authorization, address: &String) -> Authorization {
|
fn update_expiration(f_auth: &Authorization, address: &String) -> Authorization {
|
||||||
info!("modify auth expiration");
|
info!("modify auth expiration");
|
||||||
let data = utils::generate_rnd();
|
let data = utils::generate_rnd();
|
||||||
let time: i64 = chrono::offset::Utc::now().timestamp();
|
let time: i64 = chrono::offset::Utc::now().timestamp();
|
||||||
|
@ -132,7 +131,7 @@ pub async fn verify_login(aid: String, uid: String, signature: String) -> Author
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Called during auth flow to update data to sign and expiration
|
/// Called during auth flow to update data to sign and expiration
|
||||||
pub async fn verify_access(address: &String, signature: &String) -> bool {
|
async fn verify_access(address: &String, signature: &String) -> bool {
|
||||||
// look up auth for address
|
// look up auth for address
|
||||||
let f_auth: Authorization = find(address);
|
let f_auth: Authorization = find(address);
|
||||||
if f_auth.xmr_address != utils::empty_string() {
|
if f_auth.xmr_address != utils::empty_string() {
|
||||||
|
@ -140,7 +139,7 @@ pub async fn verify_access(address: &String, signature: &String) -> bool {
|
||||||
let now: i64 = chrono::offset::Utc::now().timestamp();
|
let now: i64 = chrono::offset::Utc::now().timestamp();
|
||||||
let expiration = get_auth_expiration();
|
let expiration = get_auth_expiration();
|
||||||
if now > f_auth.created + expiration {
|
if now > f_auth.created + expiration {
|
||||||
update_expiration(f_auth, address);
|
update_expiration(&f_auth, address);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -243,3 +242,101 @@ impl<'r> FromRequest<'r> for BearerToken {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Tests
|
||||||
|
//-------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use super::*;
|
||||||
|
|
||||||
|
async fn find_test_auth(k: &String) -> Authorization {
|
||||||
|
tokio::time::sleep(std::time::Duration::from_secs(1)).await;
|
||||||
|
let s: db::Interface = db::Interface::async_open().await;
|
||||||
|
let v = db::Interface::async_read(&s.env, &s.handle, k).await;
|
||||||
|
Authorization::from_db(String::from(k), v)
|
||||||
|
}
|
||||||
|
|
||||||
|
async fn cleanup(k: &String) {
|
||||||
|
tokio::time::sleep(std::time::Duration::from_secs(1)).await;
|
||||||
|
let s = db::Interface::async_open().await;
|
||||||
|
db::Interface::async_delete(&s.env, &s.handle, k).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn create_test() {
|
||||||
|
// run and async cleanup so the test doesn't fail when deleting test data
|
||||||
|
use tokio::runtime::Runtime;
|
||||||
|
let rt = Runtime::new().expect("Unable to create Runtime for test");
|
||||||
|
let _enter = rt.enter();
|
||||||
|
let address: String = String::from(
|
||||||
|
"73a4nWuvkYoYoksGurDjKZQcZkmaxLaKbbeiKzHnMmqKivrCzq5Q2JtJG1UZNZFqLPbQ3MiXCk2Q5bdwdUNSr7X9QrPubkn"
|
||||||
|
);
|
||||||
|
let test_auth = create(&address);
|
||||||
|
assert_eq!(test_auth.xmr_address, address);
|
||||||
|
tokio::spawn(async move {
|
||||||
|
cleanup(&test_auth.aid).await;
|
||||||
|
});
|
||||||
|
Runtime::shutdown_background(rt);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn find_test() {
|
||||||
|
// run and async cleanup so the test doesn't fail when deleting test data
|
||||||
|
use tokio::runtime::Runtime;
|
||||||
|
let rt = Runtime::new().expect("Unable to create Runtime for test");
|
||||||
|
let _enter = rt.enter();
|
||||||
|
let address: String = String::from(
|
||||||
|
"73a4nWuvkYoYoksGurDjKZQcZkmaxLaKbbeiKzHnMmqKivrCzq5Q2JtJG1UZNZFqLPbQ3MiXCk2Q5bdwdUNSr7X9QrPubkn"
|
||||||
|
);
|
||||||
|
let test_auth = create(&address);
|
||||||
|
let aid = String::from(&test_auth.aid);
|
||||||
|
tokio::spawn(async move {
|
||||||
|
let f_auth: Authorization = find_test_auth(&aid).await;
|
||||||
|
assert_ne!(f_auth.xmr_address, address);
|
||||||
|
cleanup(&test_auth.aid).await;
|
||||||
|
});
|
||||||
|
Runtime::shutdown_background(rt);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn update_expiration_test() {
|
||||||
|
// run and async cleanup so the test doesn't fail when deleting test data
|
||||||
|
use tokio::runtime::Runtime;
|
||||||
|
let rt = Runtime::new().expect("Unable to create Runtime for test");
|
||||||
|
let _enter = rt.enter();
|
||||||
|
let address: String = String::from(
|
||||||
|
"73a4nWuvkYoYoksGurDjKZQcZkmaxLaKbbeiKzHnMmqKivrCzq5Q2JtJG1UZNZFqLPbQ3MiXCk2Q5bdwdUNSr7X9QrPubkn"
|
||||||
|
);
|
||||||
|
let test_auth = create(&address);
|
||||||
|
let aid = String::from(&test_auth.aid);
|
||||||
|
tokio::spawn(async move {
|
||||||
|
let f_auth = find_test_auth(&aid).await;
|
||||||
|
let u_auth = update_expiration(&f_auth, &address);
|
||||||
|
assert!(f_auth.created < u_auth.created);
|
||||||
|
cleanup(&test_auth.aid).await;
|
||||||
|
});
|
||||||
|
Runtime::shutdown_background(rt);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn create_token_test() {
|
||||||
|
let test_value = "test";
|
||||||
|
let test_jwt = create_token(String::from(test_value), 0);
|
||||||
|
let jwt_secret_key = utils::get_jwt_secret_key();
|
||||||
|
let key: Hmac<Sha384> = Hmac::new_from_slice(&jwt_secret_key.as_bytes()).expect("");
|
||||||
|
let jwt: Result<
|
||||||
|
Token<jwt::Header, BTreeMap<std::string::String, std::string::String>, _>,
|
||||||
|
jwt::Error,
|
||||||
|
> = test_jwt.verify_with_key(&key);
|
||||||
|
match jwt {
|
||||||
|
Ok(j) => {
|
||||||
|
let claims = j.claims();
|
||||||
|
let expected = String::from(test_value);
|
||||||
|
let actual = String::from(&claims["address"]);
|
||||||
|
assert_eq!(expected, actual);
|
||||||
|
}
|
||||||
|
Err(_) => error!("create_token_test error"),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -67,18 +67,18 @@ impl Authorization {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
pub fn update_expiration(
|
pub fn update_expiration(
|
||||||
a: Authorization,
|
a: &Authorization,
|
||||||
created: i64,
|
created: i64,
|
||||||
rnd: String,
|
rnd: String,
|
||||||
token: String,
|
token: String,
|
||||||
) -> Authorization {
|
) -> Authorization {
|
||||||
Authorization {
|
Authorization {
|
||||||
aid: a.aid,
|
aid: String::from(&a.aid),
|
||||||
created,
|
created,
|
||||||
uid: a.uid,
|
uid: String::from(&a.uid),
|
||||||
rnd,
|
rnd,
|
||||||
token,
|
token,
|
||||||
xmr_address: a.xmr_address,
|
xmr_address: String::from(&a.xmr_address),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue