2021-01-14 09:33:12 +01:00
|
|
|
from unittest import skipUnless
|
|
|
|
|
2015-01-17 20:42:41 -05:00
|
|
|
from django.core import checks
|
2021-01-14 09:33:12 +01:00
|
|
|
from django.db import connection, models
|
2015-11-17 00:39:28 -05:00
|
|
|
from django.test import SimpleTestCase
|
|
|
|
from django.test.utils import isolate_apps
|
2015-01-17 20:42:41 -05:00
|
|
|
|
|
|
|
|
2015-11-17 00:39:28 -05:00
|
|
|
@isolate_apps("invalid_models_tests")
|
|
|
|
class DeprecatedFieldsTests(SimpleTestCase):
|
2015-01-17 20:42:41 -05:00
|
|
|
def test_IPAddressField_deprecated(self):
|
|
|
|
class IPAddressModel(models.Model):
|
|
|
|
ip = models.IPAddressField()
|
|
|
|
|
|
|
|
model = IPAddressModel()
|
|
|
|
self.assertEqual(
|
|
|
|
model.check(),
|
|
|
|
[
|
|
|
|
checks.Error(
|
|
|
|
"IPAddressField has been removed except for support in "
|
|
|
|
"historical migrations.",
|
|
|
|
hint="Use GenericIPAddressField instead.",
|
|
|
|
obj=IPAddressModel._meta.get_field("ip"),
|
|
|
|
id="fields.E900",
|
|
|
|
)
|
|
|
|
],
|
|
|
|
)
|
2016-02-07 17:22:48 -06:00
|
|
|
|
|
|
|
def test_CommaSeparatedIntegerField_deprecated(self):
|
|
|
|
class CommaSeparatedIntegerModel(models.Model):
|
|
|
|
csi = models.CommaSeparatedIntegerField(max_length=64)
|
|
|
|
|
|
|
|
model = CommaSeparatedIntegerModel()
|
|
|
|
self.assertEqual(
|
|
|
|
model.check(),
|
2016-12-31 10:30:41 -05:00
|
|
|
[
|
|
|
|
checks.Error(
|
|
|
|
"CommaSeparatedIntegerField is removed except for support in "
|
|
|
|
"historical migrations.",
|
2016-02-07 17:22:48 -06:00
|
|
|
hint=(
|
|
|
|
"Use "
|
|
|
|
"CharField(validators=[validate_comma_separated_integer_list]) "
|
|
|
|
"instead."
|
|
|
|
),
|
|
|
|
obj=CommaSeparatedIntegerModel._meta.get_field("csi"),
|
2016-12-31 10:30:41 -05:00
|
|
|
id="fields.E901",
|
2016-02-07 17:22:48 -06:00
|
|
|
)
|
|
|
|
],
|
|
|
|
)
|
2020-03-30 21:16:33 -05:00
|
|
|
|
|
|
|
def test_nullbooleanfield_deprecated(self):
|
|
|
|
class NullBooleanFieldModel(models.Model):
|
|
|
|
nb = models.NullBooleanField()
|
|
|
|
|
|
|
|
model = NullBooleanFieldModel()
|
|
|
|
self.assertEqual(
|
|
|
|
model.check(),
|
|
|
|
[
|
2021-01-13 21:28:09 +01:00
|
|
|
checks.Error(
|
|
|
|
"NullBooleanField is removed except for support in historical "
|
|
|
|
"migrations.",
|
2023-05-02 18:42:11 +00:00
|
|
|
hint="Use BooleanField(null=True, blank=True) instead.",
|
2020-03-30 21:16:33 -05:00
|
|
|
obj=NullBooleanFieldModel._meta.get_field("nb"),
|
2021-01-13 21:28:09 +01:00
|
|
|
id="fields.E903",
|
2020-03-30 21:16:33 -05:00
|
|
|
),
|
|
|
|
],
|
|
|
|
)
|
2021-01-14 09:33:12 +01:00
|
|
|
|
|
|
|
@skipUnless(connection.vendor == "postgresql", "PostgreSQL specific SQL")
|
|
|
|
def test_postgres_jsonfield_deprecated(self):
|
|
|
|
from django.contrib.postgres.fields import JSONField
|
|
|
|
|
|
|
|
class PostgresJSONFieldModel(models.Model):
|
|
|
|
field = JSONField()
|
|
|
|
|
|
|
|
self.assertEqual(
|
|
|
|
PostgresJSONFieldModel.check(),
|
|
|
|
[
|
|
|
|
checks.Error(
|
|
|
|
"django.contrib.postgres.fields.JSONField is removed except "
|
|
|
|
"for support in historical migrations.",
|
|
|
|
hint="Use django.db.models.JSONField instead.",
|
|
|
|
obj=PostgresJSONFieldModel._meta.get_field("field"),
|
|
|
|
id="fields.E904",
|
|
|
|
),
|
|
|
|
],
|
|
|
|
)
|
2022-08-03 11:42:51 +02:00
|
|
|
|
|
|
|
@skipUnless(connection.vendor == "postgresql", "PostgreSQL specific SQL")
|
|
|
|
def test_postgres_ci_fields_deprecated(self):
|
|
|
|
from django.contrib.postgres.fields import (
|
|
|
|
ArrayField,
|
|
|
|
CICharField,
|
|
|
|
CIEmailField,
|
|
|
|
CITextField,
|
|
|
|
)
|
|
|
|
|
|
|
|
class PostgresCIFieldsModel(models.Model):
|
|
|
|
ci_char = CICharField(max_length=255)
|
|
|
|
ci_email = CIEmailField()
|
|
|
|
ci_text = CITextField()
|
|
|
|
array_ci_text = ArrayField(CITextField())
|
|
|
|
|
|
|
|
self.assertEqual(
|
|
|
|
PostgresCIFieldsModel.check(),
|
|
|
|
[
|
2023-09-13 14:03:45 +02:00
|
|
|
checks.Error(
|
|
|
|
"django.contrib.postgres.fields.CICharField is removed except for "
|
|
|
|
"support in historical migrations.",
|
2022-08-03 11:42:51 +02:00
|
|
|
hint=(
|
|
|
|
'Use CharField(db_collation="…") with a case-insensitive '
|
|
|
|
"non-deterministic collation instead."
|
|
|
|
),
|
|
|
|
obj=PostgresCIFieldsModel._meta.get_field("ci_char"),
|
2023-09-13 14:03:45 +02:00
|
|
|
id="fields.E905",
|
2022-08-03 11:42:51 +02:00
|
|
|
),
|
2023-09-13 14:03:45 +02:00
|
|
|
checks.Error(
|
|
|
|
"django.contrib.postgres.fields.CIEmailField is removed except for "
|
|
|
|
"support in historical migrations.",
|
2022-08-03 11:42:51 +02:00
|
|
|
hint=(
|
|
|
|
'Use EmailField(db_collation="…") with a case-insensitive '
|
|
|
|
"non-deterministic collation instead."
|
|
|
|
),
|
|
|
|
obj=PostgresCIFieldsModel._meta.get_field("ci_email"),
|
2023-09-13 14:03:45 +02:00
|
|
|
id="fields.E906",
|
2022-08-03 11:42:51 +02:00
|
|
|
),
|
2023-09-13 14:03:45 +02:00
|
|
|
checks.Error(
|
|
|
|
"django.contrib.postgres.fields.CITextField is removed except for "
|
|
|
|
"support in historical migrations.",
|
2022-08-03 11:42:51 +02:00
|
|
|
hint=(
|
|
|
|
'Use TextField(db_collation="…") with a case-insensitive '
|
|
|
|
"non-deterministic collation instead."
|
|
|
|
),
|
|
|
|
obj=PostgresCIFieldsModel._meta.get_field("ci_text"),
|
2023-09-13 14:03:45 +02:00
|
|
|
id="fields.E907",
|
2022-08-03 11:42:51 +02:00
|
|
|
),
|
2023-09-13 14:03:45 +02:00
|
|
|
checks.Error(
|
|
|
|
"Base field for array has errors:\n"
|
|
|
|
" django.contrib.postgres.fields.CITextField is removed except "
|
|
|
|
"for support in historical migrations. (fields.E907)",
|
2022-08-03 11:42:51 +02:00
|
|
|
obj=PostgresCIFieldsModel._meta.get_field("array_ci_text"),
|
2023-09-13 14:03:45 +02:00
|
|
|
id="postgres.E001",
|
2022-08-03 11:42:51 +02:00
|
|
|
),
|
|
|
|
],
|
|
|
|
)
|