dev-python/anyio: Enable py3.14

Signed-off-by: Michał Górny <mgorny@gentoo.org>
This commit is contained in:
Michał Górny
2025-05-14 10:34:27 +02:00
parent b65f362561
commit e0428b5cd6
3 changed files with 214 additions and 1 deletions

View File

@@ -4,7 +4,7 @@
EAPI=8
DISTUTILS_USE_PEP517=setuptools
PYTHON_COMPAT=( pypy3_11 python3_{11..13} )
PYTHON_COMPAT=( pypy3_11 python3_{11..14} )
inherit distutils-r1 pypi

View File

@@ -0,0 +1,89 @@
# Copyright 1999-2025 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=8
DISTUTILS_USE_PEP517=setuptools
PYTHON_COMPAT=( pypy3_11 python3_{11..14} )
inherit distutils-r1 pypi
DESCRIPTION="Compatibility layer for multiple asynchronous event loop implementations"
HOMEPAGE="
https://github.com/agronholm/anyio/
https://pypi.org/project/anyio/
"
LICENSE="MIT"
SLOT="0"
KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~loong ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86"
RDEPEND="
>=dev-python/idna-2.8[${PYTHON_USEDEP}]
>=dev-python/sniffio-1.1[${PYTHON_USEDEP}]
>=dev-python/truststore-0.9.1[${PYTHON_USEDEP}]
$(python_gen_cond_dep '
>=dev-python/typing-extensions-4.5[${PYTHON_USEDEP}]
' 3.{11..12})
"
# On amd64, let's get more test coverage by dragging in uvloop, but let's
# not bother on other arches where uvloop may not be supported.
BDEPEND="
>=dev-python/setuptools-scm-6.4[${PYTHON_USEDEP}]
test? (
>=dev-python/exceptiongroup-1.2.0[${PYTHON_USEDEP}]
>=dev-python/hypothesis-4.0[${PYTHON_USEDEP}]
>=dev-python/psutil-5.9[${PYTHON_USEDEP}]
dev-python/trustme[${PYTHON_USEDEP}]
$(python_gen_cond_dep '
>=dev-python/trio-0.26.1[${PYTHON_USEDEP}]
' 3.{11..13})
amd64? (
$(python_gen_cond_dep '
>=dev-python/uvloop-0.21.0_beta1[${PYTHON_USEDEP}]
' python3_{11..13})
)
)
"
distutils_enable_tests pytest
distutils_enable_sphinx docs \
'>=dev-python/sphinx-rtd-theme-1.2.2' \
dev-python/sphinxcontrib-jquery \
dev-python/sphinx-autodoc-typehints
PATCHES=(
# https://github.com/agronholm/anyio/commit/f051fd45a1d34bae8dd70dba726e711e7a49deee
# https://github.com/agronholm/anyio/commit/e0e2531de14c54eed895c92b4c8e87b44f47634b
# https://github.com/agronholm/anyio/commit/8bad9c05d966f6edfa58f26257015cb657d4e5ef
"${FILESDIR}/${P}-py314.patch"
)
python_test() {
local EPYTEST_DESELECT=(
# requires link-local IPv6 interface
tests/test_sockets.py::TestTCPListener::test_bind_link_local
)
case ${EPYTHON} in
pypy3.11)
EPYTEST_DESELECT+=(
# likely related to https://github.com/pypy/pypy/issues/5264
tests/test_debugging.py::test_main_task_name
)
;;
esac
local filter=()
if ! has_version ">=dev-python/trio-0.26.1[${PYTHON_USEDEP}]"; then
filter+=( -k "not trio" )
EPYTEST_DESELECT+=(
tests/test_pytest_plugin.py::test_plugin
tests/test_pytest_plugin.py::test_autouse_async_fixture
tests/test_pytest_plugin.py::test_cancel_scope_in_asyncgen_fixture
)
fi
local -x PYTEST_DISABLE_PLUGIN_AUTOLOAD=1
epytest -m 'not network' "${filter[@]}"
}

View File

@@ -0,0 +1,124 @@
From f051fd45a1d34bae8dd70dba726e711e7a49deee Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Alex=20Gr=C3=B6nholm?= <alex.gronholm@nextday.fi>
Date: Tue, 18 Mar 2025 14:38:12 +0200
Subject: [PATCH] Fixed Path tests on Python 3.14.0a6
---
src/anyio/_core/_fileio.py | 8 +++-----
1 file changed, 3 insertions(+), 5 deletions(-)
diff --git a/src/anyio/_core/_fileio.py b/src/anyio/_core/_fileio.py
index a0d61984..17459b79 100644
--- a/src/anyio/_core/_fileio.py
+++ b/src/anyio/_core/_fileio.py
@@ -421,13 +421,11 @@ async def copy(
target: str | os.PathLike[str],
*,
follow_symlinks: bool = True,
- dirs_exist_ok: bool = False,
preserve_metadata: bool = False,
) -> Path:
func = partial(
self._path.copy,
follow_symlinks=follow_symlinks,
- dirs_exist_ok=dirs_exist_ok,
preserve_metadata=preserve_metadata,
)
return Path(await to_thread.run_sync(func, target))
@@ -437,13 +435,11 @@ async def copy_into(
target_dir: str | os.PathLike[str],
*,
follow_symlinks: bool = True,
- dirs_exist_ok: bool = False,
preserve_metadata: bool = False,
) -> Path:
func = partial(
self._path.copy_into,
follow_symlinks=follow_symlinks,
- dirs_exist_ok=dirs_exist_ok,
preserve_metadata=preserve_metadata,
)
return Path(await to_thread.run_sync(func, target_dir))
@@ -616,7 +612,9 @@ async def read_text(
def relative_to(
self, *other: str | PathLike[str], walk_up: bool = False
) -> Path:
- return Path(self._path.relative_to(*other, walk_up=walk_up))
+ # relative_to() should work with any PathLike but it doesn't
+ others = [pathlib.Path(other) for other in other]
+ return Path(self._path.relative_to(*others, walk_up=walk_up))
else:
From e0e2531de14c54eed895c92b4c8e87b44f47634b Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Alex=20Gr=C3=B6nholm?= <alex.gronholm@nextday.fi>
Date: Tue, 15 Apr 2025 00:54:22 +0300
Subject: [PATCH] Fixed Path.copy() and Path.copy_info failing on Python
3.14.0a7
---
docs/versionhistory.rst | 1 +
src/anyio/_core/_fileio.py | 4 ++--
2 files changed, 3 insertions(+), 2 deletions(-)
diff --git a/src/anyio/_core/_fileio.py b/src/anyio/_core/_fileio.py
index 17459b79..2eae029e 100644
--- a/src/anyio/_core/_fileio.py
+++ b/src/anyio/_core/_fileio.py
@@ -428,7 +428,7 @@ async def copy(
follow_symlinks=follow_symlinks,
preserve_metadata=preserve_metadata,
)
- return Path(await to_thread.run_sync(func, target))
+ return Path(await to_thread.run_sync(func, pathlib.Path(target)))
async def copy_into(
self,
@@ -442,7 +442,7 @@ async def copy_into(
follow_symlinks=follow_symlinks,
preserve_metadata=preserve_metadata,
)
- return Path(await to_thread.run_sync(func, target_dir))
+ return Path(await to_thread.run_sync(func, pathlib.Path(target_dir)))
async def move(self, target: str | os.PathLike[str]) -> Path:
# Upstream does not handle anyio.Path properly as a PathLike
From 8bad9c05d966f6edfa58f26257015cb657d4e5ef Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Alex=20Gr=C3=B6nholm?= <alex.gronholm@nextday.fi>
Date: Sat, 15 Feb 2025 16:41:44 +0200
Subject: [PATCH] Fixed test failures caused by Python 3.14.0a5
---
docs/versionhistory.rst | 1 +
src/anyio/_core/_fileio.py | 15 ++++++++++-----
tests/test_fileio.py | 2 ++
3 files changed, 13 insertions(+), 5 deletions(-)
diff --git a/src/anyio/_core/_fileio.py b/src/anyio/_core/_fileio.py
index 3728734c..350a873a 100644
--- a/src/anyio/_core/_fileio.py
+++ b/src/anyio/_core/_fileio.py
@@ -411,6 +412,10 @@ def match(self, path_pattern: str) -> bool:
if sys.version_info >= (3, 14):
+ @property
+ def info(self) -> Any: # TODO: add return type annotation when Typeshed gets it
+ return self._path.info
+
async def copy(
self,
target: str | os.PathLike[str],
diff --git a/tests/test_fileio.py b/tests/test_fileio.py
index d7a769bd..28830e6e 100644
--- a/tests/test_fileio.py
+++ b/tests/test_fileio.py
@@ -106,6 +106,8 @@ async def test_properties(self) -> None:
stdlib_properties.discard("__enter__")
stdlib_properties.discard("__exit__")
stdlib_properties.discard("__firstlineno__")
+ stdlib_properties.discard("__open_rb__")
+ stdlib_properties.discard("__open_wb__")
async_path = Path(path)
anyio_properties = {