#[macro_export]
macro_rules! assert_program_args_stdout_ge_x_as_result {
($a_program:expr, $a_args:expr, $b_expr:expr $(,)?) => {
match (&$a_program, &$a_args, &$b_expr) {
(a_program, a_args, b_expr) => {
match assert_program_args_impl_prep!(a_program, a_args) {
Ok(a_output) => {
let a = a_output.stdout;
if a.ge(b_expr) {
Ok(a)
} else {
Err(
format!(
concat!(
"assertion failed: `assert_program_args_stdout_ge_x!(a_program, a_args, b_expr)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_program_args_stdout_ge_x.html\n",
" a_program label: `{}`,\n",
" a_program debug: `{:?}`,\n",
" a_args label: `{}`,\n",
" a_args debug: `{:?}`,\n",
" b_expr label: `{}`,\n",
" b_expr debug: `{:?}`,\n",
" a: `{:?}`,\n",
" b: `{:?}`"
),
stringify!($a_program),
a_program,
stringify!($a_args),
a_args,
stringify!($b_expr),
$b_expr,
a,
b_expr
)
)
}
},
Err(err) => {
Err(
format!(
concat!(
"assertion failed: `assert_program_args_stdout_ge_x!(a_program, a_args, b_expr)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_program_args_stdout_ge_x.html\n",
" a_program label: `{}`,\n",
" a_program debug: `{:?}`,\n",
" a_args label: `{}`,\n",
" a_args debug: `{:?}`,\n",
" b_expr label: `{}`,\n",
" b_expr debug: `{:?}`,\n",
" err: `{:?}`"
),
stringify!($a_program),
a_program,
stringify!($a_args),
a_args,
stringify!($b_expr),
$b_expr,
err
)
)
}
}
}
}
};
}
#[cfg(test)]
mod test_assert_program_args_stdout_ge_x_as_result {
use std::sync::Once;
#[test]
fn gt() {
let a_program = "bin/printf-stdout";
let a_args = ["%s", "alfa"];
let b = vec![b'a', b'a'];
for _ in 0..1 {
let actual = assert_program_args_stdout_ge_x_as_result!(a_program, a_args, b);
assert_eq!(actual.unwrap(), vec![b'a', b'l', b'f', b'a']);
}
}
#[test]
fn gt_once() {
static A: Once = Once::new();
fn a() -> &'static str {
if A.is_completed() {
panic!("A.is_completed()")
} else {
A.call_once(|| {})
}
"bin/printf-stdout"
}
static A_ARGS: Once = Once::new();
fn a_args() -> [&'static str; 2] {
if A_ARGS.is_completed() {
panic!("A_ARGS.is_completed()")
} else {
A_ARGS.call_once(|| {})
}
["%s", "alfa"]
}
static B: Once = Once::new();
fn b() -> Vec<u8> {
if B.is_completed() {
panic!("B.is_completed()")
} else {
B.call_once(|| {})
}
vec![b'a', b'a']
}
assert_eq!(A.is_completed(), false);
assert_eq!(A_ARGS.is_completed(), false);
assert_eq!(B.is_completed(), false);
let result = assert_program_args_stdout_ge_x_as_result!(a(), a_args(), b());
assert!(result.is_ok());
assert_eq!(A.is_completed(), true);
assert_eq!(A_ARGS.is_completed(), true);
assert_eq!(B.is_completed(), true);
}
#[test]
fn eq() {
let a_program = "bin/printf-stdout";
let a_args = ["%s", "alfa"];
let b = vec![b'a', b'l', b'f', b'a'];
for _ in 0..1 {
let actual = assert_program_args_stdout_ge_x_as_result!(a_program, a_args, b);
assert_eq!(actual.unwrap(), vec![b'a', b'l', b'f', b'a']);
}
}
#[test]
fn eq_once() {
static A: Once = Once::new();
fn a() -> &'static str {
if A.is_completed() {
panic!("A.is_completed()")
} else {
A.call_once(|| {})
}
"bin/printf-stdout"
}
static A_ARGS: Once = Once::new();
fn a_args() -> [&'static str; 2] {
if A_ARGS.is_completed() {
panic!("A_ARGS.is_completed()")
} else {
A_ARGS.call_once(|| {})
}
["%s", "alfa"]
}
static B: Once = Once::new();
fn b() -> Vec<u8> {
if B.is_completed() {
panic!("B.is_completed()")
} else {
B.call_once(|| {})
}
vec![b'a', b'l', b'f', b'a']
}
assert_eq!(A.is_completed(), false);
assert_eq!(A_ARGS.is_completed(), false);
assert_eq!(B.is_completed(), false);
let result = assert_program_args_stdout_ge_x_as_result!(a(), a_args(), b());
assert!(result.is_ok());
assert_eq!(A.is_completed(), true);
assert_eq!(A_ARGS.is_completed(), true);
assert_eq!(B.is_completed(), true);
}
#[test]
fn lt() {
let a_program = "bin/printf-stdout";
let a_args = ["%s", "alfa"];
let b = vec![b'z', b'z'];
let actual = assert_program_args_stdout_ge_x_as_result!(a_program, a_args, b);
let message = concat!(
"assertion failed: `assert_program_args_stdout_ge_x!(a_program, a_args, b_expr)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_program_args_stdout_ge_x.html\n",
" a_program label: `a_program`,\n",
" a_program debug: `\"bin/printf-stdout\"`,\n",
" a_args label: `a_args`,\n",
" a_args debug: `[\"%s\", \"alfa\"]`,\n",
" b_expr label: `b`,\n",
" b_expr debug: `[122, 122]`,\n",
" a: `[97, 108, 102, 97]`,\n",
" b: `[122, 122]`"
);
assert_eq!(actual.unwrap_err(), message);
}
}
#[macro_export]
macro_rules! assert_program_args_stdout_ge_x {
($a_program:expr, $a_args:expr, $b_expr:expr $(,)?) => {
match $crate::assert_program_args_stdout_ge_x_as_result!($a_program, $a_args, $b_expr) {
Ok(x) => x,
Err(err) => panic!("{}", err),
}
};
($a_program:expr, $a_args:expr, $b_expr:expr, $($message:tt)+) => {
match $crate::assert_program_args_stdout_ge_x_as_result!($a_program, $a_args, $b_expr) {
Ok(x) => x,
Err(err) => panic!("{}\n{}", format_args!($($message)+), err),
}
};
}
#[cfg(test)]
mod test_assert_program_args_stdout_ge_x {
use std::panic;
#[test]
fn gt() {
let a_program = "bin/printf-stdout";
let a_args = ["%s", "alfa"];
let b = vec![b'a', b'a'];
for _ in 0..1 {
let actual = assert_program_args_stdout_ge_x!(a_program, a_args, b);
assert_eq!(actual, vec![b'a', b'l', b'f', b'a']);
}
}
#[test]
fn eq() {
let a_program = "bin/printf-stdout";
let a_args = ["%s", "alfa"];
let b = vec![b'a', b'l', b'f', b'a'];
for _ in 0..1 {
let actual = assert_program_args_stdout_ge_x!(a_program, a_args, b);
assert_eq!(actual, vec![b'a', b'l', b'f', b'a']);
}
}
#[test]
fn lt() {
let a_program = "bin/printf-stdout";
let a_args = ["%s", "alfa"];
let b = vec![b'z', b'z'];
let result = panic::catch_unwind(|| {
let _actual = assert_program_args_stdout_ge_x!(a_program, a_args, b);
});
let message = concat!(
"assertion failed: `assert_program_args_stdout_ge_x!(a_program, a_args, b_expr)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_program_args_stdout_ge_x.html\n",
" a_program label: `a_program`,\n",
" a_program debug: `\"bin/printf-stdout\"`,\n",
" a_args label: `a_args`,\n",
" a_args debug: `[\"%s\", \"alfa\"]`,\n",
" b_expr label: `b`,\n",
" b_expr debug: `[122, 122]`,\n",
" a: `[97, 108, 102, 97]`,\n",
" b: `[122, 122]`"
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}
#[macro_export]
macro_rules! debug_assert_program_args_stdout_ge_x {
($($arg:tt)*) => {
if cfg!(debug_assertions) {
$crate::assert_program_args_stdout_ge_x!($($arg)*);
}
};
}
#[cfg(test)]
mod test_debug_assert_program_args_stdout_ge_x {
use std::panic;
#[test]
fn gt() {
let a_program = "bin/printf-stdout";
let a_args = ["%s", "alfa"];
let b = vec![b'a', b'a'];
for _ in 0..1 {
let _actual = debug_assert_program_args_stdout_ge_x!(a_program, a_args, b);
}
}
#[test]
fn eq() {
let a_program = "bin/printf-stdout";
let a_args = ["%s", "alfa"];
let b = vec![b'a', b'l', b'f', b'a'];
for _ in 0..1 {
let _actual = debug_assert_program_args_stdout_ge_x!(a_program, a_args, b);
}
}
#[test]
fn lt() {
let a_program = "bin/printf-stdout";
let a_args = ["%s", "alfa"];
let b = vec![b'z', b'z'];
let result = panic::catch_unwind(|| {
let _actual = debug_assert_program_args_stdout_ge_x!(a_program, a_args, b);
});
let message = concat!(
"assertion failed: `assert_program_args_stdout_ge_x!(a_program, a_args, b_expr)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_program_args_stdout_ge_x.html\n",
" a_program label: `a_program`,\n",
" a_program debug: `\"bin/printf-stdout\"`,\n",
" a_args label: `a_args`,\n",
" a_args debug: `[\"%s\", \"alfa\"]`,\n",
" b_expr label: `b`,\n",
" b_expr debug: `[122, 122]`,\n",
" a: `[97, 108, 102, 97]`,\n",
" b: `[122, 122]`"
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}