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

Changelog

0.3.0

Features

  • a jobserver filepath can also be configured by the PYTEST_JOBSERVER environment variable

0.2.2

Bugfixes

  • move jobserver status on startup to official pytest_report_header hook

0.2.1

Bugfixes

  • remove pytest-xdist from runtime dependencies

0.2.0

Features

  • can run against a jobserver specified with make environment variables
    • note that this will deliberately not work when also using pytest-xdist

0.1.1

Bugfixes

  • fix setup.py package metadata

0.1.0

Features

  • can run against a jobserver specified at the cli

TODO

  • run against cli jobserver
  • integrate with Make jobserver from environment variables
  • factor out creation of jobservers to seperate python package

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-0.3.0.tar.gz (7.1 kB view details)

Uploaded Source

Built Distribution

pytest_jobserver-0.3.0-py2.py3-none-any.whl (7.1 kB view details)

Uploaded Python 2Python 3

File details

Details for the file pytest-jobserver-0.3.0.tar.gz.

File metadata

  • Download URL: pytest-jobserver-0.3.0.tar.gz
  • Upload date:
  • Size: 7.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.3

File hashes

Hashes for pytest-jobserver-0.3.0.tar.gz
Algorithm Hash digest
SHA256 b8e007f420bd1eb7874265233b290062c245453fe55f5681c4efdef74eb5ecc3
MD5 28e277c3700ccfd0ca7e4539d6692140
BLAKE2b-256 0b490f9e938904a5570ab0d7dd6eb0467c16d30829ec3012c3c0c8a2f1016ef2

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pytest_jobserver-0.3.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 7.1 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.3

File hashes

Hashes for pytest_jobserver-0.3.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 3776c55010e42ae7d0ed72dbe0cd4d50fc1064e0e6b2d00455ecacae1b269b9d
MD5 3d37f155a7569012fdb6847756ccacc8
BLAKE2b-256 39b7984857b83c93ca614c474dc36be02231b22cab2c2d49d77e3aad8787e931

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