Added tests for conditional_content_removal.
Refs #7581. Thanks mrmachine.
This commit is contained in:
parent
b4066d7d21
commit
5e629a015e
|
@ -0,0 +1,45 @@
|
|||
from __future__ import unicode_literals
|
||||
|
||||
from django.http import HttpRequest, HttpResponse, StreamingHttpResponse
|
||||
from django.http.utils import conditional_content_removal
|
||||
from django.test import TestCase
|
||||
|
||||
|
||||
class HttpUtilTests(TestCase):
|
||||
|
||||
def test_conditional_content_removal(self):
|
||||
"""
|
||||
Tests that content is removed from regular and streaming responses with
|
||||
a status_code of 100-199, 204, 304 or a method of "HEAD".
|
||||
"""
|
||||
req = HttpRequest()
|
||||
|
||||
# Do nothing for 200 responses.
|
||||
res = HttpResponse('abc')
|
||||
conditional_content_removal(req, res)
|
||||
self.assertEqual(res.content, b'abc')
|
||||
|
||||
res = StreamingHttpResponse(['abc'])
|
||||
conditional_content_removal(req, res)
|
||||
self.assertEqual(b''.join(res), b'abc')
|
||||
|
||||
# Strip content for some status codes.
|
||||
for status_code in (100, 150, 199, 204, 304):
|
||||
res = HttpResponse('abc', status=status_code)
|
||||
conditional_content_removal(req, res)
|
||||
self.assertEqual(res.content, b'')
|
||||
|
||||
res = StreamingHttpResponse(['abc'], status=status_code)
|
||||
conditional_content_removal(req, res)
|
||||
self.assertEqual(b''.join(res), b'')
|
||||
|
||||
# Strip content for HEAD requests.
|
||||
req.method = 'HEAD'
|
||||
|
||||
res = HttpResponse('abc')
|
||||
conditional_content_removal(req, res)
|
||||
self.assertEqual(res.content, b'')
|
||||
|
||||
res = StreamingHttpResponse(['abc'])
|
||||
conditional_content_removal(req, res)
|
||||
self.assertEqual(b''.join(res), b'')
|
Loading…
Reference in New Issue