Fixed #34578 -- Made "join" template filter respect autoescape for joiner.

This commit is contained in:
rajeeshp 2023-05-19 14:41:36 +05:30 committed by Mariusz Felisiak
parent fce90950be
commit a2da81fe08
2 changed files with 20 additions and 3 deletions

View File

@ -586,8 +586,9 @@ def join(value, arg, autoescape=True):
"""Join a list with a string, like Python's ``str.join(list)``.""" """Join a list with a string, like Python's ``str.join(list)``."""
try: try:
if autoescape: if autoescape:
value = [conditional_escape(v) for v in value] data = conditional_escape(arg).join([conditional_escape(v) for v in value])
data = conditional_escape(arg).join(value) else:
data = arg.join(value)
except TypeError: # Fail silently if arg isn't iterable. except TypeError: # Fail silently if arg isn't iterable.
return value return value
return mark_safe(data) return mark_safe(data)

View File

@ -55,6 +55,22 @@ class JoinTests(SimpleTestCase):
) )
self.assertEqual(output, "alpha & beta & me") self.assertEqual(output, "alpha & beta & me")
@setup(
{
"join_autoescape_off": (
"{% autoescape off %}"
"{{ var_list|join:var_joiner }}"
"{% endautoescape %}"
),
}
)
def test_join_autoescape_off(self):
var_list = ["<p>Hello World!</p>", "beta & me", "<script>Hi!</script>"]
context = {"var_list": var_list, "var_joiner": "<br/>"}
output = self.engine.render_to_string("join_autoescape_off", context)
expected_result = "<p>Hello World!</p><br/>beta & me<br/><script>Hi!</script>"
self.assertEqual(output, expected_result)
class FunctionTests(SimpleTestCase): class FunctionTests(SimpleTestCase):
def test_list(self): def test_list(self):
@ -69,7 +85,7 @@ class FunctionTests(SimpleTestCase):
def test_autoescape_off(self): def test_autoescape_off(self):
self.assertEqual( self.assertEqual(
join(["<a>", "<img>", "</a>"], "<br>", autoescape=False), join(["<a>", "<img>", "</a>"], "<br>", autoescape=False),
"<a>&lt;br&gt;<img>&lt;br&gt;</a>", "<a><br><img><br></a>",
) )
def test_noniterable_arg(self): def test_noniterable_arg(self):