Skip to main content

Pytest plugin providing a Rich based reporter.

Project description

resources/demo1.png resources/demo2.png

Pytest-richer

A replacement progress and reporting front end for pytest, using Rich to provide enhanced output.

Status

The most recent release is 0.1.1.

This is alpha software. Probably quite robust alpha software (I use it all the time), but there will be pytest options that cause it to fail or behave weirdly.

Please try it and raise issues if you have problems. I intend to check daily and fix things quickly.

Getting started

  • Install from PyPi using pip, for example:

    python -m pip install --user pytest-richer
  • Clone this repository and install using pip, For example:

    python -m pip install --user pytest-richer

Using

Use the --rich command option when you invoke pytest.

See --help for additional rich- options.

Features

  • Detailed per-file/per directory progress display.

    • Per-file view is used for preference.

    • Per directory view is used when the number of files becomes unwieldy.

  • Works very well with pytest-xdist

    • When pytest-xdist is enabled, the progress display stays the same, rather than switching to a simplified form.

    • Collection errors cause run to stop instead of being ignored.

    • Error reporting formatting is unaffected by pytest-xdist.

    • Order of error reports are not affected by pytest-xdist.

  • Rich is used to format the details of collection and test execution errors.

    • Arguably more human parseable error reports (at least I think so; suggestions for improvements welcome).

    • In particular, collection error reports are easier to read.

  • Additional information displayed.

    • pytest-xdist output displayed as part of progress display.

    • Slow setup and teardown phases are visible on the progress display.

    • Setup and teardown errors separately identified on the progress display and in the final summary.

    • Number of active pytest-xdist workers (parallel test count) shown.

Some other notable differences from the standard pytest reporter.

  • Collection error details are reported when the --no-summary option is used.

  • Tracebacks are not as compact when the --tb=short option is used. This may change in the future, but is currently not practicable.

  • Long tracebacks include context lines after the failure line. This may change in the future, but is currently not practicable.

  • Long tracebacks only show 3 lines of context before the failure line; pytest shows all preceding lines within the function.

There will undoubtedly be other differences and missing standard features at this stage. Please raise an issue for any problems.

Credits

This was inspired by pytest-rich.

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

pytest-richer-0.1.1.tar.gz (24.8 kB view hashes)

Uploaded Source

Built Distribution

pytest_richer-0.1.1-py3-none-any.whl (25.4 kB view hashes)

Uploaded Python 3

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