Fixed #33419 -- Restored marking forms.Field.help_text as HTML safe.

Regression in 456466d932.

Thanks Matt Westcott for the report.
This commit is contained in:
David 2022-01-07 07:46:55 +00:00 committed by Mariusz Felisiak
parent bdf3e156b4
commit 4c60c3edff
8 changed files with 44 additions and 6 deletions

View File

@ -8,7 +8,7 @@
{% if field.label %}{{ field.label_tag() }}{% endif %} {% if field.label %}{{ field.label_tag() }}{% endif %}
{{ field }} {{ field }}
{% if field.help_text %} {% if field.help_text %}
<span class="helptext">{{ field.help_text }}</span> <span class="helptext">{{ field.help_text|safe }}</span>
{% endif %} {% endif %}
{% if loop.last %} {% if loop.last %}
{% for field in hidden_fields %}{{ field }}{% endfor %} {% for field in hidden_fields %}{{ field }}{% endfor %}

View File

@ -16,7 +16,7 @@
{{ field }} {{ field }}
{% if field.help_text %} {% if field.help_text %}
<br> <br>
<span class="helptext">{{ field.help_text }}</span> <span class="helptext">{{ field.help_text|safe }}</span>
{% endif %} {% endif %}
{% if loop.last %} {% if loop.last %}
{% for field in hidden_fields %}{{ field }}{% endfor %} {% for field in hidden_fields %}{{ field }}{% endfor %}

View File

@ -12,7 +12,7 @@
{% if field.label %}{{ field.label_tag() }}{% endif %} {% if field.label %}{{ field.label_tag() }}{% endif %}
{{ field }} {{ field }}
{% if field.help_text %} {% if field.help_text %}
<span class="helptext">{{ field.help_text }}</span> <span class="helptext">{{ field.help_text|safe }}</span>
{% endif %} {% endif %}
{% if loop.last %} {% if loop.last %}
{% for field in hidden_fields %}{{ field }}{% endfor %} {% for field in hidden_fields %}{{ field }}{% endfor %}

View File

@ -8,7 +8,7 @@
{% if field.label %}{{ field.label_tag }}{% endif %} {% if field.label %}{{ field.label_tag }}{% endif %}
{{ field }} {{ field }}
{% if field.help_text %} {% if field.help_text %}
<span class="helptext">{{ field.help_text }}</span> <span class="helptext">{{ field.help_text|safe }}</span>
{% endif %} {% endif %}
{% if forloop.last %} {% if forloop.last %}
{% for field in hidden_fields %}{{ field }}{% endfor %} {% for field in hidden_fields %}{{ field }}{% endfor %}

View File

@ -16,7 +16,7 @@
{{ field }} {{ field }}
{% if field.help_text %} {% if field.help_text %}
<br> <br>
<span class="helptext">{{ field.help_text }}</span> <span class="helptext">{{ field.help_text|safe }}</span>
{% endif %} {% endif %}
{% if forloop.last %} {% if forloop.last %}
{% for field in hidden_fields %}{{ field }}{% endfor %} {% for field in hidden_fields %}{{ field }}{% endfor %}

View File

@ -12,7 +12,7 @@
{% if field.label %}{{ field.label_tag }}{% endif %} {% if field.label %}{{ field.label_tag }}{% endif %}
{{ field }} {{ field }}
{% if field.help_text %} {% if field.help_text %}
<span class="helptext">{{ field.help_text }}</span> <span class="helptext">{{ field.help_text|safe }}</span>
{% endif %} {% endif %}
{% if forloop.last %} {% if forloop.last %}
{% for field in hidden_fields %}{{ field }}{% endfor %} {% for field in hidden_fields %}{{ field }}{% endfor %}

View File

@ -11,3 +11,6 @@ Bugfixes
* Fixed a bug in Django 4.0 where ``TestCase.captureOnCommitCallbacks()`` could * Fixed a bug in Django 4.0 where ``TestCase.captureOnCommitCallbacks()`` could
execute callbacks multiple times (:ticket:`33410`). execute callbacks multiple times (:ticket:`33410`).
* Fixed a regression in Django 4.0 where ``help_text`` was HTML-escaped in
automatically-generated forms (:ticket:`33419`).

View File

@ -2326,6 +2326,41 @@ Password: <input type="password" name="password" required>
<input type="hidden" name="next" value="/"></li>""" <input type="hidden" name="next" value="/"></li>"""
) )
def test_help_text_html_safe(self):
"""help_text should not be escaped."""
class UserRegistration(Form):
username = CharField(max_length=10, help_text='e.g., user@example.com')
password = CharField(
widget=PasswordInput,
help_text='Help text is <strong>escaped</strong>.',
)
p = UserRegistration(auto_id=False)
self.assertHTMLEqual(
p.as_ul(),
'<li>Username: <input type="text" name="username" maxlength="10" required>'
'<span class="helptext">e.g., user@example.com</span></li>'
'<li>Password: <input type="password" name="password" required>'
'<span class="helptext">Help text is <strong>escaped</strong>.</span></li>'
)
self.assertHTMLEqual(
p.as_p(),
'<p>Username: <input type="text" name="username" maxlength="10" required>'
'<span class="helptext">e.g., user@example.com</span></p>'
'<p>Password: <input type="password" name="password" required>'
'<span class="helptext">Help text is <strong>escaped</strong>.</span></p>'
)
self.assertHTMLEqual(
p.as_table(),
'<tr><th>Username:</th><td>'
'<input type="text" name="username" maxlength="10" required><br>'
'<span class="helptext">e.g., user@example.com</span></td></tr>'
'<tr><th>Password:</th><td>'
'<input type="password" name="password" required><br>'
'<span class="helptext">Help text is <strong>escaped</strong>.</span>'
'</td></tr>'
)
def test_subclassing_forms(self): def test_subclassing_forms(self):
# You can subclass a Form to add fields. The resulting form subclass will have # You can subclass a Form to add fields. The resulting form subclass will have
# all of the fields of the parent Form, plus whichever fields you define in the # all of the fields of the parent Form, plus whichever fields you define in the