diff options
| author | Mariusz Felisiak <felisiak.mariusz@gmail.com> | 2023-10-24 10:00:02 +0200 |
|---|---|---|
| committer | Natalia <124304+nessita@users.noreply.github.com> | 2023-10-24 14:09:31 -0300 |
| commit | 311718feb5f1fb9ff794bbac0cda48cfc3410de8 (patch) | |
| tree | 57b6a10d662ce9e28c4995e16f63545c807b5a9b /tests/messages_tests | |
| parent | d22ba0763086f71fb6df8502162ea63944d166b1 (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.py | 21 |
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): |
