Skip to main content

Limit parallel tests with posix jobserver.

Project description

pytest-jobserver

PyPI version Python versions Code coverage Build status

Limit parallel tests with posix jobserver.

Installation

Install with pip:

pip install pytest-jobserver

The plugin officially supports Python >= 3.6 on a Linux OS. You may find other Python 3 versions/MacOS work as well.

Usage

The plugin uses a POSIX jobserver to manage parallel test loading.

Pass the --jobserver argument with a path, where this path points to a named pipe acting as a jobserver. You should probably also use pytest-xdist to enable parallelism in the first place:

pytest -n4 --jobserver /opt/jobserver

You can also pass this filepath via the PYTEST_JOBSERVER environment variable.

make

The plugin can also listen for an existing jobserver as created by make. If a jobserver is not configured by filepath, pytest-jobserver will check the following environment variables in order:

  • CARGO_MAKEFLAGS
  • MAKEFLAGS
  • MFLAGS

Please note: it is not possible to use one of these environment variables with pytest-xdist. The execnet protocol used by xdist does not support passing file descriptors to remote child processes.

Implementation

This plugin wraps pytest's call to pytest_runtest_protocol, which is called to actually run a collected item on the worker node.

Development

See the top level Makefile and .circleci/config.yml for the development flow. But in essence:

  • make dev to install deps
  • make lint to lint code (will change files)
  • make test to run lint/unit tests
  • make integrate to run integration tests

Release

Maintainers can cut a new release by pushing a vX.Y.Z tag to the repo.

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_jobserver-1.1.0.tar.gz (11.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pytest_jobserver-1.1.0-py2.py3-none-any.whl (12.5 kB view details)

Uploaded Python 2Python 3

File details

Details for the file pytest_jobserver-1.1.0.tar.gz.

File metadata

  • Download URL: pytest_jobserver-1.1.0.tar.gz
  • Upload date:
  • Size: 11.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pytest_jobserver-1.1.0.tar.gz
Algorithm Hash digest
SHA256 235d1101b6a3defd2d36223ff221aa9c2acc9e32233c7cda3c8320a269452078
MD5 3c7ce07c927a96713e001da34bbb09ca
BLAKE2b-256 6df474470708b7e0600610999b5ff89c61bfe72a2e47173d4de44e4f6ad55a0d

See more details on using hashes here.

Provenance

The following attestation bundles were made for pytest_jobserver-1.1.0.tar.gz:

Publisher: publish.yml on tommilligan/pytest-jobserver

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pytest_jobserver-1.1.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_jobserver-1.1.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 4b5521e3204f01eba1e2b79407cf3df41397115534a014ca45f769e120d42a10
MD5 b760b82671b280ffa8e724e4132d97b7
BLAKE2b-256 e5b048a7165fa51d3c3012ec108e37c759518e431853fc30daed24b377ce3c51

See more details on using hashes here.

Provenance

The following attestation bundles were made for pytest_jobserver-1.1.0-py2.py3-none-any.whl:

Publisher: publish.yml on tommilligan/pytest-jobserver

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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