2021-01-14 16:33:12 +08:00
|
|
|
from unittest import skipUnless
|
|
|
|
|
2015-01-18 09:42:41 +08:00
|
|
|
from django.core import checks
|
2021-01-14 16:33:12 +08:00
|
|
|
from django.db import connection, models
|
2015-11-17 13:39:28 +08:00
|
|
|
from django.test import SimpleTestCase
|
|
|
|
from django.test.utils import isolate_apps
|
2015-01-18 09:42:41 +08:00
|
|
|
|
|
|
|
|
2015-11-17 13:39:28 +08:00
|
|
|
@isolate_apps("invalid_models_tests")
|
|
|
|
class DeprecatedFieldsTests(SimpleTestCase):
|
2015-01-18 09:42:41 +08: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-08 07:22:48 +08: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 23:30:41 +08:00
|
|
|
[
|
|
|
|
checks.Error(
|
|
|
|
"CommaSeparatedIntegerField is removed except for support in "
|
|
|
|
"historical migrations.",
|
2016-02-08 07:22:48 +08:00
|
|
|
hint=(
|
|
|
|
"Use "
|
|
|
|
"CharField(validators=[validate_comma_separated_integer_list]) "
|
|
|
|
"instead."
|
|
|
|
),
|
|
|
|
obj=CommaSeparatedIntegerModel._meta.get_field("csi"),
|
2016-12-31 23:30:41 +08:00
|
|
|
id="fields.E901",
|
2016-02-08 07:22:48 +08:00
|
|
|
)
|
|
|
|
],
|
|
|
|
)
|
2020-03-31 10:16:33 +08:00
|
|
|
|
|
|
|
def test_nullbooleanfield_deprecated(self):
|
|
|
|
class NullBooleanFieldModel(models.Model):
|
|
|
|
nb = models.NullBooleanField()
|
|
|
|
|
|
|
|
model = NullBooleanFieldModel()
|
|
|
|
self.assertEqual(
|
|
|
|
model.check(),
|
|
|
|
[
|
2021-01-14 04:28:09 +08:00
|
|
|
checks.Error(
|
|
|
|
"NullBooleanField is removed except for support in historical "
|
|
|
|
"migrations.",
|
2020-03-31 10:16:33 +08:00
|
|
|
hint="Use BooleanField(null=True) instead.",
|
|
|
|
obj=NullBooleanFieldModel._meta.get_field("nb"),
|
2021-01-14 04:28:09 +08:00
|
|
|
id="fields.E903",
|
2020-03-31 10:16:33 +08:00
|
|
|
),
|
|
|
|
],
|
|
|
|
)
|
2021-01-14 16:33:12 +08: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 17:42:51 +08: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(),
|
|
|
|
[
|
|
|
|
checks.Warning(
|
|
|
|
"django.contrib.postgres.fields.CICharField is deprecated. Support "
|
|
|
|
"for it (except in historical migrations) will be removed in "
|
|
|
|
"Django 5.1.",
|
|
|
|
hint=(
|
|
|
|
'Use CharField(db_collation="…") with a case-insensitive '
|
|
|
|
"non-deterministic collation instead."
|
|
|
|
),
|
|
|
|
obj=PostgresCIFieldsModel._meta.get_field("ci_char"),
|
|
|
|
id="fields.W905",
|
|
|
|
),
|
|
|
|
checks.Warning(
|
|
|
|
"django.contrib.postgres.fields.CIEmailField is deprecated. "
|
|
|
|
"Support for it (except in historical migrations) will be removed "
|
|
|
|
"in Django 5.1.",
|
|
|
|
hint=(
|
|
|
|
'Use EmailField(db_collation="…") with a case-insensitive '
|
|
|
|
"non-deterministic collation instead."
|
|
|
|
),
|
|
|
|
obj=PostgresCIFieldsModel._meta.get_field("ci_email"),
|
|
|
|
id="fields.W906",
|
|
|
|
),
|
|
|
|
checks.Warning(
|
|
|
|
"django.contrib.postgres.fields.CITextField is deprecated. Support "
|
|
|
|
"for it (except in historical migrations) will be removed in "
|
|
|
|
"Django 5.1.",
|
|
|
|
hint=(
|
|
|
|
'Use TextField(db_collation="…") with a case-insensitive '
|
|
|
|
"non-deterministic collation instead."
|
|
|
|
),
|
|
|
|
obj=PostgresCIFieldsModel._meta.get_field("ci_text"),
|
|
|
|
id="fields.W907",
|
|
|
|
),
|
|
|
|
checks.Warning(
|
|
|
|
"Base field for array has warnings:\n"
|
|
|
|
" django.contrib.postgres.fields.CITextField is deprecated. "
|
|
|
|
"Support for it (except in historical migrations) will be removed "
|
|
|
|
"in Django 5.1. (fields.W907)",
|
|
|
|
obj=PostgresCIFieldsModel._meta.get_field("array_ci_text"),
|
|
|
|
id="postgres.W004",
|
|
|
|
),
|
|
|
|
],
|
|
|
|
)
|