A macro for writing tests in a Behaviour Driven (BD) style. Inspired by Catch2.
tokio::test
(and other test attributes)```rust use beady::scenario;
fn pushinganelementtoavec() { #[given(anempty_vec)] { let mut vec = vec![];
#[when(an_element_is_pushed_to_the_vec)] {
vec.push(7);
#[then(the_vec_should_have_one_element)] {
assert_eq!(vec.len(), 1);
#[and_then(that_element_should_be_the_pushed_value)] {
assert_eq!(vec[0], 7);
}
}
#[and_when(the_vec_is_cleared)] {
vec.clear();
#[then(the_vec_should_be_empty)] {
assert!(vec.is_empty());
}
}
}
}
} ```
Running cargo test -- --nocapture
will output the following:
```shell Running tests/basic.rs (target/debug/deps/basic-818c7ee31bf8afc8)
Scenario: pushing an element to a vec Given: an empty vec When: an element is pushed to the vec
Scenario: pushing an element to a vec Given: an empty vec When: an element is pushed to the vec and: the vec is cleared
Scenario: pushing an element to a vec Given: an empty vec When: an element is pushed to the vec Then: the vec should have one element
test pushinganelementtoavec::given::anemptyvec::when::anelementispushedtothevec::then::thevecshouldhaveoneelement ... ok test pushinganelementtoavec::given::anemptyvec::when::anelementispushedtothevec::and::theveciscleared::then::thevecshouldbeempty ... ok test pushinganelementtoavec::given::anemptyvec::when::anelementispushedtothevec::then::thatelementshouldbethepushed_value ... ok
test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 3 filtered out; finished in 0.00s ```
Inspired by the BDD-style test cases from Catch2, you can annotate a function with #[scenario]
to make it a test, and then use the #[given]
, #[when]
, and #[then]
attributes to describe the test. Dependent clauses can be specified with the #[and_given]
, #[and_when]
, and #[and_then]
attributes.
#[scenario]
By default the #[scenario]
attribute will generate tests like:
```rust
fn foo() { ... } ```
If you want to use another test attribute you can specifiy it after the #[scenario]
attribute like so:
```rust
async fn my_scenario() { ... } ```
Which will generate tests like:
```rust
async fn foo() { ... } ```