2021-03-22 10:13:38 +00:00
|
|
|
/// Platform-independent helper for constructing a PathBuf from individual elements
|
2016-05-22 17:35:30 +00:00
|
|
|
#[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()
|
|
|
|
}};
|
|
|
|
}
|
2016-08-23 11:52:43 +00:00
|
|
|
|
2021-03-22 10:13:38 +00:00
|
|
|
/// Deduce the name of the test binary from the test filename.
|
|
|
|
///
|
|
|
|
/// e.g.: `tests/by-util/test_cat.rs` -> `cat`
|
2016-08-23 11:52:43 +00:00
|
|
|
#[macro_export]
|
|
|
|
macro_rules! util_name {
|
2020-01-28 05:14:11 +00:00
|
|
|
() => {
|
|
|
|
module_path!().split("_").nth(1).expect("no test name")
|
|
|
|
};
|
2016-08-23 11:52:43 +00:00
|
|
|
}
|
|
|
|
|
2021-03-22 10:13:38 +00:00
|
|
|
/// 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
|
2016-08-23 11:52:43 +00:00
|
|
|
#[macro_export]
|
|
|
|
macro_rules! new_ucmd {
|
2020-01-28 05:14:11 +00:00
|
|
|
() => {
|
|
|
|
TestScenario::new(util_name!()).ucmd()
|
|
|
|
};
|
2016-08-23 11:52:43 +00:00
|
|
|
}
|
|
|
|
|
2021-03-22 10:13:38 +00:00
|
|
|
/// 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
|
2016-08-23 11:52:43 +00:00
|
|
|
#[macro_export]
|
|
|
|
macro_rules! at_and_ucmd {
|
2020-01-28 05:14:11 +00:00
|
|
|
() => {{
|
|
|
|
let ts = TestScenario::new(util_name!());
|
|
|
|
(ts.fixtures.clone(), ts.ucmd())
|
|
|
|
}};
|
2016-08-23 11:52:43 +00:00
|
|
|
}
|