AppFlowy-Cloud/tests/user/sign_in.rs

117 lines
4.2 KiB
Rust

use crate::localhost_client;
use crate::user::utils::{
generate_sign_in_action_link, generate_unique_email, generate_unique_registered_user,
};
use app_error::ErrorCode;
#[tokio::test]
async fn sign_in_unknown_user() {
let email = generate_unique_email();
let password = "Hello123!";
let c = localhost_client();
let err = c.sign_in_password(&email, password).await.unwrap_err();
assert_eq!(err.code, ErrorCode::OAuthError);
assert!(!err.message.is_empty());
}
#[tokio::test]
async fn sign_in_wrong_password() {
let c = localhost_client();
let email = generate_unique_email();
let password = "Hello123!";
c.sign_up(&email, password).await.unwrap();
let wrong_password = "Hllo123!";
let err = c
.sign_in_password(&email, wrong_password)
.await
.unwrap_err();
assert_eq!(err.code, ErrorCode::OAuthError);
assert!(!err.message.is_empty());
}
#[tokio::test]
async fn sign_in_unconfirmed_email() {
let c = localhost_client();
let email = generate_unique_email();
let password = "Hello123!";
c.sign_up(&email, password).await.unwrap();
let err = c.sign_in_password(&email, password).await.unwrap_err();
assert_eq!(err.code, ErrorCode::OAuthError);
assert!(!err.message.is_empty());
}
#[tokio::test]
async fn sign_in_success() {
let registered_user = generate_unique_registered_user().await;
{
// First Time
let c = localhost_client();
let is_new = c
.sign_in_password(&registered_user.email, &registered_user.password)
.await
.unwrap();
assert!(is_new);
assert!(c
.token()
.read()
.as_ref()
.unwrap()
.user
.confirmed_at
.is_some());
let workspaces = c.get_workspaces().await.unwrap();
assert_eq!(workspaces.0.len(), 1);
let _ = c.get_profile().await.unwrap();
}
{
// Subsequent Times
let c = localhost_client();
let is_new = c
.sign_in_password(&registered_user.email, &registered_user.password)
.await
.unwrap();
assert!(!is_new);
// workspaces should be the same
let workspaces = c.get_workspaces().await.unwrap();
assert_eq!(workspaces.0.len(), 1);
}
}
#[tokio::test]
async fn sign_in_with_invalid_url() {
let url_str = "appflowy-flutter://#access_token=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE2OTQ1ODIyMjMsInN1YiI6Ijk5MGM2NDNjLTMyMWEtNGNmMi04OWY1LTNhNmJhZGFjMTg5NCIsImVtYWlsIjoiNG5uaWhpbGF0ZWRAZ21haWwuY29tIiwicGhvbmUiOiIiLCJhcHBfbWV0YWRhdGEiOnsicHJvdmlkZXIiOiJnb29nbGUiLCJwcm92aWRlcnMiOlsiZ29vZ2xlIl19LCJ1c2VyX21ldGFkYXRhIjp7ImF2YXRhcl91cmwiOiJodHRwczovL2xoMy5nb29nbGV1c2VyY29udGVudC5jb20vYS9BQ2c4b2NJdGZpa28xX0lpMmZiNzM4VnpGekViLVBqT0NCY3FUQzdrNjVIX0hnRTQwOVk9czk2LWMiLCJlbWFpbCI6IjRubmloaWxhdGVkQGdtYWlsLmNvbSIsImVtYWlsX3ZlcmlmaWVkIjp0cnVlLCJmdWxsX25hbWUiOiJmdSB6aXhpYW5nIiwiaXNzIjoiaHR0cHM6Ly93d3cuZ29vZ2xlYXBpcy5jb20vdXNlcmluZm8vdjIvbWUiLCJuYW1lIjoiZnUgeml4aWFuZyIsInBpY3R1cmUiOiJodHRwczovL2xoMy5nb29nbGV1c2VyY29udGVudC5jb20vYS9BQ2c4b2NJdGZpa28xX0lpMmZiNzM4VnpGekViLVBqT0NCY3FUQzdrNjVIX0hnRTQwOVk9czk2LWMiLCJwcm92aWRlcl9pZCI6IjEwMTQ5OTYxMDMxOTYxNjE0NTcyNSIsInN1YiI6IjEwMTQ5OTYxMDMxOTYxNjE0NTcyNSJ9LCJyb2xlIjoiIn0.I-7j-Tdj62P56zhzEqvBc7cHMldv5MA_MM7xtrBibbE&expires_in=3600&provider_token=ya29.a0AfB_byCovXs1CUiC9_f9VBTupQPsIxwh9aSlOg0PLYJvv1x1zvVfssrQfW6_Aq9no7EKpCzFUCLElOvK1Xz4x4K5r7tug79tr5b1yiOoUMWTeWTXyV61fZHQbZ9vscAiyKYtq5NqYTiytHcQEFlKr7UMfu6BTbKsUwaCgYKAaISARISFQGOcNnC0Vsx2QCAXgYO3XbfcF91WQ0169&refresh_token=Hi3Jc3I_pj9YrexcR91i5g&token_type=bearer";
let c = localhost_client();
match c.sign_in_with_url(url_str).await {
Ok(_) => panic!("should not be ok"),
Err(e) => {
assert_eq!(e.code, ErrorCode::OAuthError);
assert!(e
.message
.contains("invalid JWT: unable to parse or verify signature, token is expired by"));
},
}
}
#[tokio::test]
async fn sign_in_with_url() {
let c = localhost_client();
let email = generate_unique_email();
let action_link = generate_sign_in_action_link(&email)
.await
.replacen("/gotrue", "", 1); // compatibility with local testing
let sign_in_url = c.extract_sign_in_url(action_link.as_str()).await.unwrap();
println!("url: {}", sign_in_url);
let is_new = c.sign_in_with_url(&sign_in_url).await.unwrap();
assert!(is_new);
}