Security News
Research
Data Theft Repackaged: A Case Study in Malicious Wrapper Packages on npm
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
.. image:: https://img.shields.io/pypi/v/pytest-pyvista.svg?color=orange&label=pypi&logo=python&logoColor=white :target: https://pypi.org/project/pytest-pyvista :alt: PyPI version
.. image:: https://img.shields.io/conda/vn/conda-forge/pytest-pyvista?color=orange&label=conda-forge&logo=conda-forge&logoColor=white :target: https://anaconda.org/conda-forge/pytest-pyvista :alt: conda-forge version
.. image:: https://img.shields.io/pypi/pyversions/pytest-pyvista.svg?color=orange&logo=python&label=python&logoColor=white :target: https://pypi.org/project/pytest-pyvista :alt: Python versions
.. image:: https://github.com/pyvista/pytest-pyvista/actions/workflows/ci_cd.yml/badge.svg :target: https://github.com/pyvista/pytest-pyvista/actions/workflows/ci_cd.yml :alt: GitHub Actions: Unit Testing and Deployment
Plugin to test PyVista plot outputs.
This pytest
_ plugin was generated with Cookiecutter
_ along with
@hackebrot
's cookiecutter-pytest-plugin
template.
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.
You must have a Python version >= 3.8, as well as PyVista installed in your environment.
pyvista version >=0.37.0 and vtk version >=9.0.0 required.
You can install "pytest-pyvista" via pip
_ from PyPI
_::
$ pip install pytest-pyvista
Alternatively, you can also install via conda
_ or mamba
_ from conda-forge
_::
$ mamba install -c conda-forge pytest-pyvista
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. By default,
the verify_image_cache fixture should be used for each test for image comparison::
import pyvista as pv
pv.OFF_SCREEN = True
def test_succeeds(verify_image_cache):
pl = pyvista.Plotter()
pl.add_mesh(pyvista.Sphere(), show_edges=True)
pl.show()
If most tests utilize this functionality, possibly restricted to a module, a wrapped version could be used::
@pytest.fixture(autouse=True)
def wrapped_verify_image_cache(verify_image_cache):
return verify_image_cache
If you need to use any flag inside the tests, you can modify the
verify_image_cache
object in 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()
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 want to
temporarily ignore regression testing, e.g. on a particular CI action.
When using --fail_extra_image_cache
if there is an extra image in the
cache, it will report as an error.
--generated_image_dir <DIR>
dumps all generated test images into
--add_missing_images
adds any missing images from the test run to the cache.
--image_cache_dir <DIR>
sets the image cache dir. This will override any
configuration, see below.
--reset_only_failed
reset the image cache of the failed tests only.
These are attributes of verify_image_cache
. You can set them as True
if needed
in the beginning of your test function.
high_variance_test
: 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.
If using pyproject.toml
or any other
pytest configuration <https://docs.pytest.org/en/latest/reference/customize.html>
_
section, consider configuring your test directory location to
avoid passing command line arguments when calling pytest
, for example in
pyproject.toml
.. code::
[tool.pytest.ini_options] image_cache_dir = "tests/plotting/image_cache"
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.
Distributed under the terms of the MIT
_ license, pytest-pyvista
is free
and open source software.
If you encounter any problems, please file an issue
_ along with a detailed
description.
.. _Cookiecutter
: https://github.com/audreyr/cookiecutter
.. _@hackebrot
: https://github.com/hackebrot
.. _MIT
: http://opensource.org/licenses/MIT
.. _BSD-3
: http://opensource.org/licenses/BSD-3-Clause
.. _GNU GPL v3.0
: http://www.gnu.org/licenses/gpl-3.0.txt
.. _Apache Software License 2.0
: http://www.apache.org/licenses/LICENSE-2.0
.. _cookiecutter-pytest-plugin
: https://github.com/pytest-dev/cookiecutter-pytest-plugin
.. _file an issue
: https://github.com/pyvista/pytest-pyvista/issues
.. _pytest
: https://github.com/pytest-dev/pytest
.. _tox
: https://tox.readthedocs.io/en/latest/
.. _pip
: https://pypi.org/project/pip/
.. _PyPI
: https://pypi.org/project
.. _conda
: https://github.com/conda/conda
.. _mamba
: https://github.com/mamba-org/mamba
.. _conda-forge
: https://anaconda.org/conda-forge/pytest-pyvista
FAQs
Pytest-pyvista package
We found that pytest-pyvista demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Research
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Research
Security News
Attackers used a malicious npm package typosquatting a popular ESLint plugin to steal sensitive data, execute commands, and exploit developer systems.
Security News
The Ultralytics' PyPI Package was compromised four times in one weekend through GitHub Actions cache poisoning and failure to rotate previously compromised API tokens.