aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTom Christie2012-12-29 18:17:48 +0000
committerTom Christie2012-12-29 18:17:48 +0000
commit18590a1568aa8720c5114dbf40c6f69bcb753aaf (patch)
tree260621ce277e92dfa8ce2708723d6f4eba6b2f3f
parent0176fab4758163476d5a12f8343043b4e7d325f4 (diff)
downloaddjango-rest-framework-18590a1568aa8720c5114dbf40c6f69bcb753aaf.tar.bz2
Add test for hyperlinked reverse FK create. Refs #511
-rw-r--r--rest_framework/tests/relations_hyperlink.py35
1 files changed, 17 insertions, 18 deletions
diff --git a/rest_framework/tests/relations_hyperlink.py b/rest_framework/tests/relations_hyperlink.py
index 5eeabddb..f1de4c92 100644
--- a/rest_framework/tests/relations_hyperlink.py
+++ b/rest_framework/tests/relations_hyperlink.py
@@ -51,7 +51,7 @@ class ForeignKeySource(models.Model):
class ForeignKeyTargetSerializer(serializers.HyperlinkedModelSerializer):
- sources = serializers.ManyHyperlinkedRelatedField(view_name='foreignkeysource-detail', read_only=True)
+ sources = serializers.ManyHyperlinkedRelatedField(view_name='foreignkeysource-detail')
class Meta:
model = ForeignKeyTarget
@@ -253,24 +253,23 @@ class HyperlinkedForeignKeyTests(TestCase):
]
self.assertEquals(serializer.data, expected)
- # TODO: Check this - is this a bug or is the test incorrect?
- # def test_reverse_foreign_key_create(self):
- # data = {'url': '/foreignkeytarget/3/', 'name': u'target-3', 'sources': ['/foreignkeysource/1/', '/foreignkeysource/3/']}
- # serializer = ForeignKeyTargetSerializer(data=data)
- # self.assertTrue(serializer.is_valid())
- # obj = serializer.save()
- # self.assertEquals(serializer.data, data)
- # self.assertEqual(obj.name, u'target-3')
+ def test_reverse_foreign_key_create(self):
+ data = {'url': '/foreignkeytarget/3/', 'name': u'target-3', 'sources': ['/foreignkeysource/1/', '/foreignkeysource/3/']}
+ serializer = ForeignKeyTargetSerializer(data=data)
+ self.assertTrue(serializer.is_valid())
+ obj = serializer.save()
+ self.assertEquals(serializer.data, data)
+ self.assertEqual(obj.name, u'target-3')
- # # Ensure target 4 is added, and everything else is as expected
- # queryset = ForeignKeyTarget.objects.all()
- # serializer = ForeignKeyTargetSerializer(queryset)
- # expected = [
- # {'url': '/foreignkeytarget/1/', 'name': u'target-1', 'sources': ['/foreignkeysource/2/']},
- # {'url': '/foreignkeytarget/2/', 'name': u'target-2', 'sources': []},
- # {'url': '/foreignkeytarget/3/', 'name': u'target-3', 'sources': ['/foreignkeysource/1/', '/foreignkeysource/3/']},
- # ]
- # self.assertEquals(serializer.data, expected)
+ # Ensure target 4 is added, and everything else is as expected
+ queryset = ForeignKeyTarget.objects.all()
+ serializer = ForeignKeyTargetSerializer(queryset)
+ expected = [
+ {'url': '/foreignkeytarget/1/', 'name': u'target-1', 'sources': ['/foreignkeysource/2/']},
+ {'url': '/foreignkeytarget/2/', 'name': u'target-2', 'sources': []},
+ {'url': '/foreignkeytarget/3/', 'name': u'target-3', 'sources': ['/foreignkeysource/1/', '/foreignkeysource/3/']},
+ ]
+ self.assertEquals(serializer.data, expected)
def test_foreign_key_update_with_invalid_null(self):
data = {'url': '/foreignkeysource/1/', 'name': u'source-1', 'target': None}