Added functions for inspectdb table filtering in tests.

This commit is contained in:
Tim Graham 2018-03-12 10:02:10 -04:00
parent e1cf2a607e
commit 25b97ee170
1 changed files with 16 additions and 16 deletions

View File

@ -10,15 +10,23 @@ from django.test import TestCase, TransactionTestCase, skipUnlessDBFeature
from .models import ColumnTypes from .models import ColumnTypes
def inspectdb_tables_only(table_name):
"""
Limit introspection to tables created for models of this app.
Some databases such as Oracle are extremely slow at introspection.
"""
return table_name.startswith('inspectdb_')
def special_table_only(table_name):
return table_name.startswith('inspectdb_special')
class InspectDBTestCase(TestCase): class InspectDBTestCase(TestCase):
def test_stealth_table_name_filter_option(self): def test_stealth_table_name_filter_option(self):
out = StringIO() out = StringIO()
# Lets limit the introspection to tables created for models of this call_command('inspectdb', table_name_filter=inspectdb_tables_only, stdout=out)
# application
call_command('inspectdb',
table_name_filter=lambda tn: tn.startswith('inspectdb_'),
stdout=out)
error_message = "inspectdb has examined a table that should have been filtered out." error_message = "inspectdb has examined a table that should have been filtered out."
# contrib.contenttypes is one of the apps always installed when running # contrib.contenttypes is one of the apps always installed when running
# the Django test suite, check that one of its tables hasn't been # the Django test suite, check that one of its tables hasn't been
@ -136,11 +144,7 @@ class InspectDBTestCase(TestCase):
@skipUnlessDBFeature('can_introspect_foreign_keys') @skipUnlessDBFeature('can_introspect_foreign_keys')
def test_attribute_name_not_python_keyword(self): def test_attribute_name_not_python_keyword(self):
out = StringIO() out = StringIO()
# Lets limit the introspection to tables created for models of this call_command('inspectdb', table_name_filter=inspectdb_tables_only, stdout=out)
# application
call_command('inspectdb',
table_name_filter=lambda tn: tn.startswith('inspectdb_'),
stdout=out)
output = out.getvalue() output = out.getvalue()
error_message = "inspectdb generated an attribute name which is a python keyword" error_message = "inspectdb generated an attribute name which is a python keyword"
# Recursive foreign keys should be set to 'self' # Recursive foreign keys should be set to 'self'
@ -186,9 +190,7 @@ class InspectDBTestCase(TestCase):
unsuitable for Python identifiers unsuitable for Python identifiers
""" """
out = StringIO() out = StringIO()
call_command('inspectdb', call_command('inspectdb', table_name_filter=special_table_only, stdout=out)
table_name_filter=lambda tn: tn.startswith('inspectdb_special'),
stdout=out)
output = out.getvalue() output = out.getvalue()
base_name = 'field' if connection.features.uppercases_column_names else 'Field' base_name = 'field' if connection.features.uppercases_column_names else 'Field'
self.assertIn("field = models.IntegerField()", output) self.assertIn("field = models.IntegerField()", output)
@ -204,9 +206,7 @@ class InspectDBTestCase(TestCase):
unsuitable for Python identifiers unsuitable for Python identifiers
""" """
out = StringIO() out = StringIO()
call_command('inspectdb', call_command('inspectdb', table_name_filter=special_table_only, stdout=out)
table_name_filter=lambda tn: tn.startswith('inspectdb_special'),
stdout=out)
output = out.getvalue() output = out.getvalue()
self.assertIn("class InspectdbSpecialTableName(models.Model):", output) self.assertIn("class InspectdbSpecialTableName(models.Model):", output)