From 247363433cb5b16129ffc4c7b7dbbc83b9757ed1 Mon Sep 17 00:00:00 2001 From: Mikko Korpela Date: Sun, 9 Oct 2022 18:27:54 +0300 Subject: [PATCH] black --- overrides/enforce.py | 16 +++++++++------- overrides/overrides.py | 4 +++- overrides/typing_utils.py | 8 ++++++-- setup.py | 4 +++- tests/test_enforce__py38.py | 5 +++-- 5 files changed, 24 insertions(+), 13 deletions(-) diff --git a/overrides/enforce.py b/overrides/enforce.py index 619c2b8..4db3c67 100644 --- a/overrides/enforce.py +++ b/overrides/enforce.py @@ -24,13 +24,16 @@ def _check_if_overrides_without_overrides_decorator(name, value, bases): for base in bases: base_class_method = getattr(base, name, False) if ( - not base_class_method - or not callable(base_class_method) - or getattr(base_class_method, "__ignored__", False) + not base_class_method + or not callable(base_class_method) + or getattr(base_class_method, "__ignored__", False) ): continue if not is_override: - raise TypeError(f"Method {name} overrides but does not have @overrides decorator") + raise TypeError( + f"Method {name} overrides but does not have @overrides decorator" + ) + @staticmethod def _check_if_overrides_final_method(name, bases): for base in bases: @@ -38,8 +41,8 @@ def _check_if_overrides_final_method(name, bases): # `__finalized__` is added by `@final` decorator if getattr(base_class_method, "__finalized__", False): raise TypeError( - f"Method {base_class_method} is finalized in {base}, it cannot be overridden" - ) + f"Method {name} is finalized in {base}, it cannot be overridden" + ) @staticmethod def _handle_special_value(value): @@ -50,7 +53,6 @@ def _handle_special_value(value): return value - class EnforceOverrides(metaclass=EnforceOverridesMeta): "Use this as the parent class for your custom classes" pass diff --git a/overrides/overrides.py b/overrides/overrides.py index 7cd862e..2dbd42d 100644 --- a/overrides/overrides.py +++ b/overrides/overrides.py @@ -95,7 +95,9 @@ def method(self): def _overrides( - method: _WrappedMethod, check_signature: bool, check_at_runtime: bool, + method: _WrappedMethod, + check_signature: bool, + check_at_runtime: bool, ) -> _WrappedMethod: setattr(method, "__override__", True) global_vars = getattr(method, "__globals__", None) diff --git a/overrides/typing_utils.py b/overrides/typing_utils.py index 2d9f919..9503124 100644 --- a/overrides/typing_utils.py +++ b/overrides/typing_utils.py @@ -291,7 +291,9 @@ def _is_origin_subtype(left: OriginType, right: OriginType) -> bool: NormalizedTypeArgs = typing.Union[ - typing.Tuple[typing.Any, ...], typing.FrozenSet[NormalizedType], NormalizedType, + typing.Tuple[typing.Any, ...], + typing.FrozenSet[NormalizedType], + NormalizedType, ] @@ -416,7 +418,9 @@ def _is_normal_subtype( def issubtype( - left: Type, right: Type, forward_refs: typing.Optional[dict] = None, + left: Type, + right: Type, + forward_refs: typing.Optional[dict] = None, ) -> typing.Optional[bool]: """Check that the left argument is a subtype of the right. For unions, check if the type arguments of the left is a subset of the right. diff --git a/setup.py b/setup.py index ac0e5c7..63bb5a0 100644 --- a/setup.py +++ b/setup.py @@ -24,7 +24,9 @@ author_email=address, url="https://github.com/mkorpela/overrides", packages=find_packages(), - package_data={"overrides": ["*.pyi", "py.typed"],}, + package_data={ + "overrides": ["*.pyi", "py.typed"], + }, include_package_data=True, install_requires=['typing;python_version<"3.5"'], python_requires=">=3.6", diff --git a/tests/test_enforce__py38.py b/tests/test_enforce__py38.py index f15fe2b..78fb2c1 100644 --- a/tests/test_enforce__py38.py +++ b/tests/test_enforce__py38.py @@ -12,7 +12,6 @@ class Enforcing(EnforceOverrides): def finality(self): return "final" - @final def __and__(self, other): return True @@ -53,23 +52,25 @@ def nonfinal1(self, param: int) -> str: def test_enforcing_when_finality_broken(self): with self.assertRaises(TypeError): + class BrokesFinality(Enforcing): def finality(self): return "NEVER HERE" def test_trying_to_override_final_magic_method(self): with self.assertRaises(TypeError): + class FinalMagicOverrides(Enforcing): def __and__(self, other): return False def test_enforcing_when_none_explicit_override(self): with self.assertRaises(TypeError): + class Overrider(Enforcing): def nonfinal2(self): return "NEVER HERE EITHER" - def test_enforcing_when_property_overriden(self): class PropertyOverrider(Enforcing): @property