Skip to content

Commit

Permalink
add rests and docs
Browse files Browse the repository at this point in the history
  • Loading branch information
mosquito committed Oct 31, 2022
1 parent 9772512 commit 489bd3f
Show file tree
Hide file tree
Showing 5 changed files with 65 additions and 4 deletions.
4 changes: 4 additions & 0 deletions aiohttp/web.py
Original file line number Diff line number Diff line change
Expand Up @@ -306,6 +306,7 @@ async def _run_app(
handle_signals: bool = True,
reuse_address: Optional[bool] = None,
reuse_port: Optional[bool] = None,
cancel_handler_on_connection_lost: bool = False
) -> None:
# An internal function to actually do all dirty job for application running
if asyncio.iscoroutine(app):
Expand All @@ -320,6 +321,7 @@ async def _run_app(
access_log_format=access_log_format,
access_log=access_log,
keepalive_timeout=keepalive_timeout,
cancel_handler_on_connection_lost=cancel_handler_on_connection_lost,
)

await runner.setup()
Expand Down Expand Up @@ -480,6 +482,7 @@ def run_app(
handle_signals: bool = True,
reuse_address: Optional[bool] = None,
reuse_port: Optional[bool] = None,
cancel_handler_on_connection_lost: bool = False,
loop: Optional[asyncio.AbstractEventLoop] = None,
) -> None:
"""Run an app locally"""
Expand Down Expand Up @@ -512,6 +515,7 @@ def run_app(
handle_signals=handle_signals,
reuse_address=reuse_address,
reuse_port=reuse_port,
cancel_handler_on_connection_lost=cancel_handler_on_connection_lost,
)
)

Expand Down
2 changes: 1 addition & 1 deletion aiohttp/web_protocol.py
Original file line number Diff line number Diff line change
Expand Up @@ -313,7 +313,7 @@ def connection_lost(self, exc: Optional[BaseException]) -> None:

super().connection_lost(exc)

should_cancel_task_handler = self._manager.cancel_when_connection_lost
should_cancel_task_handler = self._manager.cancel_handler_on_connection_lost

self._manager = None
self._force_close = True
Expand Down
4 changes: 2 additions & 2 deletions aiohttp/web_server.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ def __init__(
*,
request_factory: Optional[_RequestFactory] = None,
debug: Optional[bool] = None,
cancel_when_connection_lost: bool = False,
cancel_handler_on_connection_lost: bool = False,
**kwargs: Any,
) -> None:
if debug is not None:
Expand All @@ -34,7 +34,7 @@ def __init__(
self.requests_count = 0
self.request_handler = handler
self.request_factory = request_factory or self._make_request
self.cancel_when_connection_lost = cancel_when_connection_lost
self.cancel_handler_on_connection_lost = cancel_handler_on_connection_lost

@property
def connections(self) -> List[RequestHandler]:
Expand Down
8 changes: 7 additions & 1 deletion docs/web_reference.rst
Original file line number Diff line number Diff line change
Expand Up @@ -2809,7 +2809,8 @@ Utilities
access_log=aiohttp.log.access_logger, \
handle_signals=True, \
reuse_address=None, \
reuse_port=None)
reuse_port=None, \
cancel_handler_on_connection_lost=False)

A high-level function for running an application, serving it until
keyboard interrupt and performing a
Expand Down Expand Up @@ -2904,6 +2905,11 @@ Utilities
this flag when being created. This option is not
supported on Windows.

:param bool cancel_handler_on_connection_lost: tells the runner whether to
cancel the execution of the
handler task if the client
connection has been closed.

.. versionadded:: 3.0

Support *access_log_class* parameter.
Expand Down
51 changes: 51 additions & 0 deletions tests/test_web_server.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@

import pytest

import aiohttp
from aiohttp import client, helpers, web


Expand Down Expand Up @@ -207,3 +208,53 @@ async def handler(request):
)

logger.exception.assert_called_with("Error handling request", exc_info=exc)


async def test_cancel_handler_on_connection_lost(aiohttp_unused_port) -> None:
event = asyncio.Event()
port = aiohttp_unused_port()

async def on_request(_: web.Request) -> web.Response:
nonlocal event
try:
await asyncio.sleep(10)
except asyncio.CancelledError:
event.set()
raise
else:
raise web.HTTPInternalServerError()

app = web.Application()
app.router.add_route("GET", "/", on_request)

runner = web.AppRunner(app, cancel_handler_on_connection_lost=True)
await runner.setup()

site = web.TCPSite(runner, host="localhost", port=port)

await site.start()

async def client_request_maker():
async with aiohttp.ClientSession(
base_url=f"http://localhost:{port}"
) as session:
request = session.get("/")

with pytest.raises(asyncio.TimeoutError):
await asyncio.wait_for(request, timeout=0.1)

try:
assert runner.server.cancel_handler_on_connection_lost, "Flag was not propagated"
await client_request_maker()

await asyncio.wait_for(event.wait(), timeout=1)
assert event.is_set(), "Request handler hasn't been cancelled"
finally:
await asyncio.gather(runner.shutdown(), site.stop())


async def test_cancel_handler_on_connection_lost_flag_on_runner() -> None:
runner = web.AppRunner(web.Application(), cancel_handler_on_connection_lost=True)
await runner.setup()
assert runner.server.cancel_handler_on_connection_lost, "Flag was not propagated"
await runner.shutdown()

0 comments on commit 489bd3f

Please sign in to comment.