diff --git a/.python-html5lib.metadata b/.python-html5lib.metadata index 5e31edd..1725063 100644 --- a/.python-html5lib.metadata +++ b/.python-html5lib.metadata @@ -1 +1 @@ -3a38a57f6e255a59bc8f41cc8163d502a09cc7ee SOURCES/0.999999999.tar.gz +6d1348b6356b62305e4a410df9dfd02143d841a1 SOURCES/html5lib-1.1.tar.gz diff --git a/SOURCES/506.patch b/SOURCES/506.patch new file mode 100644 index 0000000..cdcd31f --- /dev/null +++ b/SOURCES/506.patch @@ -0,0 +1,163 @@ +From e6bd99e8f2497194ffd0a06c6954ebb28d7526bb Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Miro=20Hron=C4=8Dok?= +Date: Sat, 8 Aug 2020 13:39:22 +0200 +Subject: [PATCH] Use Node.from_parent() constructor to support pytest 6 + +Add a wrapper not to break pytest 4 (needed for Python 2 support). + + ============================= test session starts ============================== + platform linux -- Python 3.9.0b5, pytest-6.0.1, py-1.9.0, pluggy-0.13.1 + rootdir: /builddir/build/BUILD/html5lib-1.1, configfile: pytest.ini + plugins: expect-1.1.0 + collected 0 items / 1 error + + ==================================== ERRORS ==================================== + ________________________ ERROR collecting test session _________________________ + /usr/lib/python3.9/site-packages/pluggy/hooks.py:286: in __call__ + return self._hookexec(self, self.get_hookimpls(), kwargs) + /usr/lib/python3.9/site-packages/pluggy/manager.py:93: in _hookexec + return self._inner_hookexec(hook, methods, kwargs) + /usr/lib/python3.9/site-packages/pluggy/manager.py:84: in + self._inner_hookexec = lambda hook, methods, kwargs: hook.multicall( + html5lib/tests/conftest.py:105: in pytest_collect_file + return TokenizerFile(path, parent) + /usr/lib/python3.9/site-packages/_pytest/nodes.py:95: in __call__ + warnings.warn(NODE_USE_FROM_PARENT.format(name=self.__name__), stacklevel=2) + E pytest.PytestDeprecationWarning: Direct construction of TokenizerFile has been deprecated, please use TokenizerFile.from_parent. + E See https://docs.pytest.org/en/stable/deprecations.html#node-construction-changed-to-node-from-parent for more details. + +Fixes https://github.com/html5lib/html5lib-python/issues/505 +--- + html5lib/tests/conftest.py | 15 ++++++++++++--- + html5lib/tests/sanitizer.py | 2 +- + html5lib/tests/tokenizer.py | 10 +++++----- + html5lib/tests/tree_construction.py | 20 ++++++++++---------- + requirements-test.txt | 2 +- + 5 files changed, 29 insertions(+), 20 deletions(-) + +diff --git a/html5lib/tests/conftest.py b/html5lib/tests/conftest.py +index dad167c5..fffeb50c 100644 +--- a/html5lib/tests/conftest.py ++++ b/html5lib/tests/conftest.py +@@ -99,10 +99,19 @@ def pytest_collect_file(path, parent): + + if _tree_construction in dir_and_parents: + if path.ext == ".dat": +- return TreeConstructionFile(path, parent) ++ return TreeConstructionFile.from_parent(parent, fspath=path) + elif _tokenizer in dir_and_parents: + if path.ext == ".test": +- return TokenizerFile(path, parent) ++ return TokenizerFile.from_parent(parent, fspath=path) + elif _sanitizer_testdata in dir_and_parents: + if path.ext == ".dat": +- return SanitizerFile(path, parent) ++ return SanitizerFile.from_parent(parent, fspath=path) ++ ++ ++# Tiny wrapper to allow .from_parent constructors on older pytest for PY27 ++if not hasattr(pytest.Item.__base__, "from_parent"): ++ @classmethod ++ def from_parent(cls, parent, **kwargs): ++ return cls(parent=parent, **kwargs) ++ ++ pytest.Item.__base__.from_parent = from_parent +diff --git a/html5lib/tests/sanitizer.py b/html5lib/tests/sanitizer.py +index bb483421..16e53868 100644 +--- a/html5lib/tests/sanitizer.py ++++ b/html5lib/tests/sanitizer.py +@@ -13,7 +13,7 @@ def collect(self): + with codecs.open(str(self.fspath), "r", encoding="utf-8") as fp: + tests = json.load(fp) + for i, test in enumerate(tests): +- yield SanitizerTest(str(i), self, test=test) ++ yield SanitizerTest.from_parent(self, name=str(i), test=test) + + + class SanitizerTest(pytest.Item): +diff --git a/html5lib/tests/tokenizer.py b/html5lib/tests/tokenizer.py +index 47264cc3..cc9897a4 100644 +--- a/html5lib/tests/tokenizer.py ++++ b/html5lib/tests/tokenizer.py +@@ -192,7 +192,7 @@ def collect(self): + tests = json.load(fp) + if 'tests' in tests: + for i, test in enumerate(tests['tests']): +- yield TokenizerTestCollector(str(i), self, testdata=test) ++ yield TokenizerTestCollector.from_parent(self, name=str(i), testdata=test) + + + class TokenizerTestCollector(pytest.Collector): +@@ -207,10 +207,10 @@ def __init__(self, name, parent=None, config=None, session=None, testdata=None): + def collect(self): + for initialState in self.testdata["initialStates"]: + initialState = capitalize(initialState) +- item = TokenizerTest(initialState, +- self, +- self.testdata, +- initialState) ++ item = TokenizerTest.from_parent(self, ++ name=initialState, ++ test=self.testdata, ++ initialState=initialState) + if self.testdata["input"] is None: + item.add_marker(pytest.mark.skipif(True, reason="Relies on lone surrogates")) + yield item +diff --git a/html5lib/tests/tree_construction.py b/html5lib/tests/tree_construction.py +index 1ef6e725..fb0657bf 100644 +--- a/html5lib/tests/tree_construction.py ++++ b/html5lib/tests/tree_construction.py +@@ -26,7 +26,7 @@ class TreeConstructionFile(pytest.File): + def collect(self): + tests = TestData(str(self.fspath), "data") + for i, test in enumerate(tests): +- yield TreeConstructionTest(str(i), self, testdata=test) ++ yield TreeConstructionTest.from_parent(self, name=str(i), testdata=test) + + + class TreeConstructionTest(pytest.Collector): +@@ -48,11 +48,11 @@ def _getParserTests(self, treeName, treeAPIs): + nodeid = "%s::parser::namespaced" % treeName + else: + nodeid = "%s::parser::void-namespace" % treeName +- item = ParserTest(nodeid, +- self, +- self.testdata, +- treeAPIs["builder"] if treeAPIs is not None else None, +- namespaceHTMLElements) ++ item = ParserTest.from_parent(self, ++ name=nodeid, ++ test=self.testdata, ++ treeClass=treeAPIs["builder"] if treeAPIs is not None else None, ++ namespaceHTMLElements=namespaceHTMLElements) + item.add_marker(getattr(pytest.mark, treeName)) + item.add_marker(pytest.mark.parser) + if namespaceHTMLElements: +@@ -61,10 +61,10 @@ def _getParserTests(self, treeName, treeAPIs): + + def _getTreeWalkerTests(self, treeName, treeAPIs): + nodeid = "%s::treewalker" % treeName +- item = TreeWalkerTest(nodeid, +- self, +- self.testdata, +- treeAPIs) ++ item = TreeWalkerTest.from_parent(self, ++ name=nodeid, ++ test=self.testdata, ++ treeAPIs=treeAPIs) + item.add_marker(getattr(pytest.mark, treeName)) + item.add_marker(pytest.mark.treewalker) + yield item +diff --git a/requirements-test.txt b/requirements-test.txt +index 703d0e69..57f8f617 100644 +--- a/requirements-test.txt ++++ b/requirements-test.txt +@@ -3,7 +3,7 @@ + tox>=3.15.1,<4 + flake8>=3.8.1,<3.9 + pytest>=4.6.10,<5 ; python_version < '3' +-pytest>=5.4.2,<6 ; python_version >= '3' ++pytest>=5.4.2,<7 ; python_version >= '3' + coverage>=5.1,<6 + pytest-expect>=1.1.0,<2 + mock>=3.0.5,<4 ; python_version < '3.6' diff --git a/SPECS/python-html5lib.spec b/SPECS/python-html5lib.spec index 251ec68..05c180a 100644 --- a/SPECS/python-html5lib.spec +++ b/SPECS/python-html5lib.spec @@ -1,41 +1,51 @@ -%global modulename html5lib - -Name: python-%{modulename} -Summary: A python based HTML parser/tokenizer -Version: 0.999999999 -Release: 6%{?dist} -Epoch: 1 -Group: Development/Libraries -License: MIT -URL: https://pypi.python.org/pypi/%{modulename} -Source0: https://github.com/html5lib/html5lib-python/archive/%{version}.tar.gz -BuildArch: noarch +%global srcname html5lib +Name: python-%{srcname} +Summary: A python based HTML parser/tokenizer +Version: 1.1 +Release: 4%{?dist} +Epoch: 1 +License: MIT +URL: https://github.com/html5lib/html5lib-python +Source0: %pypi_source + +# Fix compatibility with pytest 6 +Patch1: %{url}/pull/506.patch + +BuildArch: noarch + +%?python_enable_dependency_generator %description A python based HTML parser/tokenizer based on the WHATWG HTML5 specification for maximum compatibility with major desktop web browsers. -%package -n python3-%{modulename} -Summary: A python based HTML parser/tokenizer -Group: Development/Libraries - -Requires: python3-six -Requires: python3-webencodings -BuildRequires: python3-devel -BuildRequires: python3-setuptools -#BuildRequires: python3-nose -#BuildRequires: python3-pytest -BuildRequires: python3-six -BuildRequires: python3-webencodings -%{?python_provide:%python_provide python3-%{modulename}} - -%description -n python3-%{modulename} + +%package -n python3-%{srcname} +Summary: %summary +BuildRequires: python3-devel +BuildRequires: python3-setuptools + +# Test deps +BuildRequires: python3dist(mock) +BuildRequires: python3dist(pytest) +BuildRequires: python3dist(pytest-expect) +BuildRequires: python3dist(six) +BuildRequires: python3dist(webencodings) + +# Optional test deps: +BuildRequires: python3dist(chardet) +BuildRequires: python3dist(genshi) +BuildRequires: python3dist(lxml) + +%{?python_provide:%python_provide python3-%{srcname}} + +%description -n python3-%{srcname} A python based HTML parser/tokenizer based on the WHATWG HTML5 specification for maximum compatibility with major desktop web browsers. %prep -%autosetup -n %{modulename}-python-%{version} +%autosetup -p1 -n %{srcname}-%{version} %build %py3_build @@ -44,21 +54,71 @@ specification for maximum compatibility with major desktop web browsers. %install %py3_install + %check -# Tests no longer run, see https://bugzilla.redhat.com/show_bug.cgi?id=1593231 -#{__python3} -m pytest +%pytest + -%files -n python3-%{modulename} +%files -n python3-%{srcname} %license LICENSE %doc CHANGES.rst README.rst -%{python3_sitelib}/%{modulename}-*.egg-info -%{python3_sitelib}/%{modulename} +%{python3_sitelib}/%{srcname}-*.egg-info/ +%{python3_sitelib}/%{srcname}/ %changelog -* Tue Jun 19 2018 Petr Viktorin - 1:0.999999999-6 -- Drop the python2 subpackage - https://bugzilla.redhat.com/show_bug.cgi?id=1590670 +* Wed Jan 27 2021 Fedora Release Engineering - 1:1.1-4 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_34_Mass_Rebuild + +* Mon Aug 10 2020 Miro Hrončok - 1:1.1-3 +- Fix compatibility with pytest 6 + +* Wed Jul 29 2020 Fedora Release Engineering - 1:1.1-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild + +* Wed Jul 01 2020 Charalampos Stratakis - 1:1.1-1 +- Update to 1.1 (#1849837) +- Use pytest 5 + +* Sat May 30 2020 Miro Hrončok - 1:1.0.1-10 +- Use pytest 4 + +* Sat May 23 2020 Miro Hrončok - 1:1.0.1-9 +- Rebuilt for Python 3.9 + +* Thu Jan 30 2020 Fedora Release Engineering - 1:1.0.1-8 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild + +* Mon Sep 16 2019 Miro Hrončok - 1:1.0.1-7 +- Drop python2-html5lib + +* Mon Aug 26 2019 Miro Hrončok - 1:1.0.1-6 +- Reduce Python 2 build dependencies + +* Fri Aug 16 2019 Miro Hrončok - 1:1.0.1-5 +- Rebuilt for Python 3.8 + +* Fri Jul 26 2019 Fedora Release Engineering - 1:1.0.1-4 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild + +* Sat Feb 02 2019 Fedora Release Engineering - 1:1.0.1-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild + +* Mon Sep 24 2018 Miro Hrončok - 1:1.0.1-2 +- Fix dire deprecation warnings (#1627071) + +* Mon Aug 20 2018 Miro Hrončok - 1:1.0.1-1 +- Update to 1.0.1 (#1584176) + +* Sat Jul 14 2018 Fedora Release Engineering - 1:0.999999999-8 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_29_Mass_Rebuild + +* Sat Jun 16 2018 Miro Hrončok - 1:0.999999999-7 +- Rebuilt for Python 3.7 + +* Mon Feb 12 2018 Iryna Shcherbina - 1:0.999999999-6 +- Update Python 2 dependency declarations to new packaging standards + (See https://fedoraproject.org/wiki/FinalizingFedoraSwitchtoPython3) * Fri Feb 09 2018 Fedora Release Engineering - 1:0.999999999-5 - Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild