test_dummy.py 3.7 KB

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