Merge pull request #1104 from FreakyDug/master

Fix a TypeError when a serializer is created with files but no data
This commit is contained in:
Tom Christie 2013-10-03 05:07:07 -07:00
commit 38049d11b6
2 changed files with 14 additions and 0 deletions

View File

@ -306,6 +306,7 @@ class WritableField(Field):
return return
try: try:
data = data or {}
if self.use_files: if self.use_files:
files = files or {} files = files or {}
try: try:

View File

@ -80,3 +80,16 @@ class FileSerializerTests(TestCase):
serializer = UploadedFileSerializer(data={'created': now, 'file': 'abc'}) serializer = UploadedFileSerializer(data={'created': now, 'file': 'abc'})
self.assertFalse(serializer.is_valid()) self.assertFalse(serializer.is_valid())
self.assertEqual(serializer.errors, {'file': [errmsg]}) self.assertEqual(serializer.errors, {'file': [errmsg]})
def test_validation_with_no_data(self):
"""
Validation should still function when no data dictionary is provided.
"""
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(files={'file': file})
self.assertFalse(serializer.is_valid())