mirror of
https://github.com/encode/django-rest-framework.git
synced 2025-02-09 08:00:52 +03:00
Merge branch 'fix_937' of git://github.com/aburgel/django-rest-framework into aburgel-fix_937
This commit is contained in:
commit
47d17b088a
|
@ -308,7 +308,10 @@ class WritableField(Field):
|
||||||
try:
|
try:
|
||||||
if self.use_files:
|
if self.use_files:
|
||||||
files = files or {}
|
files = files or {}
|
||||||
native = files[field_name]
|
try:
|
||||||
|
native = files[field_name]
|
||||||
|
except KeyError:
|
||||||
|
native = data[field_name]
|
||||||
else:
|
else:
|
||||||
native = data[field_name]
|
native = data[field_name]
|
||||||
except KeyError:
|
except KeyError:
|
||||||
|
|
|
@ -7,13 +7,13 @@ import datetime
|
||||||
|
|
||||||
|
|
||||||
class UploadedFile(object):
|
class UploadedFile(object):
|
||||||
def __init__(self, file, created=None):
|
def __init__(self, file=None, created=None):
|
||||||
self.file = file
|
self.file = file
|
||||||
self.created = created or datetime.datetime.now()
|
self.created = created or datetime.datetime.now()
|
||||||
|
|
||||||
|
|
||||||
class UploadedFileSerializer(serializers.Serializer):
|
class UploadedFileSerializer(serializers.Serializer):
|
||||||
file = serializers.FileField()
|
file = serializers.FileField(required=False)
|
||||||
created = serializers.DateTimeField()
|
created = serializers.DateTimeField()
|
||||||
|
|
||||||
def restore_object(self, attrs, instance=None):
|
def restore_object(self, attrs, instance=None):
|
||||||
|
@ -47,5 +47,25 @@ class FileSerializerTests(TestCase):
|
||||||
now = datetime.datetime.now()
|
now = datetime.datetime.now()
|
||||||
|
|
||||||
serializer = UploadedFileSerializer(data={'created': now})
|
serializer = UploadedFileSerializer(data={'created': now})
|
||||||
self.assertFalse(serializer.is_valid())
|
self.assertTrue(serializer.is_valid())
|
||||||
self.assertIn('file', serializer.errors)
|
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)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user