macro_rules! assert_program_args_stdout_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) stdout string is not equal to another.
Pseudocode:
(program1 + args1 ⇒ command ⇒ stdout) ≠ (program2 + args2 ⇒ command ⇒ stdout)
-
If true, return
(a_stdout, b_stdout). -
Otherwise, call
panic!with a message and the values of the expressions with their debug representations.
§Examples
use assertables::*;
let a_program = "bin/printf-stdout";
let a_args = ["%s", "alfa"];
let b_program = "bin/printf-stdout";
let b_args = ["%s%s", "z", "z" ];
assert_program_args_stdout_ne!(&a_program, &a_args, &b_program, &b_args);
// This will panic
let a_program = "bin/printf-stdout";
let a_args = ["%s", "alfa"];
let b_program = "bin/printf-stdout";
let b_args = ["%s%s%s%s", "a", "l", "f", "a"];
assert_program_args_stdout_ne!(&a_program, &a_args, &b_program, &b_args);
// assertion failed: `assert_program_args_stdout_ne!(a_program, a_args, b_program, b_args)`
// https://docs.rs/assertables/9.2.0/assertables/macro.assert_program_args_stdout_ne.html
// a_program label: `&a_program`,
// a_program debug: `\"bin/printf-stdout\"`,
// a_args label: `&a_args`,
// a_args debug: `[\"%s\", \"alfa\"]`,
// b_program label: `&b_program`,
// b_program debug: `\"bin/printf-stdout\"`,
// b_args label: `&b_args`,
// b_args debug: `[\"%s%s%s%s\", \"a\", \"l\", \"f\", \"a\"]`,
// a: `[97, 108, 102, 97]`,
// b: `[97, 108, 102, 97]`