2015-06-15 15:55:55 +03:00
|
|
|
from django.conf.urls import url
|
|
|
|
from django.core.exceptions import PermissionDenied
|
|
|
|
from django.template.response import TemplateResponse
|
2016-06-23 16:30:07 +02:00
|
|
|
from django.test import SimpleTestCase, modify_settings, override_settings
|
|
|
|
|
|
|
|
|
2017-01-19 02:39:46 -05:00
|
|
|
class MiddlewareAccessingContent:
|
2016-06-23 16:30:07 +02:00
|
|
|
def __init__(self, get_response):
|
|
|
|
self.get_response = get_response
|
|
|
|
|
|
|
|
def __call__(self, request):
|
|
|
|
response = self.get_response(request)
|
|
|
|
# Response.content should be available in the middleware even with a
|
|
|
|
# TemplateResponse-based exception response.
|
|
|
|
assert response.content
|
|
|
|
return response
|
2015-06-15 15:55:55 +03:00
|
|
|
|
|
|
|
|
|
|
|
def template_response_error_handler(request, exception=None):
|
|
|
|
return TemplateResponse(request, 'test_handler.html', status=403)
|
|
|
|
|
|
|
|
|
|
|
|
def permission_denied_view(request):
|
|
|
|
raise PermissionDenied
|
|
|
|
|
|
|
|
|
|
|
|
urlpatterns = [
|
|
|
|
url(r'^$', permission_denied_view),
|
|
|
|
]
|
|
|
|
|
|
|
|
handler403 = template_response_error_handler
|
|
|
|
|
|
|
|
|
|
|
|
@override_settings(ROOT_URLCONF='handlers.tests_custom_error_handlers')
|
2016-06-23 16:30:07 +02:00
|
|
|
@modify_settings(MIDDLEWARE={'append': 'handlers.tests_custom_error_handlers.MiddlewareAccessingContent'})
|
2015-06-15 15:55:55 +03:00
|
|
|
class CustomErrorHandlerTests(SimpleTestCase):
|
|
|
|
|
|
|
|
def test_handler_renders_template_response(self):
|
|
|
|
"""
|
|
|
|
BaseHandler should render TemplateResponse if necessary.
|
|
|
|
"""
|
|
|
|
response = self.client.get('/')
|
|
|
|
self.assertContains(response, 'Error handler content', status_code=403)
|