82 lines
3.4 KiB
Rust
82 lines
3.4 KiB
Rust
use shared_entity::error_code::ErrorCode;
|
|
|
|
use crate::client::utils::{
|
|
generate_unique_email, REGISTERED_EMAIL, REGISTERED_PASSWORD, REGISTERED_USER_MUTEX,
|
|
};
|
|
use crate::client_api_client;
|
|
|
|
#[tokio::test]
|
|
async fn sign_in_unknown_user() {
|
|
let email = generate_unique_email();
|
|
let password = "Hello123!";
|
|
let mut c = client_api_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 mut c = client_api_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 mut c = client_api_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 _guard = REGISTERED_USER_MUTEX.lock().await;
|
|
|
|
let mut c = client_api_client();
|
|
c.sign_in_password(®ISTERED_EMAIL, ®ISTERED_PASSWORD)
|
|
.await
|
|
.unwrap();
|
|
let token = c.token().unwrap();
|
|
assert!(token.user.confirmed_at.is_some());
|
|
|
|
let workspaces = c.workspaces().await.unwrap();
|
|
assert!(!workspaces.0.is_empty());
|
|
let profile = c.profile().await.unwrap();
|
|
let latest_workspace = workspaces.get_latest(profile);
|
|
assert!(latest_workspace.is_some());
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn sign_in_with_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 mut c = client_api_client();
|
|
match c.sign_in_url(url_str).await {
|
|
Ok(()) => panic!("should not be ok"),
|
|
Err(e) => {
|
|
assert_eq!(e.code, ErrorCode::OAuthError);
|
|
assert!(e
|
|
.message
|
|
.starts_with("invalid JWT: unable to parse or verify signature, token is expired by"));
|
|
},
|
|
}
|
|
}
|