mirror of
				https://github.com/django/django.git
				synced 2025-10-22 21:29:11 +00:00 
			
		
		
		
	Used FakePayload in requests tests
This commit is contained in:
		
							parent
							
								
									c2e19e26bc
								
							
						
					
					
						commit
						cfb3eb2e3d
					
				| @ -9,6 +9,7 @@ from django.conf import settings | |||||||
| from django.core.exceptions import SuspiciousOperation | from django.core.exceptions import SuspiciousOperation | ||||||
| from django.core.handlers.wsgi import WSGIRequest, LimitedStream | from django.core.handlers.wsgi import WSGIRequest, LimitedStream | ||||||
| from django.http import HttpRequest, HttpResponse, parse_cookie, build_request_repr, UnreadablePostError | from django.http import HttpRequest, HttpResponse, parse_cookie, build_request_repr, UnreadablePostError | ||||||
|  | from django.test.client import FakePayload | ||||||
| from django.test.utils import str_prefix | from django.test.utils import str_prefix | ||||||
| from django.utils import unittest | from django.utils import unittest | ||||||
| from django.utils.http import cookie_date | from django.utils.http import cookie_date | ||||||
| @ -328,11 +329,11 @@ class RequestsTests(unittest.TestCase): | |||||||
|         self.assertEqual(stream.read(), b'') |         self.assertEqual(stream.read(), b'') | ||||||
| 
 | 
 | ||||||
|     def test_stream(self): |     def test_stream(self): | ||||||
|         payload = b'name=value' |         payload = FakePayload('name=value') | ||||||
|         request = WSGIRequest({'REQUEST_METHOD': 'POST', |         request = WSGIRequest({'REQUEST_METHOD': 'POST', | ||||||
|                                'CONTENT_TYPE': 'application/x-www-form-urlencoded', |                                'CONTENT_TYPE': 'application/x-www-form-urlencoded', | ||||||
|                                'CONTENT_LENGTH': len(payload), |                                'CONTENT_LENGTH': len(payload), | ||||||
|                                'wsgi.input': BytesIO(payload)}) |                                'wsgi.input': payload}) | ||||||
|         self.assertEqual(request.read(), b'name=value') |         self.assertEqual(request.read(), b'name=value') | ||||||
| 
 | 
 | ||||||
|     def test_read_after_value(self): |     def test_read_after_value(self): | ||||||
| @ -340,11 +341,11 @@ class RequestsTests(unittest.TestCase): | |||||||
|         Reading from request is allowed after accessing request contents as |         Reading from request is allowed after accessing request contents as | ||||||
|         POST or body. |         POST or body. | ||||||
|         """ |         """ | ||||||
|         payload = b'name=value' |         payload = FakePayload('name=value') | ||||||
|         request = WSGIRequest({'REQUEST_METHOD': 'POST', |         request = WSGIRequest({'REQUEST_METHOD': 'POST', | ||||||
|                                'CONTENT_TYPE': 'application/x-www-form-urlencoded', |                                'CONTENT_TYPE': 'application/x-www-form-urlencoded', | ||||||
|                                'CONTENT_LENGTH': len(payload), |                                'CONTENT_LENGTH': len(payload), | ||||||
|                                'wsgi.input': BytesIO(payload)}) |                                'wsgi.input': payload}) | ||||||
|         self.assertEqual(request.POST, {'name': ['value']}) |         self.assertEqual(request.POST, {'name': ['value']}) | ||||||
|         self.assertEqual(request.body, b'name=value') |         self.assertEqual(request.body, b'name=value') | ||||||
|         self.assertEqual(request.read(), b'name=value') |         self.assertEqual(request.read(), b'name=value') | ||||||
| @ -354,11 +355,11 @@ class RequestsTests(unittest.TestCase): | |||||||
|         Construction of POST or body is not allowed after reading |         Construction of POST or body is not allowed after reading | ||||||
|         from request. |         from request. | ||||||
|         """ |         """ | ||||||
|         payload = b'name=value' |         payload = FakePayload('name=value') | ||||||
|         request = WSGIRequest({'REQUEST_METHOD': 'POST', |         request = WSGIRequest({'REQUEST_METHOD': 'POST', | ||||||
|                                'CONTENT_TYPE': 'application/x-www-form-urlencoded', |                                'CONTENT_TYPE': 'application/x-www-form-urlencoded', | ||||||
|                                'CONTENT_LENGTH': len(payload), |                                'CONTENT_LENGTH': len(payload), | ||||||
|                                'wsgi.input': BytesIO(payload)}) |                                'wsgi.input': payload}) | ||||||
|         self.assertEqual(request.read(2), b'na') |         self.assertEqual(request.read(2), b'na') | ||||||
|         self.assertRaises(Exception, lambda: request.body) |         self.assertRaises(Exception, lambda: request.body) | ||||||
|         self.assertEqual(request.POST, {}) |         self.assertEqual(request.POST, {}) | ||||||
| @ -370,17 +371,17 @@ class RequestsTests(unittest.TestCase): | |||||||
|         # Because multipart is used for large amounts fo data i.e. file uploads, |         # Because multipart is used for large amounts fo data i.e. file uploads, | ||||||
|         # we don't want the data held in memory twice, and we don't want to |         # we don't want the data held in memory twice, and we don't want to | ||||||
|         # silence the error by setting body = '' either. |         # silence the error by setting body = '' either. | ||||||
|         payload = "\r\n".join([ |         payload = FakePayload("\r\n".join([ | ||||||
|                 '--boundary', |                 '--boundary', | ||||||
|                 'Content-Disposition: form-data; name="name"', |                 'Content-Disposition: form-data; name="name"', | ||||||
|                 '', |                 '', | ||||||
|                 'value', |                 'value', | ||||||
|                 '--boundary--' |                 '--boundary--' | ||||||
|                 '']).encode('utf-8') |                 ''])) | ||||||
|         request = WSGIRequest({'REQUEST_METHOD': 'POST', |         request = WSGIRequest({'REQUEST_METHOD': 'POST', | ||||||
|                                'CONTENT_TYPE': 'multipart/form-data; boundary=boundary', |                                'CONTENT_TYPE': 'multipart/form-data; boundary=boundary', | ||||||
|                                'CONTENT_LENGTH': len(payload), |                                'CONTENT_LENGTH': len(payload), | ||||||
|                                'wsgi.input': BytesIO(payload)}) |                                'wsgi.input': payload}) | ||||||
|         self.assertEqual(request.POST, {'name': ['value']}) |         self.assertEqual(request.POST, {'name': ['value']}) | ||||||
|         self.assertRaises(Exception, lambda: request.body) |         self.assertRaises(Exception, lambda: request.body) | ||||||
| 
 | 
 | ||||||
