commit
						ad4ef4f583
					
				|  | @ -1,7 +1,5 @@ | |||
| 3.0.4.dev0 | ||||
| ========== | ||||
| 
 | ||||
| * | ||||
| 3.0.4 | ||||
| ===== | ||||
| 
 | ||||
| * Import errors when collecting test modules now display the full traceback (`#1976`_). | ||||
|   Thanks `@cwitty`_ for the report and `@nicoddemus`_ for the PR. | ||||
|  | @ -35,10 +33,6 @@ | |||
| * Clean up unittest TestCase objects after tests are complete (`#1649`_). | ||||
|   Thanks `@d_b_w`_ for the report and PR. | ||||
| 
 | ||||
| * | ||||
| 
 | ||||
| * | ||||
| 
 | ||||
| 
 | ||||
| .. _@adborden: https://github.com/adborden | ||||
| .. _@cwitty: https://github.com/cwitty | ||||
|  |  | |||
|  | @ -1,2 +1,2 @@ | |||
| # | ||||
| __version__ = '3.0.4.dev0' | ||||
| __version__ = '3.0.4' | ||||
|  |  | |||
|  | @ -6,6 +6,7 @@ Release announcements | |||
|    :maxdepth: 2 | ||||
| 
 | ||||
|     | ||||
|    release-3.0.4 | ||||
|    release-3.0.3 | ||||
|    release-3.0.2 | ||||
|    release-3.0.1 | ||||
|  |  | |||
|  | @ -0,0 +1,29 @@ | |||
| pytest-3.0.4 | ||||
| ============ | ||||
| 
 | ||||
| pytest 3.0.4 has just been released to PyPI. | ||||
| 
 | ||||
| This release fixes some regressions and bugs reported in the last version,  | ||||
| being a drop-in replacement. To upgrade:: | ||||
| 
 | ||||
|   pip install --upgrade pytest | ||||
|    | ||||
| The changelog is available at http://doc.pytest.org/en/latest/changelog.html. | ||||
| 
 | ||||
| Thanks to all who contributed to this release, among them: | ||||
| 
 | ||||
| * Bruno Oliveira | ||||
| * Dan Wandschneider | ||||
| * Florian Bruhin | ||||
| * Georgy Dyuldin | ||||
| * Grigorii Eremeev | ||||
| * Jason R. Coombs | ||||
| * Manuel Jacob | ||||
| * Mathieu Clabaut | ||||
| * Michael Seifert | ||||
| * Nikolaus Rath | ||||
| * Ronny Pfannschmidt | ||||
| * Tom V | ||||
| 
 | ||||
| Happy testing, | ||||
| The pytest Development Team | ||||
|  | @ -26,7 +26,7 @@ you will see the return value of the function call:: | |||
| 
 | ||||
|     $ pytest test_assert1.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 1 items | ||||
|      | ||||
|  | @ -170,7 +170,7 @@ if you run this module:: | |||
| 
 | ||||
|     $ pytest test_assert2.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 1 items | ||||
|      | ||||
|  |  | |||
|  | @ -80,7 +80,7 @@ If you then run it with ``--lf``:: | |||
| 
 | ||||
|     $ pytest --lf | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     run-last-failure: rerun last 2 failures | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 50 items | ||||
|  | @ -122,7 +122,7 @@ of ``FF`` and dots):: | |||
| 
 | ||||
|     $ pytest --ff | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     run-last-failure: rerun last 2 failures first | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 50 items | ||||
|  | @ -227,7 +227,7 @@ You can always peek at the content of the cache using the | |||
| 
 | ||||
|     $ py.test --cache-show | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     cachedir: $REGENDOC_TMPDIR/.cache | ||||
|     ------------------------------- cache values ------------------------------- | ||||
|  |  | |||
|  | @ -64,7 +64,7 @@ of the failing function and hide the other one:: | |||
| 
 | ||||
|     $ pytest | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 2 items | ||||
|      | ||||
|  |  | |||
|  | @ -49,7 +49,7 @@ then you can just invoke ``pytest`` without command line options:: | |||
| 
 | ||||
|     $ pytest | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile: pytest.ini | ||||
|     collected 1 items | ||||
|      | ||||
|  |  | |||
|  | @ -31,7 +31,7 @@ You can then restrict a test run to only run tests marked with ``webtest``:: | |||
| 
 | ||||
|     $ pytest -v -m webtest | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     cachedir: .cache | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collecting ... collected 4 items | ||||
|  | @ -45,7 +45,7 @@ Or the inverse, running all tests except the webtest ones:: | |||
| 
 | ||||
