//! Test helpers use std::ffi::OsString; use std::path::PathBuf; use once_cell::sync::Lazy; use std::path::Path; //// // // Paths that can simplify testing use cases. // //// #[allow(dead_code)] pub static CARGO_MANIFEST_DIR: Lazy = Lazy::new(|| [env!("CARGO_MANIFEST_DIR")].iter().collect::() ); #[allow(dead_code)] pub static TESTS_DIR: Lazy = Lazy::new(|| [env!("CARGO_MANIFEST_DIR"), "tests"].iter().collect::() ); #[allow(dead_code)] pub static TMP_DIR: Lazy = Lazy::new(|| [env!("CARGO_MANIFEST_DIR"), "tmp"].iter().collect::() ); #[allow(dead_code)] pub static BENCHES_DIR: Lazy = Lazy::new(|| [env!("CARGO_MANIFEST_DIR"), "benches"].iter().collect::() ); //// // // Command locators that can simplify testing use cases. // //// pub const COMMAND: &str = "json-to-usv"; #[allow(dead_code)] pub static COMMAND_FILE: Lazy = Lazy::new(|| [env!("CARGO_MANIFEST_DIR"), "target", "debug", &COMMAND].iter().collect::() ); #[allow(dead_code)] pub static COMMAND_OS: Lazy = Lazy::new(|| OsString::from([env!("CARGO_MANIFEST_DIR"), "target", "debug", &COMMAND].iter().collect::()) ); //// // // Command input/output helpers. // //// use std::process::{Command, Stdio}; use std::io::Write; /// Command input/output helper that takes stdin as bytes and returns stdout as a String. #[allow(dead_code)] pub fn command_io_bytes_to_string(command: &mut Command, stdin: &[u8]) -> String { // Spawn child let mut child = command .stdin(Stdio::piped()) .stdout(Stdio::piped()) .spawn() .expect("command"); // Handle stdin let child_stdin = child.stdin.as_mut().expect("child_stdin"); child_stdin.write_all(stdin).expect("write_all"); #[allow(dropping_references)] let _ = drop(child_stdin); // Handle stdout let output = child.wait_with_output().expect("wait_with_output"); String::from_utf8(output.stdout).unwrap() } pub fn command_io_str_to_string(command: &mut Command, stdin: &str) -> String { command_io_bytes_to_string(command, stdin.as_bytes()) } //// // // Utility helpers. // //// #[allow(dead_code)] pub fn remove_file_if_exists>(path: P) -> std::io::Result<()> { if path.as_ref().exists() { ::std::fs::remove_file(path) } else { Ok(()) } } //// // // Example data suitable for testing. // ////