|
|
@ -138,27 +138,27 @@ class TestProxy(unittest.TestCase): |
|
|
|
self.proxy_thread.daemon = True |
|
|
|
self.proxy_thread.start() |
|
|
|
|
|
|
|
self.cn_proxy = compat_http_server.HTTPServer( |
|
|
|
('localhost', 0), _build_proxy_handler('cn')) |
|
|
|
self.cn_port = http_server_port(self.cn_proxy) |
|
|
|
self.cn_proxy_thread = threading.Thread(target=self.cn_proxy.serve_forever) |
|
|
|
self.cn_proxy_thread.daemon = True |
|
|
|
self.cn_proxy_thread.start() |
|
|
|
self.geo_proxy = compat_http_server.HTTPServer( |
|
|
|
('localhost', 0), _build_proxy_handler('geo')) |
|
|
|
self.geo_port = http_server_port(self.geo_proxy) |
|
|
|
self.geo_proxy_thread = threading.Thread(target=self.geo_proxy.serve_forever) |
|
|
|
self.geo_proxy_thread.daemon = True |
|
|
|
self.geo_proxy_thread.start() |
|
|
|
|
|
|
|
def test_proxy(self): |
|
|
|
cn_proxy = 'localhost:{0}'.format(self.cn_port) |
|
|
|
geo_proxy = 'localhost:{0}'.format(self.geo_port) |
|
|
|
ydl = YoutubeDL({ |
|
|
|
'proxy': 'localhost:{0}'.format(self.port), |
|
|
|
'cn_verification_proxy': cn_proxy, |
|
|
|
'geo_verification_proxy': geo_proxy, |
|
|
|
}) |
|
|
|
url = 'http://foo.com/bar' |
|
|
|
response = ydl.urlopen(url).read().decode('utf-8') |
|
|
|
self.assertEqual(response, 'normal: {0}'.format(url)) |
|
|
|
|
|
|
|
req = compat_urllib_request.Request(url) |
|
|
|
req.add_header('Ytdl-request-proxy', cn_proxy) |
|
|
|
req.add_header('Ytdl-request-proxy', geo_proxy) |
|
|
|
response = ydl.urlopen(req).read().decode('utf-8') |
|
|
|
self.assertEqual(response, 'cn: {0}'.format(url)) |
|
|
|
self.assertEqual(response, 'geo: {0}'.format(url)) |
|
|
|
|
|
|
|
def test_proxy_with_idn(self): |
|
|
|
ydl = YoutubeDL({ |
|
|
|