|     $ pytest -v -m "not webtest" | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     cachedir: .cache | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collecting ... collected 4 items | ||||
|  | @ -66,7 +66,7 @@ tests based on their module, class, method, or function name:: | |||
| 
 | ||||
|     $ pytest -v test_server.py::TestClass::test_method | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     cachedir: .cache | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collecting ... collected 5 items | ||||
|  | @ -79,7 +79,7 @@ You can also select on the class:: | |||
| 
 | ||||
|     $ pytest -v test_server.py::TestClass | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     cachedir: .cache | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collecting ... collected 4 items | ||||
|  | @ -92,7 +92,7 @@ Or select multiple nodes:: | |||
| 
 | ||||
|   $ pytest -v test_server.py::TestClass test_server.py::test_send_http | ||||
|   ======= test session starts ======== | ||||
|   platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|   platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|   cachedir: .cache | ||||
|   rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|   collecting ... collected 8 items | ||||
|  | @ -130,7 +130,7 @@ select tests based on their names:: | |||
| 
 | ||||
|     $ pytest -v -k http  # running with the above defined example module | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     cachedir: .cache | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collecting ... collected 4 items | ||||
|  | @ -144,7 +144,7 @@ And you can also run all tests except the ones that match the keyword:: | |||
| 
 | ||||
|     $ pytest -k "not send_http" -v | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     cachedir: .cache | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collecting ... collected 4 items | ||||
|  | @ -160,7 +160,7 @@ Or to select "http" and "quick" tests:: | |||
| 
 | ||||
|     $ pytest -k "http or quick" -v | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     cachedir: .cache | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collecting ... collected 4 items | ||||
|  | @ -352,7 +352,7 @@ the test needs:: | |||
| 
 | ||||
|     $ pytest -E stage2 | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 1 items | ||||
|      | ||||
|  | @ -364,7 +364,7 @@ and here is one that specifies exactly the environment needed:: | |||
| 
 | ||||
|     $ pytest -E stage1 | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 1 items | ||||
|      | ||||
|  | @ -485,7 +485,7 @@ then you will see two test skipped and two executed tests as expected:: | |||
| 
 | ||||
|     $ pytest -rs # this option reports skip reasons | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 4 items | ||||
|      | ||||
|  | @ -499,7 +499,7 @@ Note that if you specify a platform via the marker-command line option like this | |||
| 
 | ||||
|     $ pytest -m linux2 | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 4 items | ||||
|      | ||||
|  | @ -551,7 +551,7 @@ We can now use the ``-m option`` to select one set:: | |||
| 
 | ||||
|   $ pytest -m interface --tb=short | ||||
|   ======= test session starts ======== | ||||
|   platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|   platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|   rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|   collected 4 items | ||||
|    | ||||
|  | @ -573,7 +573,7 @@ or to select both "event" and "interface" tests:: | |||
| 
 | ||||
|   $ pytest -m "interface or event" --tb=short | ||||
|   ======= test session starts ======== | ||||
|   platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|   platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|   rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|   collected 4 items | ||||
|    | ||||
|  |  | |||
|  | @ -27,7 +27,7 @@ now execute the test specification:: | |||
| 
 | ||||
|     nonpython $ pytest test_simple.yml | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR/nonpython, inifile:  | ||||
|     collected 2 items | ||||
|      | ||||
|  | @ -59,7 +59,7 @@ consulted when reporting in ``verbose`` mode:: | |||
| 
 | ||||
|     nonpython $ pytest -v | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     cachedir: .cache | ||||
|     rootdir: $REGENDOC_TMPDIR/nonpython, inifile:  | ||||
|     collecting ... collected 2 items | ||||
|  | @ -81,7 +81,7 @@ interesting to just look at the collection tree:: | |||
| 
 | ||||
|     nonpython $ pytest --collect-only | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR/nonpython, inifile:  | ||||
|     collected 2 items | ||||
|     <YamlFile 'test_simple.yml'> | ||||
|  |  | |||
|  | @ -130,7 +130,7 @@ objects, they are still using the default pytest representation:: | |||
| 
 | ||||
|     $ pytest test_time.py --collect-only | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 6 items | ||||
|     <Module 'test_time.py'> | ||||
|  | @ -181,7 +181,7 @@ this is a fully self-contained example which you can run with:: | |||
| 
 | ||||
|     $ pytest test_scenarios.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 4 items | ||||
|      | ||||
|  | @ -194,7 +194,7 @@ If you just collect tests you'll also nicely see 'advanced' and 'basic' as varia | |||
| 
 | ||||
