1 Star 0 Fork 0

Lin / rabbitmq-tutorials

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
test.py 4.77 KB
一键复制 编辑 原始数据 按行查看 历史
Michael Klishin 提交于 2013-08-16 14:44 . Exclude Perl from CI runs for now
#!/usr/bin/env python
import time
import random
import re
import subprocess
import signal
import sys
import os
multiplier = float(os.environ.get('SLOWNESS', 1))
def run(cmd, **kwargs):
p = subprocess.Popen(cmd.split(),
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
**kwargs)
p.wait()
out = p.stdout.read()
err = p.stderr.read()
# compensate for slow Clojure examples startup:
# lein trampoline run + clojure.core recompilation
if kwargs.get("cwd") == "clojure":
x = 3
else:
x = 1
time.sleep(0.2 * multiplier * x)
return p.returncode, out + '\n' + err
def spawn(cmd, **kwargs):
p = subprocess.Popen(cmd.split(),
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
**kwargs)
if kwargs.get("cwd") == "clojure":
x = 3
else:
x = 1
time.sleep(0.5 * multiplier * x)
return p
def wait(p, match):
os.kill(p.pid, signal.SIGINT)
p.wait()
out = p.stdout.read()
err = p.stderr.read()
return bool(re.search(match, out)), out + '\n' + err
def gen(prog, arg="", **kwargs):
Prog = ''.join([w.capitalize() for w in prog.split('_')])
ctx = {
'prog': prog,
'Prog': Prog,
# clojure ns
'ns': prog.replace("_", "-"),
'arg': arg,
'java': kwargs.get('java', Prog),
'dotnet': kwargs.get('dotnet', Prog),
'ruby': kwargs.get('ruby', os.environ.get('RUBY', 'ruby1.9.1')),
}
return [
('python', './venv/bin/python %(prog)s.py %(arg)s' % ctx),
# ('perl', 'perl %(prog)s.pl %(arg)s' % ctx),
('erlang', './%(prog)s.erl %(arg)s' % ctx),
('java', 'java -cp .:commons-io-1.2.jar:commons-cli-1.1.jar:'
'rabbitmq-client.jar %(java)s %(arg)s' % ctx),
('clojure', './bin/lein trampoline run -m rabbitmq.tutorials.%(ns)s %(arg)s' % ctx),
('dotnet', 'env MONO_PATH=lib/bin mono %(dotnet)s.exe %(arg)s' % ctx),
('ruby', 'env RUBYOPT=-rubygems GEM_HOME=gems/gems RUBYLIB=gems/lib '
'%(ruby)s %(prog)s.rb %(arg)s' % ctx),
('ruby-amqp', 'env RUBYOPT=-rubygems GEM_HOME=gems/gems RUBYLIB=gems/lib '
'%(ruby)s %(prog)s.rb %(arg)s' % ctx),
('php', 'php %(prog)s.php %(arg)s' % ctx),
('python-puka', './venv/bin/python %(prog)s.py %(arg)s' % ctx),
]
def skip(cwd_cmd, to_skip):
return [(cwd,cmd) for cwd, cmd in cwd_cmd if cwd not in to_skip]
tests = {
'tut1': (gen('send'), gen('receive', java='Recv'), 'Hello World!'),
'tut2': (gen('new_task', arg='%(arg)s'), gen('worker'), '%(arg)s'),
'tut3': (gen('emit_log', arg='%(arg)s'), gen('receive_logs'), '%(arg)s'),
'tut4': (skip(gen('emit_log_direct', arg='%(arg)s %(arg2)s'),
['php']),
skip(gen('receive_logs_direct', arg='%(arg)s'),
['php']),
'%(arg2)s'),
'tut5': (skip(gen('emit_log_topic', arg='%(arg)s.foo %(arg2)s'),
['php']),
skip(gen('receive_logs_topic', arg='%(arg)s.*'),
['php']),
'%(arg2)s'),
'tut6': (skip(gen('rpc_client', java='RPCClient', dotnet='RPCClient'),
['erlang', 'clojure']),
skip(gen('rpc_server', java='RPCServer', dotnet='RPCServer'),
['erlang', 'clojure']),
'fib[(]30[)]'),
}
def tests_to_run():
if os.environ.get('TUTORIALS'):
return sorted(str.split(os.environ.get('TUTORIALS'), ","))
else:
return sorted(tests.keys())
errors = 0
ts = tests_to_run()
print " [.] Running tests with SLOWNESS=%r" % (multiplier,)
print " [.] Will test %s" % (ts)
for test in ts:
(send_progs, recv_progs, output_mask) = tests[test]
for scwd, send_cmd in send_progs:
for rcwd, recv_cmd in recv_progs:
ctx = {
'arg': 'rand_%s' % (random.randint(1,100),),
'arg2': 'rand_%s' % (random.randint(1,100),),
}
rcmd = recv_cmd % ctx
scmd = send_cmd % ctx
mask = output_mask % ctx
p = spawn(rcmd, cwd=rcwd)
exit_code, sout = run(scmd, cwd=scwd)
matched, rout = wait(p, mask)
if matched and exit_code == 0:
print " [+] %s %-30s ok" % (test, scwd+'/'+rcwd)
else:
print " [!] %s %-30s FAILED" % (test, scwd+'/'+rcwd)
print " [!] %r exited with status %s, output:\n%s\n" % (scmd, exit_code,
sout.strip())
print " [!] %r output:\n%s\n" % (rcmd, rout.strip())
errors += 1
if errors:
print " [!] %s tests failed" % (errors,)
sys.exit(errors)
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/sanid/rabbitmq-tutorials.git
git@gitee.com:sanid/rabbitmq-tutorials.git
sanid
rabbitmq-tutorials
rabbitmq-tutorials
master

搜索帮助