Macro assertables::assertable_f_ne
source · [−]macro_rules! assertable_f_ne {
($function:path, $left:expr, $right:expr $(,)?) => { ... };
($function:path, $left:expr, $right:expr, $($arg:tt)+) => { ... };
}Expand description
Assert one function output is not equal to another function output.
-
When true, return
Ok(()). -
Otherwise, return
Errwith a message and the values of the expressions with their debug representations.
Examples
let x = assertable_f_ne!(i32::abs, 1 as i32, -2 as i32);
//-> Ok(())
assert_eq!(x.unwrap(), ());
let x = assertable_f_ne!(i32::abs, 1 as i32, -1 as i32);
//-> Err("…")
// assertable failed: `assertable_f_ne!(function, left, right)`
// function: `\"i32::abs\"`,
// left input: `1`,
// right input: `-1`,
// left output: `1`,
// right output: `1`
assert_eq!(x.unwrap_err(), "assertable failed: `assertable_f_ne!(function, left, right)`\n function: `\"i32::abs\"`,\n left input: `1`,\n right input: `-1`,\n left output: `1`,\n right output: `1`".to_string());This macro has a second form where a custom message can be provided.