mirror of
https://github.com/arcan1s/ahriman.git
synced 2025-06-27 22:31:43 +00:00
* add models tests (#1) also replace single quote to double one to confort PEP docstring + move _check_output to class properties to make it available for mocking * alpm tests implementation * try to replace os with pathlib * update tests for pathlib * fix includes glob and trim version from dependencies * build_tools package tests * repository component tests * add sign tests * complete status tests * handle exceptions in actual_version calls * complete core tests * move configuration to root conftest * application tests * complete application tests * change copyright to more generic one * base web tests * complete web tests * complete testkit also add argument parsers test
47 lines
1.6 KiB
Python
47 lines
1.6 KiB
Python
#
|
|
# Copyright (c) 2021 ahriman team.
|
|
#
|
|
# This file is part of ahriman
|
|
# (see https://github.com/arcan1s/ahriman).
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
from aiohttp.web import middleware, Request
|
|
from aiohttp.web_exceptions import HTTPClientError
|
|
from aiohttp.web_response import StreamResponse
|
|
from logging import Logger
|
|
from typing import Awaitable, Callable
|
|
|
|
|
|
HandlerType = Callable[[Request], Awaitable[StreamResponse]]
|
|
|
|
|
|
def exception_handler(logger: Logger) -> Callable[[Request, HandlerType], Awaitable[StreamResponse]]:
|
|
"""
|
|
exception handler middleware. Just log any exception (except for client ones)
|
|
:param logger: class logger
|
|
:return: built middleware
|
|
"""
|
|
@middleware
|
|
async def handle(request: Request, handler: HandlerType) -> StreamResponse:
|
|
try:
|
|
return await handler(request)
|
|
except HTTPClientError:
|
|
raise
|
|
except Exception:
|
|
logger.exception(f"exception during performing request to {request.path}")
|
|
raise
|
|
|
|
return handle
|