#[macro_export]
macro_rules! assert_command_stdout_ne_as_result {
($a_command:expr, $b_command:expr $(,)?) => {
match ($a_command.output(), $b_command.output()) {
(Ok(a), Ok(b)) => {
let a = a.stdout;
let b = b.stdout;
if a.ne(&b) {
Ok((a, b))
} else {
Err(format!(
concat!(
"assertion failed: `assert_command_stdout_ne!(a_command, b_command)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_command_stdout_ne.html\n",
" a label: `{}`,\n",
" a debug: `{:?}`,\n",
" b label: `{}`,\n",
" b debug: `{:?}`,\n",
" a value: `{:?}`,\n",
" b value: `{:?}`"
),
stringify!($a_command),
$a_command,
stringify!($b_command),
$b_command,
a,
b
))
}
}
(a, b) => Err(format!(
concat!(
"assertion failed: `assert_command_stdout_ne!(a_command, b_command)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_command_stdout_ne.html\n",
" a label: `{}`,\n",
" a debug: `{:?}`,\n",
" b label: `{}`,\n",
" b debug: `{:?}`,\n",
" a value: `{:?}`,\n",
" b value: `{:?}`"
),
stringify!($a_command),
$a_command,
stringify!($b_command),
$b_command,
a,
b
)),
}
};
}
#[cfg(test)]
mod test_assert_command_stdout_ne_as_result {
use std::process::Command;
use std::sync::Once;
#[test]
fn lt() {
let mut a = Command::new("bin/printf-stdout");
a.args(["%s", "alfa"]);
let mut b = Command::new("bin/printf-stdout");
b.args(["%s", "zz"]);
for _ in 0..1 {
let actual = assert_command_stdout_ne_as_result!(a, b);
assert_eq!(
actual.unwrap(),
(vec![b'a', b'l', b'f', b'a'], vec![b'z', b'z'])
);
}
}
#[test]
fn lt_once() {
static A: Once = Once::new();
fn a() -> Command {
if A.is_completed() {
panic!("A.is_completed()")
} else {
A.call_once(|| {})
}
let mut a = Command::new("bin/printf-stdout");
a.args(["%s", "alfa"]);
a
}
static B: Once = Once::new();
fn b() -> Command {
if B.is_completed() {
panic!("B.is_completed()")
} else {
B.call_once(|| {})
}
let mut b = Command::new("bin/printf-stdout");
b.args(["%s", "zz"]);
b
}
assert_eq!(A.is_completed(), false);
assert_eq!(B.is_completed(), false);
let result = assert_command_stdout_ne_as_result!(a(), b());
assert!(result.is_ok());
assert_eq!(A.is_completed(), true);
assert_eq!(B.is_completed(), true);
}
#[test]
fn gt() {
let mut a = Command::new("bin/printf-stdout");
a.args(["%s", "alfa"]);
let mut b = Command::new("bin/printf-stdout");
b.args(["%s", "aa"]);
for _ in 0..1 {
let actual = assert_command_stdout_ne_as_result!(a, b);
assert_eq!(
actual.unwrap(),
(vec![b'a', b'l', b'f', b'a'], vec![b'a', b'a'])
);
}
}
#[test]
fn gt_once() {
static A: Once = Once::new();
fn a() -> Command {
if A.is_completed() {
panic!("A.is_completed()")
} else {
A.call_once(|| {})
}
let mut a = Command::new("bin/printf-stdout");
a.args(["%s", "alfa"]);
a
}
static B: Once = Once::new();
fn b() -> Command {
if B.is_completed() {
panic!("B.is_completed()")
} else {
B.call_once(|| {})
}
let mut b = Command::new("bin/printf-stdout");
b.args(["%s", "aa"]);
b
}
assert_eq!(A.is_completed(), false);
assert_eq!(B.is_completed(), false);
let result = assert_command_stdout_ne_as_result!(a(), b());
assert!(result.is_ok());
assert_eq!(A.is_completed(), true);
assert_eq!(B.is_completed(), true);
}
#[test]
fn eq() {
let mut a = Command::new("bin/printf-stdout");
a.args(["%s", "alfa"]);
let mut b = Command::new("bin/printf-stdout");
b.args(["%s", "alfa"]);
let actual = assert_command_stdout_ne_as_result!(a, b);
let message = concat!(
"assertion failed: `assert_command_stdout_ne!(a_command, b_command)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_command_stdout_ne.html\n",
" a label: `a`,\n",
" a debug: `\"bin/printf-stdout\" \"%s\" \"alfa\"`,\n",
" b label: `b`,\n",
" b debug: `\"bin/printf-stdout\" \"%s\" \"alfa\"`,\n",
" a value: `[97, 108, 102, 97]`,\n",
" b value: `[97, 108, 102, 97]`"
);
assert_eq!(actual.unwrap_err(), message);
}
}
#[macro_export]
macro_rules! assert_command_stdout_ne {
($a_command:expr, $b_command:expr $(,)?) => {
match $crate::assert_command_stdout_ne_as_result!($a_command, $b_command) {
Ok(x) => x,
Err(err) => panic!("{}", err),
}
};
($a_command:expr, $b_command:expr, $($message:tt)+) => {
match $crate::assert_command_stdout_ne_as_result!($a_command, $b_command) {
Ok(x) => x,
Err(err) => panic!("{}\n{}", format_args!($($message)+), err),
}
};
}
#[cfg(test)]
mod test_assert_command_stdout_ne {
use std::panic;
use std::process::Command;
#[test]
fn lt() {
let mut a = Command::new("bin/printf-stdout");
a.args(["%s", "alfa"]);
let mut b = Command::new("bin/printf-stdout");
b.args(["%s", "zz"]);
for _ in 0..1 {
let actual = assert_command_stdout_ne!(a, b);
assert_eq!(actual, (vec![b'a', b'l', b'f', b'a'], vec![b'z', b'z']));
}
}
#[test]
fn gt() {
let mut a = Command::new("bin/printf-stdout");
a.args(["%s", "alfa"]);
let mut b = Command::new("bin/printf-stdout");
b.args(["%s", "aa"]);
for _ in 0..1 {
let actual = assert_command_stdout_ne!(a, b);
assert_eq!(actual, (vec![b'a', b'l', b'f', b'a'], vec![b'a', b'a']));
}
}
#[test]
fn eq() {
let result = panic::catch_unwind(|| {
let mut a = Command::new("bin/printf-stdout");
a.args(["%s", "alfa"]);
let mut b = Command::new("bin/printf-stdout");
b.args(["%s", "alfa"]);
let _actual = assert_command_stdout_ne!(a, b);
});
let message = concat!(
"assertion failed: `assert_command_stdout_ne!(a_command, b_command)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_command_stdout_ne.html\n",
" a label: `a`,\n",
" a debug: `\"bin/printf-stdout\" \"%s\" \"alfa\"`,\n",
" b label: `b`,\n",
" b debug: `\"bin/printf-stdout\" \"%s\" \"alfa\"`,\n",
" a value: `[97, 108, 102, 97]`,\n",
" b value: `[97, 108, 102, 97]`"
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}
#[macro_export]
macro_rules! debug_assert_command_stdout_ne {
($($arg:tt)*) => {
if cfg!(debug_assertions) {
$crate::assert_command_stdout_ne!($($arg)*);
}
};
}
#[cfg(test)]
mod test_debug_assert_command_stdout_ne {
use std::panic;
use std::process::Command;
#[test]
fn lt() {
let mut a = Command::new("bin/printf-stdout");
a.args(["%s", "alfa"]);
let mut b = Command::new("bin/printf-stdout");
b.args(["%s", "zz"]);
for _ in 0..1 {
let _actual = debug_assert_command_stdout_ne!(a, b);
}
}
#[test]
fn gt() {
let mut a = Command::new("bin/printf-stdout");
a.args(["%s", "alfa"]);
let mut b = Command::new("bin/printf-stdout");
b.args(["%s", "aa"]);
for _ in 0..1 {
let _actual = debug_assert_command_stdout_ne!(a, b);
}
}
#[test]
fn eq() {
let result = panic::catch_unwind(|| {
let mut a = Command::new("bin/printf-stdout");
a.args(["%s", "alfa"]);
let mut b = Command::new("bin/printf-stdout");
b.args(["%s", "alfa"]);
let _actual = debug_assert_command_stdout_ne!(a, b);
});
let message = concat!(
"assertion failed: `assert_command_stdout_ne!(a_command, b_command)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_command_stdout_ne.html\n",
" a label: `a`,\n",
" a debug: `\"bin/printf-stdout\" \"%s\" \"alfa\"`,\n",
" b label: `b`,\n",
" b debug: `\"bin/printf-stdout\" \"%s\" \"alfa\"`,\n",
" a value: `[97, 108, 102, 97]`,\n",
" b value: `[97, 108, 102, 97]`"
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}