diff --git a/pytest-relaxed-pr10.patch b/pytest-relaxed-pr10.patch new file mode 100644 index 0000000..269a22d --- /dev/null +++ b/pytest-relaxed-pr10.patch @@ -0,0 +1,175 @@ +From 3423a446a49548b80e13fa78fe1c3cbd21968457 Mon Sep 17 00:00:00 2001 +From: Stanislav Levin +Date: Thu, 7 May 2020 18:46:52 +0300 +Subject: [PATCH 1/2] Fix deprecated direct constructors for Nodes + +As of 5.4.0 Pytest emits deprecation warnings [0]: +``` +PytestDeprecationWarning: direct construction of Spec* has been +deprecated, please use Spec*.from_parent. +``` + +[0]: https://docs.pytest.org/en/5.4.0/changelog.html#deprecations + +Signed-off-by: Stanislav Levin +--- + pytest_relaxed/classes.py | 31 ++++++++++++++++++++++++++++--- + pytest_relaxed/plugin.py | 2 +- + 2 files changed, 29 insertions(+), 4 deletions(-) + +diff --git a/pytest_relaxed/classes.py b/pytest_relaxed/classes.py +index 10615bc..26edf4e 100644 +--- a/pytest_relaxed/classes.py ++++ b/pytest_relaxed/classes.py +@@ -3,12 +3,15 @@ + + import six + ++from pytest import __version__ as pytest_version + from pytest import Class, Instance, Module + + # NOTE: don't see any other way to get access to pytest innards besides using + # the underscored name :( + from _pytest.python import PyCollector + ++pytest_version_info = tuple(map(int, pytest_version.split(".")[:3])) ++ + + # NOTE: these are defined here for reuse by both pytest's own machinery and our + # internal bits. +@@ -45,6 +48,13 @@ def istestfunction(self, obj, name): + + class SpecModule(RelaxedMixin, Module): + ++ @classmethod ++ def from_parent(cls, parent, fspath): ++ if pytest_version_info >= (5, 4): ++ return super(SpecModule, cls).from_parent(parent, fspath=fspath) ++ else: ++ return cls(parent=parent, fspath=fspath) ++ + def _is_test_obj(self, test_func, obj, name): + # First run our super() test, which should be RelaxedMixin's. + good_name = getattr(super(SpecModule, self), test_func)(obj, name) +@@ -69,6 +79,7 @@ def collect(self): + # Get whatever our parent picked up as valid test items (given our + # relaxed name constraints above). It'll be nearly all module contents. + items = super(SpecModule, self).collect() ++ + collected = [] + for item in items: + # Replace Class objects with recursive SpecInstances (via +@@ -80,7 +91,7 @@ def collect(self): + # them to be handled by pytest's own unittest support) but since + # those are almost always in test_prefixed_filenames anyways...meh + if isinstance(item, Class): +- item = SpecClass(item.name, item.parent) ++ item = SpecClass.from_parent(item.parent, name=item.name) + collected.append(item) + return collected + +@@ -89,6 +100,13 @@ def collect(self): + # its lonesome + class SpecClass(Class): + ++ @classmethod ++ def from_parent(cls, parent, name): ++ if pytest_version_info >= (5, 4): ++ return super(SpecClass, cls).from_parent(parent, name=name) ++ else: ++ return cls(parent=parent, name=name) ++ + def collect(self): + items = super(SpecClass, self).collect() + collected = [] +@@ -96,13 +114,20 @@ def collect(self): + # recurse into inner classes. + # TODO: is this ever not a one-item list? Meh. + for item in items: +- item = SpecInstance(name=item.name, parent=item.parent) ++ item = SpecInstance.from_parent(item.parent, name=item.name) + collected.append(item) + return collected + + + class SpecInstance(RelaxedMixin, Instance): + ++ @classmethod ++ def from_parent(cls, parent, name): ++ if pytest_version_info >= (5, 4): ++ return super(SpecInstance, cls).from_parent(parent, name=name) ++ else: ++ return cls(parent=parent, name=name) ++ + def _getobj(self): + # Regular object-making first + obj = super(SpecInstance, self)._getobj() +@@ -172,5 +197,5 @@ def _makeitem(self, name, obj): + # recurse. + # TODO: can we unify this with SpecModule's same bits? + if isinstance(item, Class): +- item = SpecClass(item.name, item.parent) ++ item = SpecClass.from_parent(item.parent, name=item.name) + return item +diff --git a/pytest_relaxed/plugin.py b/pytest_relaxed/plugin.py +index 0f5a389..8f64358 100644 +--- a/pytest_relaxed/plugin.py ++++ b/pytest_relaxed/plugin.py +@@ -28,7 +28,7 @@ def pytest_collect_file(path, parent): + ): + # Then use our custom module class which performs modified + # function/class selection as well as class recursion +- return SpecModule(path, parent) ++ return SpecModule.from_parent(parent, fspath=path) + + + @pytest.mark.trylast # So we can be sure builtin terminalreporter exists + +From 6360ba2cc46b597d20478aaee1d6bd1d73588a88 Mon Sep 17 00:00:00 2001 +From: Stanislav Levin +Date: Fri, 6 Dec 2019 16:13:06 +0300 +Subject: [PATCH 2/2] Fixed expected colored statistics + +As of 5.3.0 Pytest improved colored statistics of the outcome: +https://docs.pytest.org/en/5.3.0/changelog.html#improvements + +Signed-off-by: Stanislav Levin +--- + tests/test_display.py | 12 +++++++++++- + 1 file changed, 11 insertions(+), 1 deletion(-) + +diff --git a/tests/test_display.py b/tests/test_display.py +index 5b7f9c8..2884c84 100644 +--- a/tests/test_display.py ++++ b/tests/test_display.py +@@ -1,4 +1,5 @@ + from pytest import skip ++from pytest import __version__ as pytest_version + + # Load some fixtures we expose, without actually loading our entire plugin + from pytest_relaxed.fixtures import environ # noqa +@@ -8,6 +9,8 @@ + # (May not be feasible if it has to assume something about how our collection + # works?) CLI option (99% sure we can hook into that as a plugin)? + ++pytest_version_info = tuple(map(int, pytest_version.split(".")[:3])) ++ + + def _expect_regular_output(testdir): + output = testdir.runpytest().stdout.str() +@@ -225,7 +228,14 @@ def behavior_four(self): + assert "== FAILURES ==" in output + assert "AssertionError" in output + # Summary +- assert "== 1 failed, 4 passed, 1 skipped in " in output ++ if pytest_version_info >= (5, 3): ++ expected_out = ( ++ "== \x1b[31m\x1b[1m1 failed\x1b[0m, \x1b[32m4 passed\x1b[0m, " ++ "\x1b[33m1 skipped\x1b[0m\x1b[31m in " ++ ) ++ else: ++ expected_out = "== 1 failed, 4 passed, 1 skipped in " ++ assert expected_out in output + + def test_nests_many_levels_deep_no_problem(self, testdir): + testdir.makepyfile( diff --git a/python-pytest-relaxed.changes b/python-pytest-relaxed.changes index 5427954..b9d942d 100644 --- a/python-pytest-relaxed.changes +++ b/python-pytest-relaxed.changes @@ -1,3 +1,9 @@ +------------------------------------------------------------------- +Fri May 15 22:10:39 UTC 2020 - Benjamin Greiner + +- fix test failure by pytest-relaxed-pr10.patch + gh#bitprophet/pytest-relaxed#10 + ------------------------------------------------------------------- Wed Jan 15 12:51:01 UTC 2020 - Tomáš Chvátal diff --git a/python-pytest-relaxed.spec b/python-pytest-relaxed.spec index 6fcbde3..0d932f1 100644 --- a/python-pytest-relaxed.spec +++ b/python-pytest-relaxed.spec @@ -24,6 +24,7 @@ Summary: Relaxed test discovery/organization for pytest License: BSD-2-Clause URL: https://github.com/bitprophet/pytest-relaxed Source: https://files.pythonhosted.org/packages/source/p/pytest-relaxed/pytest-relaxed-%{version}.tar.gz +Patch0: https://github.com/bitprophet/pytest-relaxed/pull/10.patch#/pytest-relaxed-pr10.patch BuildRequires: %{python_module decorator >= 4} BuildRequires: %{python_module pytest >= 3} BuildRequires: %{python_module setuptools} @@ -44,6 +45,7 @@ Relaxed test discovery/organization plugin for pytest from python-paramiko autho sed -i setup.py \ -e 's:pytest>=3,<3.3:pytest>=3:g' \ -e 's:decorator>=4,<5:decorator>=4:g' +%patch0 -p1 %build export LANG=en_US.UTF-8 @@ -55,8 +57,7 @@ export LANG=en_US.UTF-8 %python_expand %fdupes %{buildroot}%{$python_sitelib} %check -# test_tests_are_colorized_by_test_result upstream changed color output slightly in pytest 5.3 -%pytest -k 'not test_tests_are_colorized_by_test_result' +%pytest %files %{python_files} %license LICENSE