summaryrefslogtreecommitdiff
path: root/tests/utils_tests/test_safestring.py
diff options
context:
space:
mode:
authorBaptiste Mispelon <bmispelon@gmail.com>2013-04-20 13:38:14 +0200
committerClaude Paroz <claude@2xlibre.net>2013-05-25 16:06:44 +0200
commit2ee447fb5f8974b432d3dd421af9a242215aea44 (patch)
tree2bc2e50185bf04376f0a5685e2d66fb66786db82 /tests/utils_tests/test_safestring.py
parentbe0bab1bb8da80402248cd1fa22fd4cc09b34fe7 (diff)
Fixed #20296 -- Allowed SafeData and EscapeData to be lazy
Diffstat (limited to 'tests/utils_tests/test_safestring.py')
-rw-r--r--tests/utils_tests/test_safestring.py53
1 files changed, 53 insertions, 0 deletions
diff --git a/tests/utils_tests/test_safestring.py b/tests/utils_tests/test_safestring.py
new file mode 100644
index 0000000000..a6f0c0a01c
--- /dev/null
+++ b/tests/utils_tests/test_safestring.py
@@ -0,0 +1,53 @@
+from __future__ import absolute_import, unicode_literals
+
+
+from django.template import Template, Context
+from django.test import TestCase
+from django.utils.encoding import force_text, force_bytes
+from django.utils.functional import lazy, Promise
+from django.utils.html import escape, conditional_escape
+from django.utils.safestring import mark_safe, mark_for_escaping
+from django.utils import six
+from django.utils import translation
+
+lazystr = lazy(force_text, six.text_type)
+lazybytes = lazy(force_bytes, bytes)
+
+
+class SafeStringTest(TestCase):
+ def assertRenderEqual(self, tpl, expected, **context):
+ context = Context(context)
+ tpl = Template(tpl)
+ self.assertEqual(tpl.render(context), expected)
+
+ def test_mark_safe(self):
+ s = mark_safe('a&b')
+
+ self.assertRenderEqual('{{ s }}', 'a&b', s=s)
+ self.assertRenderEqual('{{ s|force_escape }}', 'a&amp;b', s=s)
+
+ def test_mark_safe_lazy(self):
+ s = lazystr('a&b')
+ b = lazybytes(b'a&b')
+
+ self.assertIsInstance(mark_safe(s), Promise)
+ self.assertIsInstance(mark_safe(b), Promise)
+ self.assertRenderEqual('{{ s }}', 'a&b', s=mark_safe(s))
+
+ def test_mark_for_escaping(self):
+ s = mark_for_escaping('a&b')
+ self.assertRenderEqual('{{ s }}', 'a&amp;b', s=s)
+ self.assertRenderEqual('{{ s }}', 'a&amp;b', s=mark_for_escaping(s))
+
+ def test_mark_for_escaping_lazy(self):
+ s = lazystr('a&b')
+ b = lazybytes(b'a&b')
+
+ self.assertIsInstance(mark_for_escaping(s), Promise)
+ self.assertIsInstance(mark_for_escaping(b), Promise)
+ self.assertRenderEqual('{% autoescape off %}{{ s }}{% endautoescape %}', 'a&amp;b', s=mark_for_escaping(s))
+
+ def test_regression_20296(self):
+ s = mark_safe(translation.ugettext_lazy("username"))
+ with translation.override('fr'):
+ self.assertRenderEqual('{{ s }}', "nom d'utilisateur", s=s)