diff options
author | Raphaël Barrois <raphael.barrois@polyconseil.fr> | 2015-03-27 17:00:32 +0100 |
---|---|---|
committer | Raphaël Barrois <raphael.barrois@polyconseil.fr> | 2015-03-27 17:46:02 +0100 |
commit | 5363951bb62ca90d971bf036851dea564204ed2e (patch) | |
tree | 7180115c88a632f9dcfc36ca0846caedbc3ec952 /factory | |
parent | bdc1b815cfdf3028379c6c3f18c9c47ee8298a70 (diff) | |
download | factory-boy-5363951bb62ca90d971bf036851dea564204ed2e.tar factory-boy-5363951bb62ca90d971bf036851dea564204ed2e.tar.gz |
Support declarations in FileField/ImageField.
Previously, the declarations (``factory.Sequence`` & co) weren't properly computed.
Diffstat (limited to 'factory')
-rw-r--r-- | factory/django.py | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/factory/django.py b/factory/django.py index ba81f13..cbf7c10 100644 --- a/factory/django.py +++ b/factory/django.py @@ -147,6 +147,7 @@ class FileField(declarations.ParameteredAttribute): """Helper to fill in django.db.models.FileField from a Factory.""" DEFAULT_FILENAME = 'example.dat' + EXTEND_CONTAINERS = True def __init__(self, **defaults): require_django() @@ -156,10 +157,8 @@ class FileField(declarations.ParameteredAttribute): """Create data for the field.""" return params.get('data', b'') - def _make_content(self, extra): + def _make_content(self, params): path = '' - params = dict(self.defaults) - params.update(extra) if params.get('from_path') and params.get('from_file'): raise ValueError( @@ -189,10 +188,12 @@ class FileField(declarations.ParameteredAttribute): filename = params.get('filename', default_filename) return filename, content - def evaluate(self, sequence, obj, create, extra=None, containers=()): + def generate(self, sequence, obj, create, params): """Fill in the field.""" - filename, content = self._make_content(extra) + params.setdefault('__sequence', sequence) + params = base.DictFactory.simple_generate(create, **params) + filename, content = self._make_content(params) return django_files.File(content.file, filename) |