42 releases (26 stable)

2.0.16 Aug 9, 2024
2.0.15 Jul 25, 2024
2.0.14 Feb 19, 2024
2.0.12 Jul 14, 2023
0.6.0 Jul 19, 2018

#17 in Testing

Download history 272289/week @ 2024-09-21 280705/week @ 2024-09-28 327944/week @ 2024-10-05 310656/week @ 2024-10-12 333506/week @ 2024-10-19 334658/week @ 2024-10-26 333957/week @ 2024-11-02 321047/week @ 2024-11-09 290415/week @ 2024-11-16 230017/week @ 2024-11-23 231472/week @ 2024-11-30 338251/week @ 2024-12-07 275700/week @ 2024-12-14 106933/week @ 2024-12-21 170471/week @ 2024-12-28 257218/week @ 2025-01-04

867,451 downloads per month
Used in 1,533 crates (1,468 directly)

MIT/Apache

89KB
1.5K SLoC

assert_cmd

Assert process::Command - Easy command initialization and assertions.

Documentation License Crates Status

assert_cmd aims to simplify the process for doing integration testing of CLIs, including:

  • Finding your crate's binary to test
  • Assert on the result of your program's run.

Example

Here's a trivial example:

use assert_cmd::Command;

let mut cmd = Command::cargo_bin("bin_fixture").unwrap();
cmd.assert().success();

See the docs for more.

Relevant crates

Other crates that might be useful in testing command line programs.

  • escargot for more control over configuring the crate's binary.
  • duct for orchestrating multiple processes.
  • rexpect for testing interactive programs.
  • assert_fs for filesystem fixtures and assertions.
    • or tempfile for scratchpad directories.
  • dir-diff for testing file side-effects.
  • cross for cross-platform testing.

License

Licensed under either of

at your option.

Testimonials

fitzgen

assert_cmd is just such a pleasure to use every single time, I fall in love all over again

bravo bravo WG-cli

passcod

Running commands and dealing with output can be complex in many many ways, so assert_cmd smoothing that is excellent, very much welcome, and improves ergonomics significantly.

volks73

I have used [assert_cmd] in other projects and I am extremely pleased with it

coreyja

[assert_cmd] pretty much IS my testing strategy so far, though my app under test is pretty small.

This library has made it really easy to add some test coverage to my project, even when I am just learning how to write Rust!

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~0.7–1MB
~15K SLoC