Skip to content

Commit

Permalink
test: BI-0 add a timeout middleware test (#554)
Browse files Browse the repository at this point in the history
  • Loading branch information
MCPN authored Jul 26, 2024
1 parent 3aef8d9 commit 4181210
Showing 1 changed file with 63 additions and 0 deletions.
63 changes: 63 additions & 0 deletions lib/dl_api_commons/dl_api_commons_tests/unit/aio/test_timeout.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
import asyncio

from aiohttp import web
import pytest

from dl_api_commons.aio.middlewares.error_handling_outer import (
AIOHTTPErrorHandler,
ErrorData,
ErrorLevel,
)
from dl_api_commons.aio.middlewares.request_bootstrap import RequestBootstrap
from dl_api_commons.aio.middlewares.request_id import RequestId
from dl_api_commons.aiohttp.aiohttp_wrappers import DLRequestView
from dl_api_commons.exc import RequestTimeoutError


class SleepingErrorHandler(AIOHTTPErrorHandler):
def _classify_error(self, err: Exception, request: web.Request) -> ErrorData:
if isinstance(err, RequestTimeoutError):
return ErrorData(
status_code=424,
response_body=dict(code=err.err_code, message=err.message),
level=ErrorLevel.info,
)
return ErrorData(status_code=500, response_body=dict(details=str(err)), level=ErrorLevel.error)


@pytest.mark.asyncio
async def test_request_bootstrap_timeout(aiohttp_client):
common_timeout = 0.5

app = web.Application(
middlewares=[
RequestBootstrap(
req_id_service=RequestId(),
error_handler=SleepingErrorHandler(use_sentry=False, sentry_app_name_tag=""),
timeout_sec=common_timeout,
).middleware,
]
)

class TestView(DLRequestView):
async def get(self):
to_sleep = float(self.request.rel_url.query["time_to_sleep"])
await asyncio.sleep(to_sleep)
return web.json_response({})

app.router.add_route("*", "/sleeping_view", TestView)
client = await aiohttp_client(app)

resp = await client.get("/sleeping_view", params={"time_to_sleep": common_timeout + 0.1})
try:
assert resp.status == 424
resp_json = await resp.json()
assert resp_json["code"] == ["REQUEST_TIMEOUT"]
finally:
resp.close()

resp = await client.get("/sleeping_view", params={"time_to_sleep": common_timeout - 0.1})
try:
assert resp.status == 200
finally:
resp.close()

0 comments on commit 4181210

Please sign in to comment.