Corrected messages of admin checks for invalid model field names.

This commit is contained in:
Hasan Ramezani 2021-03-03 14:59:45 +01:00 committed by Mariusz Felisiak
parent d1f89c9b9a
commit 1da54bfe7d
4 changed files with 21 additions and 21 deletions

View File

@ -1129,8 +1129,8 @@ def must_inherit_from(parent, option, obj, id):
def refer_to_missing_field(field, option, obj, id): def refer_to_missing_field(field, option, obj, id):
return [ return [
checks.Error( checks.Error(
"The value of '%s' refers to '%s', which is not an attribute of " "The value of '%s' refers to '%s', which is not a field of '%s'."
"'%s'." % (option, field, obj.model._meta.label), % (option, field, obj.model._meta.label),
obj=obj.__class__, obj=obj.__class__,
id=id, id=id,
), ),

View File

@ -594,7 +594,7 @@ with the admin site:
* **admin.E001**: The value of ``raw_id_fields`` must be a list or tuple. * **admin.E001**: The value of ``raw_id_fields`` must be a list or tuple.
* **admin.E002**: The value of ``raw_id_fields[n]`` refers to ``<field name>``, * **admin.E002**: The value of ``raw_id_fields[n]`` refers to ``<field name>``,
which is not an attribute of ``<model>``. which is not a field of ``<model>``.
* **admin.E003**: The value of ``raw_id_fields[n]`` must be a foreign key or * **admin.E003**: The value of ``raw_id_fields[n]`` must be a foreign key or
a many-to-many field. a many-to-many field.
* **admin.E004**: The value of ``fields`` must be a list or tuple. * **admin.E004**: The value of ``fields`` must be a list or tuple.
@ -616,12 +616,12 @@ with the admin site:
* **admin.E017**: The value of ``filter_vertical`` must be a list or tuple. * **admin.E017**: The value of ``filter_vertical`` must be a list or tuple.
* **admin.E018**: The value of ``filter_horizontal`` must be a list or tuple. * **admin.E018**: The value of ``filter_horizontal`` must be a list or tuple.
* **admin.E019**: The value of ``filter_vertical[n]/filter_horizontal[n]`` * **admin.E019**: The value of ``filter_vertical[n]/filter_horizontal[n]``
refers to ``<field name>``, which is not an attribute of ``<model>``. refers to ``<field name>``, which is not a field of ``<model>``.
* **admin.E020**: The value of ``filter_vertical[n]/filter_horizontal[n]`` * **admin.E020**: The value of ``filter_vertical[n]/filter_horizontal[n]``
must be a many-to-many field. must be a many-to-many field.
* **admin.E021**: The value of ``radio_fields`` must be a dictionary. * **admin.E021**: The value of ``radio_fields`` must be a dictionary.
* **admin.E022**: The value of ``radio_fields`` refers to ``<field name>``, * **admin.E022**: The value of ``radio_fields`` refers to ``<field name>``,
which is not an attribute of ``<model>``. which is not a field of ``<model>``.
* **admin.E023**: The value of ``radio_fields`` refers to ``<field name>``, * **admin.E023**: The value of ``radio_fields`` refers to ``<field name>``,
which is not instance of ``ForeignKey``, and does not have a ``choices`` which is not instance of ``ForeignKey``, and does not have a ``choices``
definition. definition.
@ -631,25 +631,25 @@ with the admin site:
boolean value. boolean value.
* **admin.E026**: The value of ``prepopulated_fields`` must be a dictionary. * **admin.E026**: The value of ``prepopulated_fields`` must be a dictionary.
* **admin.E027**: The value of ``prepopulated_fields`` refers to * **admin.E027**: The value of ``prepopulated_fields`` refers to
``<field name>``, which is not an attribute of ``<model>``. ``<field name>``, which is not a field of ``<model>``.
* **admin.E028**: The value of ``prepopulated_fields`` refers to * **admin.E028**: The value of ``prepopulated_fields`` refers to
``<field name>``, which must not be a ``DateTimeField``, a ``ForeignKey``, ``<field name>``, which must not be a ``DateTimeField``, a ``ForeignKey``,
a ``OneToOneField``, or a ``ManyToManyField`` field. a ``OneToOneField``, or a ``ManyToManyField`` field.
* **admin.E029**: The value of ``prepopulated_fields[<field name>]`` must be a * **admin.E029**: The value of ``prepopulated_fields[<field name>]`` must be a
list or tuple. list or tuple.
* **admin.E030**: The value of ``prepopulated_fields`` refers to * **admin.E030**: The value of ``prepopulated_fields`` refers to
``<field name>``, which is not an attribute of ``<model>``. ``<field name>``, which is not a field of ``<model>``.
* **admin.E031**: The value of ``ordering`` must be a list or tuple. * **admin.E031**: The value of ``ordering`` must be a list or tuple.
* **admin.E032**: The value of ``ordering`` has the random ordering marker * **admin.E032**: The value of ``ordering`` has the random ordering marker
``?``, but contains other fields as well. ``?``, but contains other fields as well.
* **admin.E033**: The value of ``ordering`` refers to ``<field name>``, which * **admin.E033**: The value of ``ordering`` refers to ``<field name>``, which
is not an attribute 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]`` is not a callable, an
attribute of ``<ModelAdmin class>``, or an attribute of ``<model>``. 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 an attribute of ``<model>``. ``<field name>``, which is not a field of ``<model>``.
* **admin.E038**: The value of ``autocomplete_fields[n]`` must be a foreign * **admin.E038**: The value of ``autocomplete_fields[n]`` must be a foreign
key or a many-to-many field. key or a many-to-many field.
* **admin.E039**: An admin for model ``<model>`` has to be registered to be * **admin.E039**: An admin for model ``<model>`` has to be registered to be
@ -697,7 +697,7 @@ with the admin site:
* **admin.E119**: The value of ``list_max_show_all`` must be an integer. * **admin.E119**: The value of ``list_max_show_all`` must be an integer.
* **admin.E120**: The value of ``list_editable`` must be a list or tuple. * **admin.E120**: The value of ``list_editable`` must be a list or tuple.
* **admin.E121**: The value of ``list_editable[n]`` refers to ``<label>``, * **admin.E121**: The value of ``list_editable[n]`` refers to ``<label>``,
which is not an attribute of ``<model>``. which is not a field of ``<model>``.
* **admin.E122**: The value of ``list_editable[n]`` refers to ``<label>``, * **admin.E122**: The value of ``list_editable[n]`` refers to ``<label>``,
which is not contained in ``list_display``. which is not contained in ``list_display``.
* **admin.E123**: The value of ``list_editable[n]`` cannot be in both * **admin.E123**: The value of ``list_editable[n]`` cannot be in both

View File

@ -309,7 +309,7 @@ class SystemChecksTestCase(SimpleTestCase):
self.assertEqual(SongAdmin(Song, AdminSite()).check(), [ self.assertEqual(SongAdmin(Song, AdminSite()).check(), [
checks.Error( checks.Error(
"The value of 'list_editable[0]' refers to 'test', which is " "The value of 'list_editable[0]' refers to 'test', which is "
"not an attribute of 'admin_checks.Song'.", "not a field of 'admin_checks.Song'.",
obj=SongAdmin, obj=SongAdmin,
id='admin.E121', id='admin.E121',
) )
@ -618,7 +618,7 @@ class SystemChecksTestCase(SimpleTestCase):
expected = [ expected = [
checks.Error( checks.Error(
"The value of 'raw_id_fields[0]' refers to 'nonexistent', " "The value of 'raw_id_fields[0]' refers to 'nonexistent', "
"which is not an attribute of 'admin_checks.Album'.", "which is not a field of 'admin_checks.Album'.",
obj=RawIdNonexistentAdmin, obj=RawIdNonexistentAdmin,
id='admin.E002', id='admin.E002',
) )

View File

@ -63,7 +63,7 @@ class RawIdCheckTests(CheckTestCase):
self.assertIsInvalid( self.assertIsInvalid(
TestModelAdmin, ValidationTestModel, TestModelAdmin, ValidationTestModel,
"The value of 'raw_id_fields[0]' refers to 'non_existent_field', " "The value of 'raw_id_fields[0]' refers to 'non_existent_field', "
"which is not an attribute of 'modeladmin.ValidationTestModel'.", "which is not a field of 'modeladmin.ValidationTestModel'.",
'admin.E002' 'admin.E002'
) )
@ -278,7 +278,7 @@ class FilterVerticalCheckTests(CheckTestCase):
self.assertIsInvalid( self.assertIsInvalid(
TestModelAdmin, ValidationTestModel, TestModelAdmin, ValidationTestModel,
"The value of 'filter_vertical[0]' refers to 'non_existent_field', " "The value of 'filter_vertical[0]' refers to 'non_existent_field', "
"which is not an attribute of 'modeladmin.ValidationTestModel'.", "which is not a field of 'modeladmin.ValidationTestModel'.",
'admin.E019' 'admin.E019'
) )
@ -318,7 +318,7 @@ class FilterHorizontalCheckTests(CheckTestCase):
self.assertIsInvalid( self.assertIsInvalid(
TestModelAdmin, ValidationTestModel, TestModelAdmin, ValidationTestModel,
"The value of 'filter_horizontal[0]' refers to 'non_existent_field', " "The value of 'filter_horizontal[0]' refers to 'non_existent_field', "
"which is not an attribute of 'modeladmin.ValidationTestModel'.", "which is not a field of 'modeladmin.ValidationTestModel'.",
'admin.E019' 'admin.E019'
) )
@ -359,7 +359,7 @@ class RadioFieldsCheckTests(CheckTestCase):
self.assertIsInvalid( self.assertIsInvalid(
TestModelAdmin, ValidationTestModel, TestModelAdmin, ValidationTestModel,
"The value of 'radio_fields' refers to 'non_existent_field', " "The value of 'radio_fields' refers to 'non_existent_field', "
"which is not an attribute of 'modeladmin.ValidationTestModel'.", "which is not a field of 'modeladmin.ValidationTestModel'.",
'admin.E022' 'admin.E022'
) )
@ -421,7 +421,7 @@ class PrepopulatedFieldsCheckTests(CheckTestCase):
self.assertIsInvalid( self.assertIsInvalid(
TestModelAdmin, ValidationTestModel, TestModelAdmin, ValidationTestModel,
"The value of 'prepopulated_fields' refers to 'non_existent_field', " "The value of 'prepopulated_fields' refers to 'non_existent_field', "
"which is not an attribute of 'modeladmin.ValidationTestModel'.", "which is not a field of 'modeladmin.ValidationTestModel'.",
'admin.E027' 'admin.E027'
) )
@ -432,7 +432,7 @@ class PrepopulatedFieldsCheckTests(CheckTestCase):
self.assertIsInvalid( self.assertIsInvalid(
TestModelAdmin, ValidationTestModel, TestModelAdmin, ValidationTestModel,
"The value of 'prepopulated_fields[\"slug\"][0]' refers to 'non_existent_field', " "The value of 'prepopulated_fields[\"slug\"][0]' refers to 'non_existent_field', "
"which is not an attribute of 'modeladmin.ValidationTestModel'.", "which is not a field of 'modeladmin.ValidationTestModel'.",
'admin.E030' 'admin.E030'
) )
@ -873,7 +873,7 @@ class OrderingCheckTests(CheckTestCase):
self.assertIsInvalid( self.assertIsInvalid(
TestModelAdmin, ValidationTestModel, TestModelAdmin, ValidationTestModel,
"The value of 'ordering[0]' refers to 'non_existent_field', " "The value of 'ordering[0]' refers to 'non_existent_field', "
"which is not an attribute of 'modeladmin.ValidationTestModel'.", "which is not a field of 'modeladmin.ValidationTestModel'.",
'admin.E033' 'admin.E033'
) )
@ -914,7 +914,7 @@ class OrderingCheckTests(CheckTestCase):
self.assertIsInvalid( self.assertIsInvalid(
TestModelAdmin, ValidationTestModel, TestModelAdmin, ValidationTestModel,
"The value of 'ordering[0]' refers to 'nonexistent', which is not " "The value of 'ordering[0]' refers to 'nonexistent', which is not "
"an attribute of 'modeladmin.ValidationTestModel'.", "a field of 'modeladmin.ValidationTestModel'.",
'admin.E033' 'admin.E033'
) )
@ -1342,7 +1342,7 @@ class AutocompleteFieldsTests(CheckTestCase):
Admin, ValidationTestModel, Admin, ValidationTestModel,
msg=( msg=(
"The value of 'autocomplete_fields[0]' refers to 'nonexistent', " "The value of 'autocomplete_fields[0]' refers to 'nonexistent', "
"which is not an attribute of 'modeladmin.ValidationTestModel'." "which is not a field of 'modeladmin.ValidationTestModel'."
), ),
id='admin.E037', id='admin.E037',
invalid_obj=Admin, invalid_obj=Admin,