Expand description
§test_eq!
assert_eq!
-like macros that return a Result instead.
The primary use case is in writing parsers, where you want to check that magic values are correct and that values
are as expected. The macros are implemented using macro_rules
and should therefore not have a significant impact
on compile times.
§Usage
This crate contains two kinds of macros:
- Macros that check variables are as expected (
test_eq!
,test_any!
, …). - Macros that compose the test macros (
test_and!
andtest_or!
).
§Examples
use test_eq::{TestFailure, test_eq, test_and, test_or, test_any, test_ge};
pub fn parser() -> Result<(), TestFailure> {
let magic: u32 = todo!();
test_eq!(magic, 0xDEAD_BEEF)?;
let version: u8 = todo!();
test_any!(version, 1..4, "unsupported version found")?;
let field: String = todo!();
test_or!(test_ge!(field.len(), 8), test_eq!(field, "spam"))?;
let field2: u32 = todo!();
test_and!(
test_any!(field2, 42..=2048),
test_eq!(field2 % 2, 0),
"related field: {}", field
)?;
}
§Features
§line-info
Provide the location in the source file where the error happened. This feature is enabled by default.
This information is set at compile time and cannot be removed with debug=false
or strip=true
.
§Copyright
The implementation of these macros is based on the implementations of the assert*!
macros in the standard library.
The Rust standard library is dual-licensed under the MIT and Apache-2.0 licenses just like this library.
Macros§
- test_
and - Tests that both tests pass.
- test_
any - Tests that the left expression is any of the values in the right expression.
- test_eq
- Tests that two expressions are equal to each other (using
PartialEq
). - test_ge
- Tests that the left expression is greater or equal to the right expression (using
PartialOrd
). - test_le
- Tests that the left expression is smaller or equal to the right expression (using
PartialOrd
). - test_ne
- Tests that two expressions are not equal to each other (using
PartialEq
). - test_
not_ any - Tests that the expression is not any of the values in the right expression.
- test_or
- Tests that at least one test passes.
Structs§
- Test
Failure - An error returned when a test in one of the macros fails.