Skip to main content

Functional tests for command line applications

Project description

https://github.com/Nicoretti/prysk/actions/workflows/verifier.yaml/badge.svg https://coveralls.io/repos/github/Nicoretti/prysk/badge.svg?branch=master https://img.shields.io/badge/imports-isort-ef8336.svg https://img.shields.io/badge/code%20style-black-000000.svg https://img.shields.io/badge/pypi%20package-available-blue.svg https://img.shields.io/badge/docs-available-blue.svg

Prysk is a fork of the popular snapshot testing tool Cram. Even though Cram is pretty complete and mature for everyday use, Prysk want’s to continue pushing it’s development forward.

Prysk tests look like snippets of interactive shell sessions. Prysk runs each command and compares the command output in the test with the command’s actual output.

Here’s a snippet from Prysk’s own test suite:

Set up prysk alias and example tests:

  $ . "$TESTDIR"/setup.sh

Usage:

  $ prysk -h
  [Uu]sage: prysk \[OPTIONS\] TESTS\.\.\. (re)

  [Oo]ptions: (re)
    -h, --help          show this help message and exit
    -V, --version       show version information and exit
    -q, --quiet         don't print diffs
    -v, --verbose       show filenames and test status
    -i, --interactive   interactively merge changed test output
    -d, --debug         write script output directly to the terminal
    -y, --yes           answer yes to all questions
    -n, --no            answer no to all questions
    -E, --preserve-env  don't reset common environment variables
    --keep-tmpdir       keep temporary directories
    --shell=PATH        shell to use for running tests (default: /bin/sh)
    --shell-opts=OPTS   arguments to invoke shell with
    --indent=NUM        number of spaces to use for indentation (default: 2)
    --xunit-file=PATH   path to write xUnit XML output

The format in a nutshell:

  • Prysk tests use the .t file extension.

  • Lines beginning with two spaces, a dollar sign, and a space are run in the shell.

  • Lines beginning with two spaces, a greater than sign, and a space allow multi-line commands.

  • All other lines beginning with two spaces are considered command output.

  • Output lines ending with a space and the keyword (re) are matched as Perl-compatible regular expressions.

  • Lines ending with a space and the keyword (glob) are matched with a glob-like syntax. The only special characters supported are * and ?. Both characters can be escaped using \, and the backslash can be escaped itself.

  • Output lines ending with either of the above keywords are always first matched literally with actual command output.

  • Lines ending with a space and the keyword (no-eol) will match actual output that doesn’t end in a newline.

  • Actual output lines containing unprintable characters are escaped and suffixed with a space and the keyword (esc). Lines matching unprintable output must also contain the keyword.

  • Anything else is a comment.

Usage

Prysk will print a dot for each passing test. If a test fails, a unified context diff is printed showing the test’s expected output and the actual output. Skipped tests (empty tests and tests that exit with return code 80) are marked with s instead of a dot.

For example, if we run Prysk on its own example tests:

.s.!
--- examples/fail.t
+++ examples/fail.t.err
@@ -3,21 +3,22 @@
   $ echo 1
   1
   $ echo 1
-  2
+  1
   $ echo 1
   1

 Invalid regex:

   $ echo 1
-  +++ (re)
+  1

 Offset regular expression:

   $ printf 'foo\nbar\nbaz\n\n1\nA\n@\n'
   foo
+  bar
   baz

   \d (re)
   [A-Z] (re)
-  #
+  @
s.
# Ran 6 tests, 2 skipped, 1 failed.

Prysk will also write the test with its actual output to examples/fail.t.err, allowing you to use other diff tools. This file is automatically removed the next time the test passes.

When you’re first writing a test, you might just write the commands and run the test to see what happens. If you run Prysk with -i or --interactive, you’ll be prompted to merge the actual output back into the test. This makes it easy to quickly prototype new tests.

You can specify a default set of options by creating a .prysk file. For example:

[prysk]
verbose = True
indent = 4

Is the same as invoking Prysk with --verbose and --indent=4.

To change what configuration file Prysk loads, you can set the PRYSKRC environment variable. You can also specify command line options in the PRYSK environment variable.

Note that the following environment variables are reset before tests are run:

  • TMPDIR, TEMP, and TMP are set to the test runner’s tmp directory.

  • LANG, LC_ALL, and LANGUAGE are set to C.

  • TZ is set to GMT.

  • COLUMNS is set to 80. (Note: When using --shell=zsh, this cannot be reset. It will reflect the actual terminal’s width.)

  • CDPATH and GREP_OPTIONS are set to an empty string.

Prysk also provides the following environment variables to tests:

  • PRYSK_TEMP, set to the test runner’s temporary directory.

  • TESTDIR, set to the directory containing the test file.

  • TESTFILE, set to the basename of the current test file.

  • TESTSHELL, set to the value specified by --shell.

Also note that care should be taken with commands that close the test shell’s stdin. For example, if you’re trying to invoke ssh in a test, try adding the -n option to prevent it from closing stdin. Similarly, if you invoke a daemon process that inherits stdout and fails to close it, it may cause Prysk to hang while waiting for the test shell’s stdout to be fully closed.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

prysk-0.10.0.tar.gz (55.8 kB view details)

Uploaded Source

Built Distribution

prysk-0.10.0-py3-none-any.whl (70.5 kB view details)

Uploaded Python 3

File details

Details for the file prysk-0.10.0.tar.gz.

File metadata

  • Download URL: prysk-0.10.0.tar.gz
  • Upload date:
  • Size: 55.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.8 CPython/3.10.1 Linux/5.15.15-200.fc35.x86_64

File hashes

Hashes for prysk-0.10.0.tar.gz
Algorithm Hash digest
SHA256 026c655a7e4326ec716bc024c1c51caa258b042a6bb2c7cefde5dde5f7ce9914
MD5 52d6f152f1b733a9f6ad97bc4f1f9978
BLAKE2b-256 c25cc0cc8e80a589dd5801f01b20bda6c5253f2701701c5a29f79c7c9fdf5904

See more details on using hashes here.

File details

Details for the file prysk-0.10.0-py3-none-any.whl.

File metadata

  • Download URL: prysk-0.10.0-py3-none-any.whl
  • Upload date:
  • Size: 70.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.8 CPython/3.10.1 Linux/5.15.15-200.fc35.x86_64

File hashes

Hashes for prysk-0.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b0cc0b001b504ce019edb2a6f46c5515cde9c6455573f847c93490efab9e6345
MD5 986e8d923fed9ab5a7fd08c5e434dc7a
BLAKE2b-256 2debbbc82c6a4c3e3b5ccb582aa960c59309ecab2170768fe1130ecf8146237a

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page