aboutsummaryrefslogtreecommitdiff
path: root/factory
diff options
context:
space:
mode:
authorRaphaël Barrois <raphael.barrois@polyconseil.fr>2011-05-13 16:06:13 +0200
committerRaphaël Barrois <raphael.barrois@polyconseil.fr>2011-05-13 16:06:13 +0200
commit64a059101d0119e18c1cb0b15b0e9e15795ccba1 (patch)
tree7f15e7e83dbc6fe9095aac937c211f7b5c1fbaad /factory
parentf57a0c213ffe12325e20e69e5cc03ff27633d06c (diff)
downloadfactory-boy-64a059101d0119e18c1cb0b15b0e9e15795ccba1.tar
factory-boy-64a059101d0119e18c1cb0b15b0e9e15795ccba1.tar.gz
Improve handling of custom build/create functions.
Only public attributes (i.e not starting with _) will be handled properly. Signed-off-by: Raphaël Barrois <raphael.barrois@polyconseil.fr>
Diffstat (limited to 'factory')
-rw-r--r--factory/base.py27
1 files changed, 24 insertions, 3 deletions
diff --git a/factory/base.py b/factory/base.py
index 1d84b03..222c1bf 100644
--- a/factory/base.py
+++ b/factory/base.py
@@ -86,7 +86,7 @@ class BaseFactoryMetaClass(type):
ordered_declarations = [(_name, declaration) for (_name, declaration) in ordered_declarations if _name != name]
ordered_declarations.append((name, attrs[name]))
del attrs[name]
- elif not name.startswith('__'):
+ elif not name.startswith('_'):
unordered_declarations = [(_name, value) for (_name, value) in unordered_declarations if _name != name]
unordered_declarations.append((name, attrs[name]))
del attrs[name]
@@ -230,9 +230,30 @@ class Factory(BaseFactory):
return cls._creation_function[0]
@classmethod
+ def _prepare(cls, create, **kwargs):
+ """Prepare an object for this factory.
+
+ Args:
+ create: bool, whether to create or to build the object
+ **kwargs: arguments to pass to the creation function
+ """
+ if create:
+ return cls.get_creation_function()(getattr(cls, CLASS_ATTRIBUTE_ASSOCIATED_CLASS), **kwargs)
+ else:
+ return getattr(cls, CLASS_ATTRIBUTE_ASSOCIATED_CLASS)(**kwargs)
+
+ @classmethod
+ def _build(cls, **kwargs):
+ return cls._prepare(create=False, **kwargs)
+
+ @classmethod
+ def _create(cls, **kwargs):
+ return cls._prepare(create=True, **kwargs)
+
+ @classmethod
def build(cls, **kwargs):
- return getattr(cls, CLASS_ATTRIBUTE_ASSOCIATED_CLASS)(**cls.attributes(**kwargs))
+ return cls._build(**cls.attributes(**kwargs))
@classmethod
def create(cls, **kwargs):
- return cls.get_creation_function()(getattr(cls, CLASS_ATTRIBUTE_ASSOCIATED_CLASS), **cls.attributes(**kwargs))
+ return cls._create(**cls.attributes(**kwargs))