A contract testing tool built in Rust using the filmReel format.
dark
:
``` Usage: dark [
] [-v] [--tls] [--protoTop-level command.
Options: -v, --verbose enable verbose output --tls enable TLS (not needed for HTTP/S) --proto pass proto files used for payload forming -H, --header fallback header passed to the specified protocol -C, --cut-out output of final cut file --help display usage information
Commands: version returns CARGOPKGVERSION take Takes a single frame, emitting the request then validating the returned response record Attempts to play through an entire Reel sequence running a take for every frame in the sequence
```
dark take
:
```
Usage: dark take -c
Takes a single frame, emitting the request then validating the returned response
Options: -c, --cut filepath of input cut file -o, --output output of take file --help display usage information
```
dark record
:
```
Usage: dark record
Attempts to play through an entire Reel sequence running a take for every frame in the sequence
Options: -c, --cut filepath of input cut file -o, --output output directory for successful takes -i, --interactive interactive frame sequence transitions --help display usage information
```
0.2
:${lowercase}
variables will only be kept around for the duration of the frame0.2.1
:${_HIDDEN}
dark version
commanddark
command to be shared across subcommands```sh
dark record ./reelpath reelname -c ./reelname.cut.json \ <(sops -d --extract '["KEYNAME"]' path/to/myfile.enc.json)
dark -v record -i ./testdata post -c ./testdata/post.cut.json \ <(echo '{"new":"value"}') <(echo '{"newer": "value", "new":"overridden"}') ```
```sh
dark -C >(jq .IP) take ./testdata/post.01s.body.fr.json --cut ./testdata/post.cut.json ```