2017-09-09 12:39:09 +00:00
|
|
|
from io import StringIO
|
|
|
|
|
|
|
|
from django.core.management import call_command
|
|
|
|
from django.test.utils import modify_settings
|
|
|
|
|
|
|
|
from . import PostgreSQLTestCase
|
|
|
|
|
|
|
|
|
2022-02-03 19:24:19 +00:00
|
|
|
@modify_settings(INSTALLED_APPS={"append": "django.contrib.postgres"})
|
2017-09-09 12:39:09 +00:00
|
|
|
class InspectDBTests(PostgreSQLTestCase):
|
|
|
|
def assertFieldsInModel(self, model, field_outputs):
|
|
|
|
out = StringIO()
|
|
|
|
call_command(
|
2022-02-03 19:24:19 +00:00
|
|
|
"inspectdb",
|
2017-09-09 12:39:09 +00:00
|
|
|
table_name_filter=lambda tn: tn.startswith(model),
|
|
|
|
stdout=out,
|
|
|
|
)
|
|
|
|
output = out.getvalue()
|
|
|
|
for field_output in field_outputs:
|
|
|
|
self.assertIn(field_output, output)
|
|
|
|
|
2017-09-09 16:33:05 +00:00
|
|
|
def test_range_fields(self):
|
|
|
|
self.assertFieldsInModel(
|
2022-02-03 19:24:19 +00:00
|
|
|
"postgres_tests_rangesmodel",
|
2017-09-09 16:33:05 +00:00
|
|
|
[
|
2022-02-04 07:08:27 +00:00
|
|
|
"ints = django.contrib.postgres.fields.IntegerRangeField(blank=True, "
|
|
|
|
"null=True)",
|
|
|
|
"bigints = django.contrib.postgres.fields.BigIntegerRangeField("
|
|
|
|
"blank=True, null=True)",
|
|
|
|
"decimals = django.contrib.postgres.fields.DecimalRangeField("
|
|
|
|
"blank=True, null=True)",
|
|
|
|
"timestamps = django.contrib.postgres.fields.DateTimeRangeField("
|
|
|
|
"blank=True, null=True)",
|
|
|
|
"dates = django.contrib.postgres.fields.DateRangeField(blank=True, "
|
|
|
|
"null=True)",
|
2017-09-09 16:33:05 +00:00
|
|
|
],
|
|
|
|
)
|