#[macro_export]
macro_rules! assert_any_as_result {
($iter:expr, $predicate:expr $(,)?) => {
match ($iter, $predicate) {
(mut iter, predicate) => {
if iter.any(predicate) {
Ok(())
} else {
Err(format!(
concat!(
"assertion failed: `assert_any!(iter, predicate)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_any.html\n",
" iter label: `{}`,\n",
" iter debug: `{:?}`,\n",
" predicate: `{}`",
),
stringify!($iter),
$iter,
stringify!($predicate)
))
}
}
}
};
}
#[cfg(test)]
mod test_assert_any_as_result {
use std::sync::Once;
#[test]
fn success() {
let a = [1, 2];
for _ in 0..1 {
let actual = assert_any_as_result!(a.iter(), |&x| x > 0);
assert_eq!(actual.unwrap(), ());
}
}
#[test]
fn success_once() {
static A: Once = Once::new();
fn a() -> [i8; 2] {
if A.is_completed() {
panic!("A.is_completed()")
} else {
A.call_once(|| {})
}
[1, 2]
}
assert_eq!(A.is_completed(), false);
let result = assert_any_as_result!(a().iter(), |&x| x > 0);
assert!(result.is_ok());
assert_eq!(A.is_completed(), true);
}
#[test]
fn failure() {
let a = [1, 2];
let actual = assert_any_as_result!(a.iter(), |&x| x > 3);
let message = concat!(
"assertion failed: `assert_any!(iter, predicate)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_any.html\n",
" iter label: `a.iter()`,\n",
" iter debug: `Iter([1, 2])`,\n",
" predicate: `|&x| x > 3`"
);
assert_eq!(actual.unwrap_err(), message);
}
}
#[macro_export]
macro_rules! assert_any {
($iter:expr, $predicate:expr $(,)?) => {
match $crate::assert_any_as_result!($iter, $predicate) {
Ok(()) => (),
Err(err) => panic!("{}", err),
}
};
($iter:expr, $predicate:expr, $($message:tt)+) => {
match $crate::assert_any_as_result!($iter, $predicate) {
Ok(()) => (),
Err(err) => panic!("{}\n{}", format_args!($($message)+), err),
}
};
}
#[cfg(test)]
mod test_assert_any {
use std::panic;
#[test]
fn success() {
let a = [1, 2];
for _ in 0..1 {
let actual = assert_any!(a.iter(), |&x| x > 0);
assert_eq!(actual, ());
}
}
#[test]
fn failure() {
let a = [1, 2];
let result = panic::catch_unwind(|| {
let _actual = assert_any!(a.iter(), |&x| x > 3);
});
let message = concat!(
"assertion failed: `assert_any!(iter, predicate)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_any.html\n",
" iter label: `a.iter()`,\n",
" iter debug: `Iter([1, 2])`,\n",
" predicate: `|&x| x > 3`"
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}
#[macro_export]
macro_rules! debug_assert_any {
($($arg:tt)*) => {
if cfg!(debug_assertions) {
$crate::assert_any!($($arg)*);
}
};
}
#[cfg(test)]
mod test_debug_assert_any {
use std::panic;
#[test]
fn success() {
let a = [1, 2];
for _ in 0..1 {
let _actual = debug_assert_any!(a.iter(), |&x| x > 0);
}
}
#[test]
fn failure() {
let a = [1, 2];
let result = panic::catch_unwind(|| {
let _actual = debug_assert_any!(a.iter(), |&x| x > 3);
});
let message = concat!(
"assertion failed: `assert_any!(iter, predicate)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_any.html\n",
" iter label: `a.iter()`,\n",
" iter debug: `Iter([1, 2])`,\n",
" predicate: `|&x| x > 3`"
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}