macro_rules! assert_command_stdout_eq {
    ($left_command:expr, $right_command:expr $(,)?) => { ... };
    ($left_command:expr, $right_command:expr, $($arg:tt)+) => { ... };
}
Expand description

Assert a command stdout string is equal to another.

  • When true, return ().

  • Otherwise, call panic! with a message and the values of the expressions with their debug representations.

Examples

use std::process::Command;

let mut a = Command::new("printf");
a.args(["%s", "hello"]);
let mut b = Command::new("printf");
b.args(["%s%s%s%s%s", "h", "e", "l", "l", "o"]);
assert_command_stdout_eq!(a, b);
//-> ()

let mut a = Command::new("printf");
a.args(["%s", "hello"]);
let mut b = Command::new("printf");
b.args(["%s%s%s%s%s", "w", "o", "r", "l", "d"]);
assert_command_stdout_eq!(a, b);
//-> panic!("…")
// assertion failed: `assert_command_stdout_eq!(left_command, right_command)`
//   left command program: `\"printf\"`,
//  right command program: `\"printf\"`,
//   left stdout: `\"hello\"`,
//  right stdout: `\"world\"`

This macro has a second form where a custom message can be provided.