diff options
author | Victor Stinner <victor.stinner@gmail.com> | 2015-08-18 10:23:16 -0700 |
---|---|---|
committer | Victor Stinner <victor.stinner@gmail.com> | 2015-08-18 10:23:16 -0700 |
commit | 1e26dc7ef60c19f57e779bb1f7906e446d71d343 (patch) | |
tree | f7f6f670069666b157c4092153a138f7bf8e1ee6 /Lib/test/test_cgi.py | |
parent | 8e205f7b4f852d903db223d98b96721c4bc19644 (diff) | |
parent | 6579459d4b10b8eef47e5de609de4aa54999fb06 (diff) | |
download | cpython-git-1e26dc7ef60c19f57e779bb1f7906e446d71d343.tar.gz |
(Merge 3.4) cgi.FieldStorage.read_multi ignores Content-Length
Issue #24764: cgi.FieldStorage.read_multi() now ignores the Content-Length
header in part headers. Patch written by Peter Landry and reviewed by Pierre
Quentel.
Diffstat (limited to 'Lib/test/test_cgi.py')
-rw-r--r-- | Lib/test/test_cgi.py | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/Lib/test/test_cgi.py b/Lib/test/test_cgi.py index a7a9d02fa6..ab9f6ab6a5 100644 --- a/Lib/test/test_cgi.py +++ b/Lib/test/test_cgi.py @@ -326,6 +326,24 @@ Content-Type: text/plain got = getattr(files[x], k) self.assertEqual(got, exp) + def test_fieldstorage_part_content_length(self): + BOUNDARY = "JfISa01" + POSTDATA = """--JfISa01 +Content-Disposition: form-data; name="submit-name" +Content-Length: 5 + +Larry +--JfISa01""" + env = { + 'REQUEST_METHOD': 'POST', + 'CONTENT_TYPE': 'multipart/form-data; boundary={}'.format(BOUNDARY), + 'CONTENT_LENGTH': str(len(POSTDATA))} + fp = BytesIO(POSTDATA.encode('latin-1')) + fs = cgi.FieldStorage(fp, environ=env, encoding="latin-1") + self.assertEqual(len(fs.list), 1) + self.assertEqual(fs.list[0].name, 'submit-name') + self.assertEqual(fs.list[0].value, 'Larry') + def test_fieldstorage_as_context_manager(self): fp = BytesIO(b'x' * 10) env = {'REQUEST_METHOD': 'PUT'} |