mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #28175 -- Fixed __in lookups on a foreign key when using the foreign key's parent model as the lookup value.
Thanks Simon Charette for review.
This commit is contained in:
		| @@ -81,7 +81,8 @@ class RelatedIn(In): | ||||
|                     AND) | ||||
|             return root_constraint.as_sql(compiler, connection) | ||||
|         else: | ||||
|             if not getattr(self.rhs, 'has_select_fields', True): | ||||
|             if (not getattr(self.rhs, 'has_select_fields', True) and | ||||
|                     not getattr(self.lhs.field.target_field, 'primary_key', False)): | ||||
|                 self.rhs.clear_select_clause() | ||||
|                 if (getattr(self.lhs.output_field, 'primary_key', False) and | ||||
|                         self.lhs.output_field.model == self.rhs.model): | ||||
|   | ||||
| @@ -97,3 +97,6 @@ Bugfixes | ||||
|  | ||||
| * Prevented hiding GDAL errors if it's not installed when using ``contrib.gis`` | ||||
|   (:ticket:`28160`). (It's a required dependency as of Django 1.11.) | ||||
|  | ||||
| * Fixed a regression causing ``__in`` lookups on a foreign key to fail when | ||||
|   using the foreign key's parent model as the lookup value (:ticket:`28175`). | ||||
|   | ||||
| @@ -472,6 +472,12 @@ class ModelInheritanceTest(TestCase): | ||||
|         jane = Supplier.objects.order_by("name").select_related("restaurant")[0] | ||||
|         self.assertEqual(jane.restaurant.name, "Craft") | ||||
|  | ||||
|     def test_filter_with_parent_fk(self): | ||||
|         r = Restaurant.objects.create() | ||||
|         s = Supplier.objects.create(restaurant=r) | ||||
|         # The mismatch between Restaurant and Place is intentional (#28175). | ||||
|         self.assertSequenceEqual(Supplier.objects.filter(restaurant__in=Place.objects.all()), [s]) | ||||
|  | ||||
|     def test_ptr_accessor_assigns_db(self): | ||||
|         r = Restaurant.objects.create() | ||||
|         self.assertEqual(r.place_ptr._state.db, 'default') | ||||
|   | ||||
		Reference in New Issue
	
	Block a user