Merge pull request #3490 from nicoddemus/merge-master-into-features
Merge master into features
This commit is contained in:
		
						commit
						4aa7ebaf52
					
				
							
								
								
									
										1
									
								
								AUTHORS
								
								
								
								
							
							
						
						
									
										1
									
								
								AUTHORS
								
								
								
								
							|  | @ -23,6 +23,7 @@ Antony Lee | ||||||
| Armin Rigo | Armin Rigo | ||||||
| Aron Coyle | Aron Coyle | ||||||
| Aron Curzon | Aron Curzon | ||||||
|  | Aviral Verma | ||||||
| Aviv Palivoda | Aviv Palivoda | ||||||
| Barney Gale | Barney Gale | ||||||
| Ben Webb | Ben Webb | ||||||
|  |  | ||||||
|  | @ -114,7 +114,7 @@ Features | ||||||
| 
 | 
 | ||||||
| - Captured log messages are added to the ``<system-out>`` tag in the generated | - Captured log messages are added to the ``<system-out>`` tag in the generated | ||||||
|   junit xml file if the ``junit_logging`` ini option is set to ``system-out``. |   junit xml file if the ``junit_logging`` ini option is set to ``system-out``. | ||||||
|   If the value of this ini option is ``system-err`, the logs are written to |   If the value of this ini option is ``system-err``, the logs are written to | ||||||
|   ``<system-err>``. The default value for ``junit_logging`` is ``no``, meaning |   ``<system-err>``. The default value for ``junit_logging`` is ``no``, meaning | ||||||
|   captured logs are not written to the output file. (`#3156 |   captured logs are not written to the output file. (`#3156 | ||||||
|   <https://github.com/pytest-dev/pytest/issues/3156>`_) |   <https://github.com/pytest-dev/pytest/issues/3156>`_) | ||||||
|  | @ -1206,7 +1206,7 @@ Changes | ||||||
| * Testcase reports with a ``url`` attribute will now properly write this to junitxml. | * Testcase reports with a ``url`` attribute will now properly write this to junitxml. | ||||||
|   Thanks `@fushi`_ for the PR (`#1874`_). |   Thanks `@fushi`_ for the PR (`#1874`_). | ||||||
| 
 | 
 | ||||||
| * Remove common items from dict comparision output when verbosity=1. Also update | * Remove common items from dict comparison output when verbosity=1. Also update | ||||||
|   the truncation message to make it clearer that pytest truncates all |   the truncation message to make it clearer that pytest truncates all | ||||||
|   assertion messages if verbosity < 2 (`#1512`_). |   assertion messages if verbosity < 2 (`#1512`_). | ||||||
|   Thanks `@mattduck`_ for the PR |   Thanks `@mattduck`_ for the PR | ||||||
|  | @ -1218,7 +1218,7 @@ Changes | ||||||
| * fix `#2013`_: turn RecordedWarning into ``namedtuple``, | * fix `#2013`_: turn RecordedWarning into ``namedtuple``, | ||||||
|   to give it a comprehensible repr while preventing unwarranted modification. |   to give it a comprehensible repr while preventing unwarranted modification. | ||||||
| 
 | 
 | ||||||
| * fix `#2208`_: ensure a iteration limit for _pytest.compat.get_real_func. | * fix `#2208`_: ensure an iteration limit for _pytest.compat.get_real_func. | ||||||
|   Thanks `@RonnyPfannschmidt`_ for the report and PR. |   Thanks `@RonnyPfannschmidt`_ for the report and PR. | ||||||
| 
 | 
 | ||||||
| * Hooks are now verified after collection is complete, rather than right after loading installed plugins. This | * Hooks are now verified after collection is complete, rather than right after loading installed plugins. This | ||||||
|  | @ -1322,7 +1322,7 @@ Bug Fixes | ||||||
|   Notably, importing the ``anydbm`` module is fixed. (`#2248`_). |   Notably, importing the ``anydbm`` module is fixed. (`#2248`_). | ||||||
|   Thanks `@pfhayes`_ for the PR. |   Thanks `@pfhayes`_ for the PR. | ||||||
| 
 | 
 | ||||||
| * junitxml: Fix problematic case where system-out tag occured twice per testcase | * junitxml: Fix problematic case where system-out tag occurred twice per testcase | ||||||
|   element in the XML report. Thanks `@kkoukiou`_ for the PR. |   element in the XML report. Thanks `@kkoukiou`_ for the PR. | ||||||
| 
 | 
 | ||||||
| * Fix regression, pytest now skips unittest correctly if run with ``--pdb`` | * Fix regression, pytest now skips unittest correctly if run with ``--pdb`` | ||||||
|  | @ -2918,7 +2918,7 @@ time or change existing behaviors in order to make them less surprising/more use | ||||||
|   "::" node id specifications (copy pasted from "-v" output) |   "::" node id specifications (copy pasted from "-v" output) | ||||||
| 
 | 
 | ||||||
| - fix issue544 by only removing "@NUM" at the end of "::" separated parts | - fix issue544 by only removing "@NUM" at the end of "::" separated parts | ||||||
|   and if the part has an ".py" extension |   and if the part has a ".py" extension | ||||||
| 
 | 
 | ||||||
| - don't use py.std import helper, rather import things directly. | - don't use py.std import helper, rather import things directly. | ||||||
|   Thanks Bruno Oliveira. |   Thanks Bruno Oliveira. | ||||||
|  | @ -3189,7 +3189,7 @@ time or change existing behaviors in order to make them less surprising/more use | ||||||
| 
 | 
 | ||||||
|   would not work correctly because pytest assumes @pytest.mark.some |   would not work correctly because pytest assumes @pytest.mark.some | ||||||
|   gets a function to be decorated already.  We now at least detect if this |   gets a function to be decorated already.  We now at least detect if this | ||||||
|   arg is an lambda and thus the example will work.  Thanks Alex Gaynor |   arg is a lambda and thus the example will work.  Thanks Alex Gaynor | ||||||
|   for bringing it up. |   for bringing it up. | ||||||
| 
 | 
 | ||||||
