mirror of
				https://github.com/encode/django-rest-framework.git
				synced 2025-11-04 09:57:55 +03:00 
			
		
		
		
	Merge pull request #388 from eofs/m2m_reverse
Fixed creation of objects with reversed M2M relations
This commit is contained in:
		
						commit
						a0bab819bc
					
				| 
						 | 
				
			
			@ -4,6 +4,10 @@
 | 
			
		|||
>
 | 
			
		||||
> — Eric S. Raymond, [The Cathedral and the Bazaar][cite].
 | 
			
		||||
 | 
			
		||||
## Master
 | 
			
		||||
 | 
			
		||||
* Bugfix: Cannot create objects with reverse M2M relations
 | 
			
		||||
 | 
			
		||||
## 2.1.1
 | 
			
		||||
 | 
			
		||||
**Date**: 7th Nov 2012
 | 
			
		||||
| 
						 | 
				
			
			@ -154,4 +158,4 @@
 | 
			
		|||
 | 
			
		||||
[cite]: http://www.catb.org/~esr/writings/cathedral-bazaar/cathedral-bazaar/ar01s04.html
 | 
			
		||||
[2.1.0-notes]: https://groups.google.com/d/topic/django-rest-framework/Vv2M0CMY9bg/discussion
 | 
			
		||||
[announcement]: rest-framework-2-announcement.md
 | 
			
		||||
[announcement]: rest-framework-2-announcement.md
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -447,6 +447,13 @@ class ModelSerializer(Serializer):
 | 
			
		|||
                setattr(instance, key, val)
 | 
			
		||||
            return instance
 | 
			
		||||
 | 
			
		||||
        # Reverse relations
 | 
			
		||||
        for (obj, model) in self.opts.model._meta.get_all_related_m2m_objects_with_model():
 | 
			
		||||
            field_name = obj.field.related_query_name()
 | 
			
		||||
            if field_name in attrs:
 | 
			
		||||
                self.m2m_data[field_name] = attrs.pop(field_name)
 | 
			
		||||
 | 
			
		||||
        # Forward relations
 | 
			
		||||
        for field in self.opts.model._meta.many_to_many:
 | 
			
		||||
            if field.name in attrs:
 | 
			
		||||
                self.m2m_data[field.name] = attrs.pop(field.name)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -117,6 +117,24 @@ class PrimaryKeyManyToManyTests(TestCase):
 | 
			
		|||
        ]
 | 
			
		||||
        self.assertEquals(serializer.data, expected)
 | 
			
		||||
 | 
			
		||||
    def test_reverse_many_to_many_create(self):
 | 
			
		||||
        data = {'id': 4, 'name': u'target-4', 'sources': [1, 3]}
 | 
			
		||||
        serializer = ManyToManyTargetSerializer(data=data)
 | 
			
		||||
        self.assertTrue(serializer.is_valid())
 | 
			
		||||
        obj = serializer.save()
 | 
			
		||||
        self.assertEquals(serializer.data, data)
 | 
			
		||||
        self.assertEqual(obj.name, u'target-4')
 | 
			
		||||
 | 
			
		||||
        # Ensure target 4 is added, and everything else is as expected
 | 
			
		||||
        queryset = ManyToManyTarget.objects.all()
 | 
			
		||||
        serializer = ManyToManyTargetSerializer(queryset)
 | 
			
		||||
        expected = [
 | 
			
		||||
            {'id': 1, 'name': u'target-1', 'sources': [1, 2, 3]},
 | 
			
		||||
            {'id': 2, 'name': u'target-2', 'sources': [2, 3]},
 | 
			
		||||
            {'id': 3, 'name': u'target-3', 'sources': [3]},
 | 
			
		||||
            {'id': 4, 'name': u'target-4', 'sources': [1, 3]}
 | 
			
		||||
        ]
 | 
			
		||||
        self.assertEquals(serializer.data, expected)
 | 
			
		||||
 | 
			
		||||
class PrimaryKeyForeignKeyTests(TestCase):
 | 
			
		||||
    def setUp(self):
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue
	
	Block a user