gst-libav1: update to 1.24.11
[oi-userland.git] / components / python / python39 / patches / 27-cgiserver.patch
blobca85e377a20f67cf5d29d6488879352945b72437
1 Fixes Python CGI being confused about binary files (bugs 31546357 & 31936635).
3 Upstream issue:
4 https://bugs.python.org/issue27777
6 WIP patch taken from upstream is still buggy, so we use
7 this in-house developed one.
9 --- Python-3.9.2/Lib/cgi.py
10 +++ Python-3.9.2/Lib/cgi.py
11 @@ -694,7 +694,10 @@ class FieldStorage:
12 if not data:
13 self.done = -1
14 break
15 - self.file.write(data)
16 + if self._binary_file:
17 + self.file.write(data)
18 + else:
19 + self.file.write(data.decode())
20 todo = todo - len(data)
22 def read_lines(self):
23 --- Python-3.9.2/Lib/test/test_cgi.py
24 +++ Python-3.9.2/Lib/test/test_cgi.py
25 @@ -385,6 +385,18 @@ Larry
26 self.assertEqual(fs.list[0].name, 'submit-name')
27 self.assertEqual(fs.list[0].value, 'Larry')
29 + def test_content_length_no_content_disposition(self):
30 + body = b'{"test":123}'
31 + env = {
32 + 'CONTENT_LENGTH': len(body),
33 + 'REQUEST_METHOD': 'POST',
34 + 'CONTENT_TYPE': 'application/json',
35 + 'wsgi.input': BytesIO(body),
36 + }
38 + form = cgi.FieldStorage(fp=env['wsgi.input'], environ=env)
39 + self.assertEqual(form.file.read(), body.decode(form.encoding))
41 def test_field_storage_multipart_no_content_length(self):
42 fp = BytesIO(b"""--MyBoundary
43 Content-Disposition: form-data; name="my-arg"; filename="foo"