mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	Refs #27118 -- Reallowed using pk in QuerySet.get/update_or_create().
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							040bd7c938
						
					
				
				
					commit
					1db1f74617
				
			| @@ -532,6 +532,7 @@ class QuerySet(object): | ||||
|             try: | ||||
|                 self.model._meta.get_field(param) | ||||
|             except exceptions.FieldDoesNotExist: | ||||
|                 if param != 'pk':  # It's okay to use a model's pk property. | ||||
|                     invalid_params.append(param) | ||||
|         if invalid_params: | ||||
|             raise exceptions.FieldError( | ||||
|   | ||||
| @@ -71,6 +71,12 @@ class GetOrCreateTests(TestCase): | ||||
|         with self.assertRaises(IntegrityError): | ||||
|             Person.objects.get_or_create(first_name="Tom", last_name="Smith") | ||||
|  | ||||
|     def test_get_or_create_with_pk_property(self): | ||||
|         """ | ||||
|         Using the pk property of a model is allowed. | ||||
|         """ | ||||
|         Thing.objects.get_or_create(pk=1) | ||||
|  | ||||
|     def test_get_or_create_on_related_manager(self): | ||||
|         p = Publisher.objects.create(name="Acme Publishing") | ||||
|         # Create a book through the publisher. | ||||
| @@ -324,6 +330,12 @@ class UpdateOrCreateTests(TestCase): | ||||
|             ManualPrimaryKeyTest.objects.update_or_create(id=1, data="Different") | ||||
|         self.assertEqual(ManualPrimaryKeyTest.objects.get(id=1).data, "Original") | ||||
|  | ||||
|     def test_with_pk_property(self): | ||||
|         """ | ||||
|         Using the pk property of a model is allowed. | ||||
|         """ | ||||
|         Thing.objects.update_or_create(pk=1) | ||||
|  | ||||
|     def test_error_contains_full_traceback(self): | ||||
|         """ | ||||
|         update_or_create should raise IntegrityErrors with the full traceback. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user