| @ -392,17 +393,17 @@ class RequestsTests(unittest.TestCase): | |||||||
|         # http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.13 |         # http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.13 | ||||||
|         # Every request.POST with Content-Length >= 0 is a valid request, |         # Every request.POST with Content-Length >= 0 is a valid request, | ||||||
|         # this test ensures that we handle Content-Length == 0. |         # this test ensures that we handle Content-Length == 0. | ||||||
|         payload = "\r\n".join([ |         payload = FakePayload("\r\n".join([ | ||||||
|                 '--boundary', |                 '--boundary', | ||||||
|                 'Content-Disposition: form-data; name="name"', |                 'Content-Disposition: form-data; name="name"', | ||||||
|                 '', |                 '', | ||||||
|                 'value', |                 'value', | ||||||
|                 '--boundary--' |                 '--boundary--' | ||||||
|                 '']).encode('utf-8') |                 ''])) | ||||||
|         request = WSGIRequest({'REQUEST_METHOD': 'POST', |         request = WSGIRequest({'REQUEST_METHOD': 'POST', | ||||||
|                                'CONTENT_TYPE': 'multipart/form-data; boundary=boundary', |                                'CONTENT_TYPE': 'multipart/form-data; boundary=boundary', | ||||||
|                                'CONTENT_LENGTH': 0, |                                'CONTENT_LENGTH': 0, | ||||||
|                                'wsgi.input': BytesIO(payload)}) |                                'wsgi.input': payload}) | ||||||
|         self.assertEqual(request.POST, {}) |         self.assertEqual(request.POST, {}) | ||||||
| 
 | 
 | ||||||
|     def test_POST_binary_only(self): |     def test_POST_binary_only(self): | ||||||
| @ -424,22 +425,22 @@ class RequestsTests(unittest.TestCase): | |||||||
|         self.assertEqual(request.body, payload) |         self.assertEqual(request.body, payload) | ||||||
| 
 | 
 | ||||||
|     def test_read_by_lines(self): |     def test_read_by_lines(self): | ||||||
|         payload = b'name=value' |         payload = FakePayload('name=value') | ||||||
|         request = WSGIRequest({'REQUEST_METHOD': 'POST', |         request = WSGIRequest({'REQUEST_METHOD': 'POST', | ||||||
|                                'CONTENT_TYPE': 'application/x-www-form-urlencoded', |                                'CONTENT_TYPE': 'application/x-www-form-urlencoded', | ||||||
|                                'CONTENT_LENGTH': len(payload), |                                'CONTENT_LENGTH': len(payload), | ||||||
|                                'wsgi.input': BytesIO(payload)}) |                                'wsgi.input': payload}) | ||||||
|         self.assertEqual(list(request), [b'name=value']) |         self.assertEqual(list(request), [b'name=value']) | ||||||
| 
 | 
 | ||||||
