2013-07-01 20:22:27 +08:00
|
|
|
from unittest import TestCase
|
|
|
|
|
2015-04-12 07:41:45 +08:00
|
|
|
from django.template import Context, Engine
|
2014-11-11 04:40:26 +08:00
|
|
|
from django.template.base import TemplateEncodingError
|
2015-01-28 20:35:27 +08:00
|
|
|
from django.utils.safestring import SafeData
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
|
|
|
|
|
2010-11-04 12:47:05 +08:00
|
|
|
class UnicodeTests(TestCase):
|
|
|
|
def test_template(self):
|
2017-01-21 05:04:05 +08:00
|
|
|
# Templates can be created from strings.
|
2015-04-12 07:41:45 +08:00
|
|
|
engine = Engine()
|
|
|
|
t1 = engine.from_string('ŠĐĆŽćžšđ {{ var }}')
|
2010-11-04 12:47:05 +08:00
|
|
|
# Templates can also be created from bytestrings. These are assumed to
|
|
|
|
# be encoded using UTF-8.
|
2012-05-19 23:43:34 +08:00
|
|
|
s = b'\xc5\xa0\xc4\x90\xc4\x86\xc5\xbd\xc4\x87\xc5\xbe\xc5\xa1\xc4\x91 {{ var }}'
|
2015-04-12 07:41:45 +08:00
|
|
|
t2 = engine.from_string(s)
|
|
|
|
with self.assertRaises(TemplateEncodingError):
|
|
|
|
engine.from_string(b'\x80\xc5\xc0')
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
|
2017-01-21 05:04:05 +08:00
|
|
|
# Contexts can be constructed from strings or UTF-8 bytestrings.
|
2013-10-19 20:31:38 +08:00
|
|
|
Context({b"var": b"foo"})
|
|
|
|
Context({"var": b"foo"})
|
2012-06-08 00:08:47 +08:00
|
|
|
c3 = Context({b"var": "Đđ"})
|
2013-10-19 20:31:38 +08:00
|
|
|
Context({"var": b"\xc4\x90\xc4\x91"})
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
|
2010-11-04 12:47:05 +08:00
|
|
|
# Since both templates and all four contexts represent the same thing,
|
2017-01-21 05:04:05 +08:00
|
|
|
# they all render the same (and are returned as strings and
|
2010-11-04 12:47:05 +08:00
|
|
|
# "safe" objects as well, for auto-escaping purposes).
|
|
|
|
self.assertEqual(t1.render(c3), t2.render(c3))
|
2016-12-29 23:27:49 +08:00
|
|
|
self.assertIsInstance(t1.render(c3), str)
|
2010-11-04 12:47:05 +08:00
|
|
|
self.assertIsInstance(t1.render(c3), SafeData)
|