summaryrefslogtreecommitdiff
path: root/tests/test_utils
diff options
context:
space:
mode:
authorKrishnaprasad MG <krishna@holvi.com>2025-12-15 15:39:06 +0100
committerJacob Walls <jacobtylerwalls@gmail.com>2025-12-19 12:58:29 -0500
commit7a2f35b1b755b20a1e4d290a88bf059e6897f798 (patch)
treefba0bbd7a6f6475645b8262f443652da5b5d1c58 /tests/test_utils
parent60fecd1d445224fa00385f5f1fde75999da7bec8 (diff)
Fixed #36487 -- Fixed logger error message with partial callbacks.
Diffstat (limited to 'tests/test_utils')
-rw-r--r--tests/test_utils/tests.py28
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):