helper.rs 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  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::{AFPluginDispatcher, AFPluginRequest, 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(
  27. sdk: &FlowySDKTest,
  28. data_format: ViewDataFormatPB,
  29. layout: ViewLayoutTypePB,
  30. data: Vec<u8>,
  31. ) -> Self {
  32. let workspace = create_workspace(sdk, "Workspace", "").await;
  33. open_workspace(sdk, &workspace.id).await;
  34. let app = create_app(sdk, "App", "AppFlowy GitHub Project", &workspace.id).await;
  35. let view = create_view(sdk, &app.id, data_format, layout, data).await;
  36. Self {
  37. sdk: sdk.clone(),
  38. workspace,
  39. app,
  40. view,
  41. }
  42. }
  43. pub async fn new_grid_view(sdk: &FlowySDKTest, data: Vec<u8>) -> Self {
  44. Self::new(sdk, ViewDataFormatPB::DatabaseFormat, ViewLayoutTypePB::Grid, data).await
  45. }
  46. pub async fn new_board_view(sdk: &FlowySDKTest, data: Vec<u8>) -> Self {
  47. Self::new(sdk, ViewDataFormatPB::DatabaseFormat, ViewLayoutTypePB::Board, data).await
  48. }
  49. pub async fn new_calendar_view(sdk: &FlowySDKTest, data: Vec<u8>) -> Self {
  50. Self::new(sdk, ViewDataFormatPB::DatabaseFormat, ViewLayoutTypePB::Calendar, data).await
  51. }
  52. pub async fn new_document_view(sdk: &FlowySDKTest) -> Self {
  53. let view_data_format = match sdk.document_version() {
  54. DocumentVersionPB::V0 => ViewDataFormatPB::DeltaFormat,
  55. DocumentVersionPB::V1 => ViewDataFormatPB::TreeFormat,
  56. };
  57. Self::new(sdk, view_data_format, ViewLayoutTypePB::Document, vec![]).await
  58. }
  59. }
  60. async fn create_workspace(sdk: &FlowySDKTest, name: &str, desc: &str) -> WorkspacePB {
  61. let request = CreateWorkspacePayloadPB {
  62. name: name.to_owned(),
  63. desc: desc.to_owned(),
  64. };
  65. FolderEventBuilder::new(sdk.clone())
  66. .event(CreateWorkspace)
  67. .payload(request)
  68. .async_send()
  69. .await
  70. .parse::<WorkspacePB>()
  71. }
  72. async fn open_workspace(sdk: &FlowySDKTest, workspace_id: &str) {
  73. let payload = WorkspaceIdPB {
  74. value: Some(workspace_id.to_owned()),
  75. };
  76. let _ = FolderEventBuilder::new(sdk.clone())
  77. .event(OpenWorkspace)
  78. .payload(payload)
  79. .async_send()
  80. .await;
  81. }
  82. async fn create_app(sdk: &FlowySDKTest, name: &str, desc: &str, workspace_id: &str) -> AppPB {
  83. let create_app_request = CreateAppPayloadPB {
  84. workspace_id: workspace_id.to_owned(),
  85. name: name.to_string(),
  86. desc: desc.to_string(),
  87. color_style: Default::default(),
  88. };
  89. FolderEventBuilder::new(sdk.clone())
  90. .event(CreateApp)
  91. .payload(create_app_request)
  92. .async_send()
  93. .await
  94. .parse::<AppPB>()
  95. }
  96. async fn create_view(
  97. sdk: &FlowySDKTest,
  98. app_id: &str,
  99. data_format: ViewDataFormatPB,
  100. layout: ViewLayoutTypePB,
  101. data: Vec<u8>,
  102. ) -> ViewPB {
  103. let request = CreateViewPayloadPB {
  104. belong_to_id: app_id.to_string(),
  105. name: "View A".to_string(),
  106. desc: "".to_string(),
  107. thumbnail: Some("http://1.png".to_string()),
  108. data_format,
  109. layout,
  110. view_content_data: data,
  111. };
  112. FolderEventBuilder::new(sdk.clone())
  113. .event(CreateView)
  114. .payload(request)
  115. .async_send()
  116. .await
  117. .parse::<ViewPB>()
  118. }
  119. pub fn root_dir() -> String {
  120. // https://doc.rust-lang.org/cargo/reference/environment-variables.html
  121. let manifest_dir = std::env::var("CARGO_MANIFEST_DIR").unwrap_or_else(|_| "./".to_owned());
  122. let mut path_buf = fs::canonicalize(&PathBuf::from(&manifest_dir)).unwrap();
  123. path_buf.pop(); // rust-lib
  124. path_buf.push("temp");
  125. path_buf.push("flowy");
  126. let root_dir = path_buf.to_str().unwrap().to_string();
  127. if !std::path::Path::new(&root_dir).exists() {
  128. std::fs::create_dir_all(&root_dir).unwrap();
  129. }
  130. root_dir
  131. }
  132. pub fn random_email() -> String {
  133. format!("{}@appflowy.io", nanoid!(20))
  134. }
  135. pub fn login_email() -> String {
  136. "[email protected]".to_string()
  137. }
  138. pub fn login_password() -> String {
  139. "HelloWorld!123".to_string()
  140. }
  141. pub struct SignUpContext {
  142. pub user_profile: UserProfilePB,
  143. pub password: String,
  144. }
  145. pub fn sign_up(dispatch: Arc<AFPluginDispatcher>) -> SignUpContext {
  146. let password = login_password();
  147. let payload = SignUpPayloadPB {
  148. email: random_email(),
  149. name: "app flowy".to_string(),
  150. password: password.clone(),
  151. }
  152. .into_bytes()
  153. .unwrap();
  154. let request = AFPluginRequest::new(SignUp).payload(payload);
  155. let user_profile = AFPluginDispatcher::sync_send(dispatch, request)
  156. .parse::<UserProfilePB, FlowyError>()
  157. .unwrap()
  158. .unwrap();
  159. SignUpContext { user_profile, password }
  160. }
  161. pub async fn async_sign_up(dispatch: Arc<AFPluginDispatcher>) -> SignUpContext {
  162. let password = login_password();
  163. let email = random_email();
  164. let payload = SignUpPayloadPB {
  165. email,
  166. name: "app flowy".to_string(),
  167. password: password.clone(),
  168. }
  169. .into_bytes()
  170. .unwrap();
  171. let request = AFPluginRequest::new(SignUp).payload(payload);
  172. let user_profile = AFPluginDispatcher::async_send(dispatch.clone(), request)
  173. .await
  174. .parse::<UserProfilePB, FlowyError>()
  175. .unwrap()
  176. .unwrap();
  177. // let _ = create_default_workspace_if_need(dispatch.clone(), &user_profile.id);
  178. SignUpContext { user_profile, password }
  179. }
  180. pub async fn init_user_setting(dispatch: Arc<AFPluginDispatcher>) {
  181. let request = AFPluginRequest::new(InitUser);
  182. let _ = AFPluginDispatcher::async_send(dispatch.clone(), request).await;
  183. }
  184. #[allow(dead_code)]
  185. fn sign_in(dispatch: Arc<AFPluginDispatcher>) -> UserProfilePB {
  186. let payload = SignInPayloadPB {
  187. email: login_email(),
  188. password: login_password(),
  189. name: "rust".to_owned(),
  190. }
  191. .into_bytes()
  192. .unwrap();
  193. let request = AFPluginRequest::new(SignIn).payload(payload);
  194. AFPluginDispatcher::sync_send(dispatch, request)
  195. .parse::<UserProfilePB, FlowyError>()
  196. .unwrap()
  197. .unwrap()
  198. }
  199. #[allow(dead_code)]
  200. fn logout(dispatch: Arc<AFPluginDispatcher>) {
  201. let _ = AFPluginDispatcher::sync_send(dispatch, AFPluginRequest::new(SignOut));
  202. }