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.",
|
2020-03-30 21:16:33 -05:00
|
|
|
hint="Use BooleanField(null=True) instead.",
|
|
|
|
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",
|
|
|
|
),
|
|
|
|
],
|
|
|
|
)
|