aboutsummaryrefslogtreecommitdiffstats
path: root/tests/test_serializer.py
diff options
context:
space:
mode:
authorTom Christie2014-12-13 15:08:36 +0000
committerTom Christie2014-12-13 15:08:36 +0000
commitdd712a1c2620b5dc9ad8eef5ff78ef232feb12e8 (patch)
tree9ce4ada25479a200ecabe2205a61cac2c6f194cd /tests/test_serializer.py
parent6158285856b4dee77640883cf3fde3407af9ff2a (diff)
parent4fb757146af8e805e30cfe4a8914c9fb7251b3fc (diff)
downloaddjango-rest-framework-dd712a1c2620b5dc9ad8eef5ff78ef232feb12e8.tar.bz2
Merge pull request #2267 from tomchristie/better-misconfigured-serializer-errors
Better errors when serializer has incorrectly named field.
Diffstat (limited to 'tests/test_serializer.py')
-rw-r--r--tests/test_serializer.py22
1 files changed, 22 insertions, 0 deletions
diff --git a/tests/test_serializer.py b/tests/test_serializer.py
index 6dabaf42..56b39095 100644
--- a/tests/test_serializer.py
+++ b/tests/test_serializer.py
@@ -1,3 +1,4 @@
+from __future__ import unicode_literals
from rest_framework import serializers
import pytest
@@ -175,3 +176,24 @@ class TestStarredSource:
instance = {'a': 1, 'b': 2, 'c': 3, 'd': 4}
serializer = self.Serializer(instance)
assert serializer.data == self.data
+
+
+class TestIncorrectlyConfigured:
+ def test_incorrect_field_name(self):
+ class ExampleSerializer(serializers.Serializer):
+ incorrect_name = serializers.IntegerField()
+
+ class ExampleObject:
+ def __init__(self):
+ self.correct_name = 123
+
+ instance = ExampleObject()
+ serializer = ExampleSerializer(instance)
+ with pytest.raises(AttributeError) as exc_info:
+ serializer.data
+ msg = str(exc_info.value)
+ assert msg.startswith(
+ "Got AttributeError when attempting to get a value for field `incorrect_name` on serializer `ExampleSerializer`.\n"
+ "The serializer field might be named incorrectly and not match any attribute or key on the `ExampleObject` instance.\n"
+ "Original exception text was:"
+ )