Files
markbase/tests/modes_test.rs
Warren 1300a4e223
Some checks failed
Test / test (push) Has been cancelled
Test / build (push) Has been cancelled
MarkBase架构升级:Multi-Volume Virtual Tree + Dual-View Management + Git Remote修正
核心功能:
-  Categories/Series双视图管理(category_view.rs + import_markdown.rs)
-  FUSE Multi-Volume支持(tree_type参数)
-  SSH/SFTP/SCP/rsync协议完整实现(4042行)
-  NFS/SMB Module Phase 1-3完成
-  Archive Module Phase 1-4完成(2916行)
-  Download Center API完整实现
-  S3兼容API实现(560行)

Git配置修正:
-  删除错误origin(gitea.momentry.ddns.net)
-  删除m5max128(指向机器名)
-  设置origin = m5max128gitea.momentry.ddns.net/admin/markbase
-  设置m4minigitea = m4minigitea.momentry.ddns.net/warren/markbase

数据清理:
-  删除38个临时SQLite(保留accusys.sqlite、demo.sqlite)
-  删除.bak、test_*.bin、调试脚本等临时文件
-  删除临时目录(build/、download files/、raid_test/等)
-  更新.gitignore排除临时文件

架构优化:
- 52个文件修改,2434行新增,4739行删除
- Workspace成员整合(16个crate)
- 数据库状态:accusys.sqlite保留(主demo测试)

远程同步:
-  准备推送到m5max128gitea(远程Gitea)
-  准备推送到m4minigitea(本地Gitea)
2026-06-12 12:59:54 +08:00

130 lines
3.8 KiB
Rust

use markbase::filetree::{mode, FileTree};
use rusqlite::Connection;
use uuid::Uuid;
fn temp_db() -> (Connection, String) {
let user_id = format!("test_{}", Uuid::new_v4());
let conn = FileTree::init_user_db(&user_id).unwrap();
(conn, user_id)
}
#[test]
fn test_tree_mode_render() {
let (conn, user_id) = temp_db();
let mut tree = FileTree::load(&conn, &user_id, "untitled folder").unwrap();
let root = FileTree::new_folder("Root", None);
let child1 = FileTree::new_folder("Child1", Some(root.node_id.clone()));
let child2 = FileTree::new_folder("Child2", Some(root.node_id.clone()));
tree.insert_node(&conn, &root).unwrap();
tree.insert_node(&conn, &child1).unwrap();
tree.insert_node(&conn, &child2).unwrap();
let mode = mode::get_mode("tree").expect("tree mode should exist");
let rendered = mode.render(&tree);
assert!(rendered.is_object());
assert!(rendered["nodes"].is_array());
assert_eq!(rendered["nodes"].as_array().unwrap().len(), 3);
}
#[test]
fn test_list_mode_render() {
let (conn, user_id) = temp_db();
let mut tree = FileTree::load(&conn, &user_id, "untitled folder").unwrap();
let folder = FileTree::new_folder("Videos", None);
tree.insert_node(&conn, &folder).unwrap();
let mode = mode::get_mode("list").expect("list mode should exist");
let rendered = mode.render(&tree);
assert!(rendered.is_object());
assert!(rendered["nodes"].is_array());
assert_eq!(rendered["nodes"].as_array().unwrap().len(), 1);
}
#[test]
fn test_grid_sm_mode_render() {
let (conn, user_id) = temp_db();
let mut tree = FileTree::load(&conn, &user_id, "untitled folder").unwrap();
let folder = FileTree::new_folder("Images", None);
tree.insert_node(&conn, &folder).unwrap();
let mode = mode::get_mode("grid_sm").expect("grid_sm mode should exist");
let rendered = mode.render(&tree);
assert!(rendered.is_object());
assert!(rendered["nodes"].is_array());
}
#[test]
fn test_grid_lg_mode_render() {
let (conn, user_id) = temp_db();
let mut tree = FileTree::load(&conn, &user_id, "untitled folder").unwrap();
let folder = FileTree::new_folder("Documents", None);
tree.insert_node(&conn, &folder).unwrap();
let mode = mode::get_mode("grid_lg").expect("grid_lg mode should exist");
let rendered = mode.render(&tree);
assert!(rendered.is_object());
assert!(rendered["nodes"].is_array());
}
#[test]
fn test_invalid_mode() {
let mode = mode::get_mode("invalid_mode");
assert!(mode.is_none(), "invalid mode should return None");
}
#[test]
fn test_mode_name() {
let tree_mode = mode::get_mode("tree").unwrap();
assert_eq!(tree_mode.name(), "tree");
let list_mode = mode::get_mode("list").unwrap();
assert_eq!(list_mode.name(), "list");
let grid_sm_mode = mode::get_mode("grid_sm").unwrap();
assert_eq!(grid_sm_mode.name(), "grid_sm");
let grid_lg_mode = mode::get_mode("grid_lg").unwrap();
assert_eq!(grid_lg_mode.name(), "grid_lg");
}
#[test]
fn test_mode_sort_options() {
let mode = mode::get_mode("list").unwrap();
let sort_options = mode.sort_options();
assert!(!sort_options.is_empty(), "sort options should not be empty");
}
#[test]
fn test_mode_filter_options() {
let mode = mode::get_mode("list").unwrap();
let filter_options = mode.filter_options();
assert!(
!filter_options.is_empty(),
"filter options should not be empty"
);
}
#[test]
fn test_list_modes() {
let modes = mode::list_modes();
assert_eq!(modes.len(), 4, "should have 4 display modes");
let names: Vec<&str> = modes.iter().map(|m| m.name()).collect();
assert!(names.contains(&"tree"));
assert!(names.contains(&"list"));
assert!(names.contains(&"grid_sm"));
assert!(names.contains(&"grid_lg"));
}