2010-10-11 05:45:45 +08:00
|
|
|
py.test Features
|
|
|
|
==================
|
|
|
|
|
2010-10-14 01:30:00 +08:00
|
|
|
no-boilerplate testing with Python
|
|
|
|
----------------------------------
|
2010-10-11 05:45:45 +08:00
|
|
|
|
2010-10-14 01:30:00 +08:00
|
|
|
- automatic customizable Python test discovery
|
|
|
|
- powerful parametrization of test functions
|
|
|
|
- use the ``assert`` statement for your assertions
|
|
|
|
- rely on powerful traceback and assertion reporting
|
|
|
|
- use ``print`` or ``pdb`` debugging on failures
|
2010-10-11 05:45:45 +08:00
|
|
|
|
|
|
|
extensive plugin and customization system
|
|
|
|
------------------------------------------------------
|
|
|
|
|
|
|
|
.. _`suprisingly easy`: http://bruynooghe.blogspot.com/2009/12/skipping-slow-test-by-default-in-pytest.html
|
|
|
|
|
|
|
|
- all collection, reporting, running aspects are delegated to hook functions
|
|
|
|
- hook functions are defined per-directory, per-project or through PyPI released plugins
|
|
|
|
- it is `suprisingly easy`_ to add command line options or
|
|
|
|
do other kind of add-ons and customizations.
|
|
|
|
|
2010-10-14 01:30:00 +08:00
|
|
|
mature command line testing tool
|
|
|
|
--------------------------------------
|
|
|
|
|
|
|
|
- used in many projects, ranging from 10 to 10K tests
|
|
|
|
- autodiscovery of tests
|
|
|
|
- simple well sorted command line options
|
|
|
|
- runs on Unix, Windows from Python 2.4 up to Python 3.1 and 3.2
|
|
|
|
- is itself tested extensively on a CI server
|
|
|
|
- keyword/testname based selection of tests
|
|
|
|
|
2010-10-11 05:45:45 +08:00
|
|
|
integrates well with CI systems
|
|
|
|
----------------------------------------
|
|
|
|
|
|
|
|
- produces compatible JunitXML output for Hudson or other CI servers
|
|
|
|
- produces "resultlog" text files for easy parsing
|
|
|
|
- integrates well with tox_
|
|
|
|
|
|
|
|
.. _`tox`: http://codespeak.net/tox
|
|
|
|
|
|
|
|
|
|
|
|
supports several testing practises and methods
|
|
|
|
-----------------------------------------------------------
|
|
|
|
|
|
|
|
- supports extended `xUnit style setup`_
|
|
|
|
- can integrate nose_, `unittest.py` and `doctest.py`_ style tests
|
2010-10-27 23:36:27 +08:00
|
|
|
- supports generating testing coverage reports
|
|
|
|
- supports :ref:`non-python tests`
|
2010-10-11 05:45:45 +08:00
|
|
|
- `Javasript unit- and functional testing`_
|
|
|
|
|
|
|
|
.. _`Javasript unit- and functional testing`: plugin/oejskit.html
|
|
|
|
.. _`coverage testing with figleaf`: plugin/figleaf.html
|
|
|
|
.. _`unittest.py`: http://docs.python.org/library/unittest.html
|
|
|
|
|
|
|
|
distributing tests to local/remote subprocesses
|
|
|
|
--------------------------------------------------------
|
|
|
|
|
|
|
|
.. _`pytest-xdist`: plugin/xdist.html
|
|
|
|
|
|
|
|
- distribute tests to multiple CPUs
|
|
|
|
- distribute tests to remote ssh or socket connected machines
|
|
|
|
- run tests in subprocess, re-run failing ones on file-change
|
|
|
|
|
|
|
|
skip or expect-to-fail a test
|
|
|
|
-------------------------------------------
|
|
|
|
|
|
|
|
- skip tests if there are platform or dependency mismatches
|
|
|
|
- xfail a test (on certain platforms)indicating an implementation problem
|
|
|
|
- you can use skip and xfail imperatively or as a decorating marker
|
|
|
|
|
|
|
|
.. include:: links.inc
|