mirror of
https://github.com/django/django.git
synced 2025-06-06 20:19:13 +00:00
Fixed #28384 -- Fixed ModelAdmin.lookup_allowed() for OneToOneField primary keys and nested relations.
This commit is contained in:
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.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user