test_dummy.py 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. # coding: utf-8
  2. from __future__ import unicode_literals
  3. from django.forms import CharField, Form, Media
  4. from django.http import HttpRequest
  5. from django.middleware.csrf import CsrfViewMiddleware, get_token
  6. from django.template import TemplateDoesNotExist, TemplateSyntaxError
  7. from django.template.backends.dummy import TemplateStrings
  8. from django.test import SimpleTestCase
  9. class TemplateStringsTests(SimpleTestCase):
  10. engine_class = TemplateStrings
  11. backend_name = 'dummy'
  12. options = {}
  13. @classmethod
  14. def setUpClass(cls):
  15. params = {
  16. 'DIRS': [],
  17. 'APP_DIRS': True,
  18. 'NAME': cls.backend_name,
  19. 'OPTIONS': cls.options,
  20. }
  21. cls.engine = cls.engine_class(params)
  22. def test_from_string(self):
  23. template = self.engine.from_string("Hello!\n")
  24. content = template.render()
  25. self.assertEqual(content, "Hello!\n")
  26. def test_get_template(self):
  27. template = self.engine.get_template('template_backends/hello.html')
  28. content = template.render({'name': 'world'})
  29. self.assertEqual(content, "Hello world!\n")
  30. def test_get_template_non_existing(self):
  31. with self.assertRaises(TemplateDoesNotExist) as e:
  32. self.engine.get_template('template_backends/non_existing.html')
  33. self.assertEqual(e.exception.backend, self.engine)
  34. def test_get_template_syntax_error(self):
  35. # There's no way to trigger a syntax error with the dummy backend.
  36. # The test still lives here to factor it between other backends.
  37. if self.backend_name == 'dummy':
  38. self.skipTest("test doesn't apply to dummy backend")
  39. with self.assertRaises(TemplateSyntaxError):
  40. self.engine.get_template('template_backends/syntax_error.html')
  41. def test_html_escaping(self):
  42. template = self.engine.get_template('template_backends/hello.html')
  43. context = {'name': '<script>alert("XSS!");</script>'}
  44. content = template.render(context)
  45. self.assertIn('&lt;script&gt;', content)
  46. self.assertNotIn('<script>', content)
  47. def test_django_html_escaping(self):
  48. if self.backend_name == 'dummy':
  49. self.skipTest("test doesn't apply to dummy backend")
  50. class TestForm(Form):
  51. test_field = CharField()
  52. media = Media(js=['my-script.js'])
  53. form = TestForm()
  54. template = self.engine.get_template('template_backends/django_escaping.html')
  55. content = template.render({'media': media, 'test_form': form})
  56. expected = '{}\n\n{}\n\n{}'.format(media, form, form['test_field'])
  57. self.assertHTMLEqual(content, expected)
  58. def test_csrf_token(self):
  59. request = HttpRequest()
  60. CsrfViewMiddleware().process_view(request, lambda r: None, (), {})
  61. template = self.engine.get_template('template_backends/csrf.html')
  62. content = template.render(request=request)
  63. expected = (
  64. '<input type="hidden" name="csrfmiddlewaretoken" '
  65. 'value="{}" />'.format(get_token(request)))
  66. self.assertHTMLEqual(content, expected)
  67. def test_no_directory_traversal(self):
  68. with self.assertRaises(TemplateDoesNotExist):
  69. self.engine.get_template('../forbidden/template_backends/hello.html')
  70. def test_non_ascii_characters(self):
  71. template = self.engine.get_template('template_backends/hello.html')
  72. content = template.render({'name': 'Jérôme'})
  73. self.assertEqual(content, "Hello Jérôme!\n")