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",
|
|
|
|
),
|
|
|
|
],
|
|
|
|
)
|