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-11-02 07:53:53 +08:00
|
|
|
- automatic, fully customizable Python test discovery
|
2010-11-06 06:37:31 +08:00
|
|
|
- write simple test functions and freely group tests
|
2010-11-02 07:53:53 +08:00
|
|
|
- ``assert`` statement for your assertions
|
2010-10-14 01:30:00 +08:00
|
|
|
- powerful parametrization of test functions
|
2010-11-18 21:56:16 +08:00
|
|
|
- rely on helpful traceback and failing assertion reporting
|
2010-10-14 01:30:00 +08:00
|
|
|
- use ``print`` or ``pdb`` debugging on failures
|
2010-11-18 21:56:16 +08:00
|
|
|
- enables fully :pep:`8` compliant coding style
|
2010-10-11 05:45:45 +08:00
|
|
|
|
|
|
|
extensive plugin and customization system
|
|
|
|
------------------------------------------------------
|
|
|
|
|
2010-11-18 05:12:16 +08:00
|
|
|
.. _`easy`: http://bruynooghe.blogspot.com/2009/12/skipping-slow-test-by-default-in-pytest.html
|
2010-10-11 05:45:45 +08:00
|
|
|
|
|
|
|
- all collection, reporting, running aspects are delegated to hook functions
|
2010-11-18 05:12:16 +08:00
|
|
|
- hook functions are implemented per-directory, per-project or through PyPI released plugins
|
|
|
|
- it is `easy`_ to add command line options or
|
2010-10-11 05:45:45 +08:00
|
|
|
do other kind of add-ons and customizations.
|
|
|
|
|
2010-10-14 01:30:00 +08:00
|
|
|
mature command line testing tool
|
|
|
|
--------------------------------------
|
|
|
|
|
2010-11-18 21:56:16 +08:00
|
|
|
- powerful :ref:`usage` possibilities, well sorted command line options
|
2010-10-14 01:30:00 +08:00
|
|
|
- used in many projects, ranging from 10 to 10K tests
|
2010-11-18 21:56:16 +08:00
|
|
|
- tested on Unix and Windows from Python 2.4 up to Python 3.1 and 3.2
|
2010-10-14 01:30:00 +08:00
|
|
|
- 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
|
|
|
|
|
2010-11-18 05:12:16 +08:00
|
|
|
supports common testing practises and methods
|
2010-10-11 05:45:45 +08:00
|
|
|
-----------------------------------------------------------
|
|
|
|
|
|
|
|
- supports extended `xUnit style setup`_
|
2010-11-18 05:12:16 +08:00
|
|
|
- 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`_
|
|
|
|
|
2010-11-18 05:12:16 +08:00
|
|
|
.. _`Javasript unit- and functional testing`: http://pypi.python.org/pypi/oejskit
|
2010-10-11 05:45:45 +08:00
|
|
|
|
|
|
|
distributing tests to local/remote subprocesses
|
|
|
|
--------------------------------------------------------
|
|
|
|
|
|
|
|
- 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
|