mirror of
				https://github.com/django/django.git
				synced 2025-10-23 05:39:10 +00:00 
			
		
		
		
	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…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user