summaryrefslogtreecommitdiff
path: root/tests/messages_tests
diff options
context:
space:
mode:
authorMariusz Felisiak <felisiak.mariusz@gmail.com>2023-10-24 10:00:02 +0200
committerNatalia <124304+nessita@users.noreply.github.com>2023-10-24 14:09:31 -0300
commit311718feb5f1fb9ff794bbac0cda48cfc3410de8 (patch)
tree57b6a10d662ce9e28c4995e16f63545c807b5a9b /tests/messages_tests
parentd22ba0763086f71fb6df8502162ea63944d166b1 (diff)
Fixed #34923 -- Avoided initializing LEVEL_TAGS when importing django.contrib.messages.
Regression in b7fe36ad37fb18c4bc7932c0aec6ae4f299b9622. Thanks James Gillard for the report.
Diffstat (limited to 'tests/messages_tests')
-rw-r--r--tests/messages_tests/tests.py21
1 files changed, 21 insertions, 0 deletions
diff --git a/tests/messages_tests/tests.py b/tests/messages_tests/tests.py
index 4280cb6e3b..17eb8639e8 100644
--- a/tests/messages_tests/tests.py
+++ b/tests/messages_tests/tests.py
@@ -1,5 +1,6 @@
from unittest import mock
+from django.conf import settings
from django.contrib.messages import Message, add_message, constants
from django.contrib.messages.storage import base
from django.contrib.messages.test import MessagesTestMixin
@@ -63,6 +64,26 @@ class TestLevelTags(SimpleTestCase):
def test_override_settings_level_tags(self):
self.assertEqual(base.LEVEL_TAGS, self.message_tags)
+ def test_lazy(self):
+ # Don't use @override_settings to avoid calling the setting_changed
+ # signal.
+ old_message_tags = getattr(settings, "MESSAGE_TAGS", None)
+ settings.MESSAGE_TAGS = {constants.ERROR: "bad"}
+ try:
+ self.assertEqual(base.LEVEL_TAGS[constants.ERROR], "bad")
+ finally:
+ if old_message_tags is None:
+ del settings.MESSAGE_TAGS
+ else:
+ settings.MESSAGE_TAGS = old_message_tags
+
+ @override_settings(MESSAGE_TAGS=message_tags)
+ def test_override_settings_lazy(self):
+ # The update_level_tags handler has been called at least once before
+ # running this code when using @override_settings.
+ settings.MESSAGE_TAGS = {constants.ERROR: "very-bad"}
+ self.assertEqual(base.LEVEL_TAGS[constants.ERROR], "very-bad")
+
class FakeResponse:
def __init__(self):