shadowsocks/tests/test.py

80 lines
2 KiB
Python
Raw Normal View History

2013-07-04 23:16:10 +08:00
#!/usr/bin/python
# -*- coding: utf-8 -*-
2014-06-01 17:35:32 +08:00
import sys
2013-07-04 23:16:10 +08:00
import os
import signal
import select
2014-05-17 15:00:12 +08:00
import time
2013-07-04 23:16:10 +08:00
from subprocess import Popen, PIPE
2014-07-13 01:29:57 +08:00
sys.path.insert(0, './')
2014-07-12 21:59:00 +08:00
if sys.argv[-3] == '-c':
client_config = sys.argv[-1]
server_config = sys.argv[-2]
elif sys.argv[-2] == '-c':
client_config = sys.argv[-1]
server_config = sys.argv[-1]
else:
raise Exception('usage: test.py -c server_conf [client_conf]')
2014-06-20 22:58:01 +08:00
if 'salsa20' in sys.argv[-1]:
from shadowsocks.crypto import salsa20_ctr
salsa20_ctr.test()
2014-06-20 22:58:01 +08:00
print 'encryption test passed'
2013-07-04 23:16:10 +08:00
p1 = Popen(['python', 'shadowsocks/server.py', '-c', server_config],
stdin=PIPE, stdout=PIPE, stderr=PIPE, close_fds=True)
p2 = Popen(['python', 'shadowsocks/local.py', '-c', client_config],
stdin=PIPE, stdout=PIPE, stderr=PIPE, close_fds=True)
2014-06-18 15:50:05 +08:00
p3 = None
2013-07-04 23:16:10 +08:00
try:
2014-05-22 12:09:43 +08:00
local_ready = False
server_ready = False
2013-07-04 23:16:10 +08:00
fdset = [p1.stdout, p2.stdout, p1.stderr, p2.stderr]
while True:
r, w, e = select.select(fdset, [], fdset)
if e:
break
2014-08-27 00:17:26 +08:00
2013-07-04 23:16:10 +08:00
for fd in r:
line = fd.readline()
sys.stdout.write(line)
2014-05-22 12:09:43 +08:00
if line.find('starting local') >= 0:
local_ready = True
if line.find('starting server') >= 0:
server_ready = True
if local_ready and server_ready and p3 is None:
time.sleep(1)
2014-07-11 17:35:47 +08:00
2013-07-04 23:16:10 +08:00
break
2014-06-20 22:32:10 +08:00
2014-07-11 17:35:47 +08:00
p3 = Popen(['curl', 'http://www.example.com/', '-v', '-L',
'--socks5-hostname', '127.0.0.1:1081'], close_fds=True)
2013-07-04 23:16:10 +08:00
if p3 is not None:
r = p3.wait()
2014-07-11 17:35:47 +08:00
if r != 0:
sys.exit(r)
else:
sys.exit(1)
p4 = Popen(['socksify', 'dig', '@8.8.8.8', 'www.google.com'],
close_fds=True)
if p4 is not None:
r = p4.wait()
if r != 0:
sys.exit(r)
else:
sys.exit(1)
print 'test passed'
2014-06-01 17:35:32 +08:00
2013-07-04 23:16:10 +08:00
finally:
for p in [p1, p2]:
try:
os.kill(p.pid, signal.SIGTERM)
except OSError:
pass