mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Fixed #17513 -- Prevented the MySQL backend from leaking MySQLdb-specific exceptions. Thanks Claude Paroz.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@17352 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -119,7 +119,7 @@ class CursorWrapper(object): | |||||||
|             # misclassified and Django would prefer the more logical place. |             # misclassified and Django would prefer the more logical place. | ||||||
|             if e[0] in self.codes_for_integrityerror: |             if e[0] in self.codes_for_integrityerror: | ||||||
|                 raise utils.IntegrityError, utils.IntegrityError(*tuple(e)), sys.exc_info()[2] |                 raise utils.IntegrityError, utils.IntegrityError(*tuple(e)), sys.exc_info()[2] | ||||||
|             raise |             raise utils.DatabaseError, utils.DatabaseError(*tuple(e)), sys.exc_info()[2] | ||||||
|         except Database.DatabaseError, e: |         except Database.DatabaseError, e: | ||||||
|             raise utils.DatabaseError, utils.DatabaseError(*tuple(e)), sys.exc_info()[2] |             raise utils.DatabaseError, utils.DatabaseError(*tuple(e)), sys.exc_info()[2] | ||||||
|  |  | ||||||
|   | |||||||
| @@ -351,6 +351,12 @@ class BackendTestCase(TestCase): | |||||||
|         self.assertTrue(hasattr(connection.ops, 'connection')) |         self.assertTrue(hasattr(connection.ops, 'connection')) | ||||||
|         self.assertEqual(connection, connection.ops.connection) |         self.assertEqual(connection, connection.ops.connection) | ||||||
|  |  | ||||||
|  |     def test_duplicate_table_error(self): | ||||||
|  |         """ Test that creating an existing table returns a DatabaseError """ | ||||||
|  |         cursor = connection.cursor() | ||||||
|  |         query = 'CREATE TABLE %s (id INTEGER);' % models.Article._meta.db_table | ||||||
|  |         with self.assertRaises(DatabaseError): | ||||||
|  |             cursor.execute(query) | ||||||
|  |  | ||||||
| # We don't make these tests conditional because that means we would need to | # We don't make these tests conditional because that means we would need to | ||||||
| # check and differentiate between: | # check and differentiate between: | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user