8 releases (breaking)

0.8.0 Jul 20, 2023
0.7.0 May 9, 2023
0.6.0 Jun 29, 2021
0.5.0 Jan 19, 2021
0.1.0 May 29, 2020

#65 in Testing

Download history 9465/week @ 2024-03-14 10143/week @ 2024-03-21 8232/week @ 2024-03-28 10615/week @ 2024-04-04 9149/week @ 2024-04-11 14612/week @ 2024-04-18 17070/week @ 2024-04-25 15269/week @ 2024-05-02 17844/week @ 2024-05-09 19575/week @ 2024-05-16 20158/week @ 2024-05-23 23203/week @ 2024-05-30 19042/week @ 2024-06-06 17346/week @ 2024-06-13 20348/week @ 2024-06-20 17376/week @ 2024-06-27

78,639 downloads per month
Used in 5 crates

Apache-2.0

29KB
670 lines

datadriven

datadriven is a port of the Go datadriven library originally written by Andy Kimball.

It's a tool for writing table-driven tests in Rust, with rewrite support.

Usage

A test file looks like this:

eval
1 + 1
----
2
  • eval here is the directive, which describes what kind of test is being run.
  • 1 + 1 is the input.
  • ---- is the separator between input and output.
  • 2 is the expected output.

If this file is in tests/testdata relative to the crate root, it can be processed by having a test like this:

use datadriven::walk;

#[cfg(test)]
mod tests {
    use super::*;

    #[test]
    fn run() {
        walk("tests/testdata", |f| {
            f.run(|test_case| -> String {
                // Do something with `s` and return it.
                test_case.input.to_string()

                // Can access the directive via `test_case.directive`.
            })
        });
    }
}

The closure passed to walk will be evaluated for each file in the given directory (or just a single file), and the closure passed to f.run will be evaluated for each test case in that file. Test cases can share state by closing over values in the walk closure.

Rewriting

If the env var REWRITE is set, the results will all be rewritten to match the expectation.

Running specific tests

If the env var RUN is set, its value will be appended to the directory passed to walk.

Multiline output

If the output for a test case has blank lines, that can be expressed by enclosing the entire output in a double-up of ----:

render
foo\n\nbar
----
----
foo

bar
----
----

Arguments

Strings can be passed as arguments to tests in a directive line.

render a=world
hello $a
----
hello world

Arguments can be accessed from the args field on TestCase.

They are actually Vecs of strings:

render a=(one,two)

will have the vector

vec!["one".to_string(), "two".to_string()]

Dependencies

~0.3–0.9MB
~20K SLoC