datatest-stable
is a very simple test harness intended to write data-driven tests, where
individual test cases are specified as files and not as code. Given:
* a test my_test
that accepts a path as input
* a directory to look for files in
* a pattern to match files on
datatest-stable
will call the my_test
function once per matching file in the directory.
datatest-stable
works with cargo nextest, and is part of the nextest-rs
organization on GitHub.
harness = false
in Cargo.toml
:toml
[[test]]
name = "<test target name>"
harness = false
datatest_stable::harness!(testfn, root, pattern)
macro with the following
parameters:testfn
- The test function to be executed on each matching input. This function must have
the type fn(&Utf8Path) -> datatest_stable::Result<()>
. (Utf8Path
is part of the
camino
library.)root
- The path to the root directory where the input files (fixtures) live. This path is
relative to the root of the crate.pattern
- the regex used to match against and select each file to be tested.The three parameters can be repeated if you have multiple sets of data-driven tests to be run:
datatest_stable::harness!(testfn1, root1, pattern1, testfn2, root2, pattern2)
This is an example test. Use it with harness = false
.
```rust use datatest_stable::Utf8Path;
fn mytest(path: &Utf8Path) -> datateststable::Result<()> { // ... write test here
Ok(())
}
datateststable::harness!(mytest, "path/to/fixtures", r"^./"); ```
The minimum supported Rust version is Rust 1.60. MSRV bumps may be accompanied by a minor version update; at any time, at least the last 3 stable versions of Rust will be supported.
datatest
: the original inspiration for this crate, with
a better UI and more features but targeting nightly RustThis project is available under the terms of either the Apache 2.0 license or the MIT license.