mirror of
https://github.com/elicpeter/nyx.git
synced 2026-06-24 20:28:06 +02:00
test: Add unit tests for config merging and project name sanitization (#6)
* test: Add unit tests for config merging and project name sanitization * Update src/utils/project.rs Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * test: Update assertion for follow_symlinks in scanner configuration * test: Fix typo in test function name for project info retrieval --------- Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
This commit is contained in:
parent
a0c9d0f9d4
commit
8497800b13
6 changed files with 140 additions and 1 deletions
|
|
@ -28,3 +28,36 @@ pub fn sanitize_project_name(name: &str) -> String {
|
|||
.collect::<Vec<_>>()
|
||||
.join("_")
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn sanitize_project_name_is_idempotent_and_lossless_enough() {
|
||||
let samples = [
|
||||
("My Project", "my_project"),
|
||||
("Hello-World", "hello-world"),
|
||||
("mixed_case", "mixed_case"),
|
||||
("tabs\tspaces\n", "tabs_spaces"),
|
||||
(" multiple ", "multiple"),
|
||||
("weird@$*chars", "weird_chars"),
|
||||
];
|
||||
|
||||
for (input, expected) in samples {
|
||||
assert_eq!(sanitize_project_name(input), expected, "input: {}", input);
|
||||
assert_eq!(sanitize_project_name(expected), expected);
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn get_project_info_uses_sanitized_name_in_sqlite_path() {
|
||||
let tmp = tempfile::tempdir().unwrap();
|
||||
let root = tmp.path();
|
||||
|
||||
let project_dir = root.join("Example Project");
|
||||
std::fs::create_dir(&project_dir).unwrap();
|
||||
|
||||
let (project_name, db_path) =
|
||||
get_project_info(&project_dir, root).expect("should detect project");
|
||||
|
||||
assert_eq!(project_name, "Example Project");
|
||||
assert_eq!(db_path, root.join("example_project.sqlite"));
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue