mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	[3.2.x] Fixed #32433 -- Added error message on QuerySet.delete() following distinct().
Backport of 6307c3f1a1 from master
			
			
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							98ce39b5a3
						
					
				
				
					commit
					aa1aed923b
				
			
							
								
								
									
										1
									
								
								AUTHORS
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								AUTHORS
									
									
									
									
									
								
							| @@ -274,6 +274,7 @@ answer newbie questions, and generally made Django that much better: | ||||
|     dusk@woofle.net | ||||
|     Dustyn Gibson <miigotu@gmail.com> | ||||
|     Ed Morley <https://github.com/edmorley> | ||||
|     Egidijus Macijauskas <e.macijauskas@outlook.com> | ||||
|     eibaan@gmail.com | ||||
|     elky <http://elky.me/> | ||||
|     Emmanuelle Delescolle <https://github.com/nanuxbe> | ||||
|   | ||||
| @@ -724,6 +724,8 @@ class QuerySet: | ||||
|         assert not self.query.is_sliced, \ | ||||
|             "Cannot use 'limit' or 'offset' with delete." | ||||
|  | ||||
|         if self.query.distinct or self.query.distinct_fields: | ||||
|             raise TypeError('Cannot call delete() after .distinct().') | ||||
|         if self._fields is not None: | ||||
|             raise TypeError("Cannot call delete() after .values() or .values_list()") | ||||
|  | ||||
|   | ||||
| @@ -1,7 +1,9 @@ | ||||
| import datetime | ||||
|  | ||||
| from django.db import connection, models, transaction | ||||
| from django.test import TestCase, TransactionTestCase, skipUnlessDBFeature | ||||
| from django.test import ( | ||||
|     SimpleTestCase, TestCase, TransactionTestCase, skipUnlessDBFeature, | ||||
| ) | ||||
|  | ||||
| from .models import ( | ||||
|     Award, AwardNote, Book, Child, Contact, Eaten, Email, File, Food, FooFile, | ||||
| @@ -352,3 +354,12 @@ class DeleteTests(TestCase): | ||||
|         self.assertEqual(researcher1.secondary_contact, contact2) | ||||
|         self.assertEqual(researcher2.primary_contact, contact2) | ||||
|         self.assertIsNone(researcher2.secondary_contact) | ||||
|  | ||||
|  | ||||
| class DeleteDistinct(SimpleTestCase): | ||||
|     def test_disallowed_delete_distinct(self): | ||||
|         msg = 'Cannot call delete() after .distinct().' | ||||
|         with self.assertRaisesMessage(TypeError, msg): | ||||
|             Book.objects.distinct().delete() | ||||
|         with self.assertRaisesMessage(TypeError, msg): | ||||
|             Book.objects.distinct('id').delete() | ||||
|   | ||||
		Reference in New Issue
	
	Block a user