helper.rs 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. use crate::prelude::*;
  2. use flowy_folder::prelude::WorkspaceId;
  3. use flowy_folder::{
  4. entities::{
  5. app::*,
  6. view::*,
  7. workspace::{CreateWorkspacePayload, Workspace},
  8. },
  9. event_map::FolderEvent::{CreateWorkspace, OpenWorkspace, *},
  10. };
  11. use flowy_user::{
  12. entities::{SignInPayload, SignUpPayload, UserProfile},
  13. errors::FlowyError,
  14. event_map::UserEvent::{InitUser, SignIn, SignOut, SignUp},
  15. };
  16. use lib_dispatch::prelude::{EventDispatcher, ModuleRequest, ToBytes};
  17. use lib_infra::uuid_string;
  18. use std::{fs, path::PathBuf, sync::Arc};
  19. pub struct ViewTest {
  20. pub sdk: FlowySDKTest,
  21. pub workspace: Workspace,
  22. pub app: App,
  23. pub view: View,
  24. }
  25. impl ViewTest {
  26. pub async fn new(sdk: &FlowySDKTest) -> Self {
  27. let workspace = create_workspace(sdk, "Workspace", "").await;
  28. open_workspace(sdk, &workspace.id).await;
  29. let app = create_app(sdk, "App", "AppFlowy GitHub Project", &workspace.id).await;
  30. let view = create_view(sdk, &app.id).await;
  31. Self {
  32. sdk: sdk.clone(),
  33. workspace,
  34. app,
  35. view,
  36. }
  37. }
  38. }
  39. async fn create_workspace(sdk: &FlowySDKTest, name: &str, desc: &str) -> Workspace {
  40. let request = CreateWorkspacePayload {
  41. name: name.to_owned(),
  42. desc: desc.to_owned(),
  43. };
  44. let workspace = FolderEventBuilder::new(sdk.clone())
  45. .event(CreateWorkspace)
  46. .payload(request)
  47. .async_send()
  48. .await
  49. .parse::<Workspace>();
  50. workspace
  51. }
  52. async fn open_workspace(sdk: &FlowySDKTest, workspace_id: &str) {
  53. let payload = WorkspaceId {
  54. value: Some(workspace_id.to_owned()),
  55. };
  56. let _ = FolderEventBuilder::new(sdk.clone())
  57. .event(OpenWorkspace)
  58. .payload(payload)
  59. .async_send()
  60. .await;
  61. }
  62. async fn create_app(sdk: &FlowySDKTest, name: &str, desc: &str, workspace_id: &str) -> App {
  63. let create_app_request = CreateAppPayload {
  64. workspace_id: workspace_id.to_owned(),
  65. name: name.to_string(),
  66. desc: desc.to_string(),
  67. color_style: Default::default(),
  68. };
  69. let app = FolderEventBuilder::new(sdk.clone())
  70. .event(CreateApp)
  71. .payload(create_app_request)
  72. .async_send()
  73. .await
  74. .parse::<App>();
  75. app
  76. }
  77. async fn create_view(sdk: &FlowySDKTest, app_id: &str) -> View {
  78. let request = CreateViewPayload {
  79. belong_to_id: app_id.to_string(),
  80. name: "View A".to_string(),
  81. desc: "".to_string(),
  82. thumbnail: Some("http://1.png".to_string()),
  83. data_type: ViewDataType::RichText,
  84. ext_data: "".to_string(),
  85. plugin_type: 0,
  86. };
  87. let view = FolderEventBuilder::new(sdk.clone())
  88. .event(CreateView)
  89. .payload(request)
  90. .async_send()
  91. .await
  92. .parse::<View>();
  93. view
  94. }
  95. pub fn root_dir() -> String {
  96. // https://doc.rust-lang.org/cargo/reference/environment-variables.html
  97. let manifest_dir = std::env::var("CARGO_MANIFEST_DIR").unwrap_or_else(|_| "./".to_owned());
  98. let mut path_buf = fs::canonicalize(&PathBuf::from(&manifest_dir)).unwrap();
  99. path_buf.pop(); // rust-lib
  100. path_buf.push("temp");
  101. path_buf.push("flowy");
  102. let root_dir = path_buf.to_str().unwrap().to_string();
  103. if !std::path::Path::new(&root_dir).exists() {
  104. std::fs::create_dir_all(&root_dir).unwrap();
  105. }
  106. root_dir
  107. }
  108. pub fn random_email() -> String {
  109. format!("{}@appflowy.io", uuid_string())
  110. }
  111. pub fn login_email() -> String {
  112. "[email protected]".to_string()
  113. }
  114. pub fn login_password() -> String {
  115. "HelloWorld!123".to_string()
  116. }
  117. pub struct SignUpContext {
  118. pub user_profile: UserProfile,
  119. pub password: String,
  120. }
  121. pub fn sign_up(dispatch: Arc<EventDispatcher>) -> SignUpContext {
  122. let password = login_password();
  123. let payload = SignUpPayload {
  124. email: random_email(),
  125. name: "app flowy".to_string(),
  126. password: password.clone(),
  127. }
  128. .into_bytes()
  129. .unwrap();
  130. let request = ModuleRequest::new(SignUp).payload(payload);
  131. let user_profile = EventDispatcher::sync_send(dispatch, request)
  132. .parse::<UserProfile, FlowyError>()
  133. .unwrap()
  134. .unwrap();
  135. SignUpContext { user_profile, password }
  136. }
  137. pub async fn async_sign_up(dispatch: Arc<EventDispatcher>) -> SignUpContext {
  138. let password = login_password();
  139. let payload = SignUpPayload {
  140. email: random_email(),
  141. name: "app flowy".to_string(),
  142. password: password.clone(),
  143. }
  144. .into_bytes()
  145. .unwrap();
  146. let request = ModuleRequest::new(SignUp).payload(payload);
  147. let user_profile = EventDispatcher::async_send(dispatch.clone(), request)
  148. .await
  149. .parse::<UserProfile, FlowyError>()
  150. .unwrap()
  151. .unwrap();
  152. // let _ = create_default_workspace_if_need(dispatch.clone(), &user_profile.id);
  153. SignUpContext { user_profile, password }
  154. }
  155. pub async fn init_user_setting(dispatch: Arc<EventDispatcher>) {
  156. let request = ModuleRequest::new(InitUser);
  157. let _ = EventDispatcher::async_send(dispatch.clone(), request).await;
  158. }
  159. #[allow(dead_code)]
  160. fn sign_in(dispatch: Arc<EventDispatcher>) -> UserProfile {
  161. let payload = SignInPayload {
  162. email: login_email(),
  163. password: login_password(),
  164. name: "rust".to_owned(),
  165. }
  166. .into_bytes()
  167. .unwrap();
  168. let request = ModuleRequest::new(SignIn).payload(payload);
  169. EventDispatcher::sync_send(dispatch, request)
  170. .parse::<UserProfile, FlowyError>()
  171. .unwrap()
  172. .unwrap()
  173. }
  174. #[allow(dead_code)]
  175. fn logout(dispatch: Arc<EventDispatcher>) {
  176. let _ = EventDispatcher::sync_send(dispatch, ModuleRequest::new(SignOut));
  177. }