为locust中不同类型的事件,提供的钩子方法;

from locust import TaskSet, task, events, Locust
from locust.clients import HttpSession
import subprocess
import random, traceback
from common.sec_encrypt import AESEncrypt, md5_time
from common import read_config
from common.logger import print_file def on_request_success(request_type, name, response_time, response_length):
print_file(
'success Type: {}, Name: {}, Time: {}ms, length: {}'.format(request_type, name, response_time,
response_length)) def on_request_failure(request_type, name, response_time, exception):
print_file(
'failure Type: {}, Name: {}, Time: {}ms, exception: {}'.format(request_type, name, response_time,
exception)) def on_locust_error(locust_instance, exception, tb):
print_file(
"error locust_instance: {}, exception: {}, traceback: {}".format(locust_instance, exception,
traceback.format_tb(tb))) def on_hatch_complete(user_count):
print_file("User Locust have generate {} users".format(user_count)) def on_quitting():
print_file("Locust is quiting!") events.request_success += on_request_success
events.request_failure += on_request_failure
events.locust_error += on_locust_error
events.hatch_complete += on_hatch_complete
events.quitting += on_quitting class WebUser(TaskSet):
def on_start(self):
self.session = HttpSession('http://localhost:8000/api')
self.r = random.randint(10000, 99999) @task(2)
def user_auth(self):
"""用户认证"""
auth_user = ('lixiaofeng', 'fengzi802300')
res = self.session.get('/sec_get_event_list/', params={'eid': self.r}, auth=auth_user,
name='/sec_get_event_list/?eid=[eid]')
print_file(res.json())
# assert res.json()['status'] == 200, '用户认证接口请求失败!' @task(1)
def aes_api(self):
payload = {'name': '187187011{}'.format(self.r)}
# 加密
encodeed = AESEncrypt(payload).encrypt_data()
# print(encodeed)
res = self.session.get('/sec_get_guest_list/', params={'data': encodeed},
name='/sec_get_guest_list/?data=[aes]')
print_file(res.text)
# assert res.json()['status'] == 200, 'AES接口加密请求失败!' @task(2)
def md5_api(self):
payload = {"eid": "{}".format(self.r), "name": "一加8手机发布会{}".format(str(self.r)), "limit": 2000, "status": "",
"address": "深圳宝体会展中心",
"start_time": "2019-09-15 22:40:00", 'time': '', 'sign': ''}
payload = md5_time(payload)
res = self.session.post('/sec_add_event/', data=payload, name='/sec_add_event/?data=[md5]')
print_file(res.text)
# assert res.json()['status'] == 200, 'md5接口加密请求失败!' @task(2)
def add_guest(self):
"""添加嘉宾"""
payload = {'eid': '{}'.format(self.r), 'realname': '赵小刀{}'.format(self.r),
'phone': '187011{}'.format(self.r),
'email': '187011{}@163.com'.format(self.r)}
res = self.session.post('/add_guest/', data=payload, name='/add_guest/?data=[payload]')
print_file(res.text) class Run(Locust):
# host = 'http://localhost:8000/api'
task_set = WebUser
max_wait = 6000
min_wait = 3000 # 'locust -f D:\Interface_framework_Beauty\locust_files\locust_api.py --no-web -c 100 -r 10 --run-time {}s'.format(read_config.time)
def run():
subprocess.check_call(
'locust -f G:\Interface_framework_pytest\locust_files\\locust_test.py --no-web -c 1000 -r 100 --run-time {}s'.format(
read_config.time)) if __name__ == '__main__':
run()
1.request_success 成功完成请求后触发;
  参数:
    request_tye:请求类型;
    name:被调用url路径;
    response_time:响应时间,ms;
    response_length:响应内容长度;
 
2.request_failure 请求失败时触发;

  参数:
    request_tye:请求类型;
    name:被调用url路径;
    response_time:响应时间,ms;
    exception:抛出的异常;

3.locust_eror 在执行locust类内发生异常时触发;
  参数:
    locust_instance:发生异常的locust实例;
    exception:抛出的异常;
    tb:回溯的对象;

 
4.hatch_complete 生成所有locust用户时触发;
  参数:
    user_count:生成的用户数;

 
5.quitting locust进程退出时触发;


python locust 性能测试:HOOKS<钩子方法>的更多相关文章

  1. Python Locust性能测试框架实践

    [本文出自天外归云的博客园] Locust的介绍 Locust是一个python的性能测试工具,你可以通过写python脚本的方式来对web接口进行负载测试. Locust的安装 首先你要安装pyth ...

  2. python locust 性能测试:locust安装和一些参数介绍

    安装参考 https://www.cnblogs.com/fnng/p/6081798.html <虫师大大的,很详细> ps:python3.7暂不支持locust:python3安装建 ...

  3. python locust 性能测试:locust 关联---提取返回数据并使用

    from locust import HttpLocust, TaskSet, taskimport jsonfrom common import readConfig class UserBehav ...

  4. python locust 性能测试:HttpSession

    官网解释:用于在请求之间执行Web请求和保留(会话)cookie的类(以便能够登录和退出网站):记录每个请求,以便locust可以显示统计信息: from locust import TaskSet, ...

  5. python locust 性能测试:locust 参数化(list) ---循环取数据,数据可重复使用

    from locust import TaskSet, task, HttpLocust class UserBehavior(TaskSet): def on_start(self): # 当模拟用 ...

  6. python locust 性能测试:嵌套

    TaskSet类和TaskSequence类可用于嵌套<可以在TaskSequences中嵌套TaskSets,反之亦然>: from locust import TaskSet, tas ...

  7. python locust 性能测试:locust参数-保证并发测试数据唯一性,循环取数据

    from locust import TaskSet, task, HttpLocustimport queue class UserBehavior(TaskSet): @task def test ...

  8. python locust 性能测试:locsut参数化-保证并发测试数据唯一性,不循环取数据

    from locust import TaskSet, task, HttpLocustimport queue class UserBehavior(TaskSet): @task def test ...

  9. Python locust性能测试框架模板

    locust框架模板 from locust import HttpLocust, TaskSet, task import Queue class UserBehavior(TaskSet): de ...

随机推荐

  1. Vue使用vue-echarts图表

    vue-echarts和echarts的区别: vue-echarts是封装后的vue插件, 基于 ECharts v4.0.1+ 开发,依赖 Vue.js v2.2.6+,功能一样的只是把它封装成v ...

  2. Ubuntu 安装 Redis和phpredis扩展

    服务器Ubuntu16.04 环境php7.0+Apache /****************************开始安装Redis****************************/ 1 ...

  3. idea创建第一个普通java web项目

    1.新建项目(工作空间) 选择空项目 输入项目名称,点击完成 系统会默认选中Modules,点击上面的小+号创建模块->New Module 新建一个Java EE Web Applicatio ...

  4. swust oj 983

    利用二叉树中序及后序遍历确定该二叉树的先序序列 1000(ms) 10000(kb) 2606 / 4908 已知二叉树的中序和先序遍历可以唯一确定后序遍历.已知中序和后序遍历可以唯一确定先序遍历,但 ...

  5. yield关键字

    1.yield语句有两种形式 (1)yield return <expression>;一次返回一个元素 运行yield return 语句时,会返回一个 值,并记录当前位置及保留该值.下 ...

  6. HTML5 页面编辑API之Range对象

    在 HTML5 中,一个 Range 对象代表页面上的一段连续区域.通过 Range 对象,可以获取或修改页面上的任何区域.包含获取,修改,删除和替换等操作. 一:获取range对象的值 Range对 ...

  7. python数据分析算法(决策树2)CART算法

    CART(Classification And Regression Tree),分类回归树,,决策树可以分为ID3算法,C4.5算法,和CART算法.ID3算法,C4.5算法可以生成二叉树或者多叉树 ...

  8. TestNG Suite 运行出现中文乱码如何解决

    场景: 用TestNG框架运行测试类,控制台视图输出出现中文乱码. 解决方案: 1.eclipse属性>workspace>other>utf-8 2.修改eclipse.ini 文 ...

  9. html转markdown网站

    戳下面的链接,可以直接复制富文本粘贴编程markdown: https://euangoddard.github.io/clipboard2markdown/

  10. btcpool之JobMaker

    一.简介 JobMaker从kafka消息队列接收rawgbt消息,然后解码该消息中的gbt数据,生成Job,发送到kafka消息队列. 二.StratumJob结构 StratumJob结构是Job ...