mirror of
				https://github.com/django/django.git
				synced 2025-10-24 14:16:09 +00:00 
			
		
		
		
	Fixed transaction handling in two management commands.
Previously, when createcachetable and flush operated on non-default databases, they weren't atomic.
This commit is contained in:
		| @@ -71,7 +71,7 @@ class Command(BaseCommand): | ||||
|         for i, line in enumerate(table_output): | ||||
|             full_statement.append('    %s%s' % (line, ',' if i < len(table_output) - 1 else '')) | ||||
|         full_statement.append(');') | ||||
|         with transaction.atomic(): | ||||
|         with transaction.atomic(using=database): | ||||
|             with connection.cursor() as curs: | ||||
|                 try: | ||||
|                     curs.execute("\n".join(full_statement)) | ||||
|   | ||||
| @@ -63,7 +63,7 @@ Are you sure you want to do this? | ||||
|  | ||||
|         if confirm == 'yes': | ||||
|             try: | ||||
|                 with transaction.atomic(): | ||||
|                 with transaction.atomic(using=db): | ||||
|                     with connection.cursor() as cursor: | ||||
|                         for sql in sql_list: | ||||
|                             cursor.execute(sql) | ||||
|   | ||||
							
								
								
									
										8
									
								
								tests/cache/tests.py
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								tests/cache/tests.py
									
									
									
									
										vendored
									
									
								
							| @@ -981,9 +981,11 @@ class CreateCacheTableForDBCacheTests(TestCase): | ||||
|             # cache table should be created on 'other' | ||||
|             # Queries: | ||||
|             #   1: check table doesn't already exist | ||||
|             #   2: create the table | ||||
|             #   3: create the index | ||||
|             with self.assertNumQueries(3, using='other'): | ||||
|             #   2: create savepoint | ||||
|             #   3: create the table | ||||
|             #   4: create the index | ||||
|             #   5: release savepoint | ||||
|             with self.assertNumQueries(5, using='other'): | ||||
|                 management.call_command('createcachetable', | ||||
|                                         database='other', | ||||
|                                         verbosity=0, interactive=False) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user