From cf0fc0cfc55c9779aea7f302a36a3bcf17344048 Mon Sep 17 00:00:00 2001 From: Michel Alexandre Salim Date: Tue, 12 May 2020 11:23:24 -0700 Subject: [PATCH] Update to 5.13.0 Fix NamedTuple detection on Python 3.9 --- .gitignore | 1 + hypothesis-py39-namedtuple.patch | 149 +++++++++++++++++++++++++++++++ python-hypothesis.spec | 11 ++- sources | 2 +- 4 files changed, 160 insertions(+), 3 deletions(-) create mode 100644 hypothesis-py39-namedtuple.patch diff --git a/.gitignore b/.gitignore index 3a70731..41ff2ee 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1,2 @@ /hypothesis-5.12.0.tar.gz +/hypothesis-5.13.0.tar.gz diff --git a/hypothesis-py39-namedtuple.patch b/hypothesis-py39-namedtuple.patch new file mode 100644 index 0000000..1e71626 --- /dev/null +++ b/hypothesis-py39-namedtuple.patch @@ -0,0 +1,149 @@ +From 99f99513ce19968ea0e5da15ba2084c32e6d0a2d Mon Sep 17 00:00:00 2001 +From: Michel Alexandre Salim +Date: Tue, 12 May 2020 11:14:08 -0700 +Subject: [PATCH] Add support for Python 3.9's NamedTuple changes + +In Python 3.9, NamedTuples no longer have a `_field_type` attribute; +it has been deprecated since Python 3.8 and the `__annotations__` +attribute has identical information: + +``` +>>> from typing import NamedTuple +>>> class MyNT(NamedTuple): +... x: int +... y: int = 1 +... +... +>>> issubclass(P, tuple) +True +>>> issubclass(P, NamedTuple) +False +>>> hasattr(MyNT, "_fields") +True +>>> hasattr(MyNT, "_field_types") +True +>>> hasattr(MyNT, "__annotations__") +True +>>> MyNT._field_types +{'x': , 'y': } +>>> MyNT.__annotations__ +{'x': , 'y': } +``` + +see https://bugs.python.org/issue40182 + +Testing for the existence of *either* `_field_types` or +`__annotations__` fixes the four failing tests on Python 3.9: + +``` +/builddir/build/BUILD/hypothesis-hypothesis-python-5.12.0/hypothesis-python + sh-5.0# PYTHONPATH=/builddir/build/BUILDROOT/python-hypothesis-5.12.0-1.fc33.x86_64/usr/lib/python3.9/site-packages pytest tests/cover/test_lookup.py::test_infers_args_f +or_namedtuple_builds +==================== test session starts ==================== +platform linux -- Python 3.9.0a6, pytest-4.6.10, py-1.8.0, pluggy-0.13.0 +rootdir: /builddir/build/BUILD/hypothesis-hypothesis-python-5.12.0, inifile: pytest.ini +plugins: hypothesis-5.12.0, xdist-1.32.0, forked-1.1.1 +collected 1 item + +tests/cover/test_lookup.py . [100%] + +================= slowest 20 test durations ================= +0.23s call hypothesis-python/tests/cover/test_lookup.py::test_infers_args_for_namedtuple_builds +0.02s setup hypothesis-python/tests/cover/test_lookup.py::test_infers_args_for_namedtuple_builds + +(0.00 durations hidden. Use -vv to show these durations.) +================= 1 passed in 0.45 seconds ================== + sh-5.0# grep -rl test_infers_args_for_namedtuple_builds * +tests/cover/__pycache__/test_lookup.cpython-39-PYTEST.pyc +tests/cover/test_lookup.py + sh-5.0# PYTHONPATH=/builddir/build/BUILDROOT/python-hypothesis-5.12.0-1.fc33.x86_64/usr/lib/python3.9/site-packages pytest tests/cover/test_lookup.py::test_infers_args_for_namedtuple_from_type +==================== test session starts ==================== +platform linux -- Python 3.9.0a6, pytest-4.6.10, py-1.8.0, pluggy-0.13.0 +rootdir: /builddir/build/BUILD/hypothesis-hypothesis-python-5.12.0, inifile: pytest.ini +plugins: hypothesis-5.12.0, xdist-1.32.0, forked-1.1.1 +collected 1 item + +tests/cover/test_lookup.py . [100%] + +================= slowest 20 test durations ================= +0.20s call hypothesis-python/tests/cover/test_lookup.py::test_infers_args_for_namedtuple_from_type +0.02s setup hypothesis-python/tests/cover/test_lookup.py::test_infers_args_for_namedtuple_from_type + +(0.00 durations hidden. Use -vv to show these durations.) +================= 1 passed in 0.42 seconds ================== + sh-5.0# grep -rl test_resolves_forward_references_outside_annotations * +tests/cover/test_lookup_py36.py +tests/cover/__pycache__/test_lookup_py36.cpython-39-PYTEST.pyc + sh-5.0# PYTHONPATH=/builddir/build/BUILDROOT/python-hypothesis-5.12.0-1.fc33.x86_64/usr/lib/python3.9/site-packages pytest tests/cover/test_lookup_py36.py::test_resolves +_forward_references_outside_annotations +==================== test session starts ==================== +platform linux -- Python 3.9.0a6, pytest-4.6.10, py-1.8.0, pluggy-0.13.0 +rootdir: /builddir/build/BUILD/hypothesis-hypothesis-python-5.12.0, inifile: pytest.ini +plugins: hypothesis-5.12.0, xdist-1.32.0, forked-1.1.1 +collected 1 item + +tests/cover/test_lookup_py36.py . [100%] + +================= slowest 20 test durations ================= +0.93s call hypothesis-python/tests/cover/test_lookup_py36.py::test_resolves_forward_references_outside_annotations +0.01s setup hypothesis-python/tests/cover/test_lookup_py36.py::test_resolves_forward_references_outside_annotations + +(0.00 durations hidden. Use -vv to show these durations.) +================= 1 passed in 0.95 seconds ================== + sh-5.0# PYTHONPATH=/builddir/build/BUILDROOT/python-hypothesis-5.12.0-1.fc33.x86_64/usr/lib/python3.9/site-packages pytest tests/cover/test_lookup.py::test_infers_args_for_namedtuple_from_type^C + sh-5.0# grep -rl test_specialised_collection_types * +tests/cover/__pycache__/test_lookup.cpython-39-PYTEST.pyc +tests/cover/test_lookup.py + sh-5.0# PYTHONPATH=/builddir/build/BUILDROOT/python-hypothesis-5.12.0-1.fc33.x86_64/usr/lib/python3.9/site-packages pytest tests/cover/test_lookup.py::test_specialised_collection_types +==================== test session starts ==================== +platform linux -- Python 3.9.0a6, pytest-4.6.10, py-1.8.0, pluggy-0.13.0 +rootdir: /builddir/build/BUILD/hypothesis-hypothesis-python-5.12.0, inifile: pytest.ini +plugins: hypothesis-5.12.0, xdist-1.32.0, forked-1.1.1 +collected 14 items + +tests/cover/test_lookup.py .............. [100%] + +================= slowest 20 test durations ================= +0.44s call hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ12-coll_type12-int] +0.34s call hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ2-dict-int] +0.34s call hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ4-dict_values-int] +0.34s call hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ11-coll_type11-int] +0.31s call hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ3-dict_keys-int] +0.30s call hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ10-coll_type10-int] +0.28s call hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ0-set-int] +0.26s call hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ1-frozenset-int] +0.23s call hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ9-coll_type9-int] +0.21s call hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ7-tuple-int] +0.20s call hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ5-list-int] +0.19s call hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ8-coll_type8-int] +0.13s call hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[A_NamedTuple-tuple-int] +0.10s call hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ6-tuple-int] +0.02s setup hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ2-dict-int] +0.02s setup hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ0-set-int] +0.02s setup hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[A_NamedTuple-tuple-int] +0.02s setup hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ10-coll_type10-int] +0.02s setup hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ11-coll_type11-int] +0.02s setup hypothesis-python/tests/cover/test_lookup.py::test_specialised_collection_types[typ4-dict_values-int] +================= 14 passed in 4.11 seconds ================= +``` + +This addresses issue #2427 . +--- + hypothesis-python/src/hypothesis/internal/compat.py | 4 +++- + 1 file changed, 3 insertions(+), 1 deletion(-) + +diff --git a/hypothesis-python/src/hypothesis/internal/compat.py b/hypothesis-python/src/hypothesis/internal/compat.py +index 08853a6b80..fd045a3464 100644 +--- a/hypothesis-python/src/hypothesis/internal/compat.py ++++ b/hypothesis-python/src/hypothesis/internal/compat.py +@@ -92,7 +92,9 @@ def is_typed_named_tuple(cls): + return ( + issubclass(cls, tuple) + and hasattr(cls, "_fields") +- and hasattr(cls, "_field_types") ++ and (hasattr(cls, "_field_types") ++ or hasattr(cls, "__annotations__") ++ ) + ) + + diff --git a/python-hypothesis.spec b/python-hypothesis.spec index 12d423e..1a9cc95 100644 --- a/python-hypothesis.spec +++ b/python-hypothesis.spec @@ -1,13 +1,16 @@ %global srcname hypothesis Name: python-%{srcname} -Version: 5.12.0 +Version: 5.13.0 Release: 1%{?dist} Summary: Library for property based testing License: MPLv2.0 URL: https://github.com/HypothesisWorks/hypothesis-python Source0: %{url}/archive/%{srcname}-python-%{version}/%{srcname}-%{version}.tar.gz +# Fixes detection of NamedTuple on Python 3.9 +# https://github.com/HypothesisWorks/hypothesis/pull/2428 +Patch0: https://patch-diff.githubusercontent.com/raw/HypothesisWorks/%{srcname}/pull/2428.patch#/%{srcname}-py39-namedtuple.patch BuildArch: noarch @@ -60,7 +63,7 @@ Suggests: python%{python3_version}dist(pytest) >= 3.0 Python 3 version. %prep -%autosetup -n %{srcname}-%{srcname}-python-%{version}/%{srcname}-python -p1 +%autosetup -n %{srcname}-%{srcname}-python-%{version}/%{srcname}-python -p2 # disable Sphinx extensions that require Internet access sed -i -e '/sphinx.ext.intersphinx/d' docs/conf.py @@ -94,6 +97,10 @@ PYTHONPATH=%{buildroot}%{python3_sitelib} pytest-3 -v -n auto -k "not test_healt %endif %changelog +* Tue May 12 2020 Michel Alexandre Salim - 5.13.0-1 +- Update to 5.13.0 +- Fix NamedTuple detection on Python 3.9 + * Mon May 11 2020 Michel Alexandre Salim - 5.12.0-1 - Update to 5.12.0 diff --git a/sources b/sources index 3e344d2..86a79f7 100644 --- a/sources +++ b/sources @@ -1 +1 @@ -SHA512 (hypothesis-5.12.0.tar.gz) = 5d95e62c9ada41d0d753261b3874e4ea47830769055560c7beef3eb80238b563eb34ef77096d528dbd48763dff037fed7342bc01e56ccade8ba315aa4fd079f0 +SHA512 (hypothesis-5.13.0.tar.gz) = 595a8fdb7023f9cdeba0140fe08265f460d62ad4744d1f4272e373071a96a7dc9b21c0dd67f1375016ba19b5bad439c58d2b02b00a08b1aecb4a2ab3cd29a7bd