mirror of
https://github.com/PR0M3TH3AN/Marlin.git
synced 2025-09-07 14:48:44 +00:00
Merge pull request #60 from PR0M3TH3AN/codex/fix-test-isolation-in-config_tests
Fix env var leakage in config tests
This commit is contained in:
1
Cargo.lock
generated
1
Cargo.lock
generated
@@ -633,6 +633,7 @@ dependencies = [
|
||||
"crossbeam-channel",
|
||||
"directories",
|
||||
"glob",
|
||||
"lazy_static",
|
||||
"notify",
|
||||
"priority-queue",
|
||||
"rusqlite",
|
||||
|
@@ -27,6 +27,7 @@ json = ["serde_json"]
|
||||
[dev-dependencies]
|
||||
# for temporary directories in config_tests.rs and scan_tests.rs
|
||||
tempfile = "3"
|
||||
lazy_static = "1"
|
||||
|
||||
# you already have rusqlite in [dependencies], so scan_tests.rs
|
||||
# can just use rusqlite::Connection, no need to repeat it here.
|
||||
|
@@ -1,11 +1,13 @@
|
||||
// libmarlin/src/config_tests.rs
|
||||
|
||||
use super::config::Config;
|
||||
use crate::test_utils::ENV_MUTEX;
|
||||
use std::env;
|
||||
use tempfile::tempdir;
|
||||
|
||||
#[test]
|
||||
fn load_env_override() {
|
||||
let _guard = ENV_MUTEX.lock().unwrap();
|
||||
let tmp = tempdir().unwrap();
|
||||
let db = tmp.path().join("custom.db");
|
||||
env::set_var("MARLIN_DB_PATH", &db);
|
||||
@@ -16,6 +18,7 @@ fn load_env_override() {
|
||||
|
||||
#[test]
|
||||
fn load_xdg_or_fallback() {
|
||||
let _guard = ENV_MUTEX.lock().unwrap();
|
||||
// since XDG_DATA_HOME will normally be present, just test it doesn't error
|
||||
let cfg = Config::load().unwrap();
|
||||
assert!(cfg.db_path.to_string_lossy().ends_with(".db"));
|
||||
@@ -23,6 +26,7 @@ fn load_xdg_or_fallback() {
|
||||
|
||||
#[test]
|
||||
fn load_fallback_current_dir() {
|
||||
let _guard = ENV_MUTEX.lock().unwrap();
|
||||
// Save and clear HOME & XDG_DATA_HOME
|
||||
let orig_home = env::var_os("HOME");
|
||||
let orig_xdg = env::var_os("XDG_DATA_HOME");
|
||||
|
@@ -1,11 +1,13 @@
|
||||
// libmarlin/src/facade_tests.rs
|
||||
|
||||
use super::*; // brings Marlin, config, etc.
|
||||
use crate::test_utils::ENV_MUTEX;
|
||||
use std::{env, fs};
|
||||
use tempfile::tempdir;
|
||||
|
||||
#[test]
|
||||
fn open_at_and_scan_and_search() {
|
||||
let _guard = ENV_MUTEX.lock().unwrap();
|
||||
// 1) Prepare a temp workspace with one file
|
||||
let tmp = tempdir().unwrap();
|
||||
let file = tmp.path().join("hello.txt");
|
||||
@@ -33,6 +35,7 @@ fn open_at_and_scan_and_search() {
|
||||
|
||||
#[test]
|
||||
fn tag_and_search_by_tag() {
|
||||
let _guard = ENV_MUTEX.lock().unwrap();
|
||||
let tmp = tempdir().unwrap();
|
||||
let a = tmp.path().join("a.md");
|
||||
let b = tmp.path().join("b.md");
|
||||
@@ -56,6 +59,7 @@ fn tag_and_search_by_tag() {
|
||||
|
||||
#[test]
|
||||
fn open_default_fallback_config() {
|
||||
let _guard = ENV_MUTEX.lock().unwrap();
|
||||
// Unset all overrides
|
||||
env::remove_var("MARLIN_DB_PATH");
|
||||
env::remove_var("XDG_DATA_HOME");
|
||||
|
@@ -27,6 +27,8 @@ mod logging_tests;
|
||||
#[cfg(test)]
|
||||
mod scan_tests;
|
||||
#[cfg(test)]
|
||||
mod test_utils;
|
||||
#[cfg(test)]
|
||||
mod utils_tests;
|
||||
#[cfg(test)]
|
||||
mod watcher_tests;
|
||||
|
8
libmarlin/src/test_utils.rs
Normal file
8
libmarlin/src/test_utils.rs
Normal file
@@ -0,0 +1,8 @@
|
||||
use std::sync::Mutex;
|
||||
|
||||
use lazy_static::lazy_static;
|
||||
|
||||
lazy_static! {
|
||||
/// Global mutex to serialize environment-variable modifications in tests.
|
||||
pub static ref ENV_MUTEX: Mutex<()> = Mutex::new(());
|
||||
}
|
Reference in New Issue
Block a user