diff --git a/CHANGES/3504.bugfix b/CHANGES/3504.bugfix new file mode 100644 index 00000000000..8ffa3e907a6 --- /dev/null +++ b/CHANGES/3504.bugfix @@ -0,0 +1 @@ +Fix type stubs for ``aiohttp.web.run_app(access_log=True)`` and fix edge case of ``access_log=True`` and the event loop being in debug mode. diff --git a/aiohttp/web.py b/aiohttp/web.py index 0c3b6374d0f..fa66658feed 100644 --- a/aiohttp/web.py +++ b/aiohttp/web.py @@ -269,7 +269,7 @@ async def _run_app(app: Union[Application, Awaitable[Application]], *, backlog: int=128, access_log_class: Type[AbstractAccessLogger]=AccessLogger, access_log_format: str=AccessLogger.LOG_FORMAT, - access_log: logging.Logger=access_logger, + access_log: Optional[logging.Logger]=access_logger, handle_signals: bool=True, reuse_address: Optional[bool]=None, reuse_port: Optional[bool]=None) -> None: @@ -383,7 +383,7 @@ def run_app(app: Union[Application, Awaitable[Application]], *, backlog: int=128, access_log_class: Type[AbstractAccessLogger]=AccessLogger, access_log_format: str=AccessLogger.LOG_FORMAT, - access_log: logging.Logger=access_logger, + access_log: Optional[logging.Logger]=access_logger, handle_signals: bool=True, reuse_address: Optional[bool]=None, reuse_port: Optional[bool]=None) -> None: @@ -391,7 +391,7 @@ def run_app(app: Union[Application, Awaitable[Application]], *, loop = asyncio.get_event_loop() # Configure if and only if in debugging mode and using the default logger - if loop.get_debug() and access_log.name == 'aiohttp.access': + if loop.get_debug() and access_log and access_log.name == 'aiohttp.access': if access_log.level == logging.NOTSET: access_log.setLevel(logging.DEBUG) if not access_log.hasHandlers():