summaryrefslogtreecommitdiff
path: root/paste/fixture.py
diff options
context:
space:
mode:
authorBenjamin Peterson <benjamin@python.org>2019-08-25 05:05:18 -0700
committerChris Dent <cdent@anticdent.org>2019-08-25 13:05:18 +0100
commit249c49d6cc7c28ffd2bfef92b2402f746d24ca8b (patch)
treed2acf2ec48732f8ab78cc8ea751dfb8c50d42806 /paste/fixture.py
parent13fe3fadc740067342e1ac04c8685a97da6781d9 (diff)
downloadpaste-git-249c49d6cc7c28ffd2bfef92b2402f746d24ca8b.tar.gz
Modify TestApp.encode_multipart to handle bytes filenames and params. (#29)3.1.1
As the test shows, this fixes passing boths params and upload_files on Python 3.
Diffstat (limited to 'paste/fixture.py')
-rw-r--r--paste/fixture.py22
1 files changed, 7 insertions, 15 deletions
diff --git a/paste/fixture.py b/paste/fixture.py
index 9b2a0c4..969863c 100644
--- a/paste/fixture.py
+++ b/paste/fixture.py
@@ -330,28 +330,20 @@ class TestApp(object):
lines = []
for key, value in params:
lines.append(b'--'+boundary)
- line = 'Content-Disposition: form-data; name="%s"' % key
- if six.PY3:
- line = line.encode('utf8')
+ line = b'Content-Disposition: form-data; name="%s"' % six.ensure_binary(key)
lines.append(line)
lines.append(b'')
- line = value
- if six.PY3 and isinstance(line, six.text_type):
- line = line.encode('utf8')
+ line = six.ensure_binary(value)
lines.append(line)
for file_info in files:
key, filename, value = self._get_file_info(file_info)
lines.append(b'--'+boundary)
- line = ('Content-Disposition: form-data; name="%s"; filename="%s"'
- % (key, filename))
- if six.PY3:
- line = line.encode('utf8')
+ line = (b'Content-Disposition: form-data; name="%s"; filename="%s"'
+ % (six.ensure_binary(key), six.ensure_binary(filename)))
lines.append(line)
- fcontent = mimetypes.guess_type(filename)[0]
- line = ('Content-Type: %s'
- % (fcontent or 'application/octet-stream'))
- if six.PY3:
- line = line.encode('utf8')
+ fcontent = mimetypes.guess_type(six.ensure_str(filename, 'ascii', 'ignore'))[0]
+ line = (b'Content-Type: %s'
+ % (fcontent.encode('ascii') if fcontent else b'application/octet-stream'))
lines.append(line)
lines.append(b'')
lines.append(value)