Skip to content

Commit

Permalink
Remove yarl back-compat for older versions of yarl
Browse files Browse the repository at this point in the history
#9305 increased the min version of yarl to 1.13.0
for master and 3.11
  • Loading branch information
bdraco committed Sep 27, 2024
1 parent 970c5d9 commit 734fbaa
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 49 deletions.
25 changes: 5 additions & 20 deletions aiohttp/client_reqrep.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@
)

from multidict import CIMultiDict, CIMultiDictProxy, MultiDict, MultiDictProxy
from yarl import URL, __version__ as yarl_version
from yarl import URL

from . import hdrs, helpers, http, multipart, payload
from .abc import AbstractStreamWriter
Expand Down Expand Up @@ -91,10 +91,6 @@


_CONTAINS_CONTROL_CHAR_RE = re.compile(r"[^-!#$%&'*+.^_`|~0-9a-zA-Z]")
_YARL_SUPPORTS_HOST_SUBCOMPONENT = tuple(map(int, yarl_version.split(".")[:2])) >= (
1,
13,
)


def _gen_default_accept_encoding() -> str:
Expand Down Expand Up @@ -360,13 +356,8 @@ def update_headers(self, headers: Optional[LooseHeaders]) -> None:
self.headers: CIMultiDict[str] = CIMultiDict()

# add host
if _YARL_SUPPORTS_HOST_SUBCOMPONENT:
netloc = self.url.host_subcomponent
assert netloc is not None
else:
netloc = cast(str, self.url.raw_host)
if helpers.is_ipv6_address(netloc):
netloc = f"[{netloc}]"
netloc = self.url.host_subcomponent
assert netloc is not None
# See https://github.com/aio-libs/aiohttp/issues/3636.
netloc = netloc.rstrip(".")
if self.url.port is not None and not self.url.is_default_port():
Expand Down Expand Up @@ -614,14 +605,8 @@ async def send(self, conn: "Connection") -> "ClientResponse":
# - not CONNECT proxy must send absolute form URI
# - most common is origin form URI
if self.method == hdrs.METH_CONNECT:
if _YARL_SUPPORTS_HOST_SUBCOMPONENT:
connect_host = self.url.host_subcomponent
assert connect_host is not None
else:
connect_host = self.url.raw_host
assert connect_host is not None
if helpers.is_ipv6_address(connect_host):
connect_host = f"[{connect_host}]"
connect_host = self.url.host_subcomponent
assert connect_host is not None
path = f"{connect_host}:{self.url.port}"
elif self.proxy and not self.is_ssl():
path = str(self.url)
Expand Down
17 changes: 4 additions & 13 deletions tests/test_client_request.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
from yarl import URL

import aiohttp
from aiohttp import BaseConnector, client_reqrep, hdrs, helpers, payload
from aiohttp import BaseConnector, hdrs, helpers, payload
from aiohttp.abc import AbstractStreamWriter
from aiohttp.base_protocol import BaseProtocol
from aiohttp.client_exceptions import ClientConnectionError
Expand Down Expand Up @@ -282,18 +282,9 @@ def test_host_header_ipv4(make_request: _RequestMaker) -> None:
assert req.headers["HOST"] == "127.0.0.2"


@pytest.mark.parametrize("yarl_supports_host_subcomponent", [True, False])
def test_host_header_ipv6(
make_request: _RequestMaker, yarl_supports_host_subcomponent: bool
) -> None:
# Ensure the old path is tested for old yarl versions
with mock.patch.object(
client_reqrep,
"_YARL_SUPPORTS_HOST_SUBCOMPONENT",
yarl_supports_host_subcomponent,
):
req = make_request("get", "http://[::2]")
assert req.headers["HOST"] == "[::2]"
def test_host_header_ipv6(make_request: _RequestMaker) -> None:
req = make_request("get", "http://[::2]")
assert req.headers["HOST"] == "[::2]"


def test_host_header_ipv4_with_port(make_request: _RequestMaker) -> None:
Expand Down
24 changes: 8 additions & 16 deletions tests/test_proxy_functional.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@
from yarl import URL

import aiohttp
from aiohttp import ClientResponse, client_reqrep, web
from aiohttp import ClientResponse, web
from aiohttp.client import _RequestOptions
from aiohttp.client_exceptions import ClientConnectionError
from aiohttp.pytest_plugin import AiohttpRawServer, AiohttpServer
Expand Down Expand Up @@ -135,7 +135,6 @@ async def handler(request: web.Request) -> web.Response:
reason="asyncio on this python does not support TLS in TLS",
)
@pytest.mark.parametrize("web_server_endpoint_type", ("http", "https"))
@pytest.mark.parametrize("yarl_supports_host_subcomponent", [True, False])
@pytest.mark.filterwarnings(r"ignore:.*ssl.OP_NO_SSL*")
# Filter out the warning from
# https://github.com/abhinavsingh/proxy.py/blob/30574fd0414005dfa8792a6e797023e862bdcf43/proxy/common/utils.py#L226
Expand All @@ -145,25 +144,18 @@ async def test_secure_https_proxy_absolute_path(
secure_proxy_url: URL,
web_server_endpoint_url: URL,
web_server_endpoint_payload: str,
yarl_supports_host_subcomponent: bool,
) -> None:
"""Ensure HTTP(S) sites are accessible through a secure proxy."""
conn = aiohttp.TCPConnector()
sess = aiohttp.ClientSession(connector=conn)

# Ensure the old path is tested for old yarl versions
with mock.patch.object(
client_reqrep,
"_YARL_SUPPORTS_HOST_SUBCOMPONENT",
yarl_supports_host_subcomponent,
):
async with sess.get(
web_server_endpoint_url,
proxy=secure_proxy_url,
ssl=client_ssl_ctx, # used for both proxy and endpoint connections
) as response:
assert response.status == 200
assert await response.text() == web_server_endpoint_payload
async with sess.get(
web_server_endpoint_url,
proxy=secure_proxy_url,
ssl=client_ssl_ctx, # used for both proxy and endpoint connections
) as response:
assert response.status == 200
assert await response.text() == web_server_endpoint_payload

await sess.close()
await conn.close()
Expand Down

0 comments on commit 734fbaa

Please sign in to comment.