|
@@ -1,5 +1,5 @@
|
|
|
|
+use crate::prelude::*;
|
|
use flowy_document::entities::doc::Doc;
|
|
use flowy_document::entities::doc::Doc;
|
|
-use flowy_test::prelude::*;
|
|
|
|
use flowy_workspace::{
|
|
use flowy_workspace::{
|
|
entities::{app::*, view::*, workspace::*},
|
|
entities::{app::*, view::*, workspace::*},
|
|
event::WorkspaceEvent::*,
|
|
event::WorkspaceEvent::*,
|
|
@@ -11,12 +11,16 @@ pub struct WorkspaceTest {
|
|
}
|
|
}
|
|
|
|
|
|
impl WorkspaceTest {
|
|
impl WorkspaceTest {
|
|
- pub fn new() -> Self {
|
|
|
|
- let sdk = FlowyEnv::setup().sdk;
|
|
|
|
- let workspace = create_workspace(&sdk, "Workspace", "");
|
|
|
|
- open_workspace(&sdk, &workspace.id);
|
|
|
|
-
|
|
|
|
- Self { sdk, workspace }
|
|
|
|
|
|
+ pub async fn new() -> Self {
|
|
|
|
+ let test = FlowyTest::setup();
|
|
|
|
+ let _ = test.init_user().await;
|
|
|
|
+ let workspace = create_workspace(&test.sdk, "Workspace", "").await;
|
|
|
|
+ open_workspace(&test.sdk, &workspace.id).await;
|
|
|
|
+
|
|
|
|
+ Self {
|
|
|
|
+ sdk: test.sdk,
|
|
|
|
+ workspace,
|
|
|
|
+ }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
@@ -27,15 +31,20 @@ pub struct AppTest {
|
|
}
|
|
}
|
|
|
|
|
|
impl AppTest {
|
|
impl AppTest {
|
|
- pub fn new() -> Self {
|
|
|
|
- let sdk = FlowyEnv::setup().sdk;
|
|
|
|
- let workspace = create_workspace(&sdk, "Workspace", "");
|
|
|
|
- open_workspace(&sdk, &workspace.id);
|
|
|
|
- let app = create_app(&sdk, "App", "AppFlowy Github Project", &workspace.id);
|
|
|
|
- Self { sdk, workspace, app }
|
|
|
|
|
|
+ pub async fn new() -> Self {
|
|
|
|
+ let test = FlowyTest::setup();
|
|
|
|
+ let _ = test.init_user().await;
|
|
|
|
+ let workspace = create_workspace(&test.sdk, "Workspace", "").await;
|
|
|
|
+ open_workspace(&test.sdk, &workspace.id).await;
|
|
|
|
+ let app = create_app(&test.sdk, "App", "AppFlowy Github Project", &workspace.id).await;
|
|
|
|
+ Self {
|
|
|
|
+ sdk: test.sdk,
|
|
|
|
+ workspace,
|
|
|
|
+ app,
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
- pub fn move_app_to_trash(&self) {
|
|
|
|
|
|
+ pub async fn move_app_to_trash(&self) {
|
|
let request = UpdateAppRequest {
|
|
let request = UpdateAppRequest {
|
|
app_id: self.app.id.clone(),
|
|
app_id: self.app.id.clone(),
|
|
name: None,
|
|
name: None,
|
|
@@ -43,11 +52,11 @@ impl AppTest {
|
|
color_style: None,
|
|
color_style: None,
|
|
is_trash: Some(true),
|
|
is_trash: Some(true),
|
|
};
|
|
};
|
|
- update_app(&self.sdk, request);
|
|
|
|
|
|
+ update_app(&self.sdk, request).await;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
-pub(crate) struct ViewTest {
|
|
|
|
|
|
+pub struct ViewTest {
|
|
pub sdk: FlowyTestSDK,
|
|
pub sdk: FlowyTestSDK,
|
|
pub workspace: Workspace,
|
|
pub workspace: Workspace,
|
|
pub app: App,
|
|
pub app: App,
|
|
@@ -55,16 +64,20 @@ pub(crate) struct ViewTest {
|
|
}
|
|
}
|
|
|
|
|
|
impl ViewTest {
|
|
impl ViewTest {
|
|
- pub fn new() -> Self {
|
|
|
|
- let sdk = FlowyEnv::setup().sdk;
|
|
|
|
- let workspace = create_workspace(&sdk, "Workspace", "");
|
|
|
|
- open_workspace(&sdk, &workspace.id);
|
|
|
|
- let app = create_app(&sdk, "App", "AppFlowy Github Project", &workspace.id);
|
|
|
|
- let view = create_view(&sdk, &app.id);
|
|
|
|
- Self { sdk, workspace, app, view }
|
|
|
|
|
|
+ pub async fn new(test: &FlowyTest) -> Self {
|
|
|
|
+ let workspace = create_workspace(&test.sdk, "Workspace", "").await;
|
|
|
|
+ open_workspace(&test.sdk, &workspace.id).await;
|
|
|
|
+ let app = create_app(&test.sdk, "App", "AppFlowy Github Project", &workspace.id).await;
|
|
|
|
+ let view = create_view(&test.sdk, &app.id).await;
|
|
|
|
+ Self {
|
|
|
|
+ sdk: test.sdk.clone(),
|
|
|
|
+ workspace,
|
|
|
|
+ app,
|
|
|
|
+ view,
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
- pub fn move_view_to_trash(&self) {
|
|
|
|
|
|
+ pub async fn move_view_to_trash(&self) {
|
|
let request = UpdateViewRequest {
|
|
let request = UpdateViewRequest {
|
|
view_id: self.view.id.clone(),
|
|
view_id: self.view.id.clone(),
|
|
name: None,
|
|
name: None,
|
|
@@ -72,18 +85,18 @@ impl ViewTest {
|
|
thumbnail: None,
|
|
thumbnail: None,
|
|
is_trash: Some(true),
|
|
is_trash: Some(true),
|
|
};
|
|
};
|
|
- update_view(&self.sdk, request);
|
|
|
|
|
|
+ update_view(&self.sdk, request).await;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
-pub(crate) fn invalid_workspace_name_test_case() -> Vec<String> {
|
|
|
|
|
|
+pub fn invalid_workspace_name_test_case() -> Vec<String> {
|
|
vec!["", "1234".repeat(100).as_str()]
|
|
vec!["", "1234".repeat(100).as_str()]
|
|
.iter()
|
|
.iter()
|
|
.map(|s| s.to_string())
|
|
.map(|s| s.to_string())
|
|
.collect::<Vec<_>>()
|
|
.collect::<Vec<_>>()
|
|
}
|
|
}
|
|
|
|
|
|
-pub fn create_workspace(sdk: &FlowyTestSDK, name: &str, desc: &str) -> Workspace {
|
|
|
|
|
|
+pub async fn create_workspace(sdk: &FlowyTestSDK, name: &str, desc: &str) -> Workspace {
|
|
let request = CreateWorkspaceRequest {
|
|
let request = CreateWorkspaceRequest {
|
|
name: name.to_owned(),
|
|
name: name.to_owned(),
|
|
desc: desc.to_owned(),
|
|
desc: desc.to_owned(),
|
|
@@ -92,19 +105,21 @@ pub fn create_workspace(sdk: &FlowyTestSDK, name: &str, desc: &str) -> Workspace
|
|
let workspace = FlowyWorkspaceTest::new(sdk.clone())
|
|
let workspace = FlowyWorkspaceTest::new(sdk.clone())
|
|
.event(CreateWorkspace)
|
|
.event(CreateWorkspace)
|
|
.request(request)
|
|
.request(request)
|
|
- .sync_send()
|
|
|
|
|
|
+ .async_send()
|
|
|
|
+ .await
|
|
.parse::<Workspace>();
|
|
.parse::<Workspace>();
|
|
workspace
|
|
workspace
|
|
}
|
|
}
|
|
|
|
|
|
-fn open_workspace(sdk: &FlowyTestSDK, workspace_id: &str) {
|
|
|
|
|
|
+async fn open_workspace(sdk: &FlowyTestSDK, workspace_id: &str) {
|
|
let request = QueryWorkspaceRequest {
|
|
let request = QueryWorkspaceRequest {
|
|
workspace_id: Some(workspace_id.to_owned()),
|
|
workspace_id: Some(workspace_id.to_owned()),
|
|
};
|
|
};
|
|
let _ = FlowyWorkspaceTest::new(sdk.clone())
|
|
let _ = FlowyWorkspaceTest::new(sdk.clone())
|
|
.event(OpenWorkspace)
|
|
.event(OpenWorkspace)
|
|
.request(request)
|
|
.request(request)
|
|
- .sync_send();
|
|
|
|
|
|
+ .async_send()
|
|
|
|
+ .await;
|
|
}
|
|
}
|
|
|
|
|
|
pub fn read_workspace(sdk: &FlowyTestSDK, request: QueryWorkspaceRequest) -> Option<Workspace> {
|
|
pub fn read_workspace(sdk: &FlowyTestSDK, request: QueryWorkspaceRequest) -> Option<Workspace> {
|
|
@@ -129,7 +144,7 @@ pub fn read_workspace(sdk: &FlowyTestSDK, request: QueryWorkspaceRequest) -> Opt
|
|
workspaces.drain(..1).collect::<Vec<Workspace>>().pop()
|
|
workspaces.drain(..1).collect::<Vec<Workspace>>().pop()
|
|
}
|
|
}
|
|
|
|
|
|
-pub fn create_app(sdk: &FlowyTestSDK, name: &str, desc: &str, workspace_id: &str) -> App {
|
|
|
|
|
|
+pub async fn create_app(sdk: &FlowyTestSDK, name: &str, desc: &str, workspace_id: &str) -> App {
|
|
let create_app_request = CreateAppRequest {
|
|
let create_app_request = CreateAppRequest {
|
|
workspace_id: workspace_id.to_owned(),
|
|
workspace_id: workspace_id.to_owned(),
|
|
name: name.to_string(),
|
|
name: name.to_string(),
|
|
@@ -140,7 +155,8 @@ pub fn create_app(sdk: &FlowyTestSDK, name: &str, desc: &str, workspace_id: &str
|
|
let app = FlowyWorkspaceTest::new(sdk.clone())
|
|
let app = FlowyWorkspaceTest::new(sdk.clone())
|
|
.event(CreateApp)
|
|
.event(CreateApp)
|
|
.request(create_app_request)
|
|
.request(create_app_request)
|
|
- .sync_send()
|
|
|
|
|
|
+ .async_send()
|
|
|
|
+ .await
|
|
.parse::<App>();
|
|
.parse::<App>();
|
|
app
|
|
app
|
|
}
|
|
}
|
|
@@ -156,8 +172,12 @@ pub fn delete_app(sdk: &FlowyTestSDK, app_id: &str) {
|
|
.sync_send();
|
|
.sync_send();
|
|
}
|
|
}
|
|
|
|
|
|
-pub fn update_app(sdk: &FlowyTestSDK, request: UpdateAppRequest) {
|
|
|
|
- FlowyWorkspaceTest::new(sdk.clone()).event(UpdateApp).request(request).sync_send();
|
|
|
|
|
|
+pub async fn update_app(sdk: &FlowyTestSDK, request: UpdateAppRequest) {
|
|
|
|
+ FlowyWorkspaceTest::new(sdk.clone())
|
|
|
|
+ .event(UpdateApp)
|
|
|
|
+ .request(request)
|
|
|
|
+ .async_send()
|
|
|
|
+ .await;
|
|
}
|
|
}
|
|
|
|
|
|
pub fn read_app(sdk: &FlowyTestSDK, request: QueryAppRequest) -> App {
|
|
pub fn read_app(sdk: &FlowyTestSDK, request: QueryAppRequest) -> App {
|
|
@@ -170,17 +190,17 @@ pub fn read_app(sdk: &FlowyTestSDK, request: QueryAppRequest) -> App {
|
|
app
|
|
app
|
|
}
|
|
}
|
|
|
|
|
|
-pub fn create_view_with_request(sdk: &FlowyTestSDK, request: CreateViewRequest) -> View {
|
|
|
|
|
|
+pub async fn create_view_with_request(sdk: &FlowyTestSDK, request: CreateViewRequest) -> View {
|
|
let view = FlowyWorkspaceTest::new(sdk.clone())
|
|
let view = FlowyWorkspaceTest::new(sdk.clone())
|
|
.event(CreateView)
|
|
.event(CreateView)
|
|
.request(request)
|
|
.request(request)
|
|
- .sync_send()
|
|
|
|
|
|
+ .async_send()
|
|
|
|
+ .await
|
|
.parse::<View>();
|
|
.parse::<View>();
|
|
-
|
|
|
|
view
|
|
view
|
|
}
|
|
}
|
|
|
|
|
|
-pub fn create_view(sdk: &FlowyTestSDK, app_id: &str) -> View {
|
|
|
|
|
|
+pub async fn create_view(sdk: &FlowyTestSDK, app_id: &str) -> View {
|
|
let request = CreateViewRequest {
|
|
let request = CreateViewRequest {
|
|
belong_to_id: app_id.to_string(),
|
|
belong_to_id: app_id.to_string(),
|
|
name: "View A".to_string(),
|
|
name: "View A".to_string(),
|
|
@@ -189,25 +209,31 @@ pub fn create_view(sdk: &FlowyTestSDK, app_id: &str) -> View {
|
|
view_type: ViewType::Doc,
|
|
view_type: ViewType::Doc,
|
|
};
|
|
};
|
|
|
|
|
|
- create_view_with_request(sdk, request)
|
|
|
|
|
|
+ create_view_with_request(sdk, request).await
|
|
}
|
|
}
|
|
|
|
|
|
-pub fn update_view(sdk: &FlowyTestSDK, request: UpdateViewRequest) {
|
|
|
|
- FlowyWorkspaceTest::new(sdk.clone()).event(UpdateView).request(request).sync_send();
|
|
|
|
|
|
+pub async fn update_view(sdk: &FlowyTestSDK, request: UpdateViewRequest) {
|
|
|
|
+ FlowyWorkspaceTest::new(sdk.clone())
|
|
|
|
+ .event(UpdateView)
|
|
|
|
+ .request(request)
|
|
|
|
+ .async_send()
|
|
|
|
+ .await;
|
|
}
|
|
}
|
|
|
|
|
|
-pub fn read_view(sdk: &FlowyTestSDK, request: QueryViewRequest) -> View {
|
|
|
|
|
|
+pub async fn read_view(sdk: &FlowyTestSDK, request: QueryViewRequest) -> View {
|
|
FlowyWorkspaceTest::new(sdk.clone())
|
|
FlowyWorkspaceTest::new(sdk.clone())
|
|
.event(ReadView)
|
|
.event(ReadView)
|
|
.request(request)
|
|
.request(request)
|
|
- .sync_send()
|
|
|
|
|
|
+ .async_send()
|
|
|
|
+ .await
|
|
.parse::<View>()
|
|
.parse::<View>()
|
|
}
|
|
}
|
|
|
|
|
|
-pub fn open_view(sdk: &FlowyTestSDK, request: OpenViewRequest) -> Doc {
|
|
|
|
|
|
+pub async fn open_view(sdk: &FlowyTestSDK, request: OpenViewRequest) -> Doc {
|
|
FlowyWorkspaceTest::new(sdk.clone())
|
|
FlowyWorkspaceTest::new(sdk.clone())
|
|
.event(OpenView)
|
|
.event(OpenView)
|
|
.request(request)
|
|
.request(request)
|
|
- .sync_send()
|
|
|
|
|
|
+ .async_send()
|
|
|
|
+ .await
|
|
.parse::<Doc>()
|
|
.parse::<Doc>()
|
|
}
|
|
}
|