mirror of
https://github.com/elicpeter/nyx.git
synced 2026-06-18 20:15:14 +02:00
test: Add unit tests for file handling and configuration merging (#7)
* test: Add unit tests for file handling and configuration merging * test: Update IO error conversion test to use new error creation method
This commit is contained in:
parent
8497800b13
commit
46c4732f6e
8 changed files with 225 additions and 57 deletions
|
|
@ -285,23 +285,26 @@ fn merge_configs(mut default: Config, user: Config) -> Config {
|
|||
|
||||
#[test]
|
||||
fn merge_configs_dedupes_and_keeps_order() {
|
||||
let mut default_cfg = Config::default();
|
||||
default_cfg.scanner.excluded_extensions = vec!["rs".into(), "toml".into()];
|
||||
let mut default_cfg = Config::default();
|
||||
default_cfg.scanner.excluded_extensions = vec!["rs".into(), "toml".into()];
|
||||
|
||||
let mut user_cfg = Config::default();
|
||||
user_cfg.scanner.excluded_extensions = vec!["jpg".into(), "rs".into()];
|
||||
let mut user_cfg = Config::default();
|
||||
user_cfg.scanner.excluded_extensions = vec!["jpg".into(), "rs".into()];
|
||||
|
||||
let merged = merge_configs(default_cfg, user_cfg);
|
||||
|
||||
assert_eq!(merged.scanner.excluded_extensions, vec!["jpg", "rs", "toml"]);
|
||||
let merged = merge_configs(default_cfg, user_cfg);
|
||||
|
||||
assert_eq!(
|
||||
merged.scanner.excluded_extensions,
|
||||
vec!["jpg", "rs", "toml"]
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn load_creates_example_and_reads_user_overrides() {
|
||||
let cfg_dir = tempfile::tempdir().unwrap();
|
||||
let cfg_path = cfg_dir.path();
|
||||
|
||||
let user_toml = r#"
|
||||
let cfg_dir = tempfile::tempdir().unwrap();
|
||||
let cfg_path = cfg_dir.path();
|
||||
|
||||
let user_toml = r#"
|
||||
[scanner]
|
||||
one_file_system = true
|
||||
excluded_extensions = ["foo"]
|
||||
|
|
@ -309,15 +312,15 @@ fn load_creates_example_and_reads_user_overrides() {
|
|||
[output]
|
||||
quiet = true
|
||||
"#;
|
||||
fs::write(cfg_path.join("nyx.local"), user_toml).unwrap();
|
||||
fs::write(cfg_path.join("nyx.local"), user_toml).unwrap();
|
||||
|
||||
let cfg = Config::load(cfg_path).expect("Config::load should succeed");
|
||||
let cfg = Config::load(cfg_path).expect("Config::load should succeed");
|
||||
|
||||
assert!(cfg_path.join("nyx.conf").is_file());
|
||||
|
||||
assert!(cfg.scanner.one_file_system);
|
||||
assert!(cfg.output.quiet);
|
||||
assert!(cfg.scanner.excluded_extensions.contains(&"foo".to_string()));
|
||||
assert!(cfg_path.join("nyx.conf").is_file());
|
||||
|
||||
assert!(!cfg.scanner.follow_symlinks);
|
||||
assert!(cfg.scanner.one_file_system);
|
||||
assert!(cfg.output.quiet);
|
||||
assert!(cfg.scanner.excluded_extensions.contains(&"foo".to_string()));
|
||||
|
||||
assert!(!cfg.scanner.follow_symlinks);
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue