diff options
| author | Krishnaprasad MG <krishna@holvi.com> | 2025-12-15 15:39:06 +0100 |
|---|---|---|
| committer | Jacob Walls <jacobtylerwalls@gmail.com> | 2025-12-19 12:58:29 -0500 |
| commit | 7a2f35b1b755b20a1e4d290a88bf059e6897f798 (patch) | |
| tree | fba0bbd7a6f6475645b8262f443652da5b5d1c58 /tests/test_utils | |
| parent | 60fecd1d445224fa00385f5f1fde75999da7bec8 (diff) | |
Fixed #36487 -- Fixed logger error message with partial callbacks.
Diffstat (limited to 'tests/test_utils')
| -rw-r--r-- | tests/test_utils/tests.py | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/tests/test_utils/tests.py b/tests/test_utils/tests.py index 70cca3d441..92f13ab81c 100644 --- a/tests/test_utils/tests.py +++ b/tests/test_utils/tests.py @@ -4,6 +4,7 @@ import threading import traceback import unittest import warnings +from functools import partial from io import StringIO from unittest import mock @@ -2145,6 +2146,33 @@ class CaptureOnCommitCallbacksTests(TestCase): self.assertIsInstance(raised_exception, MyException) self.assertEqual(str(raised_exception), "robust callback") + def test_execute_robust_with_callback_as_partial(self): + class MyException(Exception): + pass + + def hook(): + self.callback_called = True + raise MyException("robust callback") + + hook_partial = partial(hook) + + with self.assertLogs("django.test", "ERROR") as cm: + with self.captureOnCommitCallbacks(execute=True) as callbacks: + transaction.on_commit(hook_partial, robust=True) + + self.assertEqual(len(callbacks), 1) + self.assertIs(self.callback_called, True) + + log_record = cm.records[0] + self.assertEqual( + log_record.getMessage(), + f"Error calling {hook_partial} in on_commit() (robust callback).", + ) + self.assertIsNotNone(log_record.exc_info) + raised_exception = log_record.exc_info[1] + self.assertIsInstance(raised_exception, MyException) + self.assertEqual(str(raised_exception), "robust callback") + class DisallowedDatabaseQueriesTests(SimpleTestCase): def test_disallowed_database_connections(self): |
