mirror of
https://github.com/django/django.git
synced 2025-01-10 18:36:05 +00:00
aaacaeb096
Forwardport of ae1d663b79
from stable/1.8.x plus more.
121 lines
5.6 KiB
Python
121 lines
5.6 KiB
Python
from django.test import SimpleTestCase, ignore_warnings, override_settings
|
|
from django.test.utils import require_jinja2
|
|
from django.utils.deprecation import RemovedInDjango110Warning
|
|
|
|
|
|
@override_settings(
|
|
ROOT_URLCONF='shortcuts.urls',
|
|
)
|
|
class ShortcutTests(SimpleTestCase):
|
|
|
|
def test_render_to_response(self):
|
|
response = self.client.get('/render_to_response/')
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.content, b'FOO.BAR..\n')
|
|
self.assertEqual(response['Content-Type'], 'text/html; charset=utf-8')
|
|
|
|
def test_render_to_response_with_multiple_templates(self):
|
|
response = self.client.get('/render_to_response/multiple_templates/')
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.content, b'FOO.BAR..\n')
|
|
|
|
@ignore_warnings(category=RemovedInDjango110Warning)
|
|
def test_render_to_response_with_request_context(self):
|
|
response = self.client.get('/render_to_response/request_context/')
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.content, b'FOO.BAR../render_to_response/request_context/\n')
|
|
self.assertEqual(response['Content-Type'], 'text/html; charset=utf-8')
|
|
|
|
def test_render_to_response_with_content_type(self):
|
|
response = self.client.get('/render_to_response/content_type/')
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.content, b'FOO.BAR..\n')
|
|
self.assertEqual(response['Content-Type'], 'application/x-rendertest')
|
|
|
|
@ignore_warnings(category=RemovedInDjango110Warning)
|
|
def test_render_to_response_with_dirs(self):
|
|
response = self.client.get('/render_to_response/dirs/')
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.content, b'spam eggs\n')
|
|
self.assertEqual(response['Content-Type'], 'text/html; charset=utf-8')
|
|
|
|
def test_render_to_response_with_status(self):
|
|
response = self.client.get('/render_to_response/status/')
|
|
self.assertEqual(response.status_code, 403)
|
|
self.assertEqual(response.content, b'FOO.BAR..\n')
|
|
|
|
@require_jinja2
|
|
def test_render_to_response_with_using(self):
|
|
response = self.client.get('/render_to_response/using/')
|
|
self.assertEqual(response.content, b'DTL\n')
|
|
response = self.client.get('/render_to_response/using/?using=django')
|
|
self.assertEqual(response.content, b'DTL\n')
|
|
response = self.client.get('/render_to_response/using/?using=jinja2')
|
|
self.assertEqual(response.content, b'Jinja2\n')
|
|
|
|
@ignore_warnings(category=RemovedInDjango110Warning)
|
|
def test_render_to_response_with_context_instance_misuse(self):
|
|
"""
|
|
For backwards-compatibility, ensure that it's possible to pass a
|
|
RequestContext instance in the dictionary argument instead of the
|
|
context_instance argument.
|
|
"""
|
|
response = self.client.get('/render_to_response/context_instance_misuse/')
|
|
self.assertContains(response, 'context processor output')
|
|
|
|
def test_render(self):
|
|
response = self.client.get('/render/')
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.content, b'FOO.BAR../render/\n')
|
|
self.assertEqual(response['Content-Type'], 'text/html; charset=utf-8')
|
|
self.assertFalse(hasattr(response.context.request, 'current_app'))
|
|
|
|
def test_render_with_multiple_templates(self):
|
|
response = self.client.get('/render/multiple_templates/')
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.content, b'FOO.BAR../render/multiple_templates/\n')
|
|
|
|
@ignore_warnings(category=RemovedInDjango110Warning)
|
|
def test_render_with_base_context(self):
|
|
response = self.client.get('/render/base_context/')
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.content, b'FOO.BAR..\n')
|
|
self.assertEqual(response['Content-Type'], 'text/html; charset=utf-8')
|
|
|
|
def test_render_with_content_type(self):
|
|
response = self.client.get('/render/content_type/')
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.content, b'FOO.BAR../render/content_type/\n')
|
|
self.assertEqual(response['Content-Type'], 'application/x-rendertest')
|
|
|
|
def test_render_with_status(self):
|
|
response = self.client.get('/render/status/')
|
|
self.assertEqual(response.status_code, 403)
|
|
self.assertEqual(response.content, b'FOO.BAR../render/status/\n')
|
|
|
|
@require_jinja2
|
|
def test_render_with_using(self):
|
|
response = self.client.get('/render/using/')
|
|
self.assertEqual(response.content, b'DTL\n')
|
|
response = self.client.get('/render/using/?using=django')
|
|
self.assertEqual(response.content, b'DTL\n')
|
|
response = self.client.get('/render/using/?using=jinja2')
|
|
self.assertEqual(response.content, b'Jinja2\n')
|
|
|
|
@ignore_warnings(category=RemovedInDjango110Warning)
|
|
def test_render_with_current_app(self):
|
|
response = self.client.get('/render/current_app/')
|
|
self.assertEqual(response.context.request.current_app, "foobar_app")
|
|
|
|
@ignore_warnings(category=RemovedInDjango110Warning)
|
|
def test_render_with_dirs(self):
|
|
response = self.client.get('/render/dirs/')
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.content, b'spam eggs\n')
|
|
self.assertEqual(response['Content-Type'], 'text/html; charset=utf-8')
|
|
|
|
@ignore_warnings(category=RemovedInDjango110Warning)
|
|
def test_render_with_current_app_conflict(self):
|
|
with self.assertRaises(ValueError):
|
|
self.client.get('/render/current_app_conflict/')
|