mirror of
https://github.com/uutils/coreutils
synced 2025-01-04 17:29:04 +00:00
93c7cbe65e
- removed repeat_str helper as it's now part of std - added docstrings for usual macros and test utils
105 lines
2.9 KiB
Rust
105 lines
2.9 KiB
Rust
/// Assertion helper macro for [`CmdResult`] types
|
|
///
|
|
/// [`CmdResult`]: crate::tests::common::util::CmdResult
|
|
#[macro_export]
|
|
macro_rules! assert_empty_stderr(
|
|
($cond:expr) => (
|
|
if $cond.stderr.len() > 0 {
|
|
panic!(format!("stderr: {}", $cond.stderr))
|
|
}
|
|
);
|
|
);
|
|
|
|
/// Assertion helper macro for [`CmdResult`] types
|
|
///
|
|
/// [`CmdResult`]: crate::tests::common::util::CmdResult
|
|
#[macro_export]
|
|
macro_rules! assert_empty_stdout(
|
|
($cond:expr) => (
|
|
if $cond.stdout.len() > 0 {
|
|
panic!(format!("stdout: {}", $cond.stdout))
|
|
}
|
|
);
|
|
);
|
|
|
|
/// Assertion helper macro for [`CmdResult`] types
|
|
///
|
|
/// [`CmdResult`]: crate::tests::common::util::CmdResult
|
|
#[macro_export]
|
|
macro_rules! assert_no_error(
|
|
($cond:expr) => (
|
|
assert!($cond.success);
|
|
if $cond.stderr.len() > 0 {
|
|
panic!(format!("stderr: {}", $cond.stderr))
|
|
}
|
|
);
|
|
);
|
|
|
|
/// Platform-independent helper for constructing a PathBuf from individual elements
|
|
#[macro_export]
|
|
macro_rules! path_concat {
|
|
($e:expr, ..$n:expr) => {{
|
|
use std::path::PathBuf;
|
|
let n = $n;
|
|
let mut pb = PathBuf::new();
|
|
for _ in 0..n {
|
|
pb.push($e);
|
|
}
|
|
pb.to_str().unwrap().to_owned()
|
|
}};
|
|
($($e:expr),*) => {{
|
|
use std::path::PathBuf;
|
|
let mut pb = PathBuf::new();
|
|
$(
|
|
pb.push($e);
|
|
)*
|
|
pb.to_str().unwrap().to_owned()
|
|
}};
|
|
}
|
|
|
|
/// Deduce the name of the test binary from the test filename.
|
|
///
|
|
/// e.g.: `tests/by-util/test_cat.rs` -> `cat`
|
|
#[macro_export]
|
|
macro_rules! util_name {
|
|
() => {
|
|
module_path!().split("_").nth(1).expect("no test name")
|
|
};
|
|
}
|
|
|
|
/// Convenience macro for acquiring a [`UCommand`] builder.
|
|
///
|
|
/// Returns the following:
|
|
/// - a [`UCommand`] builder for invoking the binary to be tested
|
|
///
|
|
/// This macro is intended for quick, single-call tests. For more complex tests
|
|
/// that require multiple invocations of the tested binary, see [`TestScenario`]
|
|
///
|
|
/// [`UCommand`]: crate::tests::common::util::UCommand
|
|
/// [`TestScenario]: crate::tests::common::util::TestScenario
|
|
#[macro_export]
|
|
macro_rules! new_ucmd {
|
|
() => {
|
|
TestScenario::new(util_name!()).ucmd()
|
|
};
|
|
}
|
|
|
|
/// Convenience macro for acquiring a [`UCommand`] builder and a test path.
|
|
///
|
|
/// Returns a tuple containing the following:
|
|
/// - an [`AsPath`] that points to a unique temporary test directory
|
|
/// - a [`UCommand`] builder for invoking the binary to be tested
|
|
///
|
|
/// This macro is intended for quick, single-call tests. For more complex tests
|
|
/// that require multiple invocations of the tested binary, see [`TestScenario`]
|
|
///
|
|
/// [`UCommand`]: crate::tests::common::util::UCommand
|
|
/// [`AsPath`]: crate::tests::common::util::AsPath
|
|
/// [`TestScenario]: crate::tests::common::util::TestScenario
|
|
#[macro_export]
|
|
macro_rules! at_and_ucmd {
|
|
() => {{
|
|
let ts = TestScenario::new(util_name!());
|
|
(ts.fixtures.clone(), ts.ucmd())
|
|
}};
|
|
}
|