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 12:11:04 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
2012-06-07 18:08:47 +02:00
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
2010-11-04 04:47:05 +00:00
|
|
|
from django.template import Template, TemplateEncodingError, Context
|
|
|
|
from django.utils.safestring import SafeData
|
2012-07-20 14:48:51 +02:00
|
|
|
from django.utils import six
|
2010-11-04 04:47:05 +00:00
|
|
|
from django.utils.unittest import TestCase
|
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 12:11:04 +00:00
|
|
|
|
|
|
|
|
2010-11-04 04:47:05 +00:00
|
|
|
class UnicodeTests(TestCase):
|
|
|
|
def test_template(self):
|
|
|
|
# Templates can be created from unicode strings.
|
2012-06-07 18:08:47 +02:00
|
|
|
t1 = Template('ŠĐĆŽćžšđ {{ var }}')
|
2010-11-04 04:47:05 +00:00
|
|
|
# Templates can also be created from bytestrings. These are assumed to
|
|
|
|
# be encoded using UTF-8.
|
2012-05-19 17:43:34 +02:00
|
|
|
s = b'\xc5\xa0\xc4\x90\xc4\x86\xc5\xbd\xc4\x87\xc5\xbe\xc5\xa1\xc4\x91 {{ var }}'
|
2010-11-04 04:47:05 +00:00
|
|
|
t2 = Template(s)
|
2012-05-19 17:43:34 +02:00
|
|
|
s = b'\x80\xc5\xc0'
|
2010-11-04 04:47:05 +00:00
|
|
|
self.assertRaises(TemplateEncodingError, Template, s)
|
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 12:11:04 +00:00
|
|
|
|
2010-11-04 04:47:05 +00:00
|
|
|
# Contexts can be constructed from unicode or UTF-8 bytestrings.
|
2012-05-19 17:43:34 +02:00
|
|
|
c1 = Context({b"var": b"foo"})
|
2012-06-07 18:08:47 +02:00
|
|
|
c2 = Context({"var": b"foo"})
|
|
|
|
c3 = Context({b"var": "Đđ"})
|
|
|
|
c4 = 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 12:11:04 +00:00
|
|
|
|
2010-11-04 04:47:05 +00:00
|
|
|
# Since both templates and all four contexts represent the same thing,
|
|
|
|
# they all render the same (and are returned as unicode objects and
|
|
|
|
# "safe" objects as well, for auto-escaping purposes).
|
|
|
|
self.assertEqual(t1.render(c3), t2.render(c3))
|
2012-07-20 14:48:51 +02:00
|
|
|
self.assertIsInstance(t1.render(c3), six.text_type)
|
2010-11-04 04:47:05 +00:00
|
|
|
self.assertIsInstance(t1.render(c3), SafeData)
|