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

Fixed #34601 -- Added field name to check message for ModelAdmin.readonly_fields.

Co-authored-by: Rick van Hattem <wolph@wol.ph>
This commit is contained in:
nessita
2023-06-05 00:56:53 -03:00
committed by GitHub
parent f9936deed1
commit 89c27d8672
3 changed files with 12 additions and 8 deletions

View File

@@ -771,10 +771,11 @@ class BaseModelAdminChecks:
except FieldDoesNotExist: except FieldDoesNotExist:
return [ return [
checks.Error( checks.Error(
"The value of '%s' is not a callable, an attribute of " "The value of '%s' refers to '%s', which is not a callable, "
"'%s', or an attribute of '%s'." "an attribute of '%s', or an attribute of '%s'."
% ( % (
label, label,
field_name,
obj.__class__.__name__, obj.__class__.__name__,
obj.model._meta.label, obj.model._meta.label,
), ),

View File

@@ -675,8 +675,9 @@ with the admin site:
* **admin.E033**: The value of ``ordering`` refers to ``<field name>``, which * **admin.E033**: The value of ``ordering`` refers to ``<field name>``, which
is not a field of ``<model>``. is not a field of ``<model>``.
* **admin.E034**: The value of ``readonly_fields`` must be a list or tuple. * **admin.E034**: The value of ``readonly_fields`` must be a list or tuple.
* **admin.E035**: The value of ``readonly_fields[n]`` is not a callable, an * **admin.E035**: The value of ``readonly_fields[n]`` refers to
attribute of ``<ModelAdmin class>``, or an attribute of ``<model>``. ``<field_name>``, which is not a callable, an attribute of
``<ModelAdmin class>``, or an attribute of ``<model>``.
* **admin.E036**: The value of ``autocomplete_fields`` must be a list or tuple. * **admin.E036**: The value of ``autocomplete_fields`` must be a list or tuple.
* **admin.E037**: The value of ``autocomplete_fields[n]`` refers to * **admin.E037**: The value of ``autocomplete_fields[n]`` refers to
``<field name>``, which is not a field of ``<model>``. ``<field name>``, which is not a field of ``<model>``.

View File

@@ -798,8 +798,9 @@ class SystemChecksTestCase(SimpleTestCase):
errors = SongAdmin(Song, AdminSite()).check() errors = SongAdmin(Song, AdminSite()).check()
expected = [ expected = [
checks.Error( checks.Error(
"The value of 'readonly_fields[1]' is not a callable, an attribute " "The value of 'readonly_fields[1]' refers to 'nonexistent', which is "
"of 'SongAdmin', or an attribute of 'admin_checks.Song'.", "not a callable, an attribute of 'SongAdmin', or an attribute of "
"'admin_checks.Song'.",
obj=SongAdmin, obj=SongAdmin,
id="admin.E035", id="admin.E035",
) )
@@ -814,8 +815,9 @@ class SystemChecksTestCase(SimpleTestCase):
errors = CityInline(State, AdminSite()).check() errors = CityInline(State, AdminSite()).check()
expected = [ expected = [
checks.Error( checks.Error(
"The value of 'readonly_fields[0]' is not a callable, an attribute " "The value of 'readonly_fields[0]' refers to 'i_dont_exist', which is "
"of 'CityInline', or an attribute of 'admin_checks.City'.", "not a callable, an attribute of 'CityInline', or an attribute of "
"'admin_checks.City'.",
obj=CityInline, obj=CityInline,
id="admin.E035", id="admin.E035",
) )