mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2025-07-13 03:56:11 +00:00

* feat: implement folder indexer * feat: sqlite search views using fts5 * feat: add view indexing to user manager * feat: implement folder indexer * feat: add sqlite search documents * feat: add document indexing to user manager * feat: add document indexing to folder indexer * chore: update collab rev * feat: search frontend integration * refactor: search index * test: add event test * chore: fix ci * feat: initial command palette overlay impl (#4619) * chore: test search engine * chore: initial structure * chore: replace old search request * chore: enable log for lib-dispatch * chore: move search manager to core * feat: move traits and responsibility to search crate * feat: move search to search crate * feat: replace sqlite with tantivy * feat: deserialize tantivy documents * chore: fixes after rebase * chore: clean code * feat: fetch and sort results * fix: code review + cleaning * feat: support custom icons * feat: support view layout icons * feat: rename bloc and fix indexing * fix: prettify dialog * feat: score results * chore: update collab rev * feat: add recent view history to command palette * test: add integration_tests * fix: clippy changes * fix: focus traversal in cmd palette * fix: remove file after merging main * chore: code review and panic-safe * feat: index all views if index does not exist * chore: improve logic with conditional * chore: add is_empty check * chore: abstract logic from folder manager init * chore: update collab rev * chore: code review * chore: fixes after merge + update lock file * chore: revert cargo lock * fix: set icon type when removing icon * fix: code review + dependency inversion * fix: remove icon fix for not persisting icon type * test: simple tests manipulating views * test: create 100 views * fix: tauri build * chore: create 1000 views * chore: create util methods * chore: test * chore: test * chore: remove logs * chore: fix build.rs * chore: export models * chore: enable clear cache on Rust-CI * fix: navigate to newly created views * fix: force disable setting workspace listener on rebuilds * fix: remove late final * fix: missing returns * fix: localization and minor fixes * test: add index assert to large test * fix: missing section param after merging main * chore: try fix unzip file error * chore: lower the test * feat: show hint when result is in trash --------- Co-authored-by: nathan <nathan@appflowy.io> Co-authored-by: Jiraffe7 <twajxjiraffe@gmail.com> Co-authored-by: Lucas.Xu <lucas.xu@appflowy.io>
181 lines
6.0 KiB
Rust
181 lines
6.0 KiB
Rust
use event_integration::EventIntegrationTest;
|
|
use flowy_core::DEFAULT_NAME;
|
|
use flowy_folder::entities::ViewLayoutPB;
|
|
use std::time::Duration;
|
|
|
|
use crate::util::unzip;
|
|
|
|
#[tokio::test]
|
|
async fn migrate_020_historical_empty_document_test() {
|
|
let (cleaner, user_db_path) = unzip(
|
|
"./tests/user/migration_test/history_user_db",
|
|
"020_historical_user_data",
|
|
)
|
|
.unwrap();
|
|
let test =
|
|
EventIntegrationTest::new_with_user_data_path(user_db_path, DEFAULT_NAME.to_string()).await;
|
|
|
|
let mut views = test.get_all_workspace_views().await;
|
|
assert_eq!(views.len(), 1);
|
|
|
|
// Check the parent view
|
|
let parent_view = views.pop().unwrap();
|
|
assert_eq!(parent_view.layout, ViewLayoutPB::Document);
|
|
let data = test.open_document(parent_view.id.clone()).await.data;
|
|
assert!(!data.page_id.is_empty());
|
|
assert_eq!(data.blocks.len(), 2);
|
|
assert!(!data.meta.children_map.is_empty());
|
|
|
|
// Check the child views of the parent view
|
|
let child_views = test.get_view(&parent_view.id).await.child_views;
|
|
assert_eq!(child_views.len(), 4);
|
|
assert_eq!(child_views[0].layout, ViewLayoutPB::Document);
|
|
assert_eq!(child_views[1].layout, ViewLayoutPB::Grid);
|
|
assert_eq!(child_views[2].layout, ViewLayoutPB::Calendar);
|
|
assert_eq!(child_views[3].layout, ViewLayoutPB::Board);
|
|
|
|
let database = test.get_database(&child_views[1].id).await;
|
|
assert_eq!(database.fields.len(), 8);
|
|
assert_eq!(database.rows.len(), 3);
|
|
drop(cleaner);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn migrate_036_fav_v1_workspace_array_test() {
|
|
// Used to test migration: FavoriteV1AndWorkspaceArrayMigration
|
|
let (cleaner, 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);
|
|
drop(cleaner);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn migrate_038_trash_test() {
|
|
// Used to test migration: WorkspaceTrashMapToSectionMigration
|
|
let (cleaner, 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");
|
|
|
|
drop(cleaner);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn migrate_038_trash_test2() {
|
|
// Used to test migration: WorkspaceTrashMapToSectionMigration
|
|
let (cleaner, 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");
|
|
|
|
drop(cleaner);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn collab_db_backup_test() {
|
|
// Used to test migration: WorkspaceTrashMapToSectionMigration
|
|
let (cleaner, 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;
|
|
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"))
|
|
);
|
|
drop(cleaner);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn delete_outdated_collab_db_backup_test() {
|
|
// Used to test migration: WorkspaceTrashMapToSectionMigration
|
|
let (cleaner, 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"))
|
|
);
|
|
drop(cleaner);
|
|
}
|