GitXplorerGitXplorer
D

test-exec

public
7 stars
0 forks
0 issues

Commits

List of commits on branch master.
Verified
df018e169023c238ca2a990747ae5fe329154860

Add syntax highlighting in README.md

DDraphar committed 5 years ago
Unverified
bda070561b13c37bcff888bcc64cdc97b0526f1e

Merge branch 'master' of https://github.com/Draphar/test-exec

DDraphar committed 6 years ago
Unverified
a33e5cd41439c01171d839ff87d8f507bfd4b70e

Updated documentation

DDraphar committed 6 years ago
Verified
ee31473b41778c4bedcc56c17ee7461531d0bce9

Update .appveyor.yml

DDraphar committed 6 years ago
Unverified
e6865dfba602446c6761fde7c72436a204daa27c

Version 0.1.0

DDraphar committed 6 years ago

README

The README file for this repository.

test-exec - Test command line applications comfortably

travis-badge appveyor-badge crates.io-badge license-badge

Cargo.toml

[dev-dependencies]
test-exec = "0.1.0

test-exec is a Rust testing library to help you at testing the output of a command line application. It aims for maximum comfort, and wants to prevent messing around with Command.

The main functionality is the exec macro: it executes your command, verifies the output and is highly customizable.

A few previews, assuming you have a binary target called my_bin:

  • minimum configuration: exec!("my_bin");

  • (almost) maximum configuration:

let output = exec!{
    "my_bin",
    args: ["-p", "/"],
    cwd: "/tmp",
    env: {
        THREADS: "4"
    },
    stdin: b"show-hidden",
    timeout: 60000,
    log: true,

    code: 0,
    stdout: b"Started program...\nDone.\n",
    stderr: []
};

// `output` can be used here like a normal process::Output

If the program exits with any other code than 0, a different stdout or stderr, or is running longer than 60 seconds, a panic occurs.

As you might have noticed, the bin target is added to the PATH automatically.

See the documentation for more.

Features

  • set the arguments, current working directory, environment and stdin with one line each
  • exit code, stdout, stderr and optionally termination signal comparison directly through the macro
  • automatic availability of bin targets
  • all output of the program is returned for additional use

Installation and usage

As test-exec is a testing library, it should be added to the dev-dependencies:

[dev-dependencies]
test-exec = "0.1.0

And it can be used in code by doing

#[macro_use]
extern crate test_exec;

For instance in an integration test for a binary called my_pwd, whichs prints the current working directory

tests/bin.rs

#[macro_use]
extern crate test_exec;

#[test]
fn test_program_output() {
    exec!{
        "my_pwd",
        cwd: "/",
        log: true,
        
        code: 0,
        stdout: b"/\n",
        stderr: []
    };
}