From db88e40312dfba8d32203a0990792a4a9840f6a7 Mon Sep 17 00:00:00 2001 From: Antoine Catton Date: Fri, 25 Sep 2015 15:32:23 -0600 Subject: [PATCH] [1.9.x] Refs #16860 -- Fixed password help text when there aren't any validators. This avoids creating an empty list which is invalid HTML 4. Backport of 53ccffdb8c8e47a4d4304df453d8c79a9be295ab from master --- django/contrib/auth/password_validation.py | 2 +- tests/auth_tests/test_validators.py | 4 ++++ 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/django/contrib/auth/password_validation.py b/django/contrib/auth/password_validation.py index efad0d72a66..332d76c8450 100644 --- a/django/contrib/auth/password_validation.py +++ b/django/contrib/auth/password_validation.py @@ -84,7 +84,7 @@ def password_validators_help_text_html(password_validators=None): """ help_texts = password_validators_help_texts(password_validators) help_items = [format_html('
  • {}
  • ', help_text) for help_text in help_texts] - return '' % ''.join(help_items) + return '' % ''.join(help_items) if help_items else '' class MinimumLengthValidator(object): diff --git a/tests/auth_tests/test_validators.py b/tests/auth_tests/test_validators.py index e70feb727d6..a9f47eac1f7 100644 --- a/tests/auth_tests/test_validators.py +++ b/tests/auth_tests/test_validators.py @@ -68,6 +68,10 @@ class PasswordValidationTest(TestCase): self.assertEqual(help_text.count('
  • '), 2) self.assertIn('12 characters', help_text) + @override_settings(AUTH_PASSWORD_VALIDATORS=[]) + def test_empty_password_validator_help_text_html(self): + self.assertEqual(password_validators_help_text_html(), '') + class MinimumLengthValidatorTest(TestCase): def test_validate(self):