117 lines
4.2 KiB
Rust
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(®istered_user.email, ®istered_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(®istered_user.email, ®istered_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);
|
|
}
|