summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_cgi.py
diff options
context:
space:
mode:
authorBenjamin Peterson <benjamin@python.org>2015-03-29 20:45:19 (GMT)
committerBenjamin Peterson <benjamin@python.org>2015-03-29 20:45:19 (GMT)
commit0deefd5a9402e3bd13ed899f9b939062faf98114 (patch)
tree7fda9ee820a42082dc399dcb8e2b9033323d6291 /Lib/test/test_cgi.py
parentf375b0a4d5a0362ca9b927e626a00c8328f3ac04 (diff)
parentd90f8d10e088657593fa753ecacab95845d378aa (diff)
downloadcpython-0deefd5a9402e3bd13ed899f9b939062faf98114.zip
cpython-0deefd5a9402e3bd13ed899f9b939062faf98114.tar.gz
cpython-0deefd5a9402e3bd13ed899f9b939062faf98114.tar.bz2
merge 3.4 (#23801)
Diffstat (limited to 'Lib/test/test_cgi.py')
-rw-r--r--Lib/test/test_cgi.py19
1 files changed, 19 insertions, 0 deletions
diff --git a/Lib/test/test_cgi.py b/Lib/test/test_cgi.py
index 715bd73..a7a9d02 100644
--- a/Lib/test/test_cgi.py
+++ b/Lib/test/test_cgi.py
@@ -248,6 +248,25 @@ class CgiTests(unittest.TestCase):
got = getattr(fs.list[x], k)
self.assertEqual(got, exp)
+ def test_fieldstorage_multipart_leading_whitespace(self):
+ env = {
+ 'REQUEST_METHOD': 'POST',
+ 'CONTENT_TYPE': 'multipart/form-data; boundary={}'.format(BOUNDARY),
+ 'CONTENT_LENGTH': '560'}
+ # Add some leading whitespace to our post data that will cause the
+ # first line to not be the innerboundary.
+ fp = BytesIO(b"\r\n" + POSTDATA.encode('latin-1'))
+ fs = cgi.FieldStorage(fp, environ=env, encoding="latin-1")
+ self.assertEqual(len(fs.list), 4)
+ expect = [{'name':'id', 'filename':None, 'value':'1234'},
+ {'name':'title', 'filename':None, 'value':''},
+ {'name':'file', 'filename':'test.txt', 'value':b'Testing 123.\n'},
+ {'name':'submit', 'filename':None, 'value':' Add '}]
+ for x in range(len(fs.list)):
+ for k, exp in expect[x].items():
+ got = getattr(fs.list[x], k)
+ self.assertEqual(got, exp)
+
def test_fieldstorage_multipart_non_ascii(self):
#Test basic FieldStorage multipart parsing
env = {'REQUEST_METHOD':'POST',