mirror of
				https://github.com/django/django.git
				synced 2025-11-03 21:25:09 +00:00 
			
		
		
		
	Refs #25693 -- Added a regression test for to_attr validation on forward m2m.
				
					
				
			This commit is contained in:
		
							parent
							
								
									4a9c32f5ee
								
							
						
					
					
						commit
						cc8c02fa0f
					
				
					 1 changed files with 12 additions and 1 deletions
				
			
		| 
						 | 
				
			
			@ -223,7 +223,18 @@ class PrefetchRelatedTests(TestCase):
 | 
			
		|||
        self.assertIn('prefetch_related', str(cm.exception))
 | 
			
		||||
        self.assertIn("name", str(cm.exception))
 | 
			
		||||
 | 
			
		||||
    def test_m2m_shadow(self):
 | 
			
		||||
    def test_forward_m2m_to_attr_conflict(self):
 | 
			
		||||
        msg = 'to_attr=authors conflicts with a field on the Book model.'
 | 
			
		||||
        authors = Author.objects.all()
 | 
			
		||||
        with self.assertRaisesMessage(ValueError, msg):
 | 
			
		||||
            list(Book.objects.prefetch_related(
 | 
			
		||||
                Prefetch('authors', queryset=authors, to_attr='authors'),
 | 
			
		||||
            ))
 | 
			
		||||
        # Without the ValueError, an author was deleted due to the implicit
 | 
			
		||||
        # save of the relation assignment.
 | 
			
		||||
        self.assertEqual(self.book1.authors.count(), 3)
 | 
			
		||||
 | 
			
		||||
    def test_reverse_m2m_to_attr_conflict(self):
 | 
			
		||||
        msg = 'to_attr=books conflicts with a field on the Author model.'
 | 
			
		||||
        poems = Book.objects.filter(title='Poems')
 | 
			
		||||
        with self.assertRaisesMessage(ValueError, msg):
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue