diff options
| author | Tom Christie | 2013-08-23 11:56:22 +0100 |
|---|---|---|
| committer | Tom Christie | 2013-08-23 11:56:22 +0100 |
| commit | 47d17b088a627dc4cdf3f245f1f351fa6b34ff7d (patch) | |
| tree | 6cca776cf515b15839ca4a9b548d598712f4d418 | |
| parent | dba602781355f6ee0cbc34775209cd37a52ca4d4 (diff) | |
| parent | db9672d3048eebb3d3c3fb2b4a345e17b5aa23cc (diff) | |
| download | django-rest-framework-47d17b088a627dc4cdf3f245f1f351fa6b34ff7d.tar.bz2 | |
Merge branch 'fix_937' of git://github.com/aburgel/django-rest-framework into aburgel-fix_937
| -rw-r--r-- | rest_framework/fields.py | 5 | ||||
| -rw-r--r-- | rest_framework/tests/test_files.py | 28 |
2 files changed, 28 insertions, 5 deletions
diff --git a/rest_framework/fields.py b/rest_framework/fields.py index 07779c47..3e0ca1a1 100644 --- a/rest_framework/fields.py +++ b/rest_framework/fields.py @@ -308,7 +308,10 @@ class WritableField(Field): try: if self.use_files: files = files or {} - native = files[field_name] + try: + native = files[field_name] + except KeyError: + native = data[field_name] else: native = data[field_name] except KeyError: diff --git a/rest_framework/tests/test_files.py b/rest_framework/tests/test_files.py index 487046ac..495c2a7f 100644 --- a/rest_framework/tests/test_files.py +++ b/rest_framework/tests/test_files.py @@ -7,13 +7,13 @@ import datetime class UploadedFile(object): - def __init__(self, file, created=None): + def __init__(self, file=None, created=None): self.file = file self.created = created or datetime.datetime.now() class UploadedFileSerializer(serializers.Serializer): - file = serializers.FileField() + file = serializers.FileField(required=False) created = serializers.DateTimeField() def restore_object(self, attrs, instance=None): @@ -47,5 +47,25 @@ class FileSerializerTests(TestCase): now = datetime.datetime.now() serializer = UploadedFileSerializer(data={'created': now}) - self.assertFalse(serializer.is_valid()) - self.assertIn('file', serializer.errors) + self.assertTrue(serializer.is_valid()) + self.assertEqual(serializer.object.created, now) + self.assertIsNone(serializer.object.file) + + def test_remove_with_empty_string(self): + """ + Passing empty string as data should cause file to be removed + + Test for: + https://github.com/tomchristie/django-rest-framework/issues/937 + """ + now = datetime.datetime.now() + file = BytesIO(six.b('stuff')) + file.name = 'stuff.txt' + file.size = len(file.getvalue()) + + uploaded_file = UploadedFile(file=file, created=now) + + serializer = UploadedFileSerializer(instance=uploaded_file, data={'created': now, 'file': ''}) + self.assertTrue(serializer.is_valid()) + self.assertEqual(serializer.object.created, uploaded_file.created) + self.assertIsNone(serializer.object.file) |
