mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	The sql_flush() positional argument sequences is replaced by the boolean keyword-only argument reset_sequences. This ensures that the old function signature can't be used by mistake when upgrading Django. When the new argument is True, the sequences of the truncated tables will reset. Using a single boolean value, rather than a list, allows making a binary yes/no choice as to whether to reset all sequences rather than a working on a completely different set.
		
			
				
	
	
		
			48 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import unittest
 | |
| 
 | |
| from django.core.management.color import no_style
 | |
| from django.db import connection
 | |
| from django.test import SimpleTestCase
 | |
| 
 | |
| from ..models import Person, Tag
 | |
| 
 | |
| 
 | |
| @unittest.skipUnless(connection.vendor == 'mysql', 'MySQL tests.')
 | |
| class MySQLOperationsTests(SimpleTestCase):
 | |
|     def test_sql_flush(self):
 | |
|         # allow_cascade doesn't change statements on MySQL.
 | |
|         for allow_cascade in [False, True]:
 | |
|             with self.subTest(allow_cascade=allow_cascade):
 | |
|                 self.assertEqual(
 | |
|                     connection.ops.sql_flush(
 | |
|                         no_style(),
 | |
|                         [Person._meta.db_table, Tag._meta.db_table],
 | |
|                         allow_cascade=allow_cascade,
 | |
|                     ),
 | |
|                     [
 | |
|                         'SET FOREIGN_KEY_CHECKS = 0;',
 | |
|                         'DELETE FROM `backends_person`;',
 | |
|                         'DELETE FROM `backends_tag`;',
 | |
|                         'SET FOREIGN_KEY_CHECKS = 1;',
 | |
|                     ],
 | |
|                 )
 | |
| 
 | |
|     def test_sql_flush_sequences(self):
 | |
|         # allow_cascade doesn't change statements on MySQL.
 | |
|         for allow_cascade in [False, True]:
 | |
|             with self.subTest(allow_cascade=allow_cascade):
 | |
|                 self.assertEqual(
 | |
|                     connection.ops.sql_flush(
 | |
|                         no_style(),
 | |
|                         [Person._meta.db_table, Tag._meta.db_table],
 | |
|                         reset_sequences=True,
 | |
|                         allow_cascade=allow_cascade,
 | |
|                     ),
 | |
|                     [
 | |
|                         'SET FOREIGN_KEY_CHECKS = 0;',
 | |
|                         'TRUNCATE `backends_person`;',
 | |
|                         'TRUNCATE `backends_tag`;',
 | |
|                         'SET FOREIGN_KEY_CHECKS = 1;',
 | |
|                     ],
 | |
|                 )
 |