From 17409bb452d10ff837bd980f18ea346e8292e5df Mon Sep 17 00:00:00 2001 From: Tom Christie Date: Fri, 27 Sep 2024 13:18:34 +0100 Subject: [PATCH] Handle `trio` raising `NotImplementedError` on unsupported platforms. (#955) * Handle import of `trio` raising `NotImplementedError` on unsupported platforms. Closes #946 * Add pragma no cover to deal with oddly misbehaving test * Update CHANGELOG.md --- CHANGELOG.md | 3 ++- httpcore/_backends/anyio.py | 6 +++--- httpcore/_synchronization.py | 2 +- 3 files changed, 6 insertions(+), 5 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 992dcff6e..99b1dc0f7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,7 +6,8 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/). ## Unreleased -- Handle `SSLError` exception. (#918) +- Handle `trio` raising `NotImplementedError` on unsupported platforms. (#955) +- Handle mapping `ssl.SSLError` to `httpcore.ConnectError`. (#918) ## 1.0.5 (March 27th, 2024) diff --git a/httpcore/_backends/anyio.py b/httpcore/_backends/anyio.py index 72d03ffbf..d469e0084 100644 --- a/httpcore/_backends/anyio.py +++ b/httpcore/_backends/anyio.py @@ -104,9 +104,9 @@ async def connect_tcp( timeout: typing.Optional[float] = None, local_address: typing.Optional[str] = None, socket_options: typing.Optional[typing.Iterable[SOCKET_OPTION]] = None, - ) -> AsyncNetworkStream: + ) -> AsyncNetworkStream: # pragma: nocover if socket_options is None: - socket_options = [] # pragma: no cover + socket_options = [] exc_map = { TimeoutError: ConnectTimeout, OSError: ConnectError, @@ -120,7 +120,7 @@ async def connect_tcp( local_host=local_address, ) # By default TCP sockets opened in `asyncio` include TCP_NODELAY. - for option in socket_options: # pragma: nocover + for option in socket_options: stream._raw_socket.setsockopt(*option) # type: ignore[attr-defined] # pragma: no cover return AnyIOStream(stream) diff --git a/httpcore/_synchronization.py b/httpcore/_synchronization.py index 9619a3983..50cfefe0a 100644 --- a/httpcore/_synchronization.py +++ b/httpcore/_synchronization.py @@ -9,7 +9,7 @@ try: import trio -except ImportError: # pragma: nocover +except (ImportError, NotImplementedError): # pragma: nocover trio = None # type: ignore try: