mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2025-10-23 22:11:02 +00:00
141 lines
4.7 KiB
Rust
141 lines
4.7 KiB
Rust
use event_integration_test::EventIntegrationTest;
|
|
use flowy_core::DEFAULT_NAME;
|
|
use std::time::Duration;
|
|
|
|
use crate::util::unzip;
|
|
|
|
#[tokio::test]
|
|
async fn migrate_036_fav_v1_workspace_array_test() {
|
|
// Used to test migration: FavoriteV1AndWorkspaceArrayMigration
|
|
let user_db_path = unzip(
|
|
"./tests/user/migration_test/history_user_db",
|
|
"036_fav_v1_workspace_array",
|
|
)
|
|
.unwrap();
|
|
let test =
|
|
EventIntegrationTest::new_with_user_data_path(user_db_path, DEFAULT_NAME.to_string()).await;
|
|
|
|
let views = test.get_all_workspace_views().await;
|
|
assert_eq!(views.len(), 2);
|
|
assert_eq!(views[0].name, "root page");
|
|
assert_eq!(views[1].name, "⭐\u{fe0f} Getting started");
|
|
|
|
let views = test.get_view(&views[1].id).await;
|
|
assert_eq!(views.child_views.len(), 3);
|
|
assert!(views.child_views[2].is_favorite);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn migrate_038_trash_test() {
|
|
// Used to test migration: WorkspaceTrashMapToSectionMigration
|
|
let user_db_path = unzip("./tests/asset", "038_local").unwrap();
|
|
// Getting started
|
|
// Document1
|
|
// Document2(deleted)
|
|
// Document3(deleted)
|
|
// Document
|
|
// Document4(deleted)
|
|
// Document5
|
|
|
|
let test =
|
|
EventIntegrationTest::new_with_user_data_path(user_db_path, DEFAULT_NAME.to_string()).await;
|
|
|
|
let views = test.get_all_workspace_views().await;
|
|
assert_eq!(views.len(), 2);
|
|
assert_eq!(views[0].name, "Getting started");
|
|
assert_eq!(views[1].name, "Documents");
|
|
|
|
let get_started_child_views = test.get_view(&views[0].id).await.child_views;
|
|
assert_eq!(get_started_child_views.len(), 1);
|
|
assert_eq!(get_started_child_views[0].name, "Document1");
|
|
|
|
let get_started_child_views = test.get_view(&views[1].id).await.child_views;
|
|
assert_eq!(get_started_child_views.len(), 1);
|
|
assert_eq!(get_started_child_views[0].name, "Document5");
|
|
|
|
let trash_items = test.get_trash().await.items;
|
|
assert_eq!(trash_items.len(), 3);
|
|
assert_eq!(trash_items[0].name, "Document3");
|
|
assert_eq!(trash_items[1].name, "Document2");
|
|
assert_eq!(trash_items[2].name, "Document4");
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn migrate_038_trash_test2() {
|
|
// Used to test migration: WorkspaceTrashMapToSectionMigration
|
|
let user_db_path = unzip("./tests/asset", "038_document_with_grid").unwrap();
|
|
// Getting started
|
|
// document
|
|
// grid
|
|
// board
|
|
|
|
let test =
|
|
EventIntegrationTest::new_with_user_data_path(user_db_path, DEFAULT_NAME.to_string()).await;
|
|
|
|
let views = test.get_all_workspace_views().await;
|
|
assert_eq!(views.len(), 1);
|
|
assert_eq!(views[0].name, "Getting started");
|
|
|
|
let views = test.get_view(&views[0].id).await.child_views;
|
|
assert_eq!(views[0].name, "document");
|
|
|
|
let views = test.get_view(&views[0].id).await.child_views;
|
|
assert_eq!(views[0].name, "grid");
|
|
|
|
let views = test.get_view(&views[0].id).await.child_views;
|
|
assert_eq!(views[0].name, "board");
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn collab_db_backup_test() {
|
|
// Used to test migration: WorkspaceTrashMapToSectionMigration
|
|
let user_db_path = unzip("./tests/asset", "038_local").unwrap();
|
|
let test =
|
|
EventIntegrationTest::new_with_user_data_path(user_db_path, DEFAULT_NAME.to_string()).await;
|
|
|
|
let uid = test.get_user_profile().await.unwrap().id;
|
|
// sleep a bit to make sure the backup is generated
|
|
|
|
tokio::time::sleep(Duration::from_secs(10)).await;
|
|
let backups = test.user_manager.get_collab_backup_list(uid);
|
|
|
|
assert_eq!(backups.len(), 1);
|
|
assert_eq!(
|
|
backups[0],
|
|
format!("collab_db_{}", chrono::Local::now().format("%Y%m%d"))
|
|
);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn delete_outdated_collab_db_backup_test() {
|
|
// Used to test migration: WorkspaceTrashMapToSectionMigration
|
|
let user_db_path = unzip("./tests/asset", "040_collab_backups").unwrap();
|
|
let test =
|
|
EventIntegrationTest::new_with_user_data_path(user_db_path, DEFAULT_NAME.to_string()).await;
|
|
|
|
let uid = test.get_user_profile().await.unwrap().id;
|
|
// saving the backup is a background task, so we need to wait for it to finish
|
|
// 2 seconds should be enough for the background task to finish
|
|
tokio::time::sleep(Duration::from_secs(2)).await;
|
|
let backups = test.user_manager.get_collab_backup_list(uid);
|
|
|
|
if backups.len() != 10 {
|
|
dbg!("backups: {:?}", backups.clone());
|
|
}
|
|
|
|
assert_eq!(backups.len(), 10);
|
|
assert_eq!(backups[0], "collab_db_0.4.0_20231202");
|
|
assert_eq!(backups[1], "collab_db_0.4.0_20231203");
|
|
assert_eq!(backups[2], "collab_db_0.4.0_20231204");
|
|
assert_eq!(backups[3], "collab_db_0.4.0_20231205");
|
|
assert_eq!(backups[4], "collab_db_0.4.0_20231206");
|
|
assert_eq!(backups[5], "collab_db_0.4.0_20231207");
|
|
assert_eq!(backups[6], "collab_db_0.4.0_20231208");
|
|
assert_eq!(backups[7], "collab_db_0.4.0_20231209");
|
|
assert_eq!(backups[8], "collab_db_0.4.0_20231210");
|
|
assert_eq!(
|
|
backups[9],
|
|
format!("collab_db_{}", chrono::Local::now().format("%Y%m%d"))
|
|
);
|
|
}
|