123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 |
- use crate::helper::*;
- use flowy_test::{builder::UserTest, FlowyTest};
- use flowy_user::{errors::ErrorCode, event::UserEvent::*, prelude::*};
- use lib_infra::uuid;
- use serial_test::*;
- #[tokio::test]
- async fn user_profile_get_failed() {
- let test = FlowyTest::setup();
- let result = UserTest::new(test.sdk)
- .event(GetUserProfile)
- .assert_error()
- .async_send()
- .await;
- assert!(result.user_profile().is_none())
- }
- #[tokio::test]
- #[serial]
- async fn user_profile_get() {
- let test = FlowyTest::setup();
- let user_profile = test.init_user().await;
- let user = UserTest::new(test.sdk.clone())
- .event(GetUserProfile)
- .sync_send()
- .parse::<UserProfile>();
- assert_eq!(user_profile, user);
- }
- #[tokio::test]
- #[serial]
- async fn user_update_with_name() {
- let test = FlowyTest::setup();
- let user = test.init_user().await;
- let new_name = "hello_world".to_owned();
- let request = UpdateUserRequest::new(&user.id).name(&new_name);
- let _ = UserTest::new(test.sdk()).event(UpdateUser).request(request).sync_send();
- let user_profile = UserTest::new(test.sdk())
- .event(GetUserProfile)
- .assert_error()
- .sync_send()
- .parse::<UserProfile>();
- assert_eq!(user_profile.name, new_name,);
- }
- #[tokio::test]
- #[serial]
- async fn user_update_with_email() {
- let test = FlowyTest::setup();
- let user = test.init_user().await;
- let new_email = format!("{}@gmail.com", uuid());
- let request = UpdateUserRequest::new(&user.id).email(&new_email);
- let _ = UserTest::new(test.sdk()).event(UpdateUser).request(request).sync_send();
- let user_profile = UserTest::new(test.sdk())
- .event(GetUserProfile)
- .assert_error()
- .sync_send()
- .parse::<UserProfile>();
- assert_eq!(user_profile.email, new_email,);
- }
- #[tokio::test]
- #[serial]
- async fn user_update_with_password() {
- let test = FlowyTest::setup();
- let user = test.init_user().await;
- let new_password = "H123world!".to_owned();
- let request = UpdateUserRequest::new(&user.id).password(&new_password);
- let _ = UserTest::new(test.sdk())
- .event(UpdateUser)
- .request(request)
- .sync_send()
- .assert_success();
- }
- #[tokio::test]
- #[serial]
- async fn user_update_with_invalid_email() {
- let test = FlowyTest::setup();
- let user = test.init_user().await;
- for email in invalid_email_test_case() {
- let request = UpdateUserRequest::new(&user.id).email(&email);
- assert_eq!(
- UserTest::new(test.sdk())
- .event(UpdateUser)
- .request(request)
- .sync_send()
- .error()
- .code,
- ErrorCode::EmailFormatInvalid.value()
- );
- }
- }
- #[tokio::test]
- #[serial]
- async fn user_update_with_invalid_password() {
- let test = FlowyTest::setup();
- let user = test.init_user().await;
- for password in invalid_password_test_case() {
- let request = UpdateUserRequest::new(&user.id).password(&password);
- UserTest::new(test.sdk())
- .event(UpdateUser)
- .request(request)
- .sync_send()
- .assert_error();
- }
- }
- #[tokio::test]
- #[serial]
- async fn user_update_with_invalid_name() {
- let test = FlowyTest::setup();
- let user = test.init_user().await;
- let request = UpdateUserRequest::new(&user.id).name("");
- UserTest::new(test.sdk())
- .event(UpdateUser)
- .request(request)
- .sync_send()
- .assert_error();
- }
|