[]
(https://travis-ci.org/zummenix/expectest)
Crate provides matchers and matcher functions for unit testing. Inspired by Nimble for Swift.
Using this library you will receive helpful messages with data that is used in test case, example:
rust,should_panic
let result = vec![1, 2, 2];
expect!(result).to(be_equal_to([1, 2, 3]));
Test fails and gives us a message:
expected to be equal to <[1, 2, 3]>, got <[1, 2, 2]>
In your Cargo.toml:
toml
[dev-dependencies]
expectest = "0.6.0"
Note: If you're using nightly rust you can use
nightly
feature:toml [dev-dependencies] expectest = { version = "0.6.0", features = ["nightly"] }
In this case failure messages will be integrated in rust's standard panic message.
In your crate: ```rust,ignore
extern crate expectest; ```
You can export all needed functions and types from prelude
module:
rust,ignore
use expectest::prelude::*;
Check out the tests directory!
Take a look at change log.
Use basic syntax to express expectations:
rust,ignore
expect!(...).to(...);
expect!(...).to_not(...);
expect!(...).not_to(...);
Note:
expect!
macro provides a file name and a line number for a failed test case.
For types that implement the PartialEq
trait:
rust
expect!("hello".to_string()).to(be_equal_to("hello"));
There is a way to check if two float numbers are close each other:
rust
expect!(12.1_f64).to(be_close_to(12.0).delta(0.1));
With default delta
equal to 0.001
:
rust
expect!(12.001_f64).to(be_close_to(12.0));
For types that implement the PartialOrd
trait:
rust
expect!(1).to(be_greater_than(0));
Use any of the following matchers: be_less_than
, be_less_or_equal_to
, be_greater_than
, be_greater_or_equal_to
There are matchers for the Option<T>
type:
rust
expect!(Some(9)).to(be_some().value(9));
Use any of the following matchers: be_some
, be_none
There are matchers for the Result<T, E>
type:
rust
expect!("4".parse::<u32>()).to(be_ok().value(4));
Use any of the following matchers: be_ok
, be_err
There is be_empty
matcher for types that implement Iterator + Clone
trait:
rust
expect!("".chars()).to(be_empty());
There is have_count
matcher for types that implement Iterator + Clone
trait:
rust
expect!("abc".chars()).to(have_count(3));
rust
expect!(9 == 9).to(be_true());
Use any of the following matchers: be_true
, be_false
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
Examples in this document were tested using skeptic with the following template:
```rust,skeptic-template
extern crate expectest;
use expectest::prelude::*;
fn main() {{ {} }} ```