Merge pull request #3659 from nicoddemus/merge-master-into-features
Merge master into features
This commit is contained in:
commit
3f5e06ecc4
|
@ -8,6 +8,52 @@
|
||||||
|
|
||||||
.. towncrier release notes start
|
.. towncrier release notes start
|
||||||
|
|
||||||
|
Pytest 3.6.3 (2018-07-04)
|
||||||
|
=========================
|
||||||
|
|
||||||
|
Bug Fixes
|
||||||
|
---------
|
||||||
|
|
||||||
|
- Fix ``ImportWarning`` triggered by explicit relative imports in
|
||||||
|
assertion-rewritten package modules. (`#3061
|
||||||
|
<https://github.com/pytest-dev/pytest/issues/3061>`_)
|
||||||
|
|
||||||
|
- Fix error in ``pytest.approx`` when dealing with 0-dimension numpy
|
||||||
|
arrays. (`#3593 <https://github.com/pytest-dev/pytest/issues/3593>`_)
|
||||||
|
|
||||||
|
- No longer raise ``ValueError`` when using the ``get_marker`` API. (`#3605
|
||||||
|
<https://github.com/pytest-dev/pytest/issues/3605>`_)
|
||||||
|
|
||||||
|
- Fix problem where log messages with non-ascii characters would not
|
||||||
|
appear in the output log file.
|
||||||
|
(`#3630 <https://github.com/pytest-dev/pytest/issues/3630>`_)
|
||||||
|
|
||||||
|
- No longer raise ``AttributeError`` when legacy marks can't be stored in
|
||||||
|
functions. (`#3631 <https://github.com/pytest-dev/pytest/issues/3631>`_)
|
||||||
|
|
||||||
|
|
||||||
|
Improved Documentation
|
||||||
|
----------------------
|
||||||
|
|
||||||
|
- The description above the example for ``@pytest.mark.skipif`` now better
|
||||||
|
matches the code. (`#3611
|
||||||
|
<https://github.com/pytest-dev/pytest/issues/3611>`_)
|
||||||
|
|
||||||
|
|
||||||
|
Trivial/Internal Changes
|
||||||
|
------------------------
|
||||||
|
|
||||||
|
- Internal refactoring: removed unused ``CallSpec2tox ._globalid_args``
|
||||||
|
attribute and ``metafunc`` parameter from ``CallSpec2.copy()``. (`#3598
|
||||||
|
<https://github.com/pytest-dev/pytest/issues/3598>`_)
|
||||||
|
|
||||||
|
- Silence usage of ``reduce`` warning in Python 2 (`#3609
|
||||||
|
<https://github.com/pytest-dev/pytest/issues/3609>`_)
|
||||||
|
|
||||||
|
- Fix usage of ``attr.ib`` deprecated ``convert`` parameter. (`#3653
|
||||||
|
<https://github.com/pytest-dev/pytest/issues/3653>`_)
|
||||||
|
|
||||||
|
|
||||||
Pytest 3.6.2 (2018-06-20)
|
Pytest 3.6.2 (2018-06-20)
|
||||||
=========================
|
=========================
|
||||||
|
|
||||||
|
|
|
@ -10,10 +10,6 @@ taking a lot of time to make a new one.
|
||||||
pytest releases must be prepared on **Linux** because the docs and examples expect
|
pytest releases must be prepared on **Linux** because the docs and examples expect
|
||||||
to be executed in that platform.
|
to be executed in that platform.
|
||||||
|
|
||||||
#. Install development dependencies in a virtual environment with::
|
|
||||||
|
|
||||||
pip3 install -U -r tasks/requirements.txt
|
|
||||||
|
|
||||||
#. Create a branch ``release-X.Y.Z`` with the version for the release.
|
#. Create a branch ``release-X.Y.Z`` with the version for the release.
|
||||||
|
|
||||||
* **patch releases**: from the latest ``master``;
|
* **patch releases**: from the latest ``master``;
|
||||||
|
@ -22,9 +18,19 @@ taking a lot of time to make a new one.
|
||||||
|
|
||||||
Ensure your are in a clean work tree.
|
Ensure your are in a clean work tree.
|
||||||
|
|
||||||
#. Generate docs, changelog, announcements and a **local** tag::
|
#. Install development dependencies in a virtual environment with::
|
||||||
|
|
||||||
|
$ pip3 install -U -r tasks/requirements.txt
|
||||||
|
|
||||||
|
#. Generate docs, changelog, announcements, and a **local** tag::
|
||||||
|
|
||||||
|
$ invoke generate.pre-release <VERSION>
|
||||||
|
|
||||||
|
#. Execute pre-commit on all files to ensure the docs are conformant and commit your results::
|
||||||
|
|
||||||
|
$ pre-commit run --all-files
|
||||||
|
$ git commit -am "Fix files with pre-commit"
|
||||||
|
|
||||||
invoke generate.pre-release <VERSION>
|
|
||||||
|
|
||||||
#. Open a PR for this branch targeting ``master``.
|
#. Open a PR for this branch targeting ``master``.
|
||||||
|
|
||||||
|
|
|
@ -1 +0,0 @@
|
||||||
Fix ``ImportWarning`` triggered by explicit relative imports in assertion-rewritten package modules.
|
|
|
@ -1,5 +0,0 @@
|
||||||
If the user pass as a expected value a numpy array created like
|
|
||||||
numpy.array(5); it will creates an array with one element without shape,
|
|
||||||
when used with approx it will raise an error for the `repr`
|
|
||||||
'TypeError: iteration over a 0-d array'. With this PR pytest will iterate
|
|
||||||
properly in the numpy array even with 0 dimension.
|
|
|
@ -1 +0,0 @@
|
||||||
Internal refactoring: removed unused ``CallSpec2tox ._globalid_args`` attribute and ``metafunc`` parameter from ``CallSpec2.copy()``.
|
|
|
@ -1 +0,0 @@
|
||||||
no longer ValueError when using the ``get_marker`` api.
|
|
|
@ -1 +0,0 @@
|
||||||
Silence usage of ``reduce`` warning in python 2
|
|
|
@ -1 +0,0 @@
|
||||||
The description above the example for ``@pytest.mark.skipif`` now better matches the code.
|
|
|
@ -6,6 +6,7 @@ Release announcements
|
||||||
:maxdepth: 2
|
:maxdepth: 2
|
||||||
|
|
||||||
|
|
||||||
|
release-3.6.3
|
||||||
release-3.6.2
|
release-3.6.2
|
||||||
release-3.6.1
|
release-3.6.1
|
||||||
release-3.6.0
|
release-3.6.0
|
||||||
|
|
|
@ -0,0 +1,28 @@
|
||||||
|
pytest-3.6.3
|
||||||
|
=======================================
|
||||||
|
|
||||||
|
pytest 3.6.3 has just been released to PyPI.
|
||||||
|
|
||||||
|
This is a bug-fix release, being a drop-in replacement. To upgrade::
|
||||||
|
|
||||||
|
pip install --upgrade pytest
|
||||||
|
|
||||||
|
The full changelog is available at http://doc.pytest.org/en/latest/changelog.html.
|
||||||
|
|
||||||
|
Thanks to all who contributed to this release, among them:
|
||||||
|
|
||||||
|
* AdamEr8
|
||||||
|
* Anthony Sottile
|
||||||
|
* Bruno Oliveira
|
||||||
|
* Jean-Paul Calderone
|
||||||
|
* Jon Dufresne
|
||||||
|
* Marcelo Duarte Trevisani
|
||||||
|
* Ondřej Súkup
|
||||||
|
* Ronny Pfannschmidt
|
||||||
|
* T.E.A de Souza
|
||||||
|
* Victor
|
||||||
|
* victor
|
||||||
|
|
||||||
|
|
||||||
|
Happy testing,
|
||||||
|
The pytest Development Team
|
|
@ -90,7 +90,7 @@ For information about fixtures, see :ref:`fixtures`. To see a complete list of a
|
||||||
monkeypatch.setitem(mapping, name, value)
|
monkeypatch.setitem(mapping, name, value)
|
||||||
monkeypatch.delitem(obj, name, raising=True)
|
monkeypatch.delitem(obj, name, raising=True)
|
||||||
monkeypatch.setenv(name, value, prepend=False)
|
monkeypatch.setenv(name, value, prepend=False)
|
||||||
monkeypatch.delenv(name, value, raising=True)
|
monkeypatch.delenv(name, raising=True)
|
||||||
monkeypatch.syspath_prepend(path)
|
monkeypatch.syspath_prepend(path)
|
||||||
monkeypatch.chdir(path)
|
monkeypatch.chdir(path)
|
||||||
|
|
||||||
|
|
|
@ -416,7 +416,7 @@ Now we can profile which test functions execute the slowest::
|
||||||
========================= slowest 3 test durations =========================
|
========================= slowest 3 test durations =========================
|
||||||
0.30s call test_some_are_slow.py::test_funcslow2
|
0.30s call test_some_are_slow.py::test_funcslow2
|
||||||
0.20s call test_some_are_slow.py::test_funcslow1
|
0.20s call test_some_are_slow.py::test_funcslow1
|
||||||
0.10s call test_some_are_slow.py::test_funcfast
|
0.13s call test_some_are_slow.py::test_funcfast
|
||||||
========================= 3 passed in 0.12 seconds =========================
|
========================= 3 passed in 0.12 seconds =========================
|
||||||
|
|
||||||
incremental testing - test steps
|
incremental testing - test steps
|
||||||
|
|
|
@ -408,7 +408,9 @@ class LoggingPlugin(object):
|
||||||
config, "log_file_date_format", "log_date_format"
|
config, "log_file_date_format", "log_date_format"
|
||||||
)
|
)
|
||||||
# Each pytest runtests session will write to a clean logfile
|
# Each pytest runtests session will write to a clean logfile
|
||||||
self.log_file_handler = logging.FileHandler(log_file, mode="w")
|
self.log_file_handler = logging.FileHandler(
|
||||||
|
log_file, mode="w", encoding="UTF-8"
|
||||||
|
)
|
||||||
log_file_formatter = logging.Formatter(
|
log_file_formatter = logging.Formatter(
|
||||||
log_file_format, datefmt=log_file_date_format
|
log_file_format, datefmt=log_file_date_format
|
||||||
)
|
)
|
||||||
|
|
|
@ -259,7 +259,7 @@ def store_legacy_markinfo(func, mark):
|
||||||
if holder is None:
|
if holder is None:
|
||||||
holder = MarkInfo.for_mark(mark)
|
holder = MarkInfo.for_mark(mark)
|
||||||
setattr(func, mark.name, holder)
|
setattr(func, mark.name, holder)
|
||||||
else:
|
elif isinstance(holder, MarkInfo):
|
||||||
holder.add_mark(mark)
|
holder.add_mark(mark)
|
||||||
|
|
||||||
|
|
||||||
|
@ -294,7 +294,7 @@ def _marked(func, mark):
|
||||||
class MarkInfo(object):
|
class MarkInfo(object):
|
||||||
""" Marking object created by :class:`MarkDecorator` instances. """
|
""" Marking object created by :class:`MarkDecorator` instances. """
|
||||||
|
|
||||||
_marks = attr.ib(convert=list)
|
_marks = attr.ib(converter=list)
|
||||||
|
|
||||||
@_marks.validator
|
@_marks.validator
|
||||||
def validate_marks(self, attribute, value):
|
def validate_marks(self, attribute, value):
|
||||||
|
|
|
@ -22,7 +22,7 @@ def monkeypatch():
|
||||||
monkeypatch.setitem(mapping, name, value)
|
monkeypatch.setitem(mapping, name, value)
|
||||||
monkeypatch.delitem(obj, name, raising=True)
|
monkeypatch.delitem(obj, name, raising=True)
|
||||||
monkeypatch.setenv(name, value, prepend=False)
|
monkeypatch.setenv(name, value, prepend=False)
|
||||||
monkeypatch.delenv(name, value, raising=True)
|
monkeypatch.delenv(name, raising=True)
|
||||||
monkeypatch.syspath_prepend(path)
|
monkeypatch.syspath_prepend(path)
|
||||||
monkeypatch.chdir(path)
|
monkeypatch.chdir(path)
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
import re
|
import re
|
||||||
import os
|
import os
|
||||||
|
from io import open
|
||||||
|
|
||||||
import six
|
import six
|
||||||
|
|
||||||
|
@ -827,6 +828,43 @@ def test_log_file_ini_level(testdir):
|
||||||
assert "This log message won't be shown" not in contents
|
assert "This log message won't be shown" not in contents
|
||||||
|
|
||||||
|
|
||||||
|
def test_log_file_unicode(testdir):
|
||||||
|
log_file = testdir.tmpdir.join("pytest.log").strpath
|
||||||
|
|
||||||
|
testdir.makeini(
|
||||||
|
"""
|
||||||
|
[pytest]
|
||||||
|
log_file={}
|
||||||
|
log_file_level = INFO
|
||||||
|
""".format(
|
||||||
|
log_file
|
||||||
|
)
|
||||||
|
)
|
||||||
|
testdir.makepyfile(
|
||||||
|
"""
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
import logging
|
||||||
|
|
||||||
|
def test_log_file():
|
||||||
|
logging.getLogger('catchlog').info("Normal message")
|
||||||
|
logging.getLogger('catchlog').info("├")
|
||||||
|
logging.getLogger('catchlog').info("Another normal message")
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
|
||||||
|
result = testdir.runpytest()
|
||||||
|
|
||||||
|
# make sure that that we get a '0' exit code for the testsuite
|
||||||
|
assert result.ret == 0
|
||||||
|
assert os.path.isfile(log_file)
|
||||||
|
with open(log_file, encoding="utf-8") as rfh:
|
||||||
|
contents = rfh.read()
|
||||||
|
assert "Normal message" in contents
|
||||||
|
assert u"├" in contents
|
||||||
|
assert "Another normal message" in contents
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize("has_capture_manager", [True, False])
|
@pytest.mark.parametrize("has_capture_manager", [True, False])
|
||||||
def test_live_logging_suspends_capture(has_capture_manager, request):
|
def test_live_logging_suspends_capture(has_capture_manager, request):
|
||||||
"""Test that capture manager is suspended when we emitting messages for live logging.
|
"""Test that capture manager is suspended when we emitting messages for live logging.
|
||||||
|
|
|
@ -63,6 +63,19 @@ class TestMark(object):
|
||||||
mark.hello(f)
|
mark.hello(f)
|
||||||
assert f.hello
|
assert f.hello
|
||||||
|
|
||||||
|
def test_mark_legacy_ignore_fail(self):
|
||||||
|
def add_attribute(func):
|
||||||
|
func.foo = 1
|
||||||
|
return func
|
||||||
|
|
||||||
|
@pytest.mark.foo
|
||||||
|
@add_attribute
|
||||||
|
def test_fun():
|
||||||
|
pass
|
||||||
|
|
||||||
|
assert test_fun.foo == 1
|
||||||
|
assert test_fun.pytestmark
|
||||||
|
|
||||||
@ignore_markinfo
|
@ignore_markinfo
|
||||||
def test_pytest_mark_keywords(self):
|
def test_pytest_mark_keywords(self):
|
||||||
mark = Mark()
|
mark = Mark()
|
||||||
|
|
Loading…
Reference in New Issue