2022-03-12 13:06:15 +00:00
|
|
|
use flowy_folder::event_map::FolderEvent::*;
|
2022-05-26 09:28:44 +00:00
|
|
|
use flowy_folder::{errors::ErrorCode, services::folder_editor::FolderEditor};
|
2022-03-12 13:06:15 +00:00
|
|
|
use flowy_folder_data_model::entities::view::{RepeatedViewId, ViewId};
|
|
|
|
use flowy_folder_data_model::entities::workspace::WorkspaceId;
|
2022-01-27 12:39:54 +00:00
|
|
|
use flowy_folder_data_model::entities::{
|
2022-01-22 10:48:43 +00:00
|
|
|
app::{App, RepeatedApp},
|
|
|
|
trash::Trash,
|
2022-02-28 14:38:53 +00:00
|
|
|
view::{RepeatedView, View, ViewDataType},
|
2022-01-22 10:48:43 +00:00
|
|
|
workspace::Workspace,
|
|
|
|
};
|
2022-03-12 13:06:15 +00:00
|
|
|
use flowy_folder_data_model::entities::{
|
|
|
|
app::{AppId, CreateAppPayload, UpdateAppPayload},
|
|
|
|
trash::{RepeatedTrash, TrashId, TrashType},
|
|
|
|
view::{CreateViewPayload, UpdateViewPayload},
|
|
|
|
workspace::{CreateWorkspacePayload, RepeatedWorkspace},
|
|
|
|
};
|
2022-03-19 08:52:28 +00:00
|
|
|
use flowy_revision::disk::RevisionState;
|
|
|
|
use flowy_revision::REVISION_WRITE_INTERVAL_IN_MILLIS;
|
|
|
|
use flowy_sync::entities::text_block_info::TextBlockInfo;
|
2022-03-12 13:06:15 +00:00
|
|
|
use flowy_test::{event_builder::*, FlowySDKTest};
|
2022-01-22 10:48:43 +00:00
|
|
|
use std::{sync::Arc, time::Duration};
|
|
|
|
use tokio::time::sleep;
|
|
|
|
|
|
|
|
pub enum FolderScript {
|
|
|
|
// Workspace
|
|
|
|
ReadAllWorkspaces,
|
2022-03-12 13:06:15 +00:00
|
|
|
CreateWorkspace {
|
|
|
|
name: String,
|
|
|
|
desc: String,
|
|
|
|
},
|
2022-01-22 10:48:43 +00:00
|
|
|
AssertWorkspaceJson(String),
|
|
|
|
AssertWorkspace(Workspace),
|
|
|
|
ReadWorkspace(Option<String>),
|
|
|
|
|
|
|
|
// App
|
2022-03-12 13:06:15 +00:00
|
|
|
CreateApp {
|
|
|
|
name: String,
|
|
|
|
desc: String,
|
|
|
|
},
|
2022-01-22 10:48:43 +00:00
|
|
|
AssertAppJson(String),
|
|
|
|
AssertApp(App),
|
|
|
|
ReadApp(String),
|
2022-03-12 13:06:15 +00:00
|
|
|
UpdateApp {
|
|
|
|
name: Option<String>,
|
|
|
|
desc: Option<String>,
|
|
|
|
},
|
2022-01-22 10:48:43 +00:00
|
|
|
DeleteApp,
|
|
|
|
|
|
|
|
// View
|
2022-03-12 13:06:15 +00:00
|
|
|
CreateView {
|
|
|
|
name: String,
|
|
|
|
desc: String,
|
|
|
|
data_type: ViewDataType,
|
|
|
|
},
|
2022-01-22 10:48:43 +00:00
|
|
|
AssertView(View),
|
|
|
|
ReadView(String),
|
2022-03-12 13:06:15 +00:00
|
|
|
UpdateView {
|
|
|
|
name: Option<String>,
|
|
|
|
desc: Option<String>,
|
|
|
|
},
|
2022-01-22 10:48:43 +00:00
|
|
|
DeleteView,
|
|
|
|
DeleteViews(Vec<String>),
|
|
|
|
|
|
|
|
// Trash
|
|
|
|
RestoreAppFromTrash,
|
|
|
|
RestoreViewFromTrash,
|
|
|
|
ReadTrash,
|
|
|
|
DeleteAllTrash,
|
|
|
|
|
|
|
|
// Sync
|
|
|
|
AssertCurrentRevId(i64),
|
|
|
|
AssertNextSyncRevId(Option<i64>),
|
2022-03-12 13:06:15 +00:00
|
|
|
AssertRevisionState {
|
|
|
|
rev_id: i64,
|
|
|
|
state: RevisionState,
|
|
|
|
},
|
2022-01-22 10:48:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pub struct FolderTest {
|
|
|
|
pub sdk: FlowySDKTest,
|
|
|
|
pub all_workspace: Vec<Workspace>,
|
|
|
|
pub workspace: Workspace,
|
|
|
|
pub app: App,
|
|
|
|
pub view: View,
|
|
|
|
pub trash: Vec<Trash>,
|
|
|
|
// pub folder_editor:
|
|
|
|
}
|
|
|
|
|
|
|
|
impl FolderTest {
|
|
|
|
pub async fn new() -> Self {
|
|
|
|
let sdk = FlowySDKTest::default();
|
|
|
|
let _ = sdk.init_user().await;
|
|
|
|
let mut workspace = create_workspace(&sdk, "FolderWorkspace", "Folder test workspace").await;
|
|
|
|
let mut app = create_app(&sdk, &workspace.id, "Folder App", "Folder test app").await;
|
2022-03-12 01:30:13 +00:00
|
|
|
let view = create_view(
|
|
|
|
&sdk,
|
|
|
|
&app.id,
|
|
|
|
"Folder View",
|
|
|
|
"Folder test view",
|
|
|
|
ViewDataType::TextBlock,
|
|
|
|
)
|
|
|
|
.await;
|
2022-01-22 10:48:43 +00:00
|
|
|
app.belongings = RepeatedView {
|
|
|
|
items: vec![view.clone()],
|
|
|
|
};
|
|
|
|
|
|
|
|
workspace.apps = RepeatedApp {
|
|
|
|
items: vec![app.clone()],
|
|
|
|
};
|
|
|
|
Self {
|
|
|
|
sdk,
|
|
|
|
all_workspace: vec![],
|
|
|
|
workspace,
|
|
|
|
app,
|
|
|
|
view,
|
|
|
|
trash: vec![],
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn run_scripts(&mut self, scripts: Vec<FolderScript>) {
|
|
|
|
for script in scripts {
|
|
|
|
self.run_script(script).await;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn run_script(&mut self, script: FolderScript) {
|
|
|
|
let sdk = &self.sdk;
|
2022-05-26 09:28:44 +00:00
|
|
|
let folder_editor: Arc<FolderEditor> = sdk.folder_manager.folder_editor().await;
|
2022-01-22 10:48:43 +00:00
|
|
|
let rev_manager = folder_editor.rev_manager();
|
2022-01-25 12:37:48 +00:00
|
|
|
let cache = rev_manager.revision_cache().await;
|
2022-01-22 10:48:43 +00:00
|
|
|
|
|
|
|
match script {
|
|
|
|
FolderScript::ReadAllWorkspaces => {
|
|
|
|
let all_workspace = read_workspace(sdk, None).await;
|
|
|
|
self.all_workspace = all_workspace;
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::CreateWorkspace { name, desc } => {
|
|
|
|
let workspace = create_workspace(sdk, &name, &desc).await;
|
|
|
|
self.workspace = workspace;
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::AssertWorkspaceJson(expected_json) => {
|
|
|
|
let workspace = read_workspace(sdk, Some(self.workspace.id.clone()))
|
|
|
|
.await
|
|
|
|
.pop()
|
|
|
|
.unwrap();
|
|
|
|
let json = serde_json::to_string(&workspace).unwrap();
|
|
|
|
assert_eq!(json, expected_json);
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::AssertWorkspace(workspace) => {
|
|
|
|
assert_eq!(self.workspace, workspace);
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::ReadWorkspace(workspace_id) => {
|
|
|
|
let workspace = read_workspace(sdk, workspace_id).await.pop().unwrap();
|
|
|
|
self.workspace = workspace;
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::CreateApp { name, desc } => {
|
2022-01-26 15:29:18 +00:00
|
|
|
let app = create_app(sdk, &self.workspace.id, &name, &desc).await;
|
2022-01-22 10:48:43 +00:00
|
|
|
self.app = app;
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::AssertAppJson(expected_json) => {
|
|
|
|
let json = serde_json::to_string(&self.app).unwrap();
|
|
|
|
assert_eq!(json, expected_json);
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::AssertApp(app) => {
|
|
|
|
assert_eq!(self.app, app);
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::ReadApp(app_id) => {
|
2022-01-24 09:35:58 +00:00
|
|
|
let app = read_app(sdk, &app_id).await;
|
2022-01-22 10:48:43 +00:00
|
|
|
self.app = app;
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::UpdateApp { name, desc } => {
|
2022-01-24 09:35:58 +00:00
|
|
|
update_app(sdk, &self.app.id, name, desc).await;
|
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::DeleteApp => {
|
2022-01-24 09:35:58 +00:00
|
|
|
delete_app(sdk, &self.app.id).await;
|
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
|
2022-03-12 13:06:15 +00:00
|
|
|
FolderScript::CreateView { name, desc, data_type } => {
|
|
|
|
let view = create_view(sdk, &self.app.id, &name, &desc, data_type).await;
|
2022-01-22 10:48:43 +00:00
|
|
|
self.view = view;
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::AssertView(view) => {
|
|
|
|
assert_eq!(self.view, view);
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::ReadView(view_id) => {
|
2022-02-24 12:36:24 +00:00
|
|
|
let view = read_view(sdk, &view_id).await;
|
2022-01-22 10:48:43 +00:00
|
|
|
self.view = view;
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::UpdateView { name, desc } => {
|
2022-01-24 09:35:58 +00:00
|
|
|
update_view(sdk, &self.view.id, name, desc).await;
|
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::DeleteView => {
|
2022-01-24 09:35:58 +00:00
|
|
|
delete_view(sdk, vec![self.view.id.clone()]).await;
|
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::DeleteViews(view_ids) => {
|
2022-01-24 09:35:58 +00:00
|
|
|
delete_view(sdk, view_ids).await;
|
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::RestoreAppFromTrash => {
|
2022-01-24 09:35:58 +00:00
|
|
|
restore_app_from_trash(sdk, &self.app.id).await;
|
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::RestoreViewFromTrash => {
|
2022-01-24 09:35:58 +00:00
|
|
|
restore_view_from_trash(sdk, &self.view.id).await;
|
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::ReadTrash => {
|
2022-01-24 09:35:58 +00:00
|
|
|
let trash = read_trash(sdk).await;
|
2022-01-22 10:48:43 +00:00
|
|
|
self.trash = trash.into_inner();
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::DeleteAllTrash => {
|
2022-01-24 09:35:58 +00:00
|
|
|
delete_all_trash(sdk).await;
|
2022-01-22 10:48:43 +00:00
|
|
|
self.trash = vec![];
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::AssertRevisionState { rev_id, state } => {
|
|
|
|
let record = cache.get(rev_id).await.unwrap();
|
|
|
|
assert_eq!(record.state, state);
|
|
|
|
if let RevisionState::Ack = state {
|
|
|
|
// There is a defer action that writes the revisions to disk, so we wait here.
|
|
|
|
// Make sure everything is written.
|
|
|
|
sleep(Duration::from_millis(2 * REVISION_WRITE_INTERVAL_IN_MILLIS)).await;
|
|
|
|
}
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::AssertCurrentRevId(rev_id) => {
|
2022-01-26 15:29:18 +00:00
|
|
|
assert_eq!(rev_manager.rev_id(), rev_id, "Current rev_id is not match");
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
FolderScript::AssertNextSyncRevId(rev_id) => {
|
|
|
|
let next_revision = rev_manager.next_sync_revision().await.unwrap();
|
|
|
|
if rev_id.is_none() {
|
2022-01-24 09:35:58 +00:00
|
|
|
assert!(next_revision.is_none(), "Next revision should be None");
|
2022-01-22 10:48:43 +00:00
|
|
|
return;
|
|
|
|
}
|
2022-01-26 15:29:18 +00:00
|
|
|
let next_revision = next_revision
|
|
|
|
.unwrap_or_else(|| panic!("Expected Next revision is {}, but receive None", rev_id.unwrap()));
|
2022-02-18 15:04:55 +00:00
|
|
|
let mut notify = rev_manager.ack_notify();
|
|
|
|
let _ = notify.recv().await;
|
2022-01-22 10:48:43 +00:00
|
|
|
assert_eq!(next_revision.rev_id, rev_id.unwrap());
|
2022-01-24 09:35:58 +00:00
|
|
|
}
|
2022-01-22 10:48:43 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn invalid_workspace_name_test_case() -> Vec<(String, ErrorCode)> {
|
|
|
|
vec![
|
|
|
|
("".to_owned(), ErrorCode::WorkspaceNameInvalid),
|
|
|
|
("1234".repeat(100), ErrorCode::WorkspaceNameTooLong),
|
|
|
|
]
|
|
|
|
}
|
2022-03-12 13:06:15 +00:00
|
|
|
|
|
|
|
pub async fn create_workspace(sdk: &FlowySDKTest, name: &str, desc: &str) -> Workspace {
|
|
|
|
let request = CreateWorkspacePayload {
|
|
|
|
name: name.to_owned(),
|
|
|
|
desc: desc.to_owned(),
|
|
|
|
};
|
|
|
|
|
|
|
|
let workspace = FolderEventBuilder::new(sdk.clone())
|
|
|
|
.event(CreateWorkspace)
|
|
|
|
.payload(request)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<Workspace>();
|
|
|
|
workspace
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn read_workspace(sdk: &FlowySDKTest, workspace_id: Option<String>) -> Vec<Workspace> {
|
|
|
|
let request = WorkspaceId { value: workspace_id };
|
|
|
|
let repeated_workspace = FolderEventBuilder::new(sdk.clone())
|
|
|
|
.event(ReadWorkspaces)
|
|
|
|
.payload(request.clone())
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<RepeatedWorkspace>();
|
|
|
|
|
|
|
|
let workspaces;
|
|
|
|
if let Some(workspace_id) = &request.value {
|
|
|
|
workspaces = repeated_workspace
|
|
|
|
.into_inner()
|
|
|
|
.into_iter()
|
|
|
|
.filter(|workspace| &workspace.id == workspace_id)
|
|
|
|
.collect::<Vec<Workspace>>();
|
|
|
|
debug_assert_eq!(workspaces.len(), 1);
|
|
|
|
} else {
|
|
|
|
workspaces = repeated_workspace.items;
|
|
|
|
}
|
|
|
|
|
|
|
|
workspaces
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn create_app(sdk: &FlowySDKTest, workspace_id: &str, name: &str, desc: &str) -> App {
|
|
|
|
let create_app_request = CreateAppPayload {
|
|
|
|
workspace_id: workspace_id.to_owned(),
|
|
|
|
name: name.to_string(),
|
|
|
|
desc: desc.to_string(),
|
|
|
|
color_style: Default::default(),
|
|
|
|
};
|
|
|
|
|
|
|
|
let app = FolderEventBuilder::new(sdk.clone())
|
|
|
|
.event(CreateApp)
|
|
|
|
.payload(create_app_request)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<App>();
|
|
|
|
app
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn read_app(sdk: &FlowySDKTest, app_id: &str) -> App {
|
|
|
|
let request = AppId {
|
|
|
|
value: app_id.to_owned(),
|
|
|
|
};
|
|
|
|
|
|
|
|
let app = FolderEventBuilder::new(sdk.clone())
|
|
|
|
.event(ReadApp)
|
|
|
|
.payload(request)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<App>();
|
|
|
|
|
|
|
|
app
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn update_app(sdk: &FlowySDKTest, app_id: &str, name: Option<String>, desc: Option<String>) {
|
|
|
|
let request = UpdateAppPayload {
|
|
|
|
app_id: app_id.to_string(),
|
|
|
|
name,
|
|
|
|
desc,
|
|
|
|
color_style: None,
|
|
|
|
is_trash: None,
|
|
|
|
};
|
|
|
|
|
|
|
|
FolderEventBuilder::new(sdk.clone())
|
|
|
|
.event(UpdateApp)
|
|
|
|
.payload(request)
|
|
|
|
.async_send()
|
|
|
|
.await;
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn delete_app(sdk: &FlowySDKTest, app_id: &str) {
|
|
|
|
let request = AppId {
|
|
|
|
value: app_id.to_string(),
|
|
|
|
};
|
|
|
|
|
|
|
|
FolderEventBuilder::new(sdk.clone())
|
|
|
|
.event(DeleteApp)
|
|
|
|
.payload(request)
|
|
|
|
.async_send()
|
|
|
|
.await;
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn create_view(sdk: &FlowySDKTest, app_id: &str, name: &str, desc: &str, data_type: ViewDataType) -> View {
|
|
|
|
let request = CreateViewPayload {
|
|
|
|
belong_to_id: app_id.to_string(),
|
|
|
|
name: name.to_string(),
|
|
|
|
desc: desc.to_string(),
|
|
|
|
thumbnail: None,
|
|
|
|
data_type,
|
|
|
|
plugin_type: 0,
|
2022-03-16 02:02:37 +00:00
|
|
|
data: vec![],
|
2022-03-12 13:06:15 +00:00
|
|
|
};
|
|
|
|
let view = FolderEventBuilder::new(sdk.clone())
|
|
|
|
.event(CreateView)
|
|
|
|
.payload(request)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<View>();
|
|
|
|
view
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn read_view(sdk: &FlowySDKTest, view_id: &str) -> View {
|
|
|
|
let view_id: ViewId = view_id.into();
|
|
|
|
FolderEventBuilder::new(sdk.clone())
|
|
|
|
.event(ReadView)
|
|
|
|
.payload(view_id)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<View>()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn update_view(sdk: &FlowySDKTest, view_id: &str, name: Option<String>, desc: Option<String>) {
|
|
|
|
let request = UpdateViewPayload {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
name,
|
|
|
|
desc,
|
|
|
|
thumbnail: None,
|
|
|
|
};
|
|
|
|
FolderEventBuilder::new(sdk.clone())
|
|
|
|
.event(UpdateView)
|
|
|
|
.payload(request)
|
|
|
|
.async_send()
|
|
|
|
.await;
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn delete_view(sdk: &FlowySDKTest, view_ids: Vec<String>) {
|
|
|
|
let request = RepeatedViewId { items: view_ids };
|
|
|
|
FolderEventBuilder::new(sdk.clone())
|
|
|
|
.event(DeleteView)
|
|
|
|
.payload(request)
|
|
|
|
.async_send()
|
|
|
|
.await;
|
|
|
|
}
|
|
|
|
|
|
|
|
#[allow(dead_code)]
|
|
|
|
pub async fn set_latest_view(sdk: &FlowySDKTest, view_id: &str) -> TextBlockInfo {
|
|
|
|
let view_id: ViewId = view_id.into();
|
|
|
|
FolderEventBuilder::new(sdk.clone())
|
|
|
|
.event(SetLatestView)
|
|
|
|
.payload(view_id)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<TextBlockInfo>()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn read_trash(sdk: &FlowySDKTest) -> RepeatedTrash {
|
|
|
|
FolderEventBuilder::new(sdk.clone())
|
|
|
|
.event(ReadTrash)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<RepeatedTrash>()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn restore_app_from_trash(sdk: &FlowySDKTest, app_id: &str) {
|
|
|
|
let id = TrashId {
|
|
|
|
id: app_id.to_owned(),
|
|
|
|
ty: TrashType::TrashApp,
|
|
|
|
};
|
|
|
|
FolderEventBuilder::new(sdk.clone())
|
|
|
|
.event(PutbackTrash)
|
|
|
|
.payload(id)
|
|
|
|
.async_send()
|
|
|
|
.await;
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn restore_view_from_trash(sdk: &FlowySDKTest, view_id: &str) {
|
|
|
|
let id = TrashId {
|
|
|
|
id: view_id.to_owned(),
|
|
|
|
ty: TrashType::TrashView,
|
|
|
|
};
|
|
|
|
FolderEventBuilder::new(sdk.clone())
|
|
|
|
.event(PutbackTrash)
|
|
|
|
.payload(id)
|
|
|
|
.async_send()
|
|
|
|
.await;
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn delete_all_trash(sdk: &FlowySDKTest) {
|
|
|
|
FolderEventBuilder::new(sdk.clone())
|
|
|
|
.event(DeleteAllTrash)
|
|
|
|
.async_send()
|
|
|
|
.await;
|
|
|
|
}
|