diff options
| author | Tom Christie | 2012-12-29 18:26:47 +0000 | 
|---|---|---|
| committer | Tom Christie | 2012-12-29 18:26:47 +0000 | 
| commit | 12c4f1ecf7dd7b0e6ead5a42c0fd5cab5aa7ad27 (patch) | |
| tree | 0865fe051b1b3ff5bfb296871e1231dd05135c12 | |
| parent | 18590a1568aa8720c5114dbf40c6f69bcb753aaf (diff) | |
| download | django-rest-framework-12c4f1ecf7dd7b0e6ead5a42c0fd5cab5aa7ad27.tar.bz2 | |
Add reverse FK update tests
| -rw-r--r-- | rest_framework/tests/relations_hyperlink.py | 17 | ||||
| -rw-r--r-- | rest_framework/tests/relations_pk.py | 17 | 
2 files changed, 34 insertions, 0 deletions
| diff --git a/rest_framework/tests/relations_hyperlink.py b/rest_framework/tests/relations_hyperlink.py index f1de4c92..24039410 100644 --- a/rest_framework/tests/relations_hyperlink.py +++ b/rest_framework/tests/relations_hyperlink.py @@ -234,6 +234,23 @@ class HyperlinkedForeignKeyTests(TestCase):          ]          self.assertEquals(serializer.data, expected) +    def test_reverse_foreign_key_update(self): +        data = {'url': '/foreignkeytarget/2/', 'name': u'target-2', 'sources': ['/foreignkeysource/1/', '/foreignkeysource/3/']} +        instance = ForeignKeyTarget.objects.get(pk=2) +        serializer = ForeignKeyTargetSerializer(instance, data=data) +        self.assertTrue(serializer.is_valid()) +        self.assertEquals(serializer.data, data) +        serializer.save() + +        # Ensure target 2 is update, 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': ['/foreignkeysource/1/', '/foreignkeysource/3/']}, +        ] +        self.assertEquals(serializer.data, expected) +      def test_foreign_key_create(self):          data = {'url': '/foreignkeysource/4/', 'name': u'source-4', 'target': '/foreignkeytarget/2/'}          serializer = ForeignKeySourceSerializer(data=data) diff --git a/rest_framework/tests/relations_pk.py b/rest_framework/tests/relations_pk.py index c2e61279..01109ef9 100644 --- a/rest_framework/tests/relations_pk.py +++ b/rest_framework/tests/relations_pk.py @@ -216,6 +216,23 @@ class PKForeignKeyTests(TestCase):          ]          self.assertEquals(serializer.data, expected) +    def test_reverse_foreign_key_update(self): +        data = {'id': 2, 'name': u'target-2', 'sources': [1, 3]} +        instance = ForeignKeyTarget.objects.get(pk=2) +        serializer = ForeignKeyTargetSerializer(instance, data=data) +        self.assertTrue(serializer.is_valid()) +        self.assertEquals(serializer.data, data) +        serializer.save() + +        # Ensure target 2 is update, and everything else is as expected +        queryset = ForeignKeyTarget.objects.all() +        serializer = ForeignKeyTargetSerializer(queryset) +        expected = [ +            {'id': 1, 'name': u'target-1', 'sources': [2]}, +            {'id': 2, 'name': u'target-2', 'sources': [1, 3]}, +        ] +        self.assertEquals(serializer.data, expected) +      def test_foreign_key_create(self):          data = {'id': 4, 'name': u'source-4', 'target': 2}          serializer = ForeignKeySourceSerializer(data=data) | 
