14 releases

new 0.2.10 Dec 8, 2024
0.2.9 Apr 26, 2024
0.2.3 Aug 29, 2023
0.1.3 Aug 15, 2022
0.1.1 Apr 17, 2021

#29 in Testing

Download history 10405/week @ 2024-08-21 9343/week @ 2024-08-28 11165/week @ 2024-09-04 11425/week @ 2024-09-11 10284/week @ 2024-09-18 12970/week @ 2024-09-25 12313/week @ 2024-10-02 11565/week @ 2024-10-09 10788/week @ 2024-10-16 10198/week @ 2024-10-23 10361/week @ 2024-10-30 9161/week @ 2024-11-06 12301/week @ 2024-11-13 11610/week @ 2024-11-20 8303/week @ 2024-11-27 8920/week @ 2024-12-04

43,137 downloads per month
Used in 29 crates

MIT/Apache

32KB
478 lines

datatest-stable

datatest-stable on crates.io Documentation (latest release) Documentation (main) License License

datatest-stable is a test harness intended to write file-driven or data-driven tests, where individual test cases are specified as files and not as code.

Given:

  • a test my_test that accepts a path, and optionally the contents 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.

Usage

  1. Configure the test target by setting harness = false in Cargo.toml:
[[test]]
name = "<test target name>"
harness = false
  1. Call the datatest_stable::harness!(testfn, root, pattern) macro with the following parameters:
  • testfn - The test function to be executed on each matching input. This function can be one of:
    • fn(&Path) -> datatest_stable::Result<()>
    • fn(&Utf8Path) -> datatest_stable::Result<()> (Utf8Path is part of the camino library, and is re-exported here for convenience.)
    • fn(&P, String) -> datatest_stable::Result<()> where P is Path or Utf8Path. If the extra String parameter is specified, the contents of the file will be loaded and passed in as a string (erroring out if that failed).
    • fn(&P, Vec<u8>) -> datatest_stable::Result<()> where P is Path or Utf8Path. If the extra Vec<u8> parameter is specified, the contents of the file will be loaded and passed in as a Vec<u8> (erroring out if that failed).
  • root - The path to the root directory where the input files (fixtures) live. This path is relative to the root of the crate (the directory where the crate's Cargo.toml is located).
  • pattern - a regex used to match against and select each file to be tested. Extended regexes with lookaround and backtracking are supported via the fancy_regex crate.

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).

Examples

This is an example test. Use it with harness = false.

use datatest_stable::Utf8Path;
use std::path::Path;

fn my_test(path: &Path) -> datatest_stable::Result<()> {
    // ... write test here

    Ok(())
}

fn my_test_utf8(path: &Utf8Path, contents: String) -> datatest_stable::Result<()> {
    // ... write test here

    Ok(())
}

datatest_stable::harness!(
    my_test, "path/to/fixtures", r"^.*/*",
    my_test_utf8, "path/to/fixtures", r"^.*/*",
);

Minimum supported Rust version (MSRV)

The minimum supported Rust version is Rust 1.72. MSRV bumps may be accompanied by a minor version update; at any time, Rust versions from at least the last 6 months are supported.

See also

License

This project is available under the terms of either the Apache 2.0 license or the MIT license.

Dependencies

~4–12MB
~132K SLoC