|     def test_POST_after_body_read(self): |     def test_POST_after_body_read(self): | ||||||
|         """ |         """ | ||||||
|         POST should be populated even if body is read first |         POST should be populated even if body is read first | ||||||
|         """ |         """ | ||||||
|         payload = b'name=value' |         payload = FakePayload('name=value') | ||||||
|         request = WSGIRequest({'REQUEST_METHOD': 'POST', |         request = WSGIRequest({'REQUEST_METHOD': 'POST', | ||||||
|                                'CONTENT_TYPE': 'application/x-www-form-urlencoded', |                                'CONTENT_TYPE': 'application/x-www-form-urlencoded', | ||||||
|                                'CONTENT_LENGTH': len(payload), |                                'CONTENT_LENGTH': len(payload), | ||||||
|                                'wsgi.input': BytesIO(payload)}) |                                'wsgi.input': payload}) | ||||||
|         raw_data = request.body |         raw_data = request.body | ||||||
|         self.assertEqual(request.POST, {'name': ['value']}) |         self.assertEqual(request.POST, {'name': ['value']}) | ||||||
| 
 | 
 | ||||||
| @ -448,11 +449,11 @@ class RequestsTests(unittest.TestCase): | |||||||
|         POST should be populated even if body is read first, and then |         POST should be populated even if body is read first, and then | ||||||
|         the stream is read second. |         the stream is read second. | ||||||
|         """ |         """ | ||||||
|         payload = b'name=value' |         payload = FakePayload('name=value') | ||||||
|         request = WSGIRequest({'REQUEST_METHOD': 'POST', |         request = WSGIRequest({'REQUEST_METHOD': 'POST', | ||||||
|                                'CONTENT_TYPE': 'application/x-www-form-urlencoded', |                                'CONTENT_TYPE': 'application/x-www-form-urlencoded', | ||||||
|                                'CONTENT_LENGTH': len(payload), |                                'CONTENT_LENGTH': len(payload), | ||||||
|                                'wsgi.input': BytesIO(payload)}) |                                'wsgi.input': payload}) | ||||||
|         raw_data = request.body |         raw_data = request.body | ||||||
|         self.assertEqual(request.read(1), b'n') |         self.assertEqual(request.read(1), b'n') | ||||||
|         self.assertEqual(request.POST, {'name': ['value']}) |         self.assertEqual(request.POST, {'name': ['value']}) | ||||||
| @ -462,17 +463,17 @@ class RequestsTests(unittest.TestCase): | |||||||
|         POST should be populated even if body is read first, and then |         POST should be populated even if body is read first, and then | ||||||
|         the stream is read second. Using multipart/form-data instead of urlencoded. |         the stream is read second. Using multipart/form-data instead of urlencoded. | ||||||
|         """ |         """ | ||||||
|         payload = "\r\n".join([ |         payload = FakePayload("\r\n".join([ | ||||||
|                 '--boundary', |                 '--boundary', | ||||||
|                 'Content-Disposition: form-data; name="name"', |                 'Content-Disposition: form-data; name="name"', | ||||||
|                 '', |                 '', | ||||||
|                 'value', |                 'value', | ||||||
|                 '--boundary--' |                 '--boundary--' | ||||||
|                 '']).encode('utf-8') |                 ''])) | ||||||
|         request = WSGIRequest({'REQUEST_METHOD': 'POST', |         request = WSGIRequest({'REQUEST_METHOD': 'POST', | ||||||
|                                'CONTENT_TYPE': 'multipart/form-data; boundary=boundary', |                                'CONTENT_TYPE': 'multipart/form-data; boundary=boundary', | ||||||
|                                'CONTENT_LENGTH': len(payload), |                                'CONTENT_LENGTH': len(payload), | ||||||
|                                'wsgi.input': BytesIO(payload)}) |                                'wsgi.input': payload}) | ||||||
|         raw_data = request.body |         raw_data = request.body | ||||||
|         # Consume enough data to mess up the parsing: |         # Consume enough data to mess up the parsing: | ||||||
|         self.assertEqual(request.read(13), b'--boundary\r\nC') |         self.assertEqual(request.read(13), b'--boundary\r\nC') | ||||||
| @ -482,11 +483,11 @@ class RequestsTests(unittest.TestCase): | |||||||
|         """ |         """ | ||||||
|         HttpRequest.raw_post_body should be the same as HttpRequest.body |         HttpRequest.raw_post_body should be the same as HttpRequest.body | ||||||
|         """ |         """ | ||||||
|         payload = b'Hello There!' |         payload = FakePayload('Hello There!') | ||||||
|         request = WSGIRequest({ |         request = WSGIRequest({ | ||||||
|             'REQUEST_METHOD': 'POST', |             'REQUEST_METHOD': 'POST', | ||||||
|             'CONTENT_LENGTH': len(payload), |             'CONTENT_LENGTH': len(payload), | ||||||
|             'wsgi.input': BytesIO(payload) |             'wsgi.input': payload, | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         with warnings.catch_warnings(record=True): |         with warnings.catch_warnings(record=True): | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user