user_test.rs 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. use uuid::Uuid;
  2. use flowy_encrypt::{encrypt_text, generate_encryption_secret};
  3. use flowy_user_deps::entities::*;
  4. use lib_infra::box_any::BoxAny;
  5. use crate::supabase_test::util::{
  6. get_supabase_ci_config, third_party_sign_up_param, user_auth_service,
  7. };
  8. // ‼️‼️‼️ Warning: this test will create a table in the database
  9. #[tokio::test]
  10. async fn supabase_user_sign_up_test() {
  11. if get_supabase_ci_config().is_none() {
  12. return;
  13. }
  14. let user_service = user_auth_service();
  15. let uuid = Uuid::new_v4().to_string();
  16. let params = third_party_sign_up_param(uuid);
  17. let user: AuthResponse = user_service.sign_up(BoxAny::new(params)).await.unwrap();
  18. assert!(!user.latest_workspace.id.is_empty());
  19. assert!(!user.user_workspaces.is_empty());
  20. assert!(!user.latest_workspace.database_views_aggregate_id.is_empty());
  21. }
  22. #[tokio::test]
  23. async fn supabase_user_sign_up_with_existing_uuid_test() {
  24. if get_supabase_ci_config().is_none() {
  25. return;
  26. }
  27. let user_service = user_auth_service();
  28. let uuid = Uuid::new_v4().to_string();
  29. let params = third_party_sign_up_param(uuid);
  30. let _user: AuthResponse = user_service
  31. .sign_up(BoxAny::new(params.clone()))
  32. .await
  33. .unwrap();
  34. let user: AuthResponse = user_service.sign_up(BoxAny::new(params)).await.unwrap();
  35. assert!(!user.latest_workspace.id.is_empty());
  36. assert!(!user.latest_workspace.database_views_aggregate_id.is_empty());
  37. assert!(!user.user_workspaces.is_empty());
  38. }
  39. #[tokio::test]
  40. async fn supabase_update_user_profile_test() {
  41. if get_supabase_ci_config().is_none() {
  42. return;
  43. }
  44. let user_service = user_auth_service();
  45. let uuid = Uuid::new_v4().to_string();
  46. let params = third_party_sign_up_param(uuid);
  47. let user: AuthResponse = user_service
  48. .sign_up(BoxAny::new(params.clone()))
  49. .await
  50. .unwrap();
  51. let params = UpdateUserProfileParams::new(user.user_id)
  52. .with_name("123")
  53. .with_email(format!("{}@test.com", Uuid::new_v4()));
  54. user_service
  55. .update_user(UserCredentials::from_uid(user.user_id), params)
  56. .await
  57. .unwrap();
  58. let user_profile = user_service
  59. .get_user_profile(UserCredentials::from_uid(user.user_id))
  60. .await
  61. .unwrap()
  62. .unwrap();
  63. assert_eq!(user_profile.name, "123");
  64. }
  65. #[tokio::test]
  66. async fn supabase_get_user_profile_test() {
  67. if get_supabase_ci_config().is_none() {
  68. return;
  69. }
  70. let user_service = user_auth_service();
  71. let uuid = Uuid::new_v4().to_string();
  72. let params = third_party_sign_up_param(uuid);
  73. let user: AuthResponse = user_service
  74. .sign_up(BoxAny::new(params.clone()))
  75. .await
  76. .unwrap();
  77. let credential = UserCredentials::from_uid(user.user_id);
  78. user_service
  79. .get_user_profile(credential.clone())
  80. .await
  81. .unwrap()
  82. .unwrap();
  83. }
  84. #[tokio::test]
  85. async fn supabase_get_not_exist_user_profile_test() {
  86. if get_supabase_ci_config().is_none() {
  87. return;
  88. }
  89. let user_service = user_auth_service();
  90. let result = user_service
  91. .get_user_profile(UserCredentials::from_uid(i64::MAX))
  92. .await
  93. .unwrap();
  94. // user not found
  95. assert!(result.is_none());
  96. }
  97. #[tokio::test]
  98. async fn user_encryption_sign_test() {
  99. if get_supabase_ci_config().is_none() {
  100. return;
  101. }
  102. let user_service = user_auth_service();
  103. let uuid = Uuid::new_v4().to_string();
  104. let params = third_party_sign_up_param(uuid);
  105. let user: AuthResponse = user_service.sign_up(BoxAny::new(params)).await.unwrap();
  106. // generate encryption sign
  107. let secret = generate_encryption_secret();
  108. let sign = encrypt_text(user.user_id.to_string(), &secret).unwrap();
  109. user_service
  110. .update_user(
  111. UserCredentials::from_uid(user.user_id),
  112. UpdateUserProfileParams::new(user.user_id)
  113. .with_encryption_type(EncryptionType::SelfEncryption(sign.clone())),
  114. )
  115. .await
  116. .unwrap();
  117. let user_profile: UserProfile = user_service
  118. .get_user_profile(UserCredentials::from_uid(user.user_id))
  119. .await
  120. .unwrap()
  121. .unwrap();
  122. assert_eq!(
  123. user_profile.encryption_type,
  124. EncryptionType::SelfEncryption(sign)
  125. );
  126. }