|     $ pytest --collect-only test_scenarios.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 4 items | ||||
|     <Module 'test_scenarios.py'> | ||||
|  | @ -259,7 +259,7 @@ Let's first see how it looks like at collection time:: | |||
| 
 | ||||
|     $ pytest test_backends.py --collect-only | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 2 items | ||||
|     <Module 'test_backends.py'> | ||||
|  | @ -320,7 +320,7 @@ The result of this test will be successful:: | |||
| 
 | ||||
|     $ pytest test_indirect_list.py --collect-only | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 1 items | ||||
|     <Module 'test_indirect_list.py'> | ||||
|  | @ -447,7 +447,7 @@ If you run this with reporting for skips enabled:: | |||
| 
 | ||||
|     $ pytest -rs test_module.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 2 items | ||||
|      | ||||
|  |  | |||
|  | @ -117,7 +117,7 @@ then the test collection looks like this:: | |||
| 
 | ||||
|     $ pytest --collect-only | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile: pytest.ini | ||||
|     collected 2 items | ||||
|     <Module 'check_myapp.py'> | ||||
|  | @ -163,7 +163,7 @@ You can always peek at the collection tree without running tests like this:: | |||
| 
 | ||||
|     . $ pytest --collect-only pythoncollection.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile: pytest.ini | ||||
|     collected 3 items | ||||
|     <Module 'CWD/pythoncollection.py'> | ||||
|  | @ -230,7 +230,7 @@ will be left out:: | |||
| 
 | ||||
|     $ pytest --collect-only | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile: pytest.ini | ||||
|     collected 0 items | ||||
|      | ||||
|  |  | |||
|  | @ -11,7 +11,7 @@ get on the terminal - we are working on that):: | |||
| 
 | ||||
|     assertion $ pytest failure_demo.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR/assertion, inifile:  | ||||
|     collected 42 items | ||||
|      | ||||
|  | @ -359,7 +359,7 @@ get on the terminal - we are working on that):: | |||
|     >   int(s) | ||||
|     E   ValueError: invalid literal for int() with base 10: 'qwe' | ||||
|      | ||||
|     <0-codegen $PYTHON_PREFIX/lib/python3.5/site-packages/_pytest/python.py:1190>:1: ValueError | ||||
|     <0-codegen $PYTHON_PREFIX/lib/python3.5/site-packages/_pytest/python.py:1204>:1: ValueError | ||||
|     _______ TestRaises.test_raises_doesnt ________ | ||||
|      | ||||
|     self = <failure_demo.TestRaises object at 0xdeadbeef> | ||||
|  |  | |||
|  | @ -113,7 +113,7 @@ directory with the above conftest.py:: | |||
| 
 | ||||
|     $ pytest | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 0 items | ||||
|      | ||||
|  | @ -164,7 +164,7 @@ and when running it will see a skipped "slow" test:: | |||
| 
 | ||||
|     $ pytest -rs    # "-rs" means report details on the little 's' | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 2 items | ||||
|      | ||||
|  | @ -178,7 +178,7 @@ Or run it including the ``slow`` marked test:: | |||
| 
 | ||||
|     $ pytest --runslow | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 2 items | ||||
|      | ||||
|  | @ -302,7 +302,7 @@ which will add the string to the test header accordingly:: | |||
| 
 | ||||
|     $ pytest | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     project deps: mylib-1.1 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 0 items | ||||
|  | @ -327,7 +327,7 @@ which will add info only when run with "--v":: | |||
| 
 | ||||
|     $ pytest -v | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     cachedir: .cache | ||||
|     info1: did you know that ... | ||||
|     did you? | ||||
|  | @ -340,7 +340,7 @@ and nothing when run plainly:: | |||
| 
 | ||||
|     $ pytest | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 0 items | ||||
|      | ||||
|  | @ -374,7 +374,7 @@ Now we can profile which test functions execute the slowest:: | |||
| 
 | ||||
|     $ pytest --durations=3 | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 3 items | ||||
|      | ||||
|  | @ -440,7 +440,7 @@ If we run this:: | |||
| 
 | ||||
|     $ pytest -rx | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 4 items | ||||
|      | ||||
|  | @ -519,7 +519,7 @@ We can run this:: | |||
| 
 | ||||
|     $ pytest | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 7 items | ||||
|      | ||||
|  | @ -627,7 +627,7 @@ and run them:: | |||
| 
 | ||||
|     $ pytest test_module.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 2 items | ||||
|      | ||||
|  | @ -721,7 +721,7 @@ and run it:: | |||
| 
 | ||||
