From a58c11b6f74f6bd4bce17c8754bf0e08df0ed7df Mon Sep 17 00:00:00 2001 From: Serg Tereshchenko Date: Fri, 11 Feb 2022 22:10:52 +0200 Subject: [PATCH] feat: Found a way to type instantiating metaclass --- factory/base.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/factory/base.py b/factory/base.py index 796f3d65..13ff8188 100644 --- a/factory/base.py +++ b/factory/base.py @@ -28,7 +28,7 @@ def resolve_attribute(name, bases, default=None): return default -class FactoryMetaClass(type): +class FactoryMetaClass(Generic[T], type): """Factory metaclass for handling ordered declarations.""" def __call__(cls, **kwargs): @@ -47,7 +47,7 @@ def __call__(cls, **kwargs): raise errors.UnknownStrategy('Unknown Meta.strategy: {}'.format( cls._meta.strategy)) - def __new__(mcs, class_name, bases, attrs): + def __new__(mcs, class_name, bases, attrs) -> T: """Record attributes as a pattern for later instance construction. This is called when a new Factory subclass is defined; it will collect @@ -415,7 +415,7 @@ class BaseFactory(Generic[T]): UnknownStrategy = errors.UnknownStrategy UnsupportedStrategy = errors.UnsupportedStrategy - def __new__(cls, *args, **kwargs): + def __new__(cls, *args, **kwargs) -> T: """Would be called if trying to instantiate the class.""" raise errors.FactoryError('You cannot instantiate BaseFactory')