Fixed #21005 -- Made schema tests language-independent

Thanks Simon Charette for the review.
This commit is contained in:
Claude Paroz 2013-08-30 21:28:21 +02:00
parent 11cd7388f7
commit b04f8ddbaa
1 changed files with 9 additions and 15 deletions

View File

@ -21,7 +21,6 @@ class SchemaTests(TransactionTestCase):
available_apps = []
models = [Author, AuthorWithM2M, Book, BookWithSlug, BookWithM2M, Tag, TagIndexed, TagM2MTest, TagUniqueRename, UniqueTest]
no_table_strings = ["no such table", "unknown table", "does not exist"]
# Utility functions
@ -33,30 +32,25 @@ class SchemaTests(TransactionTestCase):
"Deletes all model tables for our models for a clean test environment"
cursor = connection.cursor()
connection.disable_constraint_checking()
table_names = connection.introspection.table_names(cursor)
for model in self.models:
# Remove any M2M tables first
for field in model._meta.local_many_to_many:
with atomic():
try:
tbl = field.rel.through._meta.db_table
if tbl in table_names:
cursor.execute(connection.schema_editor().sql_delete_table % {
"table": connection.ops.quote_name(field.rel.through._meta.db_table),
"table": connection.ops.quote_name(tbl),
})
except DatabaseError as e:
if any(s in str(e).lower() for s in self.no_table_strings):
pass
else:
raise
table_names.remove(tbl)
# Then remove the main tables
with atomic():
try:
tbl = model._meta.db_table
if tbl in table_names:
cursor.execute(connection.schema_editor().sql_delete_table % {
"table": connection.ops.quote_name(model._meta.db_table),
"table": connection.ops.quote_name(tbl),
})
except DatabaseError as e:
if any(s in str(e).lower() for s in self.no_table_strings):
pass
else:
raise
table_names.remove(tbl)
connection.enable_constraint_checking()
def column_classes(self, model):