helper.rs 6.3 KB

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