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:
Tim Graham 2017-05-05 18:35:08 -04:00 committed by GitHub
parent 2874531ab5
commit d66378a8b2
3 changed files with 11 additions and 1 deletions

View File

@ -81,7 +81,8 @@ class RelatedIn(In):
AND) AND)
return root_constraint.as_sql(compiler, connection) return root_constraint.as_sql(compiler, connection)
else: 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() self.rhs.clear_select_clause()
if (getattr(self.lhs.output_field, 'primary_key', False) and if (getattr(self.lhs.output_field, 'primary_key', False) and
self.lhs.output_field.model == self.rhs.model): self.lhs.output_field.model == self.rhs.model):

View File

@ -97,3 +97,6 @@ Bugfixes
* Prevented hiding GDAL errors if it's not installed when using ``contrib.gis`` * 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.) (: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`).

View File

@ -472,6 +472,12 @@ class ModelInheritanceTest(TestCase):
jane = Supplier.objects.order_by("name").select_related("restaurant")[0] jane = Supplier.objects.order_by("name").select_related("restaurant")[0]
self.assertEqual(jane.restaurant.name, "Craft") 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): def test_ptr_accessor_assigns_db(self):
r = Restaurant.objects.create() r = Restaurant.objects.create()
self.assertEqual(r.place_ptr._state.db, 'default') self.assertEqual(r.place_ptr._state.db, 'default')