Fixed #28116 -- Used error code filtering in PostgreSQL test database creation.
Thanks Claude Paroz and Tim Graham for reviews.
This commit is contained in:
parent
5e8625ba64
commit
e776dd2db6
|
@ -1,5 +1,7 @@
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
|
from psycopg2 import errorcodes
|
||||||
|
|
||||||
from django.db.backends.base.creation import BaseDatabaseCreation
|
from django.db.backends.base.creation import BaseDatabaseCreation
|
||||||
|
|
||||||
|
|
||||||
|
@ -32,9 +34,8 @@ class DatabaseCreation(BaseDatabaseCreation):
|
||||||
try:
|
try:
|
||||||
super()._execute_create_test_db(cursor, parameters, keepdb)
|
super()._execute_create_test_db(cursor, parameters, keepdb)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
exc_msg = 'database %s already exists' % parameters['dbname']
|
if getattr(e.__cause__, 'pgcode', '') != errorcodes.DUPLICATE_DATABASE:
|
||||||
if exc_msg not in str(e):
|
# All errors except "database already exists" cancel tests.
|
||||||
# All errors except "database already exists" cancel tests
|
|
||||||
sys.stderr.write('Got an error creating the test database: %s\n' % e)
|
sys.stderr.write('Got an error creating the test database: %s\n' % e)
|
||||||
sys.exit(2)
|
sys.exit(2)
|
||||||
elif not keepdb:
|
elif not keepdb:
|
||||||
|
|
|
@ -12,11 +12,18 @@ from django.db.backends.mysql.creation import \
|
||||||
DatabaseCreation as MySQLDatabaseCreation
|
DatabaseCreation as MySQLDatabaseCreation
|
||||||
from django.db.backends.oracle.creation import \
|
from django.db.backends.oracle.creation import \
|
||||||
DatabaseCreation as OracleDatabaseCreation
|
DatabaseCreation as OracleDatabaseCreation
|
||||||
from django.db.backends.postgresql.creation import \
|
|
||||||
DatabaseCreation as PostgreSQLDatabaseCreation
|
|
||||||
from django.db.utils import DatabaseError
|
from django.db.utils import DatabaseError
|
||||||
from django.test import SimpleTestCase, TestCase
|
from django.test import SimpleTestCase, TestCase
|
||||||
|
|
||||||
|
try:
|
||||||
|
import psycopg2 # NOQA
|
||||||
|
except ImportError:
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
from psycopg2 import errorcodes
|
||||||
|
from django.db.backends.postgresql.creation import \
|
||||||
|
DatabaseCreation as PostgreSQLDatabaseCreation
|
||||||
|
|
||||||
|
|
||||||
class TestDbSignatureTests(SimpleTestCase):
|
class TestDbSignatureTests(SimpleTestCase):
|
||||||
|
|
||||||
|
@ -98,10 +105,14 @@ class PostgreSQLDatabaseCreationTests(SimpleTestCase):
|
||||||
self.check_sql_table_creation_suffix(settings, '''WITH ENCODING 'UTF8' TEMPLATE "template0"''')
|
self.check_sql_table_creation_suffix(settings, '''WITH ENCODING 'UTF8' TEMPLATE "template0"''')
|
||||||
|
|
||||||
def _execute_raise_database_already_exists(self, cursor, parameters, keepdb=False):
|
def _execute_raise_database_already_exists(self, cursor, parameters, keepdb=False):
|
||||||
raise DatabaseError('database %s already exists' % parameters['dbname'])
|
error = DatabaseError('database %s already exists' % parameters['dbname'])
|
||||||
|
error.pgcode = errorcodes.DUPLICATE_DATABASE
|
||||||
|
raise DatabaseError() from error
|
||||||
|
|
||||||
def _execute_raise_permission_denied(self, cursor, parameters, keepdb=False):
|
def _execute_raise_permission_denied(self, cursor, parameters, keepdb=False):
|
||||||
raise DatabaseError('permission denied to create database')
|
error = DatabaseError('permission denied to create database')
|
||||||
|
error.pgcode = errorcodes.INSUFFICIENT_PRIVILEGE
|
||||||
|
raise DatabaseError() from error
|
||||||
|
|
||||||
def patch_test_db_creation(self, execute_create_test_db):
|
def patch_test_db_creation(self, execute_create_test_db):
|
||||||
return mock.patch.object(BaseDatabaseCreation, '_execute_create_test_db', execute_create_test_db)
|
return mock.patch.object(BaseDatabaseCreation, '_execute_create_test_db', execute_create_test_db)
|
||||||
|
|
Loading…
Reference in New Issue