Skip to main content

Run pytest tests in isolated subprocesses

Project description

pytest-isolate

Python package

PyPI - Version PyPI - Python Version

Isolate each test in a subprocess - pytest forked replacement, based on pytest-forked.

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

Features

  • Run each test in an forked, isolated subprocess
  • Captures stdout & stderr of crashing processes
  • Add Timeout to a forked test
  • Limit memory used by test
  • Limit CPU time used by test
  • Manage GPU resources with CUDA_VISIBLE_DEVICES
  • Plays nice with pytest-xdist
  • Shows warnings, even with xdist!
  • Create visual timeline of test execution (isolated or not)

Requirements

  • pytest

Optional Dependencies

For GPU resource management:

  • pynvml (optional, for automatic GPU detection)

Support

  • Operating Systems: Linux (tested), macOS (not tested but should work). Windows is not supported, and will probably not work as we are based on process forking.
  • Python Versions: 3.9, 3.10, 3.11, 3.12

Installation

You can install "pytest-isolate" via pip from PyPI

pip install pytest-isolate

For GPU resource management support:

pip install pytest-isolate[gpu]

Usage

pytest --isolate

To run every test in its own forked subprocess.

Or:

pytest --isolate-timeout 10 --isolate-mem-limit 1000000 --isolate-cpu-limit 10

To set a timeout to every test in addition to forking, and limit to 10 cpu seconds.

Or:

pytest --timeline

With possible combination of the above, to generate a timeline of test execution. The timeline can be viewed in chrome://tracing.

To disable the pulgin, you can use the --no-isolate option:

pytest --no-isolate

Note:

Since this plugin uses fork, it will not work on operating systems without fork support (e.g. Windows).

The flags --timeout or --forked will also be respected such that pytest-isolate is a drop-in replacement forked pytest forked and pytest timeout.

If pytest-forked or pytest-timeout are installed, then they will take precedence. Uninstall them to use pytest-isolate.

Unlike pytest-timeout, timeout in pytest-isolate is implemented by forking the test to a separate subprocess, and setting timeout for that subprocess.

Using the isolate marker

You can use a mark to isolate or time limit the memory and/or cpu usage test:

@pytest.mark.isolate(timeout=10, mem_limit=10**6, cpu_limit=10)
def test_something():
    pass

The isolate marker can also be used to request gpus for a test on a gpu machine:

# Request 2 GPUs for this test
@pytest.mark.isolate(resources={'gpu': 2})
def test_with_gpus():
    # The test will have CUDA_VISIBLE_DEVICES set to the allocated GPU IDs
    assert len(os.environ.get("CUDA_VISIBLE_DEVICES").split(",")) == 2

Configuration Options

The options can be set in an pytest configuration file, e.g:

[tool.pytest.ini_options]
isolate_timeout=10
isolate_mem_limit=1000000
isolate_cpu_limit=10

CUDA_VISIBLE_DEVICES Handling

If CUDA_VISIBLE_DEVICES is already set when pytest starts, the plugin will respect this setting and only allocate from the GPUs specified there. This works even without pynvml installed.

For example:

  • If CUDA_VISIBLE_DEVICES=0,1,2 is set, tests will only use GPUs 0, 1, and 2.
  • If CUDA_VISIBLE_DEVICES= is set (empty), no GPUs will be used.

Contributing

Contributions are very 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, pytest-isolate 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_isolate-0.0.12.tar.gz (14.6 kB view details)

Uploaded Source

Built Distribution

pytest_isolate-0.0.12-py3-none-any.whl (13.6 kB view details)

Uploaded Python 3

File details

Details for the file pytest_isolate-0.0.12.tar.gz.

File metadata

  • Download URL: pytest_isolate-0.0.12.tar.gz
  • Upload date:
  • Size: 14.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.23

File hashes

Hashes for pytest_isolate-0.0.12.tar.gz
Algorithm Hash digest
SHA256 2a421a8334e5d2fffe3b7475443c61616346759585f3b23de24c9d9a7784fa89
MD5 7b5edfbbf3e799059f45642b1b5785a1
BLAKE2b-256 2a83318942d7dfb65c02df433f95437cf58612ffcb8a8ec0a3a948c2bf5760ab

See more details on using hashes here.

File details

Details for the file pytest_isolate-0.0.12-py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_isolate-0.0.12-py3-none-any.whl
Algorithm Hash digest
SHA256 b39a109985bedd4d9e1cd9e4b84ff4b5e7cfa372b3d3e6b9bef89ff54015908f
MD5 4dd1b8e4dcf22347c800d7fecf62ca92
BLAKE2b-256 7fb6dd275b04a4c8488f23b532074e735c4131fac97fc21f8aa3481e3183f3ed

See more details on using hashes here.

Supported by

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