标签:cal 框架 error object login gravity out 负载 otl
Multi-Mechanize 是一个开源的性能和负载测试框架,它并发运行多个 Python 脚本对网站或者服务生成负载(组合事务)。测试输出报告保存为HTML或JMeter的兼容的XML。Multi-Mechanize最常用于web性能和可扩展性(scalability)测试,也适用于任何python可以访问的API。尤其适合后台性能测试。稍微懂点编程的话,这个工具会远强过商业的性能测试工具。
github:https://github.com/cgoldberg/multi-mechanize
主要特性:
multimech-newproject my_test
自动创建一个my_test目录,子目录test_scripts用来放测试脚本,config.cfg是测试配置,主要要配的是测试时间、测试脚本和并发threads量。
执行项目
# multimech-run my_test user_groups: 2 threads: 6 [================100%==================] 30s/30s transactions: 119 timers: 119 errors: 0 waiting for all requests to finish... analyzing results... transactions: 125 errors: 0 test start: 2013-09-13 11:47:47 test finish: 2013-09-13 11:48:16 created: ./my_test/results/results_2014.12.23_15.24.40/results.html done.
每个测试项目包含以下内容:
配置参数的含义如下:
下例使用mechanize进行web测试。
class Transaction(object):
def __init__(self):
pass
def run(self):
br = mechanize.Browser()
br.set_handle_robots(False)
resp = br.open(‘http://example..com‘)
assert (resp.code == 200), ‘Bad Response: HTTP %s‘ % resp.codes
assert (‘service name‘ in resp.get_data())
下面用httplib库重写脚本,并增加定时器。通过定时器,可以分析各个步骤的耗时。
import httplib
import urllib
import time
class Transaction(object):
def __init__(self):
self.custom_timers = {}
def run(self):
post_body=urllib.urlencode({
‘USERNAME‘: ‘corey‘,
‘PASSWORD‘: ‘secret‘,})
headers = {‘Content-type‘: ‘application/x-www-form-urlencoded‘}
start_timer = time.time()
conn = httplib.HTTPConnection(‘www.example.com‘)
conn.request(‘POST‘, ‘/login.cgi‘, post_body, headers)
resp = conn.getresponse()
content = resp.read()
latency = time.time() - start_timer
self.custom_timers[‘LOGIN‘] = latency
assert (resp.status == 200), ‘Bad Response: HTTP %s‘ % resp.status
assert (‘Example Web Page‘ in content), ‘Text Assertion Failed‘
下面是requests库重写脚本,并增加定时器。通过定时器,可以分析各个步骤的耗时。
标签:cal 框架 error object login gravity out 负载 otl
原文地址:http://www.cnblogs.com/saryli/p/6632104.html