Fixed #23721 -- check_related_objects without calling __iter__
Refs #14334
This commit is contained in:
parent
00aa562884
commit
ae7cb992bc
|
@ -1102,12 +1102,11 @@ class Query(object):
|
||||||
'Cannot use QuerySet for "%s": Use a QuerySet for "%s".' %
|
'Cannot use QuerySet for "%s": Use a QuerySet for "%s".' %
|
||||||
(value.model._meta.model_name, opts.object_name)
|
(value.model._meta.model_name, opts.object_name)
|
||||||
)
|
)
|
||||||
|
elif hasattr(value, '_meta'):
|
||||||
|
self.check_query_object_type(value, opts)
|
||||||
elif hasattr(value, '__iter__'):
|
elif hasattr(value, '__iter__'):
|
||||||
for v in value:
|
for v in value:
|
||||||
self.check_query_object_type(v, opts)
|
self.check_query_object_type(v, opts)
|
||||||
else:
|
|
||||||
# expecting single model instance here
|
|
||||||
self.check_query_object_type(value, opts)
|
|
||||||
|
|
||||||
def build_lookup(self, lookups, lhs, rhs):
|
def build_lookup(self, lookups, lhs, rhs):
|
||||||
lookups = lookups[:]
|
lookups = lookups[:]
|
||||||
|
|
|
@ -408,6 +408,10 @@ class ObjectA(models.Model):
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
def __iter__(self):
|
||||||
|
# Ticket #23721
|
||||||
|
assert False, 'type checking should happen without calling model __iter__'
|
||||||
|
|
||||||
|
|
||||||
class ProxyObjectA(ObjectA):
|
class ProxyObjectA(ObjectA):
|
||||||
class Meta:
|
class Meta:
|
||||||
|
|
Loading…
Reference in New Issue