mirror of https://github.com/django/django.git
[1.11.x] Fixed #28047 -- Fixed QuerySet.filter() crash when it uses the name of a OneToOneField pk.
Regression in1bc249c2a6
. Backport offce7827101
from master
This commit is contained in:
parent
fc18b51978
commit
8a13cddc26
|
@ -83,7 +83,8 @@ class RelatedIn(In):
|
|||
else:
|
||||
if getattr(self.rhs, '_forced_pk', False):
|
||||
self.rhs.clear_select_clause()
|
||||
if getattr(self.lhs.output_field, 'primary_key', False):
|
||||
if (getattr(self.lhs.output_field, 'primary_key', False) and
|
||||
self.lhs.output_field.model == self.rhs.model):
|
||||
# A case like Restaurant.objects.filter(place__in=restaurant_qs),
|
||||
# where place is a OneToOneField and the primary key of
|
||||
# Restaurant.
|
||||
|
|
|
@ -18,3 +18,6 @@ Bugfixes
|
|||
|
||||
* Fixed a crash when using a two-tuple in ``EmailMessage``’s ``attachments``
|
||||
argument (:ticket:`28042`).
|
||||
|
||||
* Fixed ``QuerySet.filter()`` crash when it references the name of a
|
||||
``OneToOneField`` primary key (:ticket:`28047`).
|
||||
|
|
|
@ -521,6 +521,10 @@ class OneToOneTests(TestCase):
|
|||
pk__in=Restaurant.objects.filter(place__id=r.place.pk)
|
||||
)
|
||||
self.assertSequenceEqual(q2, [r])
|
||||
q3 = Restaurant.objects.filter(place__in=Place.objects.all())
|
||||
self.assertSequenceEqual(q3, [r])
|
||||
q4 = Restaurant.objects.filter(place__in=Place.objects.filter(id=r.pk))
|
||||
self.assertSequenceEqual(q4, [r])
|
||||
|
||||
def test_rel_pk_exact(self):
|
||||
r = Restaurant.objects.first()
|
||||
|
|
Loading…
Reference in New Issue