#[macro_export]
macro_rules! assert_ge_as_result {
($a:expr, $b:expr $(,)?) => {
match (&$a, &$b) {
(a, b) => {
if a >= b {
Ok(())
} else {
Err(format!(
concat!(
"assertion failed: `assert_ge!(a, b)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_ge.html\n",
" a label: `{}`,\n",
" a debug: `{:?}`,\n",
" b label: `{}`,\n",
" b debug: `{:?}`",
),
stringify!($a),
a,
stringify!($b),
b
))
}
}
}
};
}
#[cfg(test)]
mod test_assert_ge_as_result {
use std::sync::Once;
mod integer {
use super::*;
#[test]
fn gt() {
let a: i8 = 2;
let b: i8 = 1;
for _ in 0..1 {
let actual = assert_ge_as_result!(a, b);
assert_eq!(actual.unwrap(), ());
}
}
#[test]
fn gt_once() {
static A: Once = Once::new();
fn a() -> i8 {
if A.is_completed() {
panic!("A.is_completed()")
} else {
A.call_once(|| {})
}
2
}
static B: Once = Once::new();
fn b() -> i8 {
if B.is_completed() {
panic!("B.is_completed()")
} else {
B.call_once(|| {})
}
1
}
assert_eq!(A.is_completed(), false);
assert_eq!(B.is_completed(), false);
let result = assert_ge_as_result!(a(), b());
assert!(result.is_ok());
assert_eq!(A.is_completed(), true);
assert_eq!(B.is_completed(), true);
}
#[test]
fn eq() {
let a: i8 = 1;
let b: i8 = 1;
for _ in 0..1 {
let actual = assert_ge_as_result!(a, b);
assert_eq!(actual.unwrap(), ());
}
}
#[test]
fn eq_once() {
static A: Once = Once::new();
fn a() -> i8 {
if A.is_completed() {
panic!("A.is_completed()")
} else {
A.call_once(|| {})
}
1
}
static B: Once = Once::new();
fn b() -> i8 {
if B.is_completed() {
panic!("B.is_completed()")
} else {
B.call_once(|| {})
}
1
}
assert_eq!(A.is_completed(), false);
assert_eq!(B.is_completed(), false);
let result = assert_ge_as_result!(a(), b());
assert!(result.is_ok());
assert_eq!(A.is_completed(), true);
assert_eq!(B.is_completed(), true);
}
#[test]
fn lt() {
let a: i8 = 1;
let b: i8 = 2;
let actual = assert_ge_as_result!(a, b);
let message = concat!(
"assertion failed: `assert_ge!(a, b)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_ge.html\n",
" a label: `a`,\n",
" a debug: `1`,\n",
" b label: `b`,\n",
" b debug: `2`",
);
assert_eq!(actual.unwrap_err(), message);
}
}
mod string {
use super::*;
#[test]
fn gt() {
let a: String = String::from("2");
let b: String = String::from("1");
for _ in 0..1 {
let actual = assert_ge_as_result!(a, b);
assert_eq!(actual.unwrap(), ());
}
}
#[test]
fn gt_once() {
static A: Once = Once::new();
fn a() -> String {
if A.is_completed() {
panic!("A.is_completed()")
} else {
A.call_once(|| {})
}
String::from("2")
}
static B: Once = Once::new();
fn b() -> String {
if B.is_completed() {
panic!("B.is_completed()")
} else {
B.call_once(|| {})
}
String::from("1")
}
assert_eq!(A.is_completed(), false);
assert_eq!(B.is_completed(), false);
let result = assert_ge_as_result!(a(), b());
assert!(result.is_ok());
assert_eq!(A.is_completed(), true);
assert_eq!(B.is_completed(), true);
}
#[test]
fn eq() {
let a: String = String::from("1");
let b: String = String::from("1");
for _ in 0..1 {
let actual = assert_ge_as_result!(a, b);
assert_eq!(actual.unwrap(), ());
}
}
#[test]
fn eq_once() {
static A: Once = Once::new();
fn a() -> String {
if A.is_completed() {
panic!("A.is_completed()")
} else {
A.call_once(|| {})
}
String::from("1")
}
static B: Once = Once::new();
fn b() -> String {
if B.is_completed() {
panic!("B.is_completed()")
} else {
B.call_once(|| {})
}
String::from("1")
}
assert_eq!(A.is_completed(), false);
assert_eq!(B.is_completed(), false);
let result = assert_ge_as_result!(a(), b());
assert!(result.is_ok());
assert_eq!(A.is_completed(), true);
assert_eq!(B.is_completed(), true);
}
#[test]
fn lt() {
let a: String = String::from("1");
let b: String = String::from("2");
let actual = assert_ge_as_result!(a, b);
let message = concat!(
"assertion failed: `assert_ge!(a, b)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_ge.html\n",
" a label: `a`,\n",
" a debug: `\"1\"`,\n",
" b label: `b`,\n",
" b debug: `\"2\"`",
);
assert_eq!(actual.unwrap_err(), message);
}
}
}
#[macro_export]
macro_rules! assert_ge {
($a:expr, $b:expr $(,)?) => {
match $crate::assert_ge_as_result!($a, $b) {
Ok(()) => (),
Err(err) => panic!("{}", err),
}
};
($a:expr, $b:expr, $($message:tt)+) => {
match $crate::assert_ge_as_result!($a, $b) {
Ok(()) => (),
Err(err) => panic!("{}\n{}", format_args!($($message)+), err),
}
};
}
#[cfg(test)]
mod test_assert_ge {
use std::panic;
mod integer {
use super::*;
#[test]
fn gt() {
let a: i8 = 2;
let b: i8 = 1;
for _ in 0..1 {
let actual = assert_ge!(a, b);
let expect = ();
assert_eq!(actual, expect);
}
}
#[test]
fn eq() {
let a: i8 = 1;
let b: i8 = 1;
for _ in 0..1 {
let actual = assert_ge!(a, b);
let expect = ();
assert_eq!(actual, expect);
}
}
#[test]
fn lt() {
let a: i8 = 1;
let b: i8 = 2;
let result = panic::catch_unwind(|| {
let _actual = assert_ge!(a, b);
});
let message = concat!(
"assertion failed: `assert_ge!(a, b)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_ge.html\n",
" a label: `a`,\n",
" a debug: `1`,\n",
" b label: `b`,\n",
" b debug: `2`",
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}
mod string {
use super::*;
#[test]
fn gt() {
let a: String = String::from("2");
let b: String = String::from("1");
for _ in 0..1 {
let actual = assert_ge!(a, b);
let expect = ();
assert_eq!(actual, expect);
}
}
#[test]
fn eq() {
let a: String = String::from("1");
let b: String = String::from("1");
for _ in 0..1 {
let actual = assert_ge!(a, b);
let expect = ();
assert_eq!(actual, expect);
}
}
#[test]
fn lt() {
let a: String = String::from("1");
let b: String = String::from("2");
let result = panic::catch_unwind(|| {
let _actual = assert_ge!(a, b);
});
let message = concat!(
"assertion failed: `assert_ge!(a, b)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_ge.html\n",
" a label: `a`,\n",
" a debug: `\"1\"`,\n",
" b label: `b`,\n",
" b debug: `\"2\"`",
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}
}
#[macro_export]
macro_rules! debug_assert_ge {
($($arg:tt)*) => {
if cfg!(debug_assertions) {
$crate::assert_ge!($($arg)*);
}
};
}
#[cfg(test)]
mod test_debug_assert_ge {
use std::panic;
mod integer {
use super::*;
#[test]
fn gt() {
let a: i8 = 2;
let b: i8 = 1;
for _ in 0..1 {
let _actual = debug_assert_ge!(a, b);
let _expect = ();
}
}
#[test]
fn eq() {
let a: i8 = 1;
let b: i8 = 1;
for _ in 0..1 {
let _actual = debug_assert_ge!(a, b);
let _expect = ();
}
}
#[test]
fn lt() {
let a: i8 = 1;
let b: i8 = 2;
let result = panic::catch_unwind(|| {
let _actual = debug_assert_ge!(a, b);
});
let message = concat!(
"assertion failed: `assert_ge!(a, b)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_ge.html\n",
" a label: `a`,\n",
" a debug: `1`,\n",
" b label: `b`,\n",
" b debug: `2`",
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}
mod string {
use super::*;
#[test]
fn gt() {
let a: String = String::from("2");
let b: String = String::from("1");
for _ in 0..1 {
let _actual = debug_assert_ge!(a, b);
let _expect = ();
}
}
#[test]
fn eq() {
let a: String = String::from("1");
let b: String = String::from("1");
for _ in 0..1 {
let _actual = debug_assert_ge!(a, b);
let _expect = ();
}
}
#[test]
fn lt() {
let a: String = String::from("1");
let b: String = String::from("2");
let result = panic::catch_unwind(|| {
let _actual = debug_assert_ge!(a, b);
});
let message = concat!(
"assertion failed: `assert_ge!(a, b)`\n",
"https://docs.rs/assertables/9.9.0/assertables/macro.assert_ge.html\n",
" a label: `a`,\n",
" a debug: `\"1\"`,\n",
" b label: `b`,\n",
" b debug: `\"2\"`",
);
assert_eq!(
result
.unwrap_err()
.downcast::<String>()
.unwrap()
.to_string(),
message
);
}
}
}