183 lines
5.9 KiB
Plaintext
183 lines
5.9 KiB
Plaintext
|
|
loop on failing tests, distribute test runs to CPUs and hosts.
|
|
==============================================================
|
|
|
|
|
|
.. contents::
|
|
:local:
|
|
|
|
The `pytest-xdist`_ plugin extends py.test with some unique
|
|
test execution modes:
|
|
|
|
* Looponfail: run your tests repeatedly in a subprocess. After each run py.test
|
|
waits until a file in your project changes and then re-runs the previously
|
|
failing tests. This is repeated until all tests pass after which again
|
|
a full run is performed.
|
|
|
|
* Load-balancing: if you have multiple CPUs or hosts you can use
|
|
those for a combined test run. This allows to speed up
|
|
development or to use special resources of remote machines.
|
|
|
|
* Multi-Platform coverage: you can specify different Python interpreters
|
|
or different platforms and run tests in parallel on all of them.
|
|
|
|
Before running tests remotely, ``py.test`` efficiently synchronizes your
|
|
program source code to the remote place. All test results
|
|
are reported back and displayed to your local test session.
|
|
You may specify different Python versions and interpreters.
|
|
|
|
.. _`pytest-xdist`: http://pytest.org/plugin/xdist.html
|
|
|
|
Usage examples
|
|
---------------------
|
|
|
|
Speed up test runs by sending tests to multiple CPUs
|
|
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
|
|
|
To send tests to multiple CPUs, type::
|
|
|
|
py.test -n NUM
|
|
|
|
Especially for longer running tests or tests requiring
|
|
a lot of IO this can lead to considerable speed ups.
|
|
|
|
|
|
Running tests in a Python subprocess
|
|
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
|
|
|
To instantiate a python2.4 sub process and send tests to it, you may type::
|
|
|
|
py.test -d --tx popen//python=python2.4
|
|
|
|
This will start a subprocess which is run with the "python2.4"
|
|
Python interpreter, found in your system binary lookup path.
|
|
|
|
If you prefix the --tx option value like this::
|
|
|
|
--tx 3*popen//python=python2.4
|
|
|
|
then three subprocesses would be created and tests
|
|
will be load-balanced across these three processes.
|
|
|
|
|
|
Sending tests to remote SSH accounts
|
|
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
|
|
|
Suppose you have a package ``mypkg`` which contains some
|
|
tests that you can successfully run locally. And you
|
|
have a ssh-reachable machine ``myhost``. Then
|
|
you can ad-hoc distribute your tests by typing::
|
|
|
|
py.test -d --tx ssh=myhostpopen --rsyncdir mypkg mypkg
|
|
|
|
This will synchronize your ``mypkg`` package directory
|
|
to an remote ssh account and then locally collect tests
|
|
and send them to remote places for execution.
|
|
|
|
You can specify multiple ``--rsyncdir`` directories
|
|
to be sent to the remote side.
|
|
|
|
**NOTE:** For py.test to collect and send tests correctly
|
|
you not only need to make sure all code and tests
|
|
directories are rsynced, but that any test (sub) directory
|
|
also has an ``__init__.py`` file because internally
|
|
py.test references tests as a fully qualified python
|
|
module path. **You will otherwise get strange errors**
|
|
during setup of the remote side.
|
|
|
|
Sending tests to remote Socket Servers
|
|
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
|
|
|
Download the single-module `socketserver.py`_ Python program
|
|
and run it like this::
|
|
|
|
python socketserver.py
|
|
|
|
It will tell you that it starts listening on the default
|
|
port. You can now on your home machine specify this
|
|
new socket host with something like this::
|
|
|
|
py.test -d --tx socket=192.168.1.102:8888 --rsyncdir mypkg mypkg
|
|
|
|
|
|
.. _`atonce`:
|
|
|
|
Running tests on many platforms at once
|
|
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
|
|
|
The basic command to run tests on multiple platforms is::
|
|
|
|
py.test --dist=each --tx=spec1 --tx=spec2
|
|
|
|
If you specify a windows host, an OSX host and a Linux
|
|
environment this command will send each tests to all
|
|
platforms - and report back failures from all platforms
|
|
at once. The specifications strings use the `xspec syntax`_.
|
|
|
|
.. _`xspec syntax`: http://codespeak.net/execnet/trunk/basics.html#xspec
|
|
|
|
.. _`socketserver.py`: http://codespeak.net/svn/py/dist/py/execnet/script/socketserver.py
|
|
|
|
.. _`execnet`: http://codespeak.net/execnet
|
|
|
|
Specifying test exec environments in a conftest.py
|
|
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
|
|
|
Instead of specifying command line options, you can
|
|
put options values in a ``conftest.py`` file like this::
|
|
|
|
pytest_option_tx = ['ssh=myhost//python=python2.5', 'popen//python=python2.5']
|
|
pytest_option_dist = True
|
|
|
|
Any commandline ``--tx`` specifictions will add to the list of available execution
|
|
environments.
|
|
|
|
Specifying "rsync" dirs in a conftest.py
|
|
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
|
|
|
In your ``mypkg/conftest.py`` you may specify directories to synchronise
|
|
or to exclude::
|
|
|
|
rsyncdirs = ['.', '../plugins']
|
|
rsyncignore = ['_cache']
|
|
|
|
These directory specifications are relative to the directory
|
|
where the ``conftest.py`` is found.
|
|
|
|
command line options
|
|
--------------------
|
|
|
|
|
|
``-f, --looponfail``
|
|
run tests in subprocess, wait for modified files and re-run failing test set until all pass.
|
|
``-n numprocesses``
|
|
shortcut for '--dist=load --tx=NUM*popen'
|
|
``--boxed``
|
|
box each test run in a separate process (unix)
|
|
``--dist=distmode``
|
|
set mode for distributing tests to exec environments.
|
|
|
|
each: send each test to each available environment.
|
|
|
|
load: send each test to available environment.
|
|
|
|
(default) no: run tests inprocess, don't distribute.
|
|
``--tx=xspec``
|
|
add a test execution environment. some examples: --tx popen//python=python2.5 --tx socket=192.168.1.102:8888 --tx ssh=user@codespeak.net//chdir=testcache
|
|
``-d``
|
|
load-balance tests. shortcut for '--dist=load'
|
|
``--rsyncdir=dir1``
|
|
add directory for rsyncing to remote tx nodes.
|
|
|
|
Start improving this plugin in 30 seconds
|
|
=========================================
|
|
|
|
|
|
1. Download `plugin.py`_ plugin source code
|
|
2. put it somewhere as ``plugin.py`` into your import path
|
|
3. a subsequent ``py.test`` run will use your local version
|
|
|
|
Checkout customize_, other plugins_ or `get in contact`_.
|
|
|
|
.. include:: links.txt
|