1
0
mirror of https://github.com/django/django.git synced 2025-10-25 22:56:12 +00:00

Fixed #23266 -- Prevented queries caused by type checking lookup values

Small modifications done by committer.
This commit is contained in:
Anubhav Joshi
2014-08-10 18:23:37 +05:30
committed by Anssi Kääriäinen
parent f0b358880a
commit cdfdcf4b70
2 changed files with 17 additions and 2 deletions

View File

@@ -1104,8 +1104,19 @@ class Query(object):
if field.rel: if field.rel:
# testing for iterable of models # testing for iterable of models
if hasattr(value, '__iter__'): if hasattr(value, '__iter__'):
for v in value: # Check if the iterable has a model attribute, if so
self.check_query_object_type(v, opts) # it is likely something like a QuerySet.
if hasattr(value, 'model') and hasattr(value.model, '_meta'):
model = value.model
if not (model == opts.concrete_model
or opts.concrete_model in model._meta.get_parent_list()
or model in opts.get_parent_list()):
raise ValueError(
'Cannot use QuerySet for "%s": Use a QuerySet for "%s".' %
(model._meta.model_name, opts.object_name))
else:
for v in value:
self.check_query_object_type(v, opts)
else: else:
# expecting single model instance here # expecting single model instance here
self.check_query_object_type(value, opts) self.check_query_object_type(value, opts)

View File

@@ -3461,6 +3461,10 @@ class RelatedLookupTypeTests(TestCase):
# parent objects # parent objects
self.assertQuerysetEqual(ObjectC.objects.exclude(childobjecta=self.oa), out_c) self.assertQuerysetEqual(ObjectC.objects.exclude(childobjecta=self.oa), out_c)
# Test for #23226
with self.assertNumQueries(0):
ObjectB.objects.filter(objecta__in=ObjectA.objects.all())
class Ticket14056Tests(TestCase): class Ticket14056Tests(TestCase):
def test_ticket_14056(self): def test_ticket_14056(self):