Skip to main content

Pytest-pyvista package

Project description

PyPI version Python versions See Build Status on AppVeyor

Plugin to test PyVista plot outputs.


This pytest plugin was generated with Cookiecutter along with @hackebrot’s cookiecutter-pytest-plugin template.

Features

This plugin facilitates the comparison of the images produced by PyVista. It generates a cache of images from the tests, using the PyVista plotting function in its first execution. Then, further executions will compare its results against this cache, so if there are any changes in the code that break the image generation, the comparison against the cache will notice it. Note that there is an error tolerance in the comparison, so minor differences won’t fail.

Requirements

You must have a Python version greater than 3.7, as well as PyVista installed in your environment.

Installation

You can install “pytest-pyvista” via pip from PyPI:

$ pip install pytest-pyvista

Usage

Once installed, you only need to use the command pl.show() in your test. The plugin will automatically manage the cache generation if it does not exist, and the image comparison itself. Make sure you enable pv.OFF_SCREEN when loading PyVista, so the pl.show() doesn’t pop up any window while testing:

import pyvista as pv
pv.OFF_SCREEN = True
def test_succeeds():
    pl = pyvista.Plotter()
    pl.add_mesh(pyvista.Sphere(), show_edges=True)
    pl.show()

If you need to use any flag inside the tests, you need to use the verify_image_cache fixture as a parameter to the test:

import pyvista as pv
pv.OFF_SCREEN = True
def test_succeeds(verify_image_cache):
    verify_image_cache.windows_skip_image_cache = True
    pl = pyvista.Plotter()
    pl.add_mesh(pyvista.Sphere(), show_edges=True)
    pl.show()

Global flags

These are the flags you can use when calling pytest in the command line:

  • --reset_image_cache creates a new image for each test in tests/plotting/test_plotting.py and is not recommended except for testing or for potentially a major or minor release.

  • You can use --ignore_image_cache if you are running on Linux and want to temporarily ignore regression testing. Realize that regression testing will still occur on our CI testing.

  • When using --fail_extra_image_cache if there is an extra image in the cache, it will report as an error.

Test specific flags

These are attributes of verify_image_cache. You can set them as True if needed in the beginning of your test function.

  • high_variance_tests: If necessary, the threshold for determining if a test will pass or not is incremented to another predetermined threshold. This is currently done due to the use of an unstable version of VTK, in stable versions this shouldn’t be necessary.

  • windows_skip_image_cache: For test where the plotting in Windows is different from MacOS/Linux.

  • macos_skip_image_cache: For test where the plotting in MacOS is different from Windows/Linux.

  • skip: If you have a test that plots a figure, but you don’t want to compare its output against the cache, you can skip it with this flag.

Contributing

Contributions are always welcome. Tests can be run with tox, please ensure the coverage at least stays the same before you submit a pull request.

License

Distributed under the terms of the MIT license, pytest-pyvista is free and open source software.

Issues

If you encounter any problems, please file an issue along with a detailed description.

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_pyvista-0.1.2.tar.gz (5.4 kB view details)

Uploaded Source

Built Distribution

pytest_pyvista-0.1.2-py2.py3-none-any.whl (6.3 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file pytest_pyvista-0.1.2.tar.gz.

File metadata

  • Download URL: pytest_pyvista-0.1.2.tar.gz
  • Upload date:
  • Size: 5.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for pytest_pyvista-0.1.2.tar.gz
Algorithm Hash digest
SHA256 b07643a5a46e1a6d8b75605a5bd24cb5add23252c620e0b51c45ce33a919fa8d
MD5 b6206e999f32026605d8712a3dd84744
BLAKE2b-256 4376eb8e8cd943bc4c48b20f7fbb16f4d5326cc71a3775fdcbf13e9034f0cc64

See more details on using hashes here.

Provenance

File details

Details for the file pytest_pyvista-0.1.2-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_pyvista-0.1.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 5eb3bcccc7fc2ea5d0e426262b66bd6958e267946d984c08e2fd1d33a318a2b8
MD5 11bd7c15525efd43f246b50483737a90
BLAKE2b-256 f3540a3542b4a50b7f9e807d88bfe24d2c181a68624816ec6a39b5b0910a05f9

See more details on using hashes here.

Provenance

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