Tweak implementation, and use FormSet style errors

This commit is contained in:
Tom Christie 2013-03-08 22:19:09 +00:00
parent 53b58a5059
commit 68683b2ea2
2 changed files with 14 additions and 25 deletions

View File

@ -285,20 +285,6 @@ class BaseSerializer(Field):
"""
Deserialize primitives -> objects.
"""
if hasattr(data, '__iter__') and not isinstance(data, (dict, six.text_type)):
object_list = list()
error_list = list()
for count, item in enumerate(data):
obj = self.from_native(item, None)
if self._errors:
error_list.append((count, self._errors))
object_list.append(obj)
if not error_list:
return object_list
self._errors = error_list
return None
self._errors = {}
if data is not None or files is not None:
attrs = self.restore_fields(data, files)
@ -364,6 +350,14 @@ class BaseSerializer(Field):
'Use the `many=True` flag when instantiating the serializer.',
PendingDeprecationWarning, stacklevel=3)
if many:
ret = []
errors = []
for item in data:
ret.append(self.from_native(item, None))
errors.append(self._errors)
self._errors = any(errors) and errors or []
else:
ret = self.from_native(data, files)
if not self._errors:

View File

@ -273,9 +273,9 @@ class ValidationTests(TestCase):
self.assertEqual(
serializer.errors,
[
(0, {'non_field_errors': ['Invalid data']}),
(1, {'non_field_errors': ['Invalid data']}),
(2, {'non_field_errors': ['Invalid data']})
{'non_field_errors': ['Invalid data']},
{'non_field_errors': ['Invalid data']},
{'non_field_errors': ['Invalid data']}
]
)
@ -1108,10 +1108,5 @@ class DeserializeListTestCase(TestCase):
serializer = CommentSerializer(data=data)
self.assertFalse(serializer.is_valid())
self.assertTrue(isinstance(serializer.errors, list))
self.assertEqual(1, len(serializer.errors))
expected = (1, {'email': ['This field is required.']})
self.assertEqual(
serializer.errors[0],
expected
)
expected = [{}, {'email': [u'This field is required.']}, {}]
self.assertEqual(serializer.errors, expected)