#[macro_export]
macro_rules! assert_fn_err_le_x_as_result {
($a_function:path, $a_param:expr, $b_expr:expr $(,)?) => {
match (&$a_function, &$a_param, &$b_expr) {
(_a_function, a_param, b_expr) => {
match ($a_function($a_param)) {
Err(a) => {
if a <= $b_expr {
Ok(a)
} else {
Err(
format!(
concat!(
"assertion failed: `assert_fn_err_le_x!(a_function, a_param, b_expr)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_fn_err_le_x.html\n",
" a_function label: `{}`,\n",
" a_param label: `{}`,\n",
" a_param debug: `{:?}`,\n",
" b_expr label: `{}`,\n",
" b_expr debug: `{:?}`,\n",
" a: `{:?}`,\n",
" b: `{:?}`",
),
stringify!($a_function),
stringify!($a_param),
a_param,
stringify!($b_expr),
b_expr,
a,
$b_expr
)
)
}
},
a => {
Err(
format!(
concat!(
"assertion failed: `assert_fn_err_le_x!(a_function, a_param, b_expr)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_fn_err_le_x.html\n",
" a_function label: `{}`,\n",
" a_param label: `{}`,\n",
" a_param debug: `{:?}`,\n",
" b_expr label: `{}`,\n",
" b_expr debug: `{:?}`,\n",
" a: `{:?}`",
),
stringify!($a_function),
stringify!($a_param),
a_param,
stringify!($b_expr),
b_expr,
a
)
)
}
}
}
}
};
($a_function:path, $b_expr:expr $(,)?) => {
match (&$a_function, &$b_expr) {
(_a_function, b_expr) => {
match ($a_function()) {
Err(a) => {
if a <= $b_expr {
Ok(a)
} else {
Err(
format!(
concat!(
"assertion failed: `assert_fn_err_le_x!(a_function, b_expr)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_fn_err_le_x.html\n",
" a_function label: `{}`,\n",
" b_expr label: `{}`,\n",
" b_expr debug: `{:?}`,\n",
" a: `{:?}`,\n",
" b: `{:?}`",
),
stringify!($a_function),
stringify!($b_expr),
b_expr,
a,
$b_expr
)
)
}
},
a => {
Err(
format!(
concat!(
"assertion failed: `assert_fn_err_le_x!(a_function, b_expr)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_fn_err_le_x.html\n",
" a_function label: `{}`,\n",
" b_expr label: `{}`,\n",
" b_expr debug: `{:?}`,\n",
" a: `{:?}`",
),
stringify!($a_function),
stringify!($b_expr),
b_expr,
a
)
)
}
}
}
}
};
}
#[cfg(test)]
mod test_assert_fn_err_le_x_as_result {
mod arity_1 {
fn f(i: i8) -> Result<i8, i8> {
Err(i)
}
#[test]
fn lt() {
let a: i8 = 1;
let b: i8 = 2;
for _ in 0..1 {
let actual = assert_fn_err_le_x_as_result!(f, a, b);
assert_eq!(actual.unwrap(), 1);
}
}
#[test]
fn eq() {
let a: i8 = 1;
let b: i8 = 1;
for _ in 0..1 {
let actual = assert_fn_err_le_x_as_result!(f, a, b);
assert_eq!(actual.unwrap(), 1);
}
}
#[test]
fn gt() {
let a: i8 = 2;
let b: i8 = 1;
let actual = assert_fn_err_le_x_as_result!(f, a, b);
let message = concat!(
"assertion failed: `assert_fn_err_le_x!(a_function, a_param, b_expr)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_fn_err_le_x.html\n",
" a_function label: `f`,\n",
" a_param label: `a`,\n",
" a_param debug: `2`,\n",
" b_expr label: `b`,\n",
" b_expr debug: `1`,\n",
" a: `2`,\n",
" b: `1`"
);
assert_eq!(actual.unwrap_err(), message);
}
}
mod arity_0 {
fn f() -> Result<i8, i8> {
Err(1)
}
#[test]
fn lt() {
let b: i8 = 2;
for _ in 0..1 {
let actual = assert_fn_err_le_x_as_result!(f, b);
assert_eq!(actual.unwrap(), 1);
}
}
#[test]
fn eq() {
let b: i8 = 1;
for _ in 0..1 {
let actual = assert_fn_err_le_x_as_result!(f, b);
assert_eq!(actual.unwrap(), 1);
}
}
#[test]
fn gt() {
let b: i8 = 0;
let actual = assert_fn_err_le_x_as_result!(f, b);
let message = concat!(
"assertion failed: `assert_fn_err_le_x!(a_function, b_expr)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_fn_err_le_x.html\n",
" a_function label: `f`,\n",
" b_expr label: `b`,\n",
" b_expr debug: `0`,\n",
" a: `1`,\n",
" b: `0`"
);
assert_eq!(actual.unwrap_err(), message);
}
}
}
#[macro_export]
macro_rules! assert_fn_err_le_x {
($a_function:path, $a_param:expr, $b_expr:expr $(,)?) => {
match $crate::assert_fn_err_le_x_as_result!($a_function, $a_param, $b_expr) {
Ok(x) => x,
Err(err) => panic!("{}", err),
}
};
($a_function:path, $a_param:expr, $b_expr:expr, $($message:tt)+) => {
match $crate::assert_fn_err_le_x_as_result!($a_function, $a_param, $b_expr) {
Ok(x) => x,
Err(err) => panic!("{}\n{}", format_args!($($message)+), err),
}
};
($a_function:path, $b_expr:expr $(,)?) => {
match $crate::assert_fn_err_le_x_as_result!($a_function, $b_expr) {
Ok(x) => x,
Err(err) => panic!("{}", err),
}
};
($a_function:path, $b_expr:expr, $($message:tt)+) => {
match $crate::assert_fn_err_le_x_as_result!($a_function, $b_expr) {
Ok(x) => x,
Err(err) => panic!("{}\n{}", format_args!($($message)+), err),
}
};
}
#[cfg(test)]
mod test_assert_fn_err_le_x {
use std::panic;
mod arity_1 {
use super::*;
fn f(i: i8) -> Result<i8, i8> {
Err(i)
}
#[test]
fn lt() {
let a: i8 = 1;
let b: i8 = 2;
for _ in 0..1 {
let actual = assert_fn_err_le_x!(f, a, b);
let expect = 1;
assert_eq!(actual, expect);
}
}
#[test]
fn eq() {
let a: i8 = 1;
let b: i8 = 1;
for _ in 0..1 {
let actual = assert_fn_err_le_x!(f, a, b);
let expect = 1;
assert_eq!(actual, expect);
}
}
#[test]
fn gt() {
let result = panic::catch_unwind(|| {
let a: i8 = 2;
let b: i8 = 1;
let _actual = assert_fn_err_le_x!(f, a, b);
});
let message = concat!(
"assertion failed: `assert_fn_err_le_x!(a_function, a_param, b_expr)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_fn_err_le_x.html\n",
" a_function label: `f`,\n",
" a_param label: `a`,\n",
" a_param debug: `2`,\n",
" b_expr label: `b`,\n",
" b_expr debug: `1`,\n",
" a: `2`,\n",
" b: `1`"
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}
mod arity_0 {
use super::*;
fn f() -> Result<i8, i8> {
Err(1)
}
#[test]
fn lt() {
let b: i8 = 2;
for _ in 0..1 {
let actual = assert_fn_err_le_x!(f, b);
let expect = 1;
assert_eq!(actual, expect);
}
}
#[test]
fn eq() {
let b: i8 = 1;
for _ in 0..1 {
let actual = assert_fn_err_le_x!(f, b);
let expect = 1;
assert_eq!(actual, expect);
}
}
#[test]
fn gt() {
let result = panic::catch_unwind(|| {
let b: i8 = 0;
let _actual = assert_fn_err_le_x!(f, b);
});
let message = concat!(
"assertion failed: `assert_fn_err_le_x!(a_function, b_expr)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_fn_err_le_x.html\n",
" a_function label: `f`,\n",
" b_expr label: `b`,\n",
" b_expr debug: `0`,\n",
" a: `1`,\n",
" b: `0`"
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}
}
#[macro_export]
macro_rules! debug_assert_fn_err_le_x {
($($arg:tt)*) => {
if cfg!(debug_assertions) {
$crate::assert_fn_err_le_x!($($arg)*);
}
};
}
#[cfg(test)]
mod test_debug_assert_fn_err_le_x {
use std::panic;
mod arity_1 {
use super::*;
fn f(i: i8) -> Result<i8, i8> {
Err(i)
}
#[test]
fn lt() {
let a: i8 = 1;
let b: i8 = 2;
for _ in 0..1 {
let _actual = debug_assert_fn_err_le_x!(f, a, b);
let _expect = 1;
}
}
#[test]
fn eq() {
let a: i8 = 1;
let b: i8 = 1;
for _ in 0..1 {
let _actual = debug_assert_fn_err_le_x!(f, a, b);
let _expect = 1;
}
}
#[test]
fn gt() {
let result = panic::catch_unwind(|| {
let a: i8 = 2;
let b: i8 = 1;
let _actual = debug_assert_fn_err_le_x!(f, a, b);
});
let message = concat!(
"assertion failed: `assert_fn_err_le_x!(a_function, a_param, b_expr)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_fn_err_le_x.html\n",
" a_function label: `f`,\n",
" a_param label: `a`,\n",
" a_param debug: `2`,\n",
" b_expr label: `b`,\n",
" b_expr debug: `1`,\n",
" a: `2`,\n",
" b: `1`"
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}
mod arity_0 {
use super::*;
fn f() -> Result<i8, i8> {
Err(1)
}
#[test]
fn lt() {
let b: i8 = 2;
for _ in 0..1 {
let _actual = debug_assert_fn_err_le_x!(f, b);
let _expect = 1;
}
}
#[test]
fn eq() {
let b: i8 = 1;
for _ in 0..1 {
let _actual = debug_assert_fn_err_le_x!(f, b);
let _expect = 1;
}
}
#[test]
fn gt() {
let result = panic::catch_unwind(|| {
let b: i8 = 0;
let _actual = debug_assert_fn_err_le_x!(f, b);
});
let message = concat!(
"assertion failed: `assert_fn_err_le_x!(a_function, b_expr)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_fn_err_le_x.html\n",
" a_function label: `f`,\n",
" b_expr label: `b`,\n",
" b_expr debug: `0`,\n",
" a: `1`,\n",
" b: `0`"
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}
}