macro_rules! assert_program_args_stderr_ne {
($a_program:expr, $a_args:expr, $b_program:expr, $b_args:expr $(,)?) => { ... };
($a_program:expr, $a_args:expr, $b_program:expr, $($message:tt)+) => { ... };
}
Expand description
Assert a command (built with program and args) stderr is not equal to another.
Pseudocode:
(a_program + a_args ⇒ command ⇒ stderr) ≠ (b_program + b_args ⇒ command ⇒ stderr)
-
If true, return
()
. -
Otherwise, call
panic!
with a message and the values of the expressions with their debug representations.
§Examples
use assertables::*;
let a_program = "bin/printf-stderr";
let a_args = ["%s", "alfa"];
let b_program = "bin/printf-stderr";
let b_args = ["%s", "zz"];
assert_program_args_stderr_ne!(a_program, a_args, b_program, b_args);
// This will panic
let a_program = "bin/printf-stderr";
let a_args = ["%s", "alfa"];
let b_program = "bin/printf-stderr";
let b_args = ["%s", "alfa"];
assert_program_args_stderr_ne!(a_program, a_args, b_program, b_args);
// assertion failed: `assert_program_args_stderr_ne!(a_program, a_args, b_program, b_args)`
// https://docs.rs/assertables/9.7.0/assertables/macro.assert_program_args_stderr_ne.html
// a_program label: `a_program`,
// a_program debug: `\"bin/printf-stderr\"`,
// a_args label: `a_args`,
// a_args debug: `[\"%s\", \"alfa\"]`,
// b_program label: `b_program`,
// b_program debug: `\"bin/printf-stderr\"`,
// b_args label: `b_args`,
// b_args debug: `[\"%s\", \"alfa\"]`,
// a: `[97, 108, 102, 97]`,
// b: `[97, 108, 102, 97]`
/// # Module macros