Skip to main content

Parallel unit test runner with coverage support

Project description

unittest-parallel

PyPI - Status PyPI GitHub PyPI - Python Version

unittest-parallel is a parallel unit test runner for Python with coverage support.

Run Tests in Parallel

To run tests in parallel with unittest-parallel, specify the directory containing your unit tests with the -s argument and your package's top-level directory using the -t argument:

unittest-parallel -t . -s tests

By default, unittest-parallel runs tests using all CPU cores.

Test Coverage

To run tests with coverage, add either the --coverage option (for line coverage) or the --coverage-branch for line and branch coverage.

unittest-parallel -t . -s tests --coverage-branch

Parallelism Level

By default, unittest-parallel runs test modules in parallel (--level=module). Here is the list of all parallelism options:

  • --level=module - Run test modules in parallel (default)

  • --level=class - Run test classes in parallel. Use this option if you have class fixtures.

  • --level=test - Run individual tests in parallel. Using this option will likely fail if you have any class or module fixtures.

Free-Threaded Python

By default, unittest-parallel uses a process pool to run tests in parallel. If you are using free-threaded Python, you can reduce test-running overhead by using the --thread argument to use a thread pool for parallelization. Note that if you use unittest.mock in your tests, --thread likely won't work since mocking modifies global state shared with all threads.

Speedup Potential

Generally speaking, unittest-parallel will run your unit tests faster by a factor of the number of CPU cores you have, as compared to unittest discover.

In other words, if you have 4 CPU cores, unittest-parallel will run your tests 4 times faster. If you have 8 CPU cores, it will run 8 times faster, and so on.

Note that you may see less benefit from unittest-parallel if your average test duration is short compared to the underlying cost of parallelization.

I/O-Bound Tests

If your tests are I/O-bound (e.g., call web services), you may benefit from using a higher number of test processes (-j). In the following case, the I/O-bound tests run 100 times faster.

unittest-parallel -j 100 -t . -s tests

Real-World Speedups

I wrote unittest-parallel for a large production backend API application with thousands of unit tests. As expected, unittest-parallel ran tests 4 times faster using 4 cores, compared to unittest discover.

A user reports that their tests ran 20 times faster on their development machine and 6 times faster on their test machine.

Another user reports that "it shaved 70% off the runtime of my painfully long integration tests."

Another user reports that "tests take 2x less times to run."

Usage

usage: unittest-parallel [-h] [-v] [-q] [-f] [-b] [-k TESTNAMEPATTERNS]
                         [-s START] [-p PATTERN] [-t TOP] [--runner RUNNER]
                         [--result RESULT] [-j COUNT]
                         [--level {module,class,test}]
                         [--disable-process-pooling] [--thread] [--coverage]
                         [--coverage-branch] [--coverage-rcfile RCFILE]
                         [--coverage-include PAT] [--coverage-omit PAT]
                         [--coverage-source SRC] [--coverage-html DIR]
                         [--coverage-xml FILE] [--coverage-fail-under MIN]

options:
  -h, --help            show this help message and exit
  -v, --verbose         Verbose output
  -q, --quiet           Quiet output
  -f, --failfast        Stop on first fail or error
  -b, --buffer          Buffer stdout and stderr during tests
  -k TESTNAMEPATTERNS   Only run tests which match the given substring
  -s, --start-directory START
                        Directory to start discovery ('.' default)
  -p, --pattern PATTERN
                        Pattern to match tests ('test*.py' default)
  -t, --top-level-directory TOP
                        Top level directory of project (defaults to start
                        directory)
  --runner RUNNER       Custom unittest runner class <module>.<class>
  --result RESULT       Custom unittest result class <module>.<class>

parallelization options:
  -j, --jobs COUNT      The number of test processes (default is 0, all cores)
  --level {module,class,test}
                        Set the test parallelism level (default is 'module')
  --disable-process-pooling
                        Do not reuse processes used to run test suites
  --thread              Use a thread pool for parallelization

coverage options:
  --coverage            Run tests with coverage
  --coverage-branch     Run tests with branch coverage
  --coverage-rcfile RCFILE
                        Specify coverage configuration file
  --coverage-include PAT
                        Include only files matching one of these patterns.
                        Accepts shell-style (quoted) wildcards.
  --coverage-omit PAT   Omit files matching one of these patterns. Accepts
                        shell-style (quoted) wildcards.
  --coverage-source SRC
                        A list of packages or directories of code to be
                        measured
  --coverage-html DIR   Generate coverage HTML report
  --coverage-xml FILE   Generate coverage XML report
  --coverage-fail-under MIN
                        Fail if coverage percentage under min

Development

This package is developed using python-build. It was started using python-template as follows:

template-specialize python-template/template/ unittest-parallel/ -k package unittest-parallel -k name 'Craig A. Hobbs' -k email 'craigahobbs@gmail.com' -k github 'craigahobbs' -k noapi 1

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

unittest_parallel-1.8.1.tar.gz (10.4 kB view details)

Uploaded Source

Built Distribution

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

unittest_parallel-1.8.1-py3-none-any.whl (9.6 kB view details)

Uploaded Python 3

File details

Details for the file unittest_parallel-1.8.1.tar.gz.

File metadata

  • Download URL: unittest_parallel-1.8.1.tar.gz
  • Upload date:
  • Size: 10.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for unittest_parallel-1.8.1.tar.gz
Algorithm Hash digest
SHA256 0c2f52dc737fcf81cbd2fc68ebdc4c77445eb5416e3e36cf0f1da92dd4788c16
MD5 4d214c910ba3ee6e9ee760b60bb8e6ba
BLAKE2b-256 5cf9dfec919c10ab888e1fc6d374172fd281639d33d82eb37b80556bad4a66ea

See more details on using hashes here.

File details

Details for the file unittest_parallel-1.8.1-py3-none-any.whl.

File metadata

File hashes

Hashes for unittest_parallel-1.8.1-py3-none-any.whl
Algorithm Hash digest
SHA256 6c68b38b43019d9c6c88cd48f9b3a88fdbf7f5d4c719fe24af56b14fb4f06745
MD5 65b5490fef1f3e4a77cfd595ae8c583d
BLAKE2b-256 828fb29487d4f44c6d590532dd2b027b18978af6e318cc240896369b420b5b86

See more details on using hashes here.

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