AppFlowy-Cloud/tests/user/update.rs

66 lines
1.7 KiB
Rust

use shared_entity::dto::UserUpdateParams;
use shared_entity::error_code::ErrorCode;
use crate::localhost_client;
use crate::user::utils::{generate_unique_email, generate_unique_registered_user_client};
#[tokio::test]
async fn update_but_not_logged_in() {
let c = localhost_client();
let new_email = generate_unique_email();
let new_password = "Hello123!";
let res = c
.update(
UserUpdateParams::new()
.with_email(new_email)
.with_password(new_password),
)
.await;
assert!(res.is_err());
}
#[tokio::test]
async fn update_password_same_password() {
let (c, user) = generate_unique_registered_user_client().await;
c.sign_in_password(&user.email, &user.password)
.await
.unwrap();
let err = c
.update(
UserUpdateParams::new()
.with_email(&user.email)
.with_password(&user.password),
)
.await
.err()
.unwrap();
assert_eq!(err.code, ErrorCode::InvalidRequestParams);
assert_eq!(
err.message,
"New password should be different from the old password."
);
}
#[tokio::test]
async fn update_password_and_revert() {
let (c, user) = generate_unique_registered_user_client().await;
let new_password = "Hello456!";
{
// change password to new_password
c.sign_in_password(&user.email, &user.password)
.await
.unwrap();
c.update(UserUpdateParams::new().with_password(new_password))
.await
.unwrap();
}
{
// revert password to old_password
let c = localhost_client();
c.sign_in_password(&user.email, new_password).await.unwrap();
c.update(UserUpdateParams::new().with_password(&user.password))
.await
.unwrap();
}
}