Fixed tests broken in 2ee21d9
.
This commit is contained in:
parent
2ee21d9f0d
commit
cf30469164
|
@ -39,6 +39,9 @@ class DefaultConnectionProxy(object):
|
||||||
def __setattr__(self, name, value):
|
def __setattr__(self, name, value):
|
||||||
return setattr(connections[DEFAULT_DB_ALIAS], name, value)
|
return setattr(connections[DEFAULT_DB_ALIAS], name, value)
|
||||||
|
|
||||||
|
def __delattr__(self, name):
|
||||||
|
return delattr(connections[DEFAULT_DB_ALIAS], name)
|
||||||
|
|
||||||
connection = DefaultConnectionProxy()
|
connection = DefaultConnectionProxy()
|
||||||
backend = load_backend(connection.settings_dict['ENGINE'])
|
backend = load_backend(connection.settings_dict['ENGINE'])
|
||||||
|
|
||||||
|
|
|
@ -183,6 +183,9 @@ class ConnectionHandler(object):
|
||||||
def __setitem__(self, key, value):
|
def __setitem__(self, key, value):
|
||||||
setattr(self._connections, key, value)
|
setattr(self._connections, key, value)
|
||||||
|
|
||||||
|
def __delitem__(self, key):
|
||||||
|
delattr(self._connections, key)
|
||||||
|
|
||||||
def __iter__(self):
|
def __iter__(self):
|
||||||
return iter(self.databases)
|
return iter(self.databases)
|
||||||
|
|
||||||
|
|
|
@ -548,8 +548,27 @@ class RequestsTests(unittest.TestCase):
|
||||||
with self.assertRaises(UnreadablePostError):
|
with self.assertRaises(UnreadablePostError):
|
||||||
request.body
|
request.body
|
||||||
|
|
||||||
class TransactionRequestTests(TransactionTestCase):
|
|
||||||
|
@unittest.skipIf(connection.vendor == 'sqlite'
|
||||||
|
and connection.settings_dict['NAME'] in ('', ':memory:'),
|
||||||
|
"Cannot establish two connections to an in-memory SQLite database.")
|
||||||
|
class DatabaseConnectionHandlingTests(TransactionTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
# Use a temporary connection to avoid messing with the main one.
|
||||||
|
self._old_default_connection = connections['default']
|
||||||
|
del connections['default']
|
||||||
|
|
||||||
|
def tearDown(self):
|
||||||
|
try:
|
||||||
|
connections['default'].close()
|
||||||
|
finally:
|
||||||
|
connections['default'] = self._old_default_connection
|
||||||
|
|
||||||
def test_request_finished_db_state(self):
|
def test_request_finished_db_state(self):
|
||||||
|
# Force closing connection on request end
|
||||||
|
connection.settings_dict['CONN_MAX_AGE'] = 0
|
||||||
|
|
||||||
# The GET below will not succeed, but it will give a response with
|
# The GET below will not succeed, but it will give a response with
|
||||||
# defined ._handler_class. That is needed for sending the
|
# defined ._handler_class. That is needed for sending the
|
||||||
# request_finished signal.
|
# request_finished signal.
|
||||||
|
@ -559,31 +578,27 @@ class TransactionRequestTests(TransactionTestCase):
|
||||||
connection.enter_transaction_management()
|
connection.enter_transaction_management()
|
||||||
connection.managed(True)
|
connection.managed(True)
|
||||||
signals.request_finished.send(sender=response._handler_class)
|
signals.request_finished.send(sender=response._handler_class)
|
||||||
# In-memory sqlite doesn't actually close connections.
|
|
||||||
if connection.vendor != 'sqlite':
|
|
||||||
self.assertIs(connection.connection, None)
|
|
||||||
self.assertEqual(len(connection.transaction_state), 0)
|
self.assertEqual(len(connection.transaction_state), 0)
|
||||||
|
|
||||||
@unittest.skipIf(connection.vendor == 'sqlite',
|
|
||||||
'This test will close the connection, in-memory '
|
|
||||||
'sqlite connections must not be closed.')
|
|
||||||
def test_request_finished_failed_connection(self):
|
def test_request_finished_failed_connection(self):
|
||||||
conn = connections[DEFAULT_DB_ALIAS]
|
# Force closing connection on request end
|
||||||
conn.enter_transaction_management()
|
connection.settings_dict['CONN_MAX_AGE'] = 0
|
||||||
conn.managed(True)
|
|
||||||
conn.set_dirty()
|
connection.enter_transaction_management()
|
||||||
|
connection.managed(True)
|
||||||
|
connection.set_dirty()
|
||||||
# Test that the rollback doesn't succeed (for example network failure
|
# Test that the rollback doesn't succeed (for example network failure
|
||||||
# could cause this).
|
# could cause this).
|
||||||
def fail_horribly():
|
def fail_horribly():
|
||||||
raise Exception("Horrible failure!")
|
raise Exception("Horrible failure!")
|
||||||
conn._rollback = fail_horribly
|
connection._rollback = fail_horribly
|
||||||
try:
|
try:
|
||||||
with self.assertRaises(Exception):
|
with self.assertRaises(Exception):
|
||||||
signals.request_finished.send(sender=self.__class__)
|
signals.request_finished.send(sender=self.__class__)
|
||||||
# The connection's state wasn't cleaned up
|
# The connection's state wasn't cleaned up
|
||||||
self.assertTrue(len(connection.transaction_state), 1)
|
self.assertEqual(len(connection.transaction_state), 1)
|
||||||
finally:
|
finally:
|
||||||
del conn._rollback
|
del connection._rollback
|
||||||
# The connection will be cleaned on next request where the conn
|
# The connection will be cleaned on next request where the conn
|
||||||
# works again.
|
# works again.
|
||||||
signals.request_finished.send(sender=self.__class__)
|
signals.request_finished.send(sender=self.__class__)
|
||||||
|
|
Loading…
Reference in New Issue