mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #33054 -- Made TestCase.captureOnCommitCallbacks() capture callbacks recursively.
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							02bc7161ec
						
					
				
				
					commit
					d89f976bdd
				
			| @@ -1282,11 +1282,18 @@ class TestCase(TransactionTestCase): | |||||||
|         try: |         try: | ||||||
|             yield callbacks |             yield callbacks | ||||||
|         finally: |         finally: | ||||||
|             run_on_commit = connections[using].run_on_commit[start_count:] |             callback_count = len(connections[using].run_on_commit) | ||||||
|             callbacks[:] = [func for sids, func in run_on_commit] |             while True: | ||||||
|             if execute: |                 run_on_commit = connections[using].run_on_commit[start_count:] | ||||||
|                 for callback in callbacks: |                 callbacks[:] = [func for sids, func in run_on_commit] | ||||||
|                     callback() |                 if execute: | ||||||
|  |                     for callback in callbacks: | ||||||
|  |                         callback() | ||||||
|  |  | ||||||
|  |                 if callback_count == len(connections[using].run_on_commit): | ||||||
|  |                     break | ||||||
|  |                 start_count = callback_count - 1 | ||||||
|  |                 callback_count = len(connections[using].run_on_commit) | ||||||
|  |  | ||||||
|  |  | ||||||
| class CheckCondition: | class CheckCondition: | ||||||
|   | |||||||
| @@ -368,6 +368,9 @@ Tests | |||||||
| * The :option:`test --parallel` option now supports the value ``auto`` to run | * The :option:`test --parallel` option now supports the value ``auto`` to run | ||||||
|   one test process for each processor core. |   one test process for each processor core. | ||||||
|  |  | ||||||
|  | * :meth:`.TestCase.captureOnCommitCallbacks` now captures new callbacks added | ||||||
|  |   while executing :func:`.transaction.on_commit` callbacks. | ||||||
|  |  | ||||||
| URLs | URLs | ||||||
| ~~~~ | ~~~~ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -912,6 +912,11 @@ It also provides an additional method: | |||||||
|                 self.assertEqual(mail.outbox[0].subject, 'Contact Form') |                 self.assertEqual(mail.outbox[0].subject, 'Contact Form') | ||||||
|                 self.assertEqual(mail.outbox[0].body, 'I like your site') |                 self.assertEqual(mail.outbox[0].body, 'I like your site') | ||||||
|  |  | ||||||
|  |     .. versionchanged:: 4.0 | ||||||
|  |  | ||||||
|  |         In older versions, new callbacks added while executing | ||||||
|  |         :func:`.transaction.on_commit` callbacks were not captured. | ||||||
|  |  | ||||||
| .. _live-test-server: | .. _live-test-server: | ||||||
|  |  | ||||||
| ``LiveServerTestCase`` | ``LiveServerTestCase`` | ||||||
|   | |||||||
| @@ -1502,6 +1502,13 @@ class CaptureOnCommitCallbacksTests(TestCase): | |||||||
|  |  | ||||||
|         self.assertEqual(callbacks, []) |         self.assertEqual(callbacks, []) | ||||||
|  |  | ||||||
|  |     def test_execute_recursive(self): | ||||||
|  |         with self.captureOnCommitCallbacks(execute=True) as callbacks: | ||||||
|  |             transaction.on_commit(self.enqueue_callback) | ||||||
|  |  | ||||||
|  |         self.assertEqual(len(callbacks), 2) | ||||||
|  |         self.assertIs(self.callback_called, True) | ||||||
|  |  | ||||||
|  |  | ||||||
| class DisallowedDatabaseQueriesTests(SimpleTestCase): | class DisallowedDatabaseQueriesTests(SimpleTestCase): | ||||||
|     def test_disallowed_database_connections(self): |     def test_disallowed_database_connections(self): | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user