| - xfail a test on pypy that checks wrong encoding/ascii (pypy does | - xfail a test on pypy that checks wrong encoding/ascii (pypy does | ||||||
|  | @ -3502,7 +3502,7 @@ Bug fixes: | ||||||
|   rather use the post-2.0 parametrize features instead of yield, see: |   rather use the post-2.0 parametrize features instead of yield, see: | ||||||
|   http://pytest.org/latest/example/parametrize.html |   http://pytest.org/latest/example/parametrize.html | ||||||
| - fix autouse-issue where autouse-fixtures would not be discovered | - fix autouse-issue where autouse-fixtures would not be discovered | ||||||
|   if defined in a a/conftest.py file and tests in a/tests/test_some.py |   if defined in an a/conftest.py file and tests in a/tests/test_some.py | ||||||
| - fix issue226 - LIFO ordering for fixture teardowns | - fix issue226 - LIFO ordering for fixture teardowns | ||||||
| - fix issue224 - invocations with >256 char arguments now work | - fix issue224 - invocations with >256 char arguments now work | ||||||
| - fix issue91 - add/discuss package/directory level setups in example | - fix issue91 - add/discuss package/directory level setups in example | ||||||
|  | @ -4072,7 +4072,7 @@ Bug fixes: | ||||||
| - make path.bestrelpath(path) return ".", note that when calling | - make path.bestrelpath(path) return ".", note that when calling | ||||||
|   X.bestrelpath the assumption is that X is a directory. |   X.bestrelpath the assumption is that X is a directory. | ||||||
| - make initial conftest discovery ignore "--" prefixed arguments | - make initial conftest discovery ignore "--" prefixed arguments | ||||||
| - fix resultlog plugin when used in an multicpu/multihost xdist situation | - fix resultlog plugin when used in a multicpu/multihost xdist situation | ||||||
|   (thanks Jakub Gustak) |   (thanks Jakub Gustak) | ||||||
| - perform distributed testing related reporting in the xdist-plugin | - perform distributed testing related reporting in the xdist-plugin | ||||||
|   rather than having dist-related code in the generic py.test |   rather than having dist-related code in the generic py.test | ||||||
|  |  | ||||||
|  | @ -6,13 +6,13 @@ | ||||||
| ------ | ------ | ||||||
| 
 | 
 | ||||||
| .. image:: https://img.shields.io/pypi/v/pytest.svg | .. image:: https://img.shields.io/pypi/v/pytest.svg | ||||||
|     :target: https://pypi.python.org/pypi/pytest |     :target: https://pypi.org/project/pytest/ | ||||||
| 
 | 
 | ||||||
| .. image:: https://anaconda.org/conda-forge/pytest/badges/version.svg | .. image:: https://img.shields.io/conda/vn/conda-forge/pytest.svg | ||||||
|     :target: https://anaconda.org/conda-forge/pytest |     :target: https://anaconda.org/conda-forge/pytest | ||||||
| 
 | 
 | ||||||
| .. image:: https://img.shields.io/pypi/pyversions/pytest.svg | .. image:: https://img.shields.io/pypi/pyversions/pytest.svg | ||||||
|     :target: https://pypi.python.org/pypi/pytest |     :target: https://pypi.org/project/pytest/ | ||||||
| 
 | 
 | ||||||
| .. image:: https://img.shields.io/coveralls/pytest-dev/pytest/master.svg | .. image:: https://img.shields.io/coveralls/pytest-dev/pytest/master.svg | ||||||
|     :target: https://coveralls.io/r/pytest-dev/pytest |     :target: https://coveralls.io/r/pytest-dev/pytest | ||||||
|  |  | ||||||
|  | @ -14,7 +14,7 @@ cpy_compile = compile | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class Source(object): | class Source(object): | ||||||
|     """ a immutable object holding a source code fragment, |     """ an immutable object holding a source code fragment, | ||||||
|         possibly deindenting it. |         possibly deindenting it. | ||||||
|     """ |     """ | ||||||
|     _compilecounter = 0 |     _compilecounter = 0 | ||||||
|  |  | ||||||
|  | @ -171,10 +171,22 @@ def _diff_text(left, right, verbose=False): | ||||||
|     """ |     """ | ||||||
|     from difflib import ndiff |     from difflib import ndiff | ||||||
|     explanation = [] |     explanation = [] | ||||||
|  | 
 | ||||||
|  |     def escape_for_readable_diff(binary_text): | ||||||
|  |         """ | ||||||
|  |         Ensures that the internal string is always valid unicode, converting any bytes safely to valid unicode. | ||||||
|  |         This is done using repr() which then needs post-processing to fix the encompassing quotes and un-escape | ||||||
|  |         newlines and carriage returns (#429). | ||||||
|  |         """ | ||||||
|  |         r = six.text_type(repr(binary_text)[1:-1]) | ||||||
|  |         r = r.replace(r'\n', '\n') | ||||||
|  |         r = r.replace(r'\r', '\r') | ||||||
|  |         return r | ||||||
|  | 
 | ||||||
|     if isinstance(left, six.binary_type): |     if isinstance(left, six.binary_type): | ||||||
|         left = u(repr(left)[1:-1]).replace(r'\n', '\n') |         left = escape_for_readable_diff(left) | ||||||
|     if isinstance(right, six.binary_type): |     if isinstance(right, six.binary_type): | ||||||
|         right = u(repr(right)[1:-1]).replace(r'\n', '\n') |         right = escape_for_readable_diff(right) | ||||||
|     if not verbose: |     if not verbose: | ||||||
|         i = 0  # just in case left or right has zero length |         i = 0  # just in case left or right has zero length | ||||||
|         for i in range(min(len(left), len(right))): |         for i in range(min(len(left), len(right))): | ||||||
|  | @ -197,6 +209,10 @@ def _diff_text(left, right, verbose=False): | ||||||
|                 left = left[:-i] |                 left = left[:-i] | ||||||
|                 right = right[:-i] |                 right = right[:-i] | ||||||
|     keepends = True |     keepends = True | ||||||
|  |     if left.isspace() or right.isspace(): | ||||||
|  |         left = repr(str(left)) | ||||||
|  |         right = repr(str(right)) | ||||||
|  |         explanation += [u'Strings contain only whitespace, escaping them using repr()'] | ||||||
|     explanation += [line.strip('\n') |     explanation += [line.strip('\n') | ||||||
|                     for line in ndiff(left.splitlines(keepends), |                     for line in ndiff(left.splitlines(keepends), | ||||||
|                                       right.splitlines(keepends))] |                                       right.splitlines(keepends))] | ||||||
|  |  | ||||||
|  | @ -315,7 +315,7 @@ class CaptureFixture(object): | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def safe_text_dupfile(f, mode, default_encoding="UTF8"): | def safe_text_dupfile(f, mode, default_encoding="UTF8"): | ||||||
|     """ return a open text file object that's a duplicate of f on the |     """ return an open text file object that's a duplicate of f on the | ||||||
|         FD-level if possible. |         FD-level if possible. | ||||||
|     """ |     """ | ||||||
|     encoding = getattr(f, "encoding", None) |     encoding = getattr(f, "encoding", None) | ||||||
|  |  | ||||||
|  | @ -257,7 +257,7 @@ def safe_getattr(object, name, default): | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def _is_unittest_unexpected_success_a_failure(): | def _is_unittest_unexpected_success_a_failure(): | ||||||
|     """Return if the test suite should fail if a @expectedFailure unittest test PASSES. |     """Return if the test suite should fail if an @expectedFailure unittest test PASSES. | ||||||
| 
 | 
 | ||||||
|     From https://docs.python.org/3/library/unittest.html?highlight=unittest#unittest.TestResult.wasSuccessful: |     From https://docs.python.org/3/library/unittest.html?highlight=unittest#unittest.TestResult.wasSuccessful: | ||||||
|         Changed in version 3.4: Returns False if there were any |         Changed in version 3.4: Returns False if there were any | ||||||
|  |  | ||||||
|  | @ -24,7 +24,7 @@ DOCTEST_REPORT_CHOICES = ( | ||||||
|     DOCTEST_REPORT_CHOICE_ONLY_FIRST_FAILURE, |     DOCTEST_REPORT_CHOICE_ONLY_FIRST_FAILURE, | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| # Lazy definiton of runner class | # Lazy definition of runner class | ||||||
| RUNNER_CLASS = None | RUNNER_CLASS = None | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -291,7 +291,7 @@ class FixtureRequest(FuncargnamesCompatAttr): | ||||||
|     def _getnextfixturedef(self, argname): |     def _getnextfixturedef(self, argname): | ||||||
|         fixturedefs = self._arg2fixturedefs.get(argname, None) |         fixturedefs = self._arg2fixturedefs.get(argname, None) | ||||||
|         if fixturedefs is None: |         if fixturedefs is None: | ||||||
|             # we arrive here because of a  a dynamic call to |             # we arrive here because of a dynamic call to | ||||||
|             # getfixturevalue(argname) usage which was naturally |             # getfixturevalue(argname) usage which was naturally | ||||||
|             # not known at parsing/collection time |             # not known at parsing/collection time | ||||||
|             parentid = self._pyfuncitem.parent.nodeid |             parentid = self._pyfuncitem.parent.nodeid | ||||||
|  | @ -1028,7 +1028,7 @@ class FixtureManager(object): | ||||||
|     def getfixtureclosure(self, fixturenames, parentnode): |     def getfixtureclosure(self, fixturenames, parentnode): | ||||||
|         # collect the closure of all fixtures , starting with the given |         # collect the closure of all fixtures , starting with the given | ||||||
|         # fixturenames as the initial set.  As we have to visit all |         # fixturenames as the initial set.  As we have to visit all | ||||||
|         # factory definitions anyway, we also return a arg2fixturedefs |         # factory definitions anyway, we also return an arg2fixturedefs | ||||||
|         # mapping so that the caller can reuse it and does not have |         # mapping so that the caller can reuse it and does not have | ||||||
|         # to re-discover fixturedefs again for each fixturename |         # to re-discover fixturedefs again for each fixturename | ||||||
|         # (discovering matching fixtures for a given name/node is expensive) |         # (discovering matching fixtures for a given name/node is expensive) | ||||||
|  |  | ||||||
|  | @ -7,7 +7,7 @@ from __future__ import absolute_import, division, print_function | ||||||
| 
 | 
 | ||||||
| def freeze_includes(): | def freeze_includes(): | ||||||
|     """ |     """ | ||||||
|     Returns a list of module names used by py.test that should be |     Returns a list of module names used by pytest that should be | ||||||
|     included by cx_freeze. |     included by cx_freeze. | ||||||
|     """ |     """ | ||||||
|     import py |     import py | ||||||
|  |  | ||||||
|  | @ -90,7 +90,7 @@ def pytest_addoption(parser): | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def pytest_configure(config): | def pytest_configure(config): | ||||||
|     __import__('pytest').config = config  # compatibiltiy |     __import__('pytest').config = config  # compatibility | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def wrap_session(config, doit): | def wrap_session(config, doit): | ||||||
|  | @ -290,7 +290,7 @@ class Interrupted(KeyboardInterrupt): | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class Failed(Exception): | class Failed(Exception): | ||||||
|     """ signals an stop as failed test run. """ |     """ signals a stop as failed test run. """ | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class Session(nodes.FSCollector): | class Session(nodes.FSCollector): | ||||||
|  |  | ||||||
|  | @ -215,7 +215,7 @@ class MarkDecorator(object): | ||||||
| 
 | 
 | ||||||
| def get_unpacked_marks(obj): | def get_unpacked_marks(obj): | ||||||
|     """ |     """ | ||||||
|     obtain the unpacked marks that are stored on a object |     obtain the unpacked marks that are stored on an object | ||||||
|     """ |     """ | ||||||
|     mark_list = getattr(obj, 'pytestmark', []) |     mark_list = getattr(obj, 'pytestmark', []) | ||||||
| 
 | 
 | ||||||
|  | @ -228,7 +228,7 @@ def get_unpacked_marks(obj): | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def store_mark(obj, mark): | def store_mark(obj, mark): | ||||||
|     """store a Mark on a object |     """store a Mark on an object | ||||||
|     this is used to implement the Mark declarations/decorators correctly |     this is used to implement the Mark declarations/decorators correctly | ||||||
|     """ |     """ | ||||||
|     assert isinstance(mark, Mark), mark |     assert isinstance(mark, Mark), mark | ||||||
|  |  | ||||||
|  | @ -83,7 +83,7 @@ skip.Exception = Skipped | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def fail(msg="", pytrace=True): | def fail(msg="", pytrace=True): | ||||||
|     """ explicitly fail an currently-executing test with the given Message. |     """ explicitly fail a currently-executing test with the given Message. | ||||||
| 
 | 
 | ||||||
|     :arg pytrace: if false the msg represents the full failure information |     :arg pytrace: if false the msg represents the full failure information | ||||||
|                   and no python traceback will be reported. |                   and no python traceback will be reported. | ||||||
|  |  | ||||||
|  | @ -714,7 +714,7 @@ class Testdir(object): | ||||||
|         """ |         """ | ||||||
|         finalizers = [] |         finalizers = [] | ||||||
|         try: |         try: | ||||||
|             # When running py.test inline any plugins active in the main test |             # When running pytest inline any plugins active in the main test | ||||||
|             # process are already imported.  So this disables the warning which |             # process are already imported.  So this disables the warning which | ||||||
|             # will trigger to say they can no longer be rewritten, which is |             # will trigger to say they can no longer be rewritten, which is | ||||||
|             # fine as they have already been rewritten. |             # fine as they have already been rewritten. | ||||||
|  | @ -725,7 +725,7 @@ class Testdir(object): | ||||||
|             finalizers.append(revert_warn_already_imported) |             finalizers.append(revert_warn_already_imported) | ||||||
|             AssertionRewritingHook._warn_already_imported = lambda *a: None |             AssertionRewritingHook._warn_already_imported = lambda *a: None | ||||||
| 
 | 
 | ||||||
|             # Any sys.module or sys.path changes done while running py.test |             # Any sys.module or sys.path changes done while running pytest | ||||||
|             # inline should be reverted after the test run completes to avoid |             # inline should be reverted after the test run completes to avoid | ||||||
|             # clashing with later inline tests run within the same pytest test, |             # clashing with later inline tests run within the same pytest test, | ||||||
|             # e.g. just because they use matching test module names. |             # e.g. just because they use matching test module names. | ||||||
|  |  | ||||||
|  | @ -55,7 +55,7 @@ def filter_traceback(entry): | ||||||
|     is_generated = '<' in raw_filename and '>' in raw_filename |     is_generated = '<' in raw_filename and '>' in raw_filename | ||||||
|     if is_generated: |     if is_generated: | ||||||
|         return False |         return False | ||||||
|     # entry.path might point to an non-existing file, in which case it will |     # entry.path might point to a non-existing file, in which case it will | ||||||
|     # also return a str object. see #1133 |     # also return a str object. see #1133 | ||||||
|     p = py.path.local(entry.path) |     p = py.path.local(entry.path) | ||||||
|     return not p.relto(_pluggy_dir) and not p.relto(_pytest_dir) and not p.relto(_py_dir) |     return not p.relto(_pluggy_dir) and not p.relto(_pytest_dir) and not p.relto(_py_dir) | ||||||
|  |  | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | Change documentation copyright year to a range which auto-updates itself each time it is published. | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | Update all pypi.python.org URLs to pypi.org. | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | When showing diffs of failed assertions where the contents contain only whitespace, escape them using ``repr()`` first to make it easy to spot the differences. | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| <h3>Useful Links</h3> | <h3>Useful Links</h3> | ||||||
| <ul> | <ul> | ||||||
|   <li><a href="https://pypi.python.org/pypi/pytest">pytest @ PyPI</a></li> |   <li><a href="https://pypi.org/project/pytest/">pytest @ PyPI</a></li> | ||||||
|   <li><a href="https://github.com/pytest-dev/pytest/">pytest @ GitHub</a></li> |   <li><a href="https://github.com/pytest-dev/pytest/">pytest @ GitHub</a></li> | ||||||
|   <li><a href="http://plugincompat.herokuapp.com/">3rd party plugins</a></li> |   <li><a href="http://plugincompat.herokuapp.com/">3rd party plugins</a></li> | ||||||
|   <li><a href="https://github.com/pytest-dev/pytest/issues">Issue Tracker</a></li> |   <li><a href="https://github.com/pytest-dev/pytest/issues">Issue Tracker</a></li> | ||||||
|  |  | ||||||
|  | @ -18,7 +18,7 @@ comes with the following fixes and features: | ||||||
|   rather use the post-2.0 parametrize features instead of yield, see: |   rather use the post-2.0 parametrize features instead of yield, see: | ||||||
|   http://pytest.org/latest/example/parametrize.html |   http://pytest.org/latest/example/parametrize.html | ||||||
| - fix autouse-issue where autouse-fixtures would not be discovered | - fix autouse-issue where autouse-fixtures would not be discovered | ||||||
|   if defined in a a/conftest.py file and tests in a/tests/test_some.py |   if defined in an a/conftest.py file and tests in a/tests/test_some.py | ||||||
| - fix issue226 - LIFO ordering for fixture teardowns | - fix issue226 - LIFO ordering for fixture teardowns | ||||||
| - fix issue224 - invocations with >256 char arguments now work | - fix issue224 - invocations with >256 char arguments now work | ||||||
| - fix issue91 - add/discuss package/directory level setups in example | - fix issue91 - add/discuss package/directory level setups in example | ||||||
|  |  | ||||||
|  | @ -14,7 +14,7 @@ few interesting new plugins saw the light last month: | ||||||
| 
 | 
 | ||||||
| And several others like pytest-django saw maintenance releases. | And several others like pytest-django saw maintenance releases. | ||||||
| For a more complete list, check out  | For a more complete list, check out  | ||||||
| https://pypi.python.org/pypi?%3Aaction=search&term=pytest&submit=search. | https://pypi.org/search/?q=pytest | ||||||
| 
 | 
 | ||||||
| For general information see: | For general information see: | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -23,14 +23,14 @@ a full list of details.  A few feature highlights: | ||||||
|   called if the corresponding setup method succeeded. |   called if the corresponding setup method succeeded. | ||||||
| 
 | 
 | ||||||
| - integrate tab-completion on command line options if you | - integrate tab-completion on command line options if you | ||||||
|   have `argcomplete <http://pypi.python.org/pypi/argcomplete>`_  |   have `argcomplete <https://pypi.org/project/argcomplete/>`_  | ||||||
|   configured. |   configured. | ||||||
| 
 | 
 | ||||||
| - allow boolean expression directly with skipif/xfail | - allow boolean expression directly with skipif/xfail | ||||||
|   if a "reason" is also specified. |   if a "reason" is also specified. | ||||||
| 
 | 
 | ||||||
| - a new hook ``pytest_load_initial_conftests`` allows plugins like | - a new hook ``pytest_load_initial_conftests`` allows plugins like | ||||||
|   `pytest-django <http://pypi.python.org/pypi/pytest-django>`_ to |   `pytest-django <https://pypi.org/project/pytest-django/>`_ to | ||||||
|   influence the environment before conftest files import ``django``. |   influence the environment before conftest files import ``django``. | ||||||
| 
 | 
 | ||||||
| - reporting: color the last line red or green depending if | - reporting: color the last line red or green depending if | ||||||
|  |  | ||||||
|  | @ -52,7 +52,7 @@ Changes 2.6.1 | ||||||
|   "::" node id specifications (copy pasted from "-v" output) |   "::" node id specifications (copy pasted from "-v" output) | ||||||
| 
 | 
 | ||||||
| - fix issue544 by only removing "@NUM" at the end of "::" separated parts | - fix issue544 by only removing "@NUM" at the end of "::" separated parts | ||||||
|   and if the part has an ".py" extension |   and if the part has a ".py" extension | ||||||
| 
 | 
 | ||||||
| - don't use py.std import helper, rather import things directly. | - don't use py.std import helper, rather import things directly. | ||||||
|   Thanks Bruno Oliveira. |   Thanks Bruno Oliveira. | ||||||
|  |  | ||||||
|  | @ -234,7 +234,7 @@ Inspecting Cache content | ||||||
| You can always peek at the content of the cache using the | You can always peek at the content of the cache using the | ||||||
| ``--cache-show`` command line option:: | ``--cache-show`` command line option:: | ||||||
| 
 | 
 | ||||||
|     $ py.test --cache-show |     $ pytest --cache-show | ||||||
|     =========================== test session starts ============================ |     =========================== test session starts ============================ | ||||||
|     platform linux -- Python 3.x.y, pytest-3.x.y, py-1.x.y, pluggy-0.x.y |     platform linux -- Python 3.x.y, pytest-3.x.y, py-1.x.y, pluggy-0.x.y | ||||||
|     rootdir: $REGENDOC_TMPDIR, inifile: |     rootdir: $REGENDOC_TMPDIR, inifile: | ||||||
|  |  | ||||||
|  | @ -20,6 +20,7 @@ | ||||||
| 
 | 
 | ||||||
| import os | import os | ||||||
| import sys | import sys | ||||||
|  | import datetime | ||||||
| 
 | 
 | ||||||
| from _pytest import __version__ as version | from _pytest import __version__ as version | ||||||
| 
 | 
 | ||||||
|  | @ -57,7 +58,8 @@ master_doc = 'contents' | ||||||
| 
 | 
 | ||||||
| # General information about the project. | # General information about the project. | ||||||
| project = u'pytest' | project = u'pytest' | ||||||
| copyright = u'2015, holger krekel and pytest-dev team' | year = datetime.datetime.utcnow().year | ||||||
|  | copyright = u'2015–{} , holger krekel and pytest-dev team'.format(year) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -10,7 +10,7 @@ Code Style | ||||||
| ---------- | ---------- | ||||||
| 
 | 
 | ||||||
| * `PEP-8 <https://www.python.org/dev/peps/pep-0008>`_ | * `PEP-8 <https://www.python.org/dev/peps/pep-0008>`_ | ||||||
| * `flake8 <https://pypi.python.org/pypi/flake8>`_ for quality checks | * `flake8 <https://pypi.org/project/flake8/>`_ for quality checks | ||||||
| * `invoke <http://www.pyinvoke.org/>`_ to automate development tasks | * `invoke <http://www.pyinvoke.org/>`_ to automate development tasks | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -10,7 +10,7 @@ A basic example for specifying tests in Yaml files | ||||||
| -------------------------------------------------------------- | -------------------------------------------------------------- | ||||||
| 
 | 
 | ||||||
| .. _`pytest-yamlwsgi`: http://bitbucket.org/aafshar/pytest-yamlwsgi/src/tip/pytest_yamlwsgi.py | .. _`pytest-yamlwsgi`: http://bitbucket.org/aafshar/pytest-yamlwsgi/src/tip/pytest_yamlwsgi.py | ||||||
| .. _`PyYAML`: http://pypi.python.org/pypi/PyYAML/ | .. _`PyYAML`: https://pypi.org/project/PyYAML/ | ||||||
| 
 | 
 | ||||||
| Here is an example ``conftest.py`` (extracted from Ali Afshnars special purpose `pytest-yamlwsgi`_ plugin).   This ``conftest.py`` will  collect ``test*.yml`` files and will execute the yaml-formatted content as custom tests: | Here is an example ``conftest.py`` (extracted from Ali Afshnars special purpose `pytest-yamlwsgi`_ plugin).   This ``conftest.py`` will  collect ``test*.yml`` files and will execute the yaml-formatted content as custom tests: | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -160,7 +160,7 @@ together with the actual data, instead of listing them separately. | ||||||
| A quick port of "testscenarios" | A quick port of "testscenarios" | ||||||
| ------------------------------------ | ------------------------------------ | ||||||
| 
 | 
 | ||||||
| .. _`test scenarios`: http://pypi.python.org/pypi/testscenarios/ | .. _`test scenarios`: https://pypi.org/project/testscenarios/ | ||||||
| 
 | 
 | ||||||
| Here is a quick port to run tests configured with `test scenarios`_, | Here is a quick port to run tests configured with `test scenarios`_, | ||||||
| an add-on from Robert Collins for the standard unittest framework. We | an add-on from Robert Collins for the standard unittest framework. We | ||||||
|  | @ -469,7 +469,7 @@ If you run this with reporting for skips enabled:: | ||||||
|      |      | ||||||
|     =================== 1 passed, 1 skipped in 0.12 seconds ==================== |     =================== 1 passed, 1 skipped in 0.12 seconds ==================== | ||||||
| 
 | 
 | ||||||
| You'll see that we don't have a ``opt2`` module and thus the second test run | You'll see that we don't have an ``opt2`` module and thus the second test run | ||||||
| of our ``test_func1`` was skipped.  A few notes: | of our ``test_func1`` was skipped.  A few notes: | ||||||
| 
 | 
 | ||||||
| - the fixture functions in the ``conftest.py`` file are "session-scoped" because we | - the fixture functions in the ``conftest.py`` file are "session-scoped" because we | ||||||
|  |  | ||||||
|  | @ -54,7 +54,7 @@ Keeping duplicate paths specified from command line | ||||||
| Default behavior of ``pytest`` is to ignore duplicate paths specified from the command line. | Default behavior of ``pytest`` is to ignore duplicate paths specified from the command line. | ||||||
| Example:: | Example:: | ||||||
| 
 | 
 | ||||||
|     py.test path_a path_a |     pytest path_a path_a | ||||||
| 
 | 
 | ||||||
|     ... |     ... | ||||||
|     collected 1 item |     collected 1 item | ||||||
|  | @ -65,7 +65,7 @@ Just collect tests once. | ||||||
| To collect duplicate tests, use the ``--keep-duplicates`` option on the cli. | To collect duplicate tests, use the ``--keep-duplicates`` option on the cli. | ||||||
| Example:: | Example:: | ||||||
| 
 | 
 | ||||||
|     py.test --keep-duplicates path_a path_a |     pytest --keep-duplicates path_a path_a | ||||||
| 
 | 
 | ||||||
|     ... |     ... | ||||||
|     collected 2 items |     collected 2 items | ||||||
|  | @ -75,7 +75,7 @@ As the collector just works on directories, if you specify twice a single test f | ||||||
| still collect it twice, no matter if the ``--keep-duplicates`` is not specified. | still collect it twice, no matter if the ``--keep-duplicates`` is not specified. | ||||||
| Example:: | Example:: | ||||||
| 
 | 
 | ||||||
|     py.test test_a.py test_a.py |     pytest test_a.py test_a.py | ||||||
| 
 | 
 | ||||||
|     ... |     ... | ||||||
|     collected 2 items |     collected 2 items | ||||||
|  |  | ||||||
|  | @ -108,7 +108,7 @@ the command line arguments before they get processed: | ||||||
|             num = max(multiprocessing.cpu_count() / 2, 1) |             num = max(multiprocessing.cpu_count() / 2, 1) | ||||||
|             args[:] = ["-n", str(num)] + args |             args[:] = ["-n", str(num)] + args | ||||||
| 
 | 
 | ||||||
| If you have the `xdist plugin <https://pypi.python.org/pypi/pytest-xdist>`_ installed | If you have the `xdist plugin <https://pypi.org/project/pytest-xdist/>`_ installed | ||||||
| you will now always perform test runs using a number | you will now always perform test runs using a number | ||||||
| of subprocesses close to your CPU. Running in an empty | of subprocesses close to your CPU. Running in an empty | ||||||
| directory with the above conftest.py:: | directory with the above conftest.py:: | ||||||
|  | @ -778,7 +778,7 @@ which test got stuck, for example if pytest was run in quiet mode (``-q``) or yo | ||||||
| output. This is particularly a problem if the problem helps only sporadically, the famous "flaky" kind of tests. | output. This is particularly a problem if the problem helps only sporadically, the famous "flaky" kind of tests. | ||||||
| 
 | 
 | ||||||
| ``pytest`` sets a ``PYTEST_CURRENT_TEST`` environment variable when running tests, which can be inspected | ``pytest`` sets a ``PYTEST_CURRENT_TEST`` environment variable when running tests, which can be inspected | ||||||
| by process monitoring utilities or libraries like `psutil <https://pypi.python.org/pypi/psutil>`_ to discover which | by process monitoring utilities or libraries like `psutil <https://pypi.org/project/psutil/>`_ to discover which | ||||||
| test got stuck if necessary: | test got stuck if necessary: | ||||||
| 
 | 
 | ||||||
| .. code-block:: python | .. code-block:: python | ||||||
|  |  | ||||||
|  | @ -30,14 +30,14 @@ and does not handle Deferreds returned from a test in pytest style. | ||||||
| If you are using trial's unittest.TestCase chances are that you can | If you are using trial's unittest.TestCase chances are that you can | ||||||
| just run your tests even if you return Deferreds.  In addition, | just run your tests even if you return Deferreds.  In addition, | ||||||
| there also is a dedicated `pytest-twisted | there also is a dedicated `pytest-twisted | ||||||
| <http://pypi.python.org/pypi/pytest-twisted>`_ plugin which allows you to | <https://pypi.org/project/pytest-twisted/>`_ plugin which allows you to | ||||||
| return deferreds from pytest-style tests, allowing the use of | return deferreds from pytest-style tests, allowing the use of | ||||||
| :ref:`fixtures` and other features. | :ref:`fixtures` and other features. | ||||||
| 
 | 
 | ||||||
| how does pytest work with Django? | how does pytest work with Django? | ||||||
| ++++++++++++++++++++++++++++++++++++++++++++++ | ++++++++++++++++++++++++++++++++++++++++++++++ | ||||||
| 
 | 
 | ||||||
| In 2012, some work is going into the `pytest-django plugin <http://pypi.python.org/pypi/pytest-django>`_.  It substitutes the usage of Django's | In 2012, some work is going into the `pytest-django plugin <https://pypi.org/project/pytest-django/>`_.  It substitutes the usage of Django's | ||||||
| ``manage.py test`` and allows the use of all pytest features_ most of which | ``manage.py test`` and allows the use of all pytest features_ most of which | ||||||
| are not available from Django directly. | are not available from Django directly. | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -154,7 +154,7 @@ This makes use of the automatic caching mechanisms of pytest. | ||||||
| Another good approach is by adding the data files in the ``tests`` folder. | Another good approach is by adding the data files in the ``tests`` folder. | ||||||
| There are also community plugins available to help managing this aspect of  | There are also community plugins available to help managing this aspect of  | ||||||
| testing, e.g. `pytest-datadir <https://github.com/gabrielcnr/pytest-datadir>`__  | testing, e.g. `pytest-datadir <https://github.com/gabrielcnr/pytest-datadir>`__  | ||||||
| and `pytest-datafiles <https://pypi.python.org/pypi/pytest-datafiles>`__.  | and `pytest-datafiles <https://pypi.org/project/pytest-datafiles/>`__.  | ||||||
| 
 | 
 | ||||||
| .. _smtpshared: | .. _smtpshared: | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -5,10 +5,10 @@ Installation and Getting Started | ||||||
| 
 | 
 | ||||||
| **Platforms**: Unix/Posix and Windows | **Platforms**: Unix/Posix and Windows | ||||||
| 
 | 
 | ||||||
| **PyPI package name**: `pytest <http://pypi.python.org/pypi/pytest>`_ | **PyPI package name**: `pytest <https://pypi.org/project/pytest/>`_ | ||||||
| 
 | 
 | ||||||
| **Dependencies**: `py <http://pypi.python.org/pypi/py>`_, | **Dependencies**: `py <https://pypi.org/project/py/>`_, | ||||||
| `colorama (Windows) <http://pypi.python.org/pypi/colorama>`_, | `colorama (Windows) <https://pypi.org/project/colorama/>`_, | ||||||
| 
 | 
 | ||||||
| **Documentation as PDF**: `download latest <https://media.readthedocs.org/pdf/pytest/latest/pytest.pdf>`_ | **Documentation as PDF**: `download latest <https://media.readthedocs.org/pdf/pytest/latest/pytest.pdf>`_ | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -145,7 +145,7 @@ Note that this layout also works in conjunction with the ``src`` layout mentione | ||||||
| 
 | 
 | ||||||
| .. note:: | .. note:: | ||||||
| 
 | 
 | ||||||
|     If ``pytest`` finds a "a/b/test_module.py" test file while |     If ``pytest`` finds an "a/b/test_module.py" test file while | ||||||
|     recursing into the filesystem it determines the import name |     recursing into the filesystem it determines the import name | ||||||
|     as follows: |     as follows: | ||||||
| 
 | 
 | ||||||
|  | @ -168,9 +168,9 @@ Note that this layout also works in conjunction with the ``src`` layout mentione | ||||||
|     to avoid surprises such as a test module getting imported twice. |     to avoid surprises such as a test module getting imported twice. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| .. _`virtualenv`: http://pypi.python.org/pypi/virtualenv | .. _`virtualenv`: https://pypi.org/project/virtualenv/ | ||||||
| .. _`buildout`: http://www.buildout.org/ | .. _`buildout`: http://www.buildout.org/ | ||||||
| .. _pip: http://pypi.python.org/pypi/pip | .. _pip: https://pypi.org/project/pip/ | ||||||
| 
 | 
 | ||||||
| .. _`use tox`: | .. _`use tox`: | ||||||
| 
 | 
 | ||||||
|  | @ -205,7 +205,7 @@ Integrating with setuptools / ``python setup.py test`` / ``pytest-runner`` | ||||||
| -------------------------------------------------------------------------- | -------------------------------------------------------------------------- | ||||||
| 
 | 
 | ||||||
| You can integrate test runs into your setuptools based project | You can integrate test runs into your setuptools based project | ||||||
| with the `pytest-runner <https://pypi.python.org/pypi/pytest-runner>`_ plugin. | with the `pytest-runner <https://pypi.org/project/pytest-runner/>`_ plugin. | ||||||
| 
 | 
 | ||||||
| Add this to ``setup.py`` file: | Add this to ``setup.py`` file: | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -7,14 +7,14 @@ | ||||||
| .. _`reStructured Text`: http://docutils.sourceforge.net | .. _`reStructured Text`: http://docutils.sourceforge.net | ||||||
| .. _`Python debugger`: http://docs.python.org/lib/module-pdb.html | .. _`Python debugger`: http://docs.python.org/lib/module-pdb.html | ||||||
| .. _nose: https://nose.readthedocs.io/en/latest/ | .. _nose: https://nose.readthedocs.io/en/latest/ | ||||||
| .. _pytest: http://pypi.python.org/pypi/pytest | .. _pytest: https://pypi.org/project/pytest/ | ||||||
| .. _mercurial: http://mercurial.selenic.com/wiki/ | .. _mercurial: http://mercurial.selenic.com/wiki/ | ||||||
| .. _`setuptools`: http://pypi.python.org/pypi/setuptools | .. _`setuptools`: https://pypi.org/project/setuptools/ | ||||||
| .. _`easy_install`: | .. _`easy_install`: | ||||||
| .. _`distribute docs`: | .. _`distribute docs`: | ||||||
| .. _`distribute`: http://pypi.python.org/pypi/distribute | .. _`distribute`: https://pypi.org/project/distribute/ | ||||||
| .. _`pip`: http://pypi.python.org/pypi/pip | .. _`pip`: https://pypi.org/project/pip/ | ||||||
| .. _`virtualenv`: http://pypi.python.org/pypi/virtualenv | .. _`virtualenv`: https://pypi.org/project/virtualenv/ | ||||||
| .. _hudson: http://hudson-ci.org/ | .. _hudson: http://hudson-ci.org/ | ||||||
| .. _jenkins: http://jenkins-ci.org/ | .. _jenkins: http://jenkins-ci.org/ | ||||||
| .. _tox: http://testrun.org/tox | .. _tox: http://testrun.org/tox | ||||||
|  |  | ||||||
|  | @ -20,39 +20,39 @@ Here is a little annotated list for some popular plugins: | ||||||
| 
 | 
 | ||||||
| .. _`django`: https://www.djangoproject.com/ | .. _`django`: https://www.djangoproject.com/ | ||||||
| 
 | 
 | ||||||
| * `pytest-django <http://pypi.python.org/pypi/pytest-django>`_: write tests | * `pytest-django <https://pypi.org/project/pytest-django/>`_: write tests | ||||||
|   for `django`_ apps, using pytest integration. |   for `django`_ apps, using pytest integration. | ||||||
| 
 | 
 | ||||||
| * `pytest-twisted <http://pypi.python.org/pypi/pytest-twisted>`_: write tests | * `pytest-twisted <https://pypi.org/project/pytest-twisted/>`_: write tests | ||||||
|   for `twisted <http://twistedmatrix.com>`_ apps, starting a reactor and |   for `twisted <http://twistedmatrix.com>`_ apps, starting a reactor and | ||||||
|   processing deferreds from test functions. |   processing deferreds from test functions. | ||||||
| 
 | 
 | ||||||
| * `pytest-cov <http://pypi.python.org/pypi/pytest-cov>`_: | * `pytest-cov <https://pypi.org/project/pytest-cov/>`_: | ||||||
|   coverage reporting, compatible with distributed testing |   coverage reporting, compatible with distributed testing | ||||||
| 
 | 
 | ||||||
| * `pytest-xdist <http://pypi.python.org/pypi/pytest-xdist>`_: | * `pytest-xdist <https://pypi.org/project/pytest-xdist/>`_: | ||||||
|   to distribute tests to CPUs and remote hosts, to run in boxed |   to distribute tests to CPUs and remote hosts, to run in boxed | ||||||
|   mode which allows to survive segmentation faults, to run in |   mode which allows to survive segmentation faults, to run in | ||||||
|   looponfailing mode, automatically re-running failing tests |   looponfailing mode, automatically re-running failing tests | ||||||
|   on file changes. |   on file changes. | ||||||
| 
 | 
 | ||||||
| * `pytest-instafail <http://pypi.python.org/pypi/pytest-instafail>`_: | * `pytest-instafail <https://pypi.org/project/pytest-instafail/>`_: | ||||||
|   to report failures while the test run is happening. |   to report failures while the test run is happening. | ||||||
| 
 | 
 | ||||||
| * `pytest-bdd <http://pypi.python.org/pypi/pytest-bdd>`_ and | * `pytest-bdd <https://pypi.org/project/pytest-bdd/>`_ and | ||||||
|   `pytest-konira <http://pypi.python.org/pypi/pytest-konira>`_ |   `pytest-konira <https://pypi.org/project/pytest-konira/>`_ | ||||||
|   to write tests using behaviour-driven testing. |   to write tests using behaviour-driven testing. | ||||||
| 
 | 
 | ||||||
| * `pytest-timeout <http://pypi.python.org/pypi/pytest-timeout>`_: | * `pytest-timeout <https://pypi.org/project/pytest-timeout/>`_: | ||||||
|   to timeout tests based on function marks or global definitions. |   to timeout tests based on function marks or global definitions. | ||||||
| 
 | 
 | ||||||
| * `pytest-pep8 <http://pypi.python.org/pypi/pytest-pep8>`_: | * `pytest-pep8 <https://pypi.org/project/pytest-pep8/>`_: | ||||||
|   a ``--pep8`` option to enable PEP8 compliance checking. |   a ``--pep8`` option to enable PEP8 compliance checking. | ||||||
| 
 | 
 | ||||||
| * `pytest-flakes <https://pypi.python.org/pypi/pytest-flakes>`_: | * `pytest-flakes <https://pypi.org/project/pytest-flakes/>`_: | ||||||
|   check source code with pyflakes. |   check source code with pyflakes. | ||||||
| 
 | 
 | ||||||
| * `oejskit <http://pypi.python.org/pypi/oejskit>`_: | * `oejskit <https://pypi.org/project/oejskit/>`_: | ||||||
|   a plugin to run javascript unittests in live browsers. |   a plugin to run javascript unittests in live browsers. | ||||||
| 
 | 
 | ||||||
| To see a complete list of all plugins with their latest testing | To see a complete list of all plugins with their latest testing | ||||||
|  | @ -61,7 +61,7 @@ status against different pytest and Python versions, please visit | ||||||
| 
 | 
 | ||||||
| You may also discover more plugins through a `pytest- pypi.python.org search`_. | You may also discover more plugins through a `pytest- pypi.python.org search`_. | ||||||
| 
 | 
 | ||||||
| .. _`pytest- pypi.python.org search`: http://pypi.python.org/pypi?%3Aaction=search&term=pytest-&submit=search | .. _`pytest- pypi.python.org search`: https://pypi.org/search/?q=pytest- | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| .. _`available installable plugins`: | .. _`available installable plugins`: | ||||||
|  |  | ||||||
|  | @ -32,40 +32,40 @@ Here are some examples of projects using ``pytest`` (please send notes via :ref: | ||||||
| * `PyPM <http://code.activestate.com/pypm/>`_ ActiveState's package manager | * `PyPM <http://code.activestate.com/pypm/>`_ ActiveState's package manager | ||||||
| * `Fom <http://packages.python.org/Fom/>`_ a fluid object mapper for FluidDB | * `Fom <http://packages.python.org/Fom/>`_ a fluid object mapper for FluidDB | ||||||
| * `applib <https://github.com/ActiveState/applib>`_ cross-platform utilities | * `applib <https://github.com/ActiveState/applib>`_ cross-platform utilities | ||||||
| * `six <http://pypi.python.org/pypi/six/>`_ Python 2 and 3 compatibility utilities | * `six <https://pypi.org/project/six/>`_ Python 2 and 3 compatibility utilities | ||||||
| * `pediapress <http://code.pediapress.com/wiki/wiki>`_ MediaWiki articles | * `pediapress <http://code.pediapress.com/wiki/wiki>`_ MediaWiki articles | ||||||
| * `mwlib <http://pypi.python.org/pypi/mwlib>`_ mediawiki parser and utility library | * `mwlib <https://pypi.org/project/mwlib/>`_ mediawiki parser and utility library | ||||||
| * `The Translate Toolkit <http://translate.sourceforge.net/wiki/toolkit/index>`_ for localization and conversion | * `The Translate Toolkit <http://translate.sourceforge.net/wiki/toolkit/index>`_ for localization and conversion | ||||||
| * `execnet <http://codespeak.net/execnet>`_ rapid multi-Python deployment | * `execnet <http://codespeak.net/execnet>`_ rapid multi-Python deployment | ||||||
| * `pylib <https://py.readthedocs.io>`_ cross-platform path, IO, dynamic code library | * `pylib <https://py.readthedocs.io>`_ cross-platform path, IO, dynamic code library | ||||||
| * `Pacha <http://pacha.cafepais.com/>`_ configuration management in five minutes | * `Pacha <http://pacha.cafepais.com/>`_ configuration management in five minutes | ||||||
| * `bbfreeze <http://pypi.python.org/pypi/bbfreeze>`_ create standalone executables from Python scripts | * `bbfreeze <https://pypi.org/project/bbfreeze/>`_ create standalone executables from Python scripts | ||||||
| * `pdb++ <http://bitbucket.org/antocuni/pdb>`_ a fancier version of PDB | * `pdb++ <http://bitbucket.org/antocuni/pdb>`_ a fancier version of PDB | ||||||
| * `py-s3fuse <http://code.google.com/p/py-s3fuse/>`_ Amazon S3 FUSE based filesystem | * `py-s3fuse <http://code.google.com/p/py-s3fuse/>`_ Amazon S3 FUSE based filesystem | ||||||
| * `waskr <http://code.google.com/p/waskr/>`_ WSGI Stats Middleware | * `waskr <http://code.google.com/p/waskr/>`_ WSGI Stats Middleware | ||||||
| * `guachi <http://code.google.com/p/guachi/>`_ global persistent configs for Python modules | * `guachi <http://code.google.com/p/guachi/>`_ global persistent configs for Python modules | ||||||
| * `Circuits <http://pypi.python.org/pypi/circuits>`_ lightweight Event Driven Framework | * `Circuits <https://pypi.org/project/circuits/>`_ lightweight Event Driven Framework | ||||||
| * `pygtk-helpers <http://bitbucket.org/aafshar/pygtkhelpers-main/>`_ easy interaction with PyGTK | * `pygtk-helpers <http://bitbucket.org/aafshar/pygtkhelpers-main/>`_ easy interaction with PyGTK | ||||||
| * `QuantumCore <http://quantumcore.org/>`_ statusmessage and repoze openid plugin | * `QuantumCore <http://quantumcore.org/>`_ statusmessage and repoze openid plugin | ||||||
| * `pydataportability <http://pydataportability.net/>`_ libraries for managing the open web | * `pydataportability <http://pydataportability.net/>`_ libraries for managing the open web | ||||||
| * `XIST <http://www.livinglogic.de/Python/xist/>`_ extensible HTML/XML generator | * `XIST <http://www.livinglogic.de/Python/xist/>`_ extensible HTML/XML generator | ||||||
| * `tiddlyweb <http://pypi.python.org/pypi/tiddlyweb>`_ optionally headless, extensible RESTful datastore | * `tiddlyweb <https://pypi.org/project/tiddlyweb/>`_ optionally headless, extensible RESTful datastore | ||||||
| * `fancycompleter <http://bitbucket.org/antocuni/fancycompleter/src>`_ for colorful tab-completion | * `fancycompleter <http://bitbucket.org/antocuni/fancycompleter/src>`_ for colorful tab-completion | ||||||
| * `Paludis <http://paludis.exherbo.org/>`_ tools for Gentoo Paludis package manager | * `Paludis <http://paludis.exherbo.org/>`_ tools for Gentoo Paludis package manager | ||||||
| * `Gerald <http://halfcooked.com/code/gerald/>`_ schema comparison tool | * `Gerald <http://halfcooked.com/code/gerald/>`_ schema comparison tool | ||||||
| * `abjad <http://code.google.com/p/abjad/>`_ Python API for Formalized Score control | * `abjad <http://code.google.com/p/abjad/>`_ Python API for Formalized Score control | ||||||
| * `bu <http://packages.python.org/bu/>`_ a microscopic build system | * `bu <http://packages.python.org/bu/>`_ a microscopic build system | ||||||
| * `katcp <https://bitbucket.org/hodgestar/katcp>`_ Telescope communication protocol over Twisted | * `katcp <https://bitbucket.org/hodgestar/katcp>`_ Telescope communication protocol over Twisted | ||||||
| * `kss plugin timer <http://pypi.python.org/pypi/kss.plugin.timer>`_ | * `kss plugin timer <https://pypi.org/project/kss.plugin.timer/>`_ | ||||||
| * `pyudev <https://pyudev.readthedocs.io/en/latest/tests/plugins.html>`_ a pure Python binding to the Linux library libudev | * `pyudev <https://pyudev.readthedocs.io/en/latest/tests/plugins.html>`_ a pure Python binding to the Linux library libudev | ||||||
| * `pytest-localserver <https://bitbucket.org/pytest-dev/pytest-localserver/>`_ a plugin for pytest that provides an httpserver and smtpserver | * `pytest-localserver <https://bitbucket.org/pytest-dev/pytest-localserver/>`_ a plugin for pytest that provides an httpserver and smtpserver | ||||||
| * `pytest-monkeyplus <http://pypi.python.org/pypi/pytest-monkeyplus/>`_ a plugin that extends monkeypatch | * `pytest-monkeyplus <https://pypi.org/project/pytest-monkeyplus/>`_ a plugin that extends monkeypatch | ||||||
| 
 | 
 | ||||||
| These projects help integrate ``pytest`` into other Python frameworks: | These projects help integrate ``pytest`` into other Python frameworks: | ||||||
| 
 | 
 | ||||||
| * `pytest-django <http://pypi.python.org/pypi/pytest-django/>`_ for Django | * `pytest-django <https://pypi.org/project/pytest-django/>`_ for Django | ||||||
| * `zope.pytest <http://packages.python.org/zope.pytest/>`_ for Zope and Grok | * `zope.pytest <http://packages.python.org/zope.pytest/>`_ for Zope and Grok | ||||||
| * `pytest_gae <http://pypi.python.org/pypi/pytest_gae/0.2.1>`_ for Google App Engine | * `pytest_gae <https://pypi.org/project/pytest_gae/0.2.1/>`_ for Google App Engine | ||||||
| * There is `some work <https://github.com/Kotti/Kotti/blob/master/kotti/testing.py>`_ underway for Kotti, a CMS built in Pyramid/Pylons | * There is `some work <https://github.com/Kotti/Kotti/blob/master/kotti/testing.py>`_ underway for Kotti, a CMS built in Pyramid/Pylons | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -118,7 +118,7 @@ all parameters marked as a fixture. | ||||||
| 
 | 
 | ||||||
| .. note:: | .. note:: | ||||||
| 
 | 
 | ||||||
|     The `pytest-lazy-fixture <https://pypi.python.org/pypi/pytest-lazy-fixture>`_ plugin implements a very |     The `pytest-lazy-fixture <https://pypi.org/project/pytest-lazy-fixture/>`_ plugin implements a very | ||||||
|     similar solution to the proposal below, make sure to check it out. |     similar solution to the proposal below, make sure to check it out. | ||||||
| 
 | 
 | ||||||
| .. code-block:: python | .. code-block:: python | ||||||
|  |  | ||||||
|  | @ -150,7 +150,7 @@ Unconditionally skip a test function. | ||||||
| pytest.mark.skipif | pytest.mark.skipif | ||||||
| ~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~ | ||||||
| 
 | 
 | ||||||
| **Tutorial**: :ref:`xfail`. | **Tutorial**: :ref:`skipif`. | ||||||
| 
 | 
 | ||||||
| Skip a test function if a condition is ``True``. | Skip a test function if a condition is ``True``. | ||||||
| 
 | 
 | ||||||
|  | @ -945,8 +945,8 @@ passed multiple times. The expected format is ``name=value``. For example:: | ||||||
| 
 | 
 | ||||||
|     Allows to pick the action for empty parametersets in parameterization |     Allows to pick the action for empty parametersets in parameterization | ||||||
| 
 | 
 | ||||||
|     * ``skip`` skips tests with a empty parameterset (default) |     * ``skip`` skips tests with an empty parameterset (default) | ||||||
|     * ``xfail`` marks tests with a empty parameterset as xfail(run=False) |     * ``xfail`` marks tests with an empty parameterset as xfail(run=False) | ||||||
| 
 | 
 | ||||||
|     .. code-block:: ini |     .. code-block:: ini | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -21,7 +21,7 @@ The `pytest-cov`_ package may be installed with pip or easy_install:: | ||||||
|     pip install pytest-cov |     pip install pytest-cov | ||||||
|     easy_install pytest-cov |     easy_install pytest-cov | ||||||
| 
 | 
 | ||||||
| .. _`pytest-cov`: http://pypi.python.org/pypi/pytest-cov/ | .. _`pytest-cov`: https://pypi.org/project/pytest-cov/ | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| Uninstallation | Uninstallation | ||||||
|  |  | ||||||
|  | @ -7,6 +7,6 @@ The approach enables to write integration tests such that the JavaScript code is | ||||||
| For more info and download please visit the `oejskit PyPI`_ page. | For more info and download please visit the `oejskit PyPI`_ page. | ||||||
| 
 | 
 | ||||||
| .. _`oejskit`: | .. _`oejskit`: | ||||||
| .. _`oejskit PyPI`: http://pypi.python.org/pypi/oejskit | .. _`oejskit PyPI`: https://pypi.org/project/oejskit/ | ||||||
| 
 | 
 | ||||||
| .. source link 'http://bitbucket.org/pedronis/js-infrastructure/src/tip/pytest_jstests.py', | .. source link 'http://bitbucket.org/pedronis/js-infrastructure/src/tip/pytest_jstests.py', | ||||||
|  |  | ||||||
|  | @ -26,7 +26,7 @@ program source code to the remote place.  All test results | ||||||
| are reported back and displayed to your local test session. | are reported back and displayed to your local test session. | ||||||
| You may specify different Python versions and interpreters. | You may specify different Python versions and interpreters. | ||||||
| 
 | 
 | ||||||
| .. _`pytest-xdist`: http://pypi.python.org/pypi/pytest-xdist | .. _`pytest-xdist`: https://pypi.org/project/pytest-xdist/ | ||||||
| 
 | 
 | ||||||
| Usage examples | Usage examples | ||||||
| --------------------- | --------------------- | ||||||
|  |  | ||||||
|  | @ -46,9 +46,9 @@ in most cases without having to modify existing code: | ||||||
| * :ref:`maxfail`; | * :ref:`maxfail`; | ||||||
| * :ref:`--pdb <pdb-option>` command-line option for debugging on test failures | * :ref:`--pdb <pdb-option>` command-line option for debugging on test failures | ||||||
|   (see :ref:`note <pdb-unittest-note>` below); |   (see :ref:`note <pdb-unittest-note>` below); | ||||||
| * Distribute tests to multiple CPUs using the `pytest-xdist <http://pypi.python.org/pypi/pytest-xdist>`_ plugin; | * Distribute tests to multiple CPUs using the `pytest-xdist <https://pypi.org/project/pytest-xdist/>`_ plugin; | ||||||
| * Use :ref:`plain assert-statements <assert>` instead of ``self.assert*`` functions (`unittest2pytest | * Use :ref:`plain assert-statements <assert>` instead of ``self.assert*`` functions (`unittest2pytest | ||||||
|   <https://pypi.python.org/pypi/unittest2pytest/>`__ is immensely helpful in this); |   <https://pypi.org/project/unittest2pytest/>`__ is immensely helpful in this); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| pytest features in ``unittest.TestCase`` subclasses | pytest features in ``unittest.TestCase`` subclasses | ||||||
|  |  | ||||||
|  | @ -421,7 +421,7 @@ Creating resultlog format files | ||||||
|     This option is rarely used and is scheduled for removal in 4.0. |     This option is rarely used and is scheduled for removal in 4.0. | ||||||
| 
 | 
 | ||||||
|     An alternative for users which still need similar functionality is to use the |     An alternative for users which still need similar functionality is to use the | ||||||
|     `pytest-tap <https://pypi.python.org/pypi/pytest-tap>`_ plugin which provides |     `pytest-tap <https://pypi.org/project/pytest-tap/>`_ plugin which provides | ||||||
|     a stream of test data. |     a stream of test data. | ||||||
| 
 | 
 | ||||||
|     If you have any concerns, please don't hesitate to |     If you have any concerns, please don't hesitate to | ||||||
|  |  | ||||||
|  | @ -103,7 +103,7 @@ Here is how you might run it:: | ||||||
| Writing your own plugin | Writing your own plugin | ||||||
| ----------------------- | ----------------------- | ||||||
| 
 | 
 | ||||||
| .. _`setuptools`: http://pypi.python.org/pypi/setuptools | .. _`setuptools`: https://pypi.org/project/setuptools/ | ||||||
| 
 | 
 | ||||||
| If you want to write a plugin, there are many real-life examples | If you want to write a plugin, there are many real-life examples | ||||||
| you can copy from: | you can copy from: | ||||||
|  |  | ||||||
|  | @ -1198,7 +1198,7 @@ def test_cwd_deleted(testdir): | ||||||
| def test_exception_repr_extraction_error_on_recursion(): | def test_exception_repr_extraction_error_on_recursion(): | ||||||
|     """ |     """ | ||||||
|     Ensure we can properly detect a recursion error even |     Ensure we can properly detect a recursion error even | ||||||
|     if some locals raise error on comparision (#2459). |     if some locals raise error on comparison (#2459). | ||||||
|     """ |     """ | ||||||
|     class numpy_like(object): |     class numpy_like(object): | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -523,6 +523,7 @@ class TestRequestBasic(object): | ||||||
|         testdir.makepyfile(""" |         testdir.makepyfile(""" | ||||||
|             import sys |             import sys | ||||||
|             import pytest |             import pytest | ||||||
|  |             from _pytest.compat import safe_str | ||||||
|             import gc |             import gc | ||||||
| 
 | 
 | ||||||
|             @pytest.fixture(autouse=True) |             @pytest.fixture(autouse=True) | ||||||
|  | @ -539,7 +540,7 @@ class TestRequestBasic(object): | ||||||
| 
 | 
 | ||||||
|                     gc.collect() |                     gc.collect() | ||||||
|                     leaked_types = sum(1 for _ in gc.garbage |                     leaked_types = sum(1 for _ in gc.garbage | ||||||
|                                     if 'PseudoFixtureDef' in str(_)) |                                        if 'PseudoFixtureDef' in safe_str(_)) | ||||||
| 
 | 
 | ||||||
|                     gc.garbage[:] = [] |                     gc.garbage[:] = [] | ||||||
| 
 | 
 | ||||||
|  | @ -1552,7 +1553,7 @@ class TestAutouseDiscovery(object): | ||||||
| 
 | 
 | ||||||
|     def test_callables_nocode(self, testdir): |     def test_callables_nocode(self, testdir): | ||||||
|         """ |         """ | ||||||
|         a imported mock.call would break setup/factory discovery |         an imported mock.call would break setup/factory discovery | ||||||
|         due to it being callable and __code__ not being a code object |         due to it being callable and __code__ not being a code object | ||||||
|         """ |         """ | ||||||
|         testdir.makepyfile(""" |         testdir.makepyfile(""" | ||||||
|  |  | ||||||
|  | @ -194,6 +194,7 @@ class TestMetafunc(object): | ||||||
|         assert metafunc._calls[3].id == "x1-b" |         assert metafunc._calls[3].id == "x1-b" | ||||||
| 
 | 
 | ||||||
|     @hypothesis.given(strategies.text() | strategies.binary()) |     @hypothesis.given(strategies.text() | strategies.binary()) | ||||||
|  |     @hypothesis.settings(deadline=400.0)  # very close to std deadline and CI boxes are not reliable in CPU power | ||||||
|     def test_idval_hypothesis(self, value): |     def test_idval_hypothesis(self, value): | ||||||
|         from _pytest.python import _idval |         from _pytest.python import _idval | ||||||
|         escaped = _idval(value, 'a', 6, None) |         escaped = _idval(value, 'a', 6, None) | ||||||
|  |  | ||||||
|  | @ -473,7 +473,7 @@ class TestAssert_reprcompare(object): | ||||||
|     def test_one_repr_empty(self): |     def test_one_repr_empty(self): | ||||||
|         """ |         """ | ||||||
|         the faulty empty string repr did trigger |         the faulty empty string repr did trigger | ||||||
|         a unbound local error in _diff_text |         an unbound local error in _diff_text | ||||||
|         """ |         """ | ||||||
|         class A(str): |         class A(str): | ||||||
|             def __repr__(self): |             def __repr__(self): | ||||||
|  | @ -746,6 +746,18 @@ def test_reprcompare_notin(mock_config): | ||||||
|     assert detail == ["'foo' is contained here:", '  aaafoobbb', '?    +++'] |     assert detail == ["'foo' is contained here:", '  aaafoobbb', '?    +++'] | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | def test_reprcompare_whitespaces(mock_config): | ||||||
|  |     detail = plugin.pytest_assertrepr_compare( | ||||||
|  |         mock_config, '==', '\r\n', '\n') | ||||||
|  |     assert detail == [ | ||||||
|  |         r"'\r\n' == '\n'", | ||||||
|  |         r"Strings contain only whitespace, escaping them using repr()", | ||||||
|  |         r"- '\r\n'", | ||||||
|  |         r"?  --", | ||||||
|  |         r"+ '\n'", | ||||||
|  |     ] | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| def test_pytest_assertrepr_compare_integration(testdir): | def test_pytest_assertrepr_compare_integration(testdir): | ||||||
|     testdir.makepyfile(""" |     testdir.makepyfile(""" | ||||||
|         def test_hello(): |         def test_hello(): | ||||||
|  |  | ||||||
|  | @ -998,7 +998,7 @@ class TestStdCapture(object): | ||||||
|                         reason='text output different for bytes on python3') |                         reason='text output different for bytes on python3') | ||||||
|     def test_capturing_readouterr_decode_error_handling(self): |     def test_capturing_readouterr_decode_error_handling(self): | ||||||
|         with self.getcapture() as cap: |         with self.getcapture() as cap: | ||||||
|             # triggered a internal error in pytest |             # triggered an internal error in pytest | ||||||
|             print('\xa6') |             print('\xa6') | ||||||
|             out, err = cap.readouterr() |             out, err = cap.readouterr() | ||||||
|         assert out == py.builtin._totext('\ufffd\n', 'unicode-escape') |         assert out == py.builtin._totext('\ufffd\n', 'unicode-escape') | ||||||
|  |  | ||||||
|  | @ -373,7 +373,7 @@ class TestConftestVisibility(object): | ||||||
|     (None, 1, 1), |     (None, 1, 1), | ||||||
| ]) | ]) | ||||||
| def test_search_conftest_up_to_inifile(testdir, confcutdir, passed, error): | def test_search_conftest_up_to_inifile(testdir, confcutdir, passed, error): | ||||||
|     """Test that conftest files are detected only up to a ini file, unless |     """Test that conftest files are detected only up to an ini file, unless | ||||||
|     an explicit --confcutdir option is given. |     an explicit --confcutdir option is given. | ||||||
|     """ |     """ | ||||||
|     root = testdir.tmpdir |     root = testdir.tmpdir | ||||||
|  |  | ||||||
|  | @ -289,7 +289,7 @@ def test_nose_setup_ordering(testdir): | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def test_apiwrapper_problem_issue260(testdir): | def test_apiwrapper_problem_issue260(testdir): | ||||||
|     # this would end up trying a call a optional teardown on the class |     # this would end up trying a call an optional teardown on the class | ||||||
|     # for plain unittests we dont want nose behaviour |     # for plain unittests we dont want nose behaviour | ||||||
|     testdir.makepyfile(""" |     testdir.makepyfile(""" | ||||||
|         import unittest |         import unittest | ||||||
|  |  | ||||||
							
								
								
									
										6
									
								
								tox.ini
								
								
								
								
							
							
						
						
									
										6
									
								
								tox.ini
								
								
								
								
							|  | @ -20,7 +20,7 @@ envlist = | ||||||
| commands = pytest --lsof -ra {posargs:testing} | commands = pytest --lsof -ra {posargs:testing} | ||||||
| passenv = USER USERNAME | passenv = USER USERNAME | ||||||
| deps = | deps = | ||||||
|     hypothesis>=3.5.2 |     hypothesis>=3.56 | ||||||
|     nose |     nose | ||||||
|     mock |     mock | ||||||
|     requests |     requests | ||||||
|  | @ -53,7 +53,7 @@ deps = | ||||||
|     pytest-xdist>=1.13 |     pytest-xdist>=1.13 | ||||||
|     mock |     mock | ||||||
|     nose |     nose | ||||||
|     hypothesis>=3.5.2 |     hypothesis>=3.56 | ||||||
| changedir=testing | changedir=testing | ||||||
| commands = | commands = | ||||||
|     pytest -n8 -ra {posargs:.} |     pytest -n8 -ra {posargs:.} | ||||||
|  | @ -78,7 +78,7 @@ commands = {[testenv:py27-pexpect]commands} | ||||||
| [testenv:py27-nobyte] | [testenv:py27-nobyte] | ||||||
| deps = | deps = | ||||||
|     pytest-xdist>=1.13 |     pytest-xdist>=1.13 | ||||||
|     hypothesis>=3.5.2 |     hypothesis>=3.56 | ||||||
| distribute = true | distribute = true | ||||||
| changedir=testing | changedir=testing | ||||||
| setenv = | setenv = | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue