From d22ba0763086f71fb6df8502162ea63944d166b1 Mon Sep 17 00:00:00 2001 From: ksg97031 Date: Tue, 24 Oct 2023 00:36:18 +0900 Subject: [PATCH 1/2] Fixed #34920 -- Made FileExtensionValidator.__eq__() ignore allowed_extensions ordering. --- django/core/validators.py | 3 ++- tests/validators/tests.py | 4 ++++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/django/core/validators.py b/django/core/validators.py index fe8d46526ab5..a5641d85b356 100644 --- a/django/core/validators.py +++ b/django/core/validators.py @@ -595,7 +595,8 @@ def __call__(self, value): def __eq__(self, other): return ( isinstance(other, self.__class__) - and self.allowed_extensions == other.allowed_extensions + and set(self.allowed_extensions or []) + == set(other.allowed_extensions or []) and self.message == other.message and self.code == other.code ) diff --git a/tests/validators/tests.py b/tests/validators/tests.py index cf64638ebb8a..cae64045bd3d 100644 --- a/tests/validators/tests.py +++ b/tests/validators/tests.py @@ -804,6 +804,10 @@ def test_file_extension_equality(self): FileExtensionValidator(["TXT", "png"]), FileExtensionValidator(["txt", "png"]), ) + self.assertEqual( + FileExtensionValidator(["jpg", "png", "txt"]), + FileExtensionValidator(["txt", "jpg", "png"]), + ) self.assertEqual( FileExtensionValidator(["txt"]), FileExtensionValidator(["txt"], code="invalid_extension"), From 311718feb5f1fb9ff794bbac0cda48cfc3410de8 Mon Sep 17 00:00:00 2001 From: Mariusz Felisiak Date: Tue, 24 Oct 2023 10:00:02 +0200 Subject: [PATCH 2/2] Fixed #34923 -- Avoided initializing LEVEL_TAGS when importing django.contrib.messages. Regression in b7fe36ad37fb18c4bc7932c0aec6ae4f299b9622. Thanks James Gillard for the report. --- django/contrib/messages/apps.py | 3 ++- django/contrib/messages/storage/base.py | 3 ++- tests/messages_tests/tests.py | 21 +++++++++++++++++++++ 3 files changed, 25 insertions(+), 2 deletions(-) diff --git a/django/contrib/messages/apps.py b/django/contrib/messages/apps.py index 09a9554b70b0..5bda152ab351 100644 --- a/django/contrib/messages/apps.py +++ b/django/contrib/messages/apps.py @@ -2,12 +2,13 @@ from django.contrib.messages.storage import base from django.contrib.messages.utils import get_level_tags from django.core.signals import setting_changed +from django.utils.functional import SimpleLazyObject from django.utils.translation import gettext_lazy as _ def update_level_tags(setting, **kwargs): if setting == "MESSAGE_TAGS": - base.LEVEL_TAGS = get_level_tags() + base.LEVEL_TAGS = SimpleLazyObject(get_level_tags) class MessagesConfig(AppConfig): diff --git a/django/contrib/messages/storage/base.py b/django/contrib/messages/storage/base.py index 124049a5e247..5d89acfe6911 100644 --- a/django/contrib/messages/storage/base.py +++ b/django/contrib/messages/storage/base.py @@ -1,7 +1,8 @@ from django.conf import settings from django.contrib.messages import constants, utils +from django.utils.functional import SimpleLazyObject -LEVEL_TAGS = utils.get_level_tags() +LEVEL_TAGS = SimpleLazyObject(utils.get_level_tags) class Message: diff --git a/tests/messages_tests/tests.py b/tests/messages_tests/tests.py index 4280cb6e3bc4..17eb8639e860 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):