Skip to content

Commit

Permalink
Merge pull request #91 from marier-nico/fix/types
Browse files Browse the repository at this point in the history
fix: make Depends type work with mypy
  • Loading branch information
marier-nico authored Oct 12, 2022
2 parents 9e6f392 + 46dd6e2 commit 6e3f5c3
Showing 1 changed file with 15 additions and 5 deletions.
20 changes: 15 additions & 5 deletions src/event_processor/dependencies.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,17 +19,27 @@
from src.event_processor.util import py37_get_args as get_args


DependsReturn = typing.TypeVar("DependsReturn")


class Event(dict):
"""Type to wrap a dict to be used as a dependency."""

def __init__(self, dict_event: dict):
super().__init__(dict_event)


class Depends:
# We need to use a function if we want mypy to give proper type hints, since our dependency should be
# interpreted as the type returned by the user supplied callable and not as a `Depends` instance.
def Depends(callable_: Callable[..., DependsReturn], cache: bool = True) -> DependsReturn:
"""Create a dependency."""
return _Depends(callable_, cache) # type: ignore


class _Depends:
"""Class to designate a dependency"""

def __init__(self, callable_: Callable, cache: bool = True):
def __init__(self, callable_: Callable[..., DependsReturn], cache: bool = True):
"""Create a dependency.
:param callable_: The callable on which there is a dependency
Expand Down Expand Up @@ -69,7 +79,7 @@ def call_with_injection(


def resolve(
dependency: Depends, event: Optional[Event] = None, cache: Optional[dict] = None
dependency: _Depends, event: Optional[Event] = None, cache: Optional[dict] = None
) -> Tuple[Optional[Any], bool]:
"""Resolve a dependency into a value.
Expand Down Expand Up @@ -115,7 +125,7 @@ def resolve(
return value, cacheable


def get_required_dependencies(callable_: Callable) -> Dict[str, Depends]:
def get_required_dependencies(callable_: Callable) -> Dict[str, _Depends]:
"""Get the required dependencies for a callable.
:param callable_: The callable for which to get dependencies
Expand All @@ -125,7 +135,7 @@ def get_required_dependencies(callable_: Callable) -> Dict[str, Depends]:
required_dependencies = {
name: arg.default
for name, arg in signature.parameters.items()
if arg.default is not inspect.Parameter.empty and isinstance(arg.default, Depends)
if arg.default is not inspect.Parameter.empty and isinstance(arg.default, _Depends)
}
return required_dependencies

Expand Down

0 comments on commit 6e3f5c3

Please sign in to comment.