Cucumber testing framework for Rust

crates.io Rust 1.70+ Unsafe Forbidden
CI Rust docs

An implementation of the [Cucumber] testing framework for Rust. Fully native, no external test runners or dependencies.

Usage

Describe testing scenarios in .feature files: ```gherkin Feature: Eating too much cucumbers may not be good for you

Scenario: Eating a few isn't a problem Given Alice is hungry When she eats 3 cucumbers Then she is full ```

Implement World trait and describe steps: ```rust use std::time::Duration;

use cucumber::{given, then, when, World as _}; use tokio::time::sleep;

[derive(cucumber::World, Debug, Default)]

struct World { user: Option, capacity: usize, }

[given(expr = "{word} is hungry")] // Cucumber Expression

async fn someoneishungry(w: &mut World, user: String) { sleep(Duration::from_secs(2)).await;

w.user = Some(user);

}

[when(regex = r"^(?:he|she|they) eats? (\d+) cucumbers?$")]

async fn eatcucumbers(w: &mut World, count: usize) { sleep(Duration::fromsecs(2)).await;

w.capacity += count;

assert!(w.capacity < 4, "{} exploded!", w.user.as_ref().unwrap());

}

[then("she is full")]

async fn isfull(w: &mut World) { sleep(Duration::fromsecs(2)).await;

assert_eq!(w.capacity, 3, "{} isn't full!", w.user.as_ref().unwrap());

}

[tokio::main]

async fn main() { World::run("tests/features/readme").await; } ```

Add test to Cargo.toml: toml [[test]] name = "readme" harness = false # allows Cucumber to print output instead of libtest

For more examples check out the Book (current | edge).

Cargo features

Supporting crates

The full gamut of Cucumber's [Gherkin] language is implemented by the gherkin crate. Most features of the [Gherkin] language are parsed already and accessible via the relevant structs.

Known issues

License

This project is licensed under either of

at your option.