|
|
|
@ -8,11 +8,20 @@ import sys
|
|
|
|
|
import unittest
|
|
|
|
|
sys.path.insert(0, os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
|
|
|
|
|
|
|
|
|
|
from test.helper import (FakeYDL, get_params)
|
|
|
|
|
from youtube_dl.compat import compat_urllib_request
|
|
|
|
|
import random
|
|
|
|
|
import subprocess
|
|
|
|
|
|
|
|
|
|
from test.helper import (
|
|
|
|
|
FakeYDL,
|
|
|
|
|
get_params,
|
|
|
|
|
)
|
|
|
|
|
from youtube_dl.compat import (
|
|
|
|
|
compat_str,
|
|
|
|
|
compat_urllib_request,
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
class TestSocks(unittest.TestCase):
|
|
|
|
|
|
|
|
|
|
class TestMultipleSocks(unittest.TestCase):
|
|
|
|
|
@staticmethod
|
|
|
|
|
def _check_params(attrs):
|
|
|
|
|
params = get_params()
|
|
|
|
@ -67,5 +76,32 @@ class TestSocks(unittest.TestCase):
|
|
|
|
|
params['secondary_server_ip'])
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class TestSocks(unittest.TestCase):
|
|
|
|
|
def setUp(self):
|
|
|
|
|
self.port = random.randint(49152, 65535)
|
|
|
|
|
self.server_process = subprocess.Popen([
|
|
|
|
|
'srelay', '-f', '-i', '127.0.0.1:%d' % self.port],
|
|
|
|
|
stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
|
|
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
|
self.server_process.terminate()
|
|
|
|
|
self.server_process.communicate()
|
|
|
|
|
|
|
|
|
|
def _get_ip(self, protocol):
|
|
|
|
|
ydl = FakeYDL({
|
|
|
|
|
'proxy': '%s://127.0.0.1:%d' % (protocol, self.port),
|
|
|
|
|
})
|
|
|
|
|
return ydl.urlopen('http://yt-dl.org/ip').read().decode('utf-8')
|
|
|
|
|
|
|
|
|
|
def test_socks4(self):
|
|
|
|
|
self.assertTrue(isinstance(self._get_ip('socks4'), compat_str))
|
|
|
|
|
|
|
|
|
|
def test_socks4a(self):
|
|
|
|
|
self.assertTrue(isinstance(self._get_ip('socks4a'), compat_str))
|
|
|
|
|
|
|
|
|
|
def test_socks5(self):
|
|
|
|
|
self.assertTrue(isinstance(self._get_ip('socks5'), compat_str))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
|
unittest.main()
|
|
|
|
|