mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #28384 -- Fixed ModelAdmin.lookup_allowed() for OneToOneField primary keys and nested relations.
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							d687febce5
						
					
				
				
					commit
					45ecd9acca
				
			| @@ -461,12 +461,14 @@ class BaseModelAdmin(metaclass=forms.MediaDefiningClass): | |||||||
|                 # Lookups on nonexistent fields are ok, since they're ignored |                 # Lookups on nonexistent fields are ok, since they're ignored | ||||||
|                 # later. |                 # later. | ||||||
|                 break |                 break | ||||||
|             # It is allowed to filter on values that would be found from local |  | ||||||
|             # model anyways. For example, if you filter on employee__department__id, |  | ||||||
|             # then the id value would be found already from employee__department_id. |  | ||||||
|             if not prev_field or ( |             if not prev_field or ( | ||||||
|                 prev_field.is_relation |                 prev_field.is_relation | ||||||
|                 and field not in prev_field.path_infos[-1].target_fields |                 and field not in model._meta.parents.values() | ||||||
|  |                 and field is not model._meta.auto_field | ||||||
|  |                 and ( | ||||||
|  |                     model._meta.auto_field is None | ||||||
|  |                     or part not in getattr(prev_field, "to_fields", []) | ||||||
|  |                 ) | ||||||
|             ): |             ): | ||||||
|                 relation_parts.append(part) |                 relation_parts.append(part) | ||||||
|             if not getattr(field, "path_infos", None): |             if not getattr(field, "path_infos", None): | ||||||
|   | |||||||
| @@ -154,6 +154,35 @@ class ModelAdminTests(TestCase): | |||||||
|             ma.lookup_allowed("employee__department__code", "test_value"), True |             ma.lookup_allowed("employee__department__code", "test_value"), True | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|  |     @isolate_apps("modeladmin") | ||||||
|  |     def test_lookup_allowed_foreign_primary(self): | ||||||
|  |         class Country(models.Model): | ||||||
|  |             name = models.CharField(max_length=256) | ||||||
|  |  | ||||||
|  |         class Place(models.Model): | ||||||
|  |             country = models.ForeignKey(Country, models.CASCADE) | ||||||
|  |  | ||||||
|  |         class Restaurant(models.Model): | ||||||
|  |             place = models.OneToOneField(Place, models.CASCADE, primary_key=True) | ||||||
|  |  | ||||||
|  |         class Waiter(models.Model): | ||||||
|  |             restaurant = models.ForeignKey(Restaurant, models.CASCADE) | ||||||
|  |  | ||||||
|  |         class WaiterAdmin(ModelAdmin): | ||||||
|  |             list_filter = [ | ||||||
|  |                 "restaurant__place__country", | ||||||
|  |                 "restaurant__place__country__name", | ||||||
|  |             ] | ||||||
|  |  | ||||||
|  |         ma = WaiterAdmin(Waiter, self.site) | ||||||
|  |         self.assertIs(ma.lookup_allowed("restaurant__place__country", "1"), True) | ||||||
|  |         self.assertIs( | ||||||
|  |             ma.lookup_allowed("restaurant__place__country__id__exact", "1"), True | ||||||
|  |         ) | ||||||
|  |         self.assertIs( | ||||||
|  |             ma.lookup_allowed("restaurant__place__country__name", "test_value"), True | ||||||
|  |         ) | ||||||
|  |  | ||||||
|     def test_field_arguments(self): |     def test_field_arguments(self): | ||||||
|         # If fields is specified, fieldsets_add and fieldsets_change should |         # If fields is specified, fieldsets_add and fieldsets_change should | ||||||
|         # just stick the fields into a formsets structure and return it. |         # just stick the fields into a formsets structure and return it. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user