summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_httplib.py
diff options
context:
space:
mode:
authorAshwin Ramaswami <aramaswamis@gmail.com>2020-03-14 18:56:06 (GMT)
committerGitHub <noreply@github.com>2020-03-14 18:56:06 (GMT)
commit9165addc22d05e776a54319a8531ebd0b2fe01ef (patch)
tree288869da768bf6c9c5c930bf50e58a36114b04e6 /Lib/test/test_httplib.py
parent6672c16b1d7f83789bf3a2016bd19edfd3568e71 (diff)
downloadcpython-9165addc22d05e776a54319a8531ebd0b2fe01ef.zip
cpython-9165addc22d05e776a54319a8531ebd0b2fe01ef.tar.gz
cpython-9165addc22d05e776a54319a8531ebd0b2fe01ef.tar.bz2
bpo-38576: Disallow control characters in hostnames in http.client (GH-18995)
Add host validation for control characters for more CVE-2019-18348 protection.
Diffstat (limited to 'Lib/test/test_httplib.py')
-rw-r--r--Lib/test/test_httplib.py13
1 files changed, 12 insertions, 1 deletions
diff --git a/Lib/test/test_httplib.py b/Lib/test/test_httplib.py
index 95eca7e..7f4decc 100644
--- a/Lib/test/test_httplib.py
+++ b/Lib/test/test_httplib.py
@@ -1155,7 +1155,7 @@ class BasicTest(TestCase):
thread.join()
self.assertEqual(result, b"proxied data\n")
- def test_putrequest_override_validation(self):
+ def test_putrequest_override_domain_validation(self):
"""
It should be possible to override the default validation
behavior in putrequest (bpo-38216).
@@ -1168,6 +1168,17 @@ class BasicTest(TestCase):
conn.sock = FakeSocket('')
conn.putrequest('GET', '/\x00')
+ def test_putrequest_override_host_validation(self):
+ class UnsafeHTTPConnection(client.HTTPConnection):
+ def _validate_host(self, url):
+ pass
+
+ conn = UnsafeHTTPConnection('example.com\r\n')
+ conn.sock = FakeSocket('')
+ # set skip_host so a ValueError is not raised upon adding the
+ # invalid URL as the value of the "Host:" header
+ conn.putrequest('GET', '/', skip_host=1)
+
def test_putrequest_override_encoding(self):
"""
It should be possible to override the default encoding