Skip to main content

Fixtures for seeding tests and making randomness reproducible

Project description

pytest-rng

pytest-rng provides fixtures for ensuring “randomness” in your tests is reproducible from one run to the next. It also allows the seed for all tests to be changed if requested, to help ensure that test successes are not dependent on particular random number seeds.

  • Use the rng fixture to get a pre-seeded random number generator (RNG) that exposes NumPy’s ~numpy.random.mtrand.RandomState interface.

  • Use the seed fixture to get an integer seed that can be used to initialize your own RNG.

The following example prints the same four random numbers every time the test is run.

import numpy as np

def test_rectification(rng, seed):
    print(rng.uniform(-1, 1, size=3))
    print(seed)

To use these fixtures, install with

pip install pytest-rng

Once installed, you can use these fixtures like any other fixture: add rng or seed to the arguments of a test function or class.

Seed generation

For the seed fixture, we generate a seed by doing the following:

  1. Concatenate the test’s nodeid and a salt value, if provided.

  2. Hash that string to yield an integer seed.

For the rng fixture, we also add the string "rng" to the salt value before generating the seed as above. The seed is used to instantiate a ~numpy.random.mtrand.RandomState, which is returned.

salt

salt is a string that is added to the test’s nodeid in order to change the seed for all tests. It is advantageous to change seeds regularly to ensure that your test suite is robust to different seeds.

The salt value can be specified in a configuration file like setup.cfg or pytest.ini.

[tool:pytest]

rng_salt = v0.3.0

The salt value can also be specified through the command line.

pytest --rng-salt "v0.4.0"

The salt value passed through the command line takes precedence over the value set in the configuration file so that you can change seeds on-the-fly.


See the full documentation for more details.

Release History

1.0.0 (August 8, 2019)

Initial release of pytest-rng! Thanks to all of the contributors for making this possible!

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-rng-1.0.0.tar.gz (14.8 kB view details)

Uploaded Source

Built Distribution

pytest_rng-1.0.0-py3-none-any.whl (8.0 kB view details)

Uploaded Python 3

File details

Details for the file pytest-rng-1.0.0.tar.gz.

File metadata

  • Download URL: pytest-rng-1.0.0.tar.gz
  • Upload date:
  • Size: 14.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.33.0 CPython/3.6.3

File hashes

Hashes for pytest-rng-1.0.0.tar.gz
Algorithm Hash digest
SHA256 9d9ee96557246756072133ff9b990588f28f12d3e80357cad959ef0b05aed9fa
MD5 da285194851f709b2287e3e824711319
BLAKE2b-256 e1b711c928ffabbb79d86cc120b9b67b74c2ac0d132b3ea19f14024f7f0a0e4c

See more details on using hashes here.

File details

Details for the file pytest_rng-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: pytest_rng-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 8.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.33.0 CPython/3.6.3

File hashes

Hashes for pytest_rng-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 346e76a34f19c1f70e1059567460df9edf34aa6b41441c8707bf9ed40446b9c7
MD5 13aa90963c2a02a711dcdd7260e8e447
BLAKE2b-256 ac6640c88e87c8731d96bb2f9a49329785d24236debb9685f6aaccc52536e697

See more details on using hashes here.

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