diff options
| author | Alex Burgel | 2013-07-24 17:24:29 -0400 | 
|---|---|---|
| committer | Alex Burgel | 2013-07-24 17:24:29 -0400 | 
| commit | db9672d3048eebb3d3c3fb2b4a345e17b5aa23cc (patch) | |
| tree | 36b0c74b7324af221be3b4ff794a838d927e857b /rest_framework | |
| parent | c23412b51c5d8abbe1c103d7e177606644f9f0b7 (diff) | |
| download | django-rest-framework-db9672d3048eebb3d3c3fb2b4a345e17b5aa23cc.tar.bz2 | |
Add support for removing field files by sending an empty string
Diffstat (limited to 'rest_framework')
| -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 f9931887..9ba5c0eb 100644 --- a/rest_framework/fields.py +++ b/rest_framework/fields.py @@ -307,7 +307,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)  | 
