From d147a36ebfe57e1ad9f5858caf20591b37fda5aa Mon Sep 17 00:00:00 2001 From: Pierre Souchay Date: Fri, 13 Aug 2021 04:11:36 +0200 Subject: [PATCH] Proper type hints for @metric_scope decorator to work nicely with mypy When using @metric_scope on a typed function, mypy produces this kind of error: error: Untyped decorator makes function "handler" untyped This fix avoid this error and will let people using typehint now having those kind of error messages. See https://mypy.readthedocs.io/en/stable/generics.html#declaring-decorators --- aws_embedded_metrics/metric_scope/__init__.py | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/aws_embedded_metrics/metric_scope/__init__.py b/aws_embedded_metrics/metric_scope/__init__.py index 47044bc..a970460 100644 --- a/aws_embedded_metrics/metric_scope/__init__.py +++ b/aws_embedded_metrics/metric_scope/__init__.py @@ -11,13 +11,16 @@ # See the License for the specific language governing permissions and # limitations under the License. +from typing import Any, Callable, TypeVar, cast from aws_embedded_metrics.logger.metrics_logger_factory import create_metrics_logger import inspect import asyncio from functools import wraps +F = TypeVar('F', bound=Callable[..., Any]) -def metric_scope(fn): # type: ignore + +def metric_scope(fn: F) -> F: if asyncio.iscoroutinefunction(fn): @@ -33,7 +36,7 @@ async def wrapper(*args, **kwargs): # type: ignore finally: await logger.flush() - return wrapper + return cast(F, wrapper) else: @wraps(fn) @@ -49,4 +52,4 @@ def wrapper(*args, **kwargs): # type: ignore loop = asyncio.get_event_loop() loop.run_until_complete(logger.flush()) - return wrapper + return cast(F, wrapper)