#[macro_export]
macro_rules! assert_set_joint_as_result {
($a_collection:expr, $b_collection:expr $(,)?) => {
match (&$a_collection, &$b_collection) {
(a_collection, b_collection) => {
let a: ::std::collections::BTreeSet<_> = $crate::assert_set_impl_prep!(a_collection);
let b: ::std::collections::BTreeSet<_> = $crate::assert_set_impl_prep!(b_collection);
if !a.is_disjoint(&b) {
Ok((a, b))
} else {
Err(format!(
concat!(
"assertion failed: `assert_set_joint!(a_collection, b_collection)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_set_joint.html\n",
" a label: `{}`,\n",
" a debug: `{:?}`,\n",
" b label: `{}`,\n",
" b debug: `{:?}`,\n",
" a: `{:?}`,\n",
" b: `{:?}`"
),
stringify!($a_collection),
a_collection,
stringify!($b_collection),
b_collection,
a,
b
))
}
}
}
};
}
#[cfg(test)]
mod test_assert_set_joint_as_result {
use std::collections::BTreeSet;
#[test]
fn success() {
let a = [1, 2];
let b = [2, 3];
let actual = assert_set_joint_as_result!(a, b);
assert_eq!(
actual.unwrap(),
(BTreeSet::from([&1, &2]), BTreeSet::from([&2, &3]))
);
}
#[test]
fn failure() {
let a = [1, 2];
let b = [3, 4];
let actual = assert_set_joint_as_result!(a, b);
let message = concat!(
"assertion failed: `assert_set_joint!(a_collection, b_collection)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_set_joint.html\n",
" a label: `a`,\n",
" a debug: `[1, 2]`,\n",
" b label: `b`,\n",
" b debug: `[3, 4]`,\n",
" a: `{1, 2}`,\n",
" b: `{3, 4}`"
);
assert_eq!(actual.unwrap_err(), message);
}
}
#[macro_export]
macro_rules! assert_set_joint {
($a_collection:expr, $b_collection:expr $(,)?) => {
match $crate::assert_set_joint_as_result!($a_collection, $b_collection) {
Ok(x) => x,
Err(err) => panic!("{}", err),
}
};
($a_collection:expr, $b_collection:expr, $($message:tt)+) => {
match $crate::assert_set_joint_as_result!($a_collection, $b_collection) {
Ok(x) => x,
Err(err) => panic!("{}\n{}", format_args!($($message)+), err),
}
};
}
#[cfg(test)]
mod test_assert_set_joint {
use std::collections::BTreeSet;
use std::panic;
#[test]
fn success() {
let a = [1, 2];
let b = [2, 3];
for _ in 0..1 {
let actual = assert_set_joint!(a, b);
assert_eq!(actual, (BTreeSet::from([&1, &2]), BTreeSet::from([&2, &3])));
}
}
#[test]
fn failure() {
let a = [1, 2];
let b = [3, 4];
let result = panic::catch_unwind(|| {
let _actual = assert_set_joint!(a, b);
});
let message = concat!(
"assertion failed: `assert_set_joint!(a_collection, b_collection)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_set_joint.html\n",
" a label: `a`,\n",
" a debug: `[1, 2]`,\n",
" b label: `b`,\n",
" b debug: `[3, 4]`,\n",
" a: `{1, 2}`,\n",
" b: `{3, 4}`"
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}
#[macro_export]
macro_rules! debug_assert_set_joint {
($($arg:tt)*) => {
if cfg!(debug_assertions) {
$crate::assert_set_joint!($($arg)*);
}
};
}
#[cfg(test)]
mod test_debug_assert_set_joint {
use std::collections::BTreeSet;
use std::panic;
#[test]
fn success() {
let a = [1, 2];
let b = [2, 3];
for _ in 0..1 {
let _actual = debug_assert_set_joint!(a, b);
let _expect = (BTreeSet::from([&1, &2]), BTreeSet::from([&2, &3]));
}
}
#[test]
fn failure() {
let a = [1, 2];
let b = [3, 4];
let result = panic::catch_unwind(|| {
let _actual = debug_assert_set_joint!(a, b);
});
let message = concat!(
"assertion failed: `assert_set_joint!(a_collection, b_collection)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_set_joint.html\n",
" a label: `a`,\n",
" a debug: `[1, 2]`,\n",
" b label: `b`,\n",
" b debug: `[3, 4]`,\n",
" a: `{1, 2}`,\n",
" b: `{3, 4}`"
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}