|     $ pytest -s test_module.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 3 items | ||||
|      | ||||
|  |  | |||
|  | @ -70,7 +70,7 @@ marked ``smtp`` fixture function.  Running the test looks like this:: | |||
| 
 | ||||
|     $ pytest test_smtpsimple.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 1 items | ||||
|      | ||||
|  | @ -188,7 +188,7 @@ inspect what is going on and can now run the tests:: | |||
| 
 | ||||
|     $ pytest test_module.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 2 items | ||||
|      | ||||
|  | @ -375,6 +375,8 @@ Running it:: | |||
|         assert 0, smtp.helo() | ||||
|     E   AssertionError: (250, b'mail.python.org') | ||||
|     E   assert 0 | ||||
|     ------------------------- Captured stdout teardown ------------------------- | ||||
|     finalizing <smtplib.SMTP object at 0xdeadbeef> (mail.python.org) | ||||
| 
 | ||||
| voila! The ``smtp`` fixture function picked up our mail server name | ||||
| from the module namespace. | ||||
|  | @ -464,6 +466,8 @@ So let's just do another run:: | |||
|     E       assert 0 | ||||
|      | ||||
|     test_module.py:11: AssertionError | ||||
|     ------------------------- Captured stdout teardown ------------------------- | ||||
|     finalizing <smtplib.SMTP object at 0xdeadbeef> | ||||
|     4 failed in 0.12 seconds | ||||
| 
 | ||||
| We see that our two test functions each ran twice, against the different | ||||
|  | @ -516,7 +520,7 @@ Running the above tests results in the following test IDs being used:: | |||
| 
 | ||||
|    $ pytest --collect-only | ||||
|    ======= test session starts ======== | ||||
|    platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|    platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|    rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|    collected 11 items | ||||
|    <Module 'test_anothersmtp.py'> | ||||
|  | @ -569,7 +573,7 @@ Here we declare an ``app`` fixture which receives the previously defined | |||
| 
 | ||||
|     $ pytest -v test_appsetup.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     cachedir: .cache | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collecting ... collected 2 items | ||||
|  | @ -638,7 +642,7 @@ Let's run the tests in verbose mode and with looking at the print-output:: | |||
| 
 | ||||
|     $ pytest -v -s test_module.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 -- $PYTHON_PREFIX/bin/python3.5 | ||||
|     cachedir: .cache | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collecting ... collected 8 items | ||||
|  |  | |||
|  | @ -26,7 +26,7 @@ Installation:: | |||
| To check your installation has installed the correct version:: | ||||
| 
 | ||||
|     $ pytest --version | ||||
|     This is pytest version 3.0.3, imported from $PYTHON_PREFIX/lib/python3.5/site-packages/pytest.py | ||||
|     This is pytest version 3.0.4, imported from $PYTHON_PREFIX/lib/python3.5/site-packages/pytest.py | ||||
| 
 | ||||
| .. _`simpletest`: | ||||
| 
 | ||||
|  | @ -46,7 +46,7 @@ That's it. You can execute the test function now:: | |||
| 
 | ||||
|     $ pytest | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 1 items | ||||
|      | ||||
|  |  | |||
|  | @ -25,7 +25,7 @@ To execute it:: | |||
| 
 | ||||
|     $ pytest | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 1 items | ||||
|      | ||||
|  |  | |||
|  | @ -55,7 +55,7 @@ them in turn:: | |||
| 
 | ||||
|     $ pytest | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 3 items | ||||
|      | ||||
|  | @ -103,7 +103,7 @@ Let's run this:: | |||
| 
 | ||||
|     $ pytest | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 3 items | ||||
|      | ||||
|  |  | |||
|  | @ -224,7 +224,7 @@ Running it with the report-on-xfail option gives this output:: | |||
| 
 | ||||
|     example $ pytest -rx xfail_demo.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR/example, inifile:  | ||||
|     collected 7 items | ||||
|      | ||||
|  |  | |||
|  | @ -29,7 +29,7 @@ Running this would result in a passed test except for the last | |||
| 
 | ||||
|     $ pytest test_tmpdir.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 1 items | ||||
|      | ||||
|  |  | |||
|  | @ -100,7 +100,7 @@ the ``self.db`` values in the traceback:: | |||
| 
 | ||||
|     $ pytest test_unittest_db.py | ||||
|     ======= test session starts ======== | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.3, py-1.4.31, pluggy-0.4.0 | ||||
|     platform linux -- Python 3.5.2, pytest-3.0.4, py-1.4.31, pluggy-0.4.0 | ||||
|     rootdir: $REGENDOC_TMPDIR, inifile:  | ||||
|     collected 2 items | ||||
|      | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue