Accepting request 830019 from home:mcalabkova:branches:devel:languages:python:pytest
- Update to 1.1 * Drop support for Python 3.3 and 3.4. * Try to import from ``collections.abc`` to remove DeprecationWarning and ensure ``html5lib`` keeps working in future Python versions. (#403) * Drop optional ``datrie`` dependency. (#442) - Drop merged patches: * pytest4-mhroncok.patch * collections-abc.patch * pytest5.patch - Add upstream patch pytest6.patch OBS-URL: https://build.opensuse.org/request/show/830019 OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-html5lib?expand=0&rev=47
This commit is contained in:
parent
8db09d7c48
commit
bc0eb93e65
@ -1,44 +0,0 @@
|
|||||||
From 322a2d57bfdc52a9ce14bee93f9abb372cc08487 Mon Sep 17 00:00:00 2001
|
|
||||||
From: 5j9 <5j9@users.noreply.github.com>
|
|
||||||
Date: Sun, 23 Sep 2018 11:32:46 +0330
|
|
||||||
Subject: [PATCH] Try to import MutableMapping from collections.abc
|
|
||||||
|
|
||||||
Note that collections.abc has been added in Python 3.3.
|
|
||||||
|
|
||||||
Fixes #402
|
|
||||||
---
|
|
||||||
html5lib/_trie/_base.py | 5 ++++-
|
|
||||||
html5lib/treebuilders/dom.py | 5 ++++-
|
|
||||||
2 files changed, 8 insertions(+), 2 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/html5lib/_trie/_base.py b/html5lib/_trie/_base.py
|
|
||||||
index a1158bbb..6b71975f 100644
|
|
||||||
--- a/html5lib/_trie/_base.py
|
|
||||||
+++ b/html5lib/_trie/_base.py
|
|
||||||
@@ -1,6 +1,9 @@
|
|
||||||
from __future__ import absolute_import, division, unicode_literals
|
|
||||||
|
|
||||||
-from collections import Mapping
|
|
||||||
+try:
|
|
||||||
+ from collections.abc import Mapping
|
|
||||||
+except ImportError: # Python 2.7
|
|
||||||
+ from collections import Mapping
|
|
||||||
|
|
||||||
|
|
||||||
class Trie(Mapping):
|
|
||||||
diff --git a/html5lib/treebuilders/dom.py b/html5lib/treebuilders/dom.py
|
|
||||||
index dcfac220..d8b53004 100644
|
|
||||||
--- a/html5lib/treebuilders/dom.py
|
|
||||||
+++ b/html5lib/treebuilders/dom.py
|
|
||||||
@@ -1,7 +1,10 @@
|
|
||||||
from __future__ import absolute_import, division, unicode_literals
|
|
||||||
|
|
||||||
|
|
||||||
-from collections import MutableMapping
|
|
||||||
+try:
|
|
||||||
+ from collections.abc import MutableMapping
|
|
||||||
+except ImportError: # Python 2.7
|
|
||||||
+ from collections import MutableMapping
|
|
||||||
from xml.dom import minidom, Node
|
|
||||||
import weakref
|
|
||||||
|
|
@ -1,3 +0,0 @@
|
|||||||
version https://git-lfs.github.com/spec/v1
|
|
||||||
oid sha256:66cb0dcfdbbc4f9c3ba1a63fdb511ffdbd4f513b2b6d81b80cd26ce6b3fb3736
|
|
||||||
size 252959
|
|
BIN
html5lib-1.1.tar.gz
(Stored with Git LFS)
Normal file
BIN
html5lib-1.1.tar.gz
(Stored with Git LFS)
Normal file
Binary file not shown.
@ -1,143 +0,0 @@
|
|||||||
From dd117cc62d961573e9867d79ae1c3461a42e6167 Mon Sep 17 00:00:00 2001
|
|
||||||
From: =?UTF-8?q?Miro=20Hron=C4=8Dok?= <miro@hroncok.cz>
|
|
||||||
Date: Thu, 28 Mar 2019 01:45:43 +0100
|
|
||||||
Subject: [PATCH] Support pytest 4
|
|
||||||
|
|
||||||
Fixes https://github.com/html5lib/html5lib-python/issues/411
|
|
||||||
---
|
|
||||||
html5lib/tests/test_encoding.py | 4 ++--
|
|
||||||
html5lib/tests/test_sanitizer.py | 14 +++++++-------
|
|
||||||
html5lib/tests/test_serializer.py | 2 +-
|
|
||||||
html5lib/tests/test_stream.py | 7 ++++---
|
|
||||||
html5lib/tests/test_treewalkers.py | 2 +-
|
|
||||||
requirements-test.txt | 2 +-
|
|
||||||
tox.ini | 2 +-
|
|
||||||
7 files changed, 17 insertions(+), 16 deletions(-)
|
|
||||||
|
|
||||||
--- a/html5lib/tests/test_encoding.py
|
|
||||||
+++ b/html5lib/tests/test_encoding.py
|
|
||||||
@@ -94,13 +94,13 @@ def runPreScanEncodingTest(data, encodin
|
|
||||||
|
|
||||||
assert encoding == stream.charEncoding[0].name, errorMessage(data, encoding, stream.charEncoding[0].name)
|
|
||||||
|
|
||||||
-
|
|
||||||
+@pytest.mark.skip(reason="broken under pytest4")
|
|
||||||
def test_encoding():
|
|
||||||
for filename in get_data_files("encoding"):
|
|
||||||
tests = _TestData(filename, b"data", encoding=None)
|
|
||||||
for test in tests:
|
|
||||||
- yield (runParserEncodingTest, test[b'data'], test[b'encoding'])
|
|
||||||
- yield (runPreScanEncodingTest, test[b'data'], test[b'encoding'])
|
|
||||||
+ runParserEncodingTest(test[b'data'], test[b'encoding'])
|
|
||||||
+ runPreScanEncodingTest(test[b'data'], test[b'encoding'])
|
|
||||||
|
|
||||||
|
|
||||||
# pylint:disable=wrong-import-position
|
|
||||||
--- a/html5lib/tests/test_sanitizer.py
|
|
||||||
+++ b/html5lib/tests/test_sanitizer.py
|
|
||||||
@@ -67,19 +67,19 @@ def test_sanitizer():
|
|
||||||
'tfoot', 'th', 'thead', 'tr', 'select']:
|
|
||||||
continue # TODO
|
|
||||||
if tag_name == 'image':
|
|
||||||
- yield (runSanitizerTest, "test_should_allow_%s_tag" % tag_name,
|
|
||||||
+ runSanitizerTest("test_should_allow_%s_tag" % tag_name,
|
|
||||||
"<img title=\"1\"/>foo <bad>bar</bad> baz",
|
|
||||||
"<%s title='1'>foo <bad>bar</bad> baz</%s>" % (tag_name, tag_name))
|
|
||||||
elif tag_name == 'br':
|
|
||||||
- yield (runSanitizerTest, "test_should_allow_%s_tag" % tag_name,
|
|
||||||
+ runSanitizerTest("test_should_allow_%s_tag" % tag_name,
|
|
||||||
"<br title=\"1\"/>foo <bad>bar</bad> baz<br/>",
|
|
||||||
"<%s title='1'>foo <bad>bar</bad> baz</%s>" % (tag_name, tag_name))
|
|
||||||
elif tag_name in constants.voidElements:
|
|
||||||
- yield (runSanitizerTest, "test_should_allow_%s_tag" % tag_name,
|
|
||||||
+ runSanitizerTest("test_should_allow_%s_tag" % tag_name,
|
|
||||||
"<%s title=\"1\"/>foo <bad>bar</bad> baz" % tag_name,
|
|
||||||
"<%s title='1'>foo <bad>bar</bad> baz</%s>" % (tag_name, tag_name))
|
|
||||||
else:
|
|
||||||
- yield (runSanitizerTest, "test_should_allow_%s_tag" % tag_name,
|
|
||||||
+ runSanitizerTest("test_should_allow_%s_tag" % tag_name,
|
|
||||||
"<%s title=\"1\">foo <bad>bar</bad> baz</%s>" % (tag_name, tag_name),
|
|
||||||
"<%s title='1'>foo <bad>bar</bad> baz</%s>" % (tag_name, tag_name))
|
|
||||||
|
|
||||||
@@ -93,7 +93,7 @@ def test_sanitizer():
|
|
||||||
attribute_value = 'foo'
|
|
||||||
if attribute_name in sanitizer.attr_val_is_uri:
|
|
||||||
attribute_value = '%s://sub.domain.tld/path/object.ext' % sanitizer.allowed_protocols[0]
|
|
||||||
- yield (runSanitizerTest, "test_should_allow_%s_attribute" % attribute_name,
|
|
||||||
+ runSanitizerTest("test_should_allow_%s_attribute" % attribute_name,
|
|
||||||
"<p %s=\"%s\">foo <bad>bar</bad> baz</p>" % (attribute_name, attribute_value),
|
|
||||||
"<p %s='%s'>foo <bad>bar</bad> baz</p>" % (attribute_name, attribute_value))
|
|
||||||
|
|
||||||
@@ -101,7 +101,7 @@ def test_sanitizer():
|
|
||||||
rest_of_uri = '//sub.domain.tld/path/object.ext'
|
|
||||||
if protocol == 'data':
|
|
||||||
rest_of_uri = 'image/png;base64,aGVsbG8gd29ybGQ='
|
|
||||||
- yield (runSanitizerTest, "test_should_allow_uppercase_%s_uris" % protocol,
|
|
||||||
+ runSanitizerTest("test_should_allow_uppercase_%s_uris" % protocol,
|
|
||||||
"<img src=\"%s:%s\">foo</a>" % (protocol, rest_of_uri),
|
|
||||||
"""<img src="%s:%s">foo</a>""" % (protocol, rest_of_uri))
|
|
||||||
|
|
||||||
@@ -110,7 +110,7 @@ def test_sanitizer():
|
|
||||||
if protocol == 'data':
|
|
||||||
rest_of_uri = 'image/png;base64,aGVsbG8gd29ybGQ='
|
|
||||||
protocol = protocol.upper()
|
|
||||||
- yield (runSanitizerTest, "test_should_allow_uppercase_%s_uris" % protocol,
|
|
||||||
+ runSanitizerTest("test_should_allow_uppercase_%s_uris" % protocol,
|
|
||||||
"<img src=\"%s:%s\">foo</a>" % (protocol, rest_of_uri),
|
|
||||||
"""<img src="%s:%s">foo</a>""" % (protocol, rest_of_uri))
|
|
||||||
|
|
||||||
--- a/html5lib/tests/test_serializer.py
|
|
||||||
+++ b/html5lib/tests/test_serializer.py
|
|
||||||
@@ -222,4 +222,4 @@ def test_serializer():
|
|
||||||
with open(filename) as fp:
|
|
||||||
tests = json.load(fp)
|
|
||||||
for test in tests['tests']:
|
|
||||||
- yield runSerializerTest, test["input"], test["expected"], test.get("options", {})
|
|
||||||
+ runSerializerTest(test["input"], test["expected"], test.get("options", {}))
|
|
||||||
--- a/html5lib/tests/test_stream.py
|
|
||||||
+++ b/html5lib/tests/test_stream.py
|
|
||||||
@@ -308,9 +308,10 @@ def test_invalid_codepoints(inp, num):
|
|
||||||
("'\\uD800\\uD800\\uD800'", 3),
|
|
||||||
("'a\\uD800a\\uD800a\\uD800a'", 3),
|
|
||||||
("'\\uDFFF\\uDBFF'", 2),
|
|
||||||
- pytest.mark.skipif(sys.maxunicode == 0xFFFF,
|
|
||||||
- ("'\\uDBFF\\uDFFF'", 2),
|
|
||||||
- reason="narrow Python")])
|
|
||||||
+ pytest.param(
|
|
||||||
+ "'\\uDBFF\\uDFFF'", 2,
|
|
||||||
+ marks=pytest.mark.skipif(sys.maxunicode == 0xFFFF,
|
|
||||||
+ reason="narrow Python"))])
|
|
||||||
def test_invalid_codepoints_surrogates(inp, num):
|
|
||||||
inp = eval(inp) # pylint:disable=eval-used
|
|
||||||
fp = StringIO(inp)
|
|
||||||
--- a/html5lib/tests/test_treewalkers.py
|
|
||||||
+++ b/html5lib/tests/test_treewalkers.py
|
|
||||||
@@ -99,7 +99,7 @@ def test_treewalker_six_mix():
|
|
||||||
|
|
||||||
for tree in sorted(treeTypes.items()):
|
|
||||||
for intext, attrs, expected in sm_tests:
|
|
||||||
- yield runTreewalkerEditTest, intext, expected, attrs, tree
|
|
||||||
+ runTreewalkerEditTest(intext, expected, attrs, tree)
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize("tree,char", itertools.product(sorted(treeTypes.items()), ["x", "\u1234"]))
|
|
||||||
--- a/requirements-test.txt
|
|
||||||
+++ b/requirements-test.txt
|
|
||||||
@@ -4,7 +4,7 @@ tox
|
|
||||||
|
|
||||||
flake8<3.0
|
|
||||||
|
|
||||||
-pytest==3.2.5
|
|
||||||
+pytest>=4.3,<4.4
|
|
||||||
coverage
|
|
||||||
pytest-expect>=1.1,<2.0
|
|
||||||
mock
|
|
||||||
--- a/tox.ini
|
|
||||||
+++ b/tox.ini
|
|
||||||
@@ -1,5 +1,5 @@
|
|
||||||
[tox]
|
|
||||||
-envlist = {py27,py33,py34,py35,py36,pypy}-{base,six19,optional}
|
|
||||||
+envlist = {py27,py34,py35,py36,py37,py38,pypy}-{base,six19,optional}
|
|
||||||
|
|
||||||
[testenv]
|
|
||||||
deps =
|
|
@ -1,63 +0,0 @@
|
|||||||
From 3f10121d98ce8ca36b4b856275093dd189fdf1d2 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Sam Sneddon <me@gsnedders.com>
|
|
||||||
Date: Fri, 22 May 2020 20:37:19 +0100
|
|
||||||
Subject: [PATCH] Update pytest
|
|
||||||
|
|
||||||
---
|
|
||||||
.pytest.expect | 4 +--
|
|
||||||
html5lib/tests/tree_construction.py | 12 ++++-----
|
|
||||||
3 files changed, 15 insertions(+), 42 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/html5lib/tests/tree_construction.py b/html5lib/tests/tree_construction.py
|
|
||||||
index 6112d11d..1ef6e725 100644
|
|
||||||
--- a/html5lib/tests/tree_construction.py
|
|
||||||
+++ b/html5lib/tests/tree_construction.py
|
|
||||||
@@ -57,8 +57,6 @@ def _getParserTests(self, treeName, treeAPIs):
|
|
||||||
item.add_marker(pytest.mark.parser)
|
|
||||||
if namespaceHTMLElements:
|
|
||||||
item.add_marker(pytest.mark.namespaced)
|
|
||||||
- if treeAPIs is None:
|
|
||||||
- item.add_marker(pytest.mark.skipif(True, reason="Treebuilder not loaded"))
|
|
||||||
yield item
|
|
||||||
|
|
||||||
def _getTreeWalkerTests(self, treeName, treeAPIs):
|
|
||||||
@@ -69,8 +67,6 @@ def _getTreeWalkerTests(self, treeName, treeAPIs):
|
|
||||||
treeAPIs)
|
|
||||||
item.add_marker(getattr(pytest.mark, treeName))
|
|
||||||
item.add_marker(pytest.mark.treewalker)
|
|
||||||
- if treeAPIs is None:
|
|
||||||
- item.add_marker(pytest.mark.skipif(True, reason="Treebuilder not loaded"))
|
|
||||||
yield item
|
|
||||||
|
|
||||||
|
|
||||||
@@ -84,12 +80,14 @@ def convertTreeDump(data):
|
|
||||||
class ParserTest(pytest.Item):
|
|
||||||
def __init__(self, name, parent, test, treeClass, namespaceHTMLElements):
|
|
||||||
super(ParserTest, self).__init__(name, parent)
|
|
||||||
- self.obj = lambda: 1 # this is to hack around skipif needing a function!
|
|
||||||
self.test = test
|
|
||||||
self.treeClass = treeClass
|
|
||||||
self.namespaceHTMLElements = namespaceHTMLElements
|
|
||||||
|
|
||||||
def runtest(self):
|
|
||||||
+ if self.treeClass is None:
|
|
||||||
+ pytest.skip("Treebuilder not loaded")
|
|
||||||
+
|
|
||||||
p = html5parser.HTMLParser(tree=self.treeClass,
|
|
||||||
namespaceHTMLElements=self.namespaceHTMLElements)
|
|
||||||
|
|
||||||
@@ -147,11 +145,13 @@ def repr_failure(self, excinfo):
|
|
||||||
class TreeWalkerTest(pytest.Item):
|
|
||||||
def __init__(self, name, parent, test, treeAPIs):
|
|
||||||
super(TreeWalkerTest, self).__init__(name, parent)
|
|
||||||
- self.obj = lambda: 1 # this is to hack around skipif needing a function!
|
|
||||||
self.test = test
|
|
||||||
self.treeAPIs = treeAPIs
|
|
||||||
|
|
||||||
def runtest(self):
|
|
||||||
+ if self.treeAPIs is None:
|
|
||||||
+ pytest.skip("Treebuilder not loaded")
|
|
||||||
+
|
|
||||||
p = html5parser.HTMLParser(tree=self.treeAPIs["builder"])
|
|
||||||
|
|
||||||
input = self.test['data']
|
|
163
pytest6.patch
Normal file
163
pytest6.patch
Normal file
@ -0,0 +1,163 @@
|
|||||||
|
From 2c19b9899ab3a3e8bd0ca35e5d78544334204169 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?Miro=20Hron=C4=8Dok?= <miro@hroncok.cz>
|
||||||
|
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 <lambda>
|
||||||
|
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'
|
@ -1,3 +1,17 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Thu Aug 27 14:03:46 UTC 2020 - Marketa Calabkova <mcalabkova@suse.com>
|
||||||
|
|
||||||
|
- Update to 1.1
|
||||||
|
* Drop support for Python 3.3 and 3.4.
|
||||||
|
* Try to import from ``collections.abc`` to remove DeprecationWarning and ensure
|
||||||
|
``html5lib`` keeps working in future Python versions. (#403)
|
||||||
|
* Drop optional ``datrie`` dependency. (#442)
|
||||||
|
- Drop merged patches:
|
||||||
|
* pytest4-mhroncok.patch
|
||||||
|
* collections-abc.patch
|
||||||
|
* pytest5.patch
|
||||||
|
- Add upstream patch pytest6.patch
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Fri May 29 09:17:23 UTC 2020 - Tomáš Chvátal <tchvatal@suse.com>
|
Fri May 29 09:17:23 UTC 2020 - Tomáš Chvátal <tchvatal@suse.com>
|
||||||
|
|
||||||
|
@ -18,19 +18,15 @@
|
|||||||
|
|
||||||
%{?!python_module:%define python_module() python-%{**} python3-%{**}}
|
%{?!python_module:%define python_module() python-%{**} python3-%{**}}
|
||||||
Name: python-html5lib
|
Name: python-html5lib
|
||||||
Version: 1.0.1
|
Version: 1.1
|
||||||
Release: 0
|
Release: 0
|
||||||
Summary: HTML parser based on the WHAT-WG Web Applications 1
|
Summary: HTML parser based on the WHAT-WG Web Applications 1
|
||||||
License: MIT
|
License: MIT
|
||||||
URL: https://github.com/html5lib/html5lib-python
|
URL: https://github.com/html5lib/html5lib-python
|
||||||
Source: https://files.pythonhosted.org/packages/source/h/html5lib/html5lib-%{version}.tar.gz
|
Source: https://files.pythonhosted.org/packages/source/h/html5lib/html5lib-%{version}.tar.gz
|
||||||
# PATCH-FIX-UPSTREAM pytest4-mhroncok.patch gh#html5lib/html5lib-python#429 mcepl@suse.com
|
# PATCH-FIX_UPSTREAM https://github.com/html5lib/html5lib-python/commit/2c19b9899ab3a3e8bd0ca35e5d78544334204169 Use Node.from_parent() constructor to support pytest 6
|
||||||
# This patch makes testsuite pass with pytest4
|
Patch0: pytest6.patch
|
||||||
Patch0: pytest4-mhroncok.patch
|
|
||||||
Patch1: collections-abc.patch
|
|
||||||
Patch2: pytest5.patch
|
|
||||||
BuildRequires: %{python_module Genshi}
|
BuildRequires: %{python_module Genshi}
|
||||||
BuildRequires: %{python_module datrie}
|
|
||||||
BuildRequires: %{python_module lxml}
|
BuildRequires: %{python_module lxml}
|
||||||
BuildRequires: %{python_module mock}
|
BuildRequires: %{python_module mock}
|
||||||
BuildRequires: %{python_module pytest >= 4.0}
|
BuildRequires: %{python_module pytest >= 4.0}
|
||||||
|
Loading…
Reference in New Issue
Block a user