helper.rs 6.0 KB

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