locust 检查点、集合点、参数化设置。
1.参数化
方式1:循环取数据,数据可以重复使用。
所有并发虚拟用户共享同一份测试数据,各虚拟用户在数据列表中循环取值。
例如,模拟10个用户并发请求网页,总共有4个URL地址,每个虚拟用户都会依次循环加载这4个URL地址。
class HttpTask(TaskSet):
index = 0
@task
def test001(self):
url = self.user.data[self.index]
self.index = (self.index + 1) % len(self.user.data)
print(url)
self.client.get(url) class MyUser(HttpUser):
host = "https://www.baidu.com"
tasks = [HttpTask]
between(0, 3)
data = ['https://www.baidu.com/',
'https://www.baidu.com/s?wd=1',
'https://www.baidu.com/s?wd=2',
'https://www.baidu.com/s?wd=3',
'https://www.baidu.com/s?wd=4']
方式2:保证并发测试数据唯一性,不循环取数据,使用队列的方法。
所有并发虚拟用户共享同一份测试数据,并且保证虚拟用户使用的数据不重复。
列如,模拟10用户并发注册账号,总共有100个账号,邀请注册账号不重复。注册完毕后自动结束测试。
class HttpTask(TaskSet):
@task
def test001(self):
try:
url = self.user.queue.get()
except queue.Empty:
exit(0)
self.client.get(url)
class MyUser(HttpUser):
host = "https://www.baidu.com"
tasks = [HttpTask]
between(0, 3)
queue = queue.Queue()
data = 'https://www.baidu.com/'
for i in range(5):
queue.put_nowait(data)
方式3:保证并发数据的唯一性,循环取数据,使用队列方法,,欸出使用完数据后在放入到队列中。
所有并发虚拟用户共享同一份测试数据,保证并发虚拟用户使用的数据不重复,并且数据可循环重复使用。
列如:模拟10用户并发登录账号。总共有100个账号,要求并发登录账号不相同,但数据可循环使用。
class HttpTask(TaskSet):
@task
def test001(self):
try:
url = self.user.queue.get()
except queue.Empty:
exit(0)
self.client.get(url)
self.user.queue.put_nowait(url)
class MyUser(HttpUser):
host = "https://www.baidu.com"
tasks = [HttpTask]
between(0, 3)
queue = queue.Queue()
data1 = ["https://www.baidu.com/",
"https://www.baidu.com/s?wd=1",
"https://www.baidu.com/s?wd=2",
"https://www.baidu.com/s?wd=3",
"https://www.baidu.com/s?wd=4"]
for i in range(0,5):
data = data1[i]
queue.put_nowait(data)
2集合
from locust import SequentialTaskSet, task, HttpUser,events
from gevent._semaphore import Semaphore
all_locusts_spawned = Semaphore()
all_locusts_spawned.acquire() def on_hatch_complete(**kwargs):
all_locusts_spawned.release() # 创建钩子方法
# events.on_hatch_complete += on_hatch_complete
# 挂在到locust钩子函数(所有的Locust示例产生完成时触发)
events.spawning_complete.add_listener(on_hatch_complete) class UserBehavior(SequentialTaskSet):
index = 0
# 限制在所有用户准备完成前处于等待状态
def on_start(self):
all_locusts_spawned.wait() @task
def test_visit(self):
all_locusts_spawned.wait() # 限制在所有用户准备完成前处于等待状态
url = self.user.share_data[self.index]
self.index = (self.index + 1) % len(self.user.share_data)
with self.client.get(url,catch_response=True) as response:
if response.status_code == 200:
response.success()
else:
response.failure("查询失败")
print('visit url: %s' % url) class WebsiteUser(HttpUser):
host = "https://www.baidu.com"
tasks = [UserBehavior]
share_data = ['https://www.baidu.com/',
'https://www.baidu.com/s?wd=1',
'https://www.baidu.com/s?wd=2',
'https://www.baidu.com/s?wd=3',
'https://www.baidu.com/s?wd=4']
min_wait = 100
max_wait = 300 if __name__ == '__main__':
import os
os.system("locust -f parameterized.py")
locust 检查点、集合点、参数化设置。的更多相关文章
- 性能学习笔记之四--事务,思考时间,检查点,集合点和手写lr接口
一.事物,思考时间,检查点,集合点 1.事务 lr里面的事物是lr运行脚本的基础.lr里面 要测试的三个维度都以事物为单位,所以一定要有事物.事务的概念贯穿loadrunner的使用,比如我们说的响应 ...
- 【Loadrunner】初学Loadrunner——参数化设置(Table类型关联数据库)
参数化输入是Loadrrunner里面一个强大的功能,属于Loadrunner的高级使用技巧. 我们在登录系统的时候,需要输入一组定义的用户名和密码,比如有5个虚拟用户同时登陆系统,则这五个用户都用这 ...
- Junit4学习(六)Junit4参数化设置
一,背景, 有时候会对相同的代码结构做同样的操作,不同的时对参数的设置数据和预期结果:有没有好的办法提取出来相同的代码,提高代码的可重用度,junit4中使用参数化设置,来处理此种场景: 二,代码展示 ...
- 【JMeter】集合点的设置
[JMeter]集合点的设置 简单来理解一下,虽然我们的“性能测试”理解为“多用户并发测试”,但真正的并发是不存在的,为了更真实的实现并发这感念,我们可以在需要压力的地方设置集合点,每到输入用户名和密 ...
- 【Jmeter】如何通过文件导入方式对用户名和密码进行参数化设置
JMeter 参数化 注意:param和data body只能用一个.所有任何一个里面有内容,切换都会报错,这不是问题,jmeter是这么设计的 方法一:通过添加CSV Data Set Config ...
- Jmeter参数化设置,多用户登录
一.模拟多用户登录场景 如登录模式如下图所示,登录界面中需要输入:用户名.密码.验证码 用户名以及密码均是固定值,不需要做处理.验证码需要处理一下,可以后台配置成固定值,具体可以找开发咨询. 在此场景 ...
- LoadRunner脚本参数化设置
LoadRunner,是一种预测系统行为和性能的负载测试工具,其中VUG(Virtual User Generator)主要用于虚拟用户生成和脚本编辑.为了实现单用户多次迭代执行脚本,VUG提供了强大 ...
- LR参数化设置(转)
LR学习笔记---参数设置 2010-10-20 14:58:55| 分类: 默认分类|举报|字号 订阅 LR在录制程序运行的过程中,VuGen(脚本生成器) 自动生成了包含录制过程中实际用 ...
- Jmeter中各种参数化设置的方法
Jmeter中有较多需要参数化测试的地方: 1.从一个用户登录的接口获取登录后的token值,取值后用于后续接口调用 2.获取用户浏览后的cookies信息,需要用到HTTP Cookie 管理器来为 ...
- 性能测试工具LoadRunner07-LR之Virtual User Generator 参数化设置
1.Select next row[选择下一行]: 顺序(Sequential):按照参数化的数据顺序,一个一个的取 随机(Random):参数化中的数据,每次随机的从中抽取数据 唯一(Unique) ...
随机推荐
- 笔记:C#Datatable 根据某字段数量 自动复制该行的数量
/// <summary> /// 根据Datatable某字段数量自动复制该行查询 /// </summary> /// <param name="dt&qu ...
- 在执行npm install执行报错node-sass
1 错误信息 这个错误信息不是我当时的报错信息,是网上找的,报错的时候忘记存了,处理好了又找不到错误信息,就从网上找的差不多的错误信息 gyp ERR! configure error gyp ERR ...
- 调用HttpClient.PostAsync时传token等值
做内部接口转发时加token验证需要传token值过去,有如下两种方式 string jsonContent = JsonConvert.SerializeObject(args); using(va ...
- uboot目录
目录 api 与硬件无关的 API 函数. arch 与架构体系有关的代码. 各种架构,例如arm cpu 各种版本的cpu, 例如armv7, arm9 各种厂商,例如瑞芯微mach-rockch ...
- 2021级《JAVA语言程序设计》上机考试试题4
现在就是写学生,学生查看个人信息,,修改个人密码,学生功能页的页面,代码最一开始给了 然后,这三个比较紧密,所以一起写了 学生功能页 <%@ page language="java&q ...
- servlet传入多个数据
通过&来传入值:<a href="bookquery?page=1&nameBook=&author=&publisher=>1</a> ...
- 郁金香-了解MFC信息机制
控件的事件 窗口的信息
- MQ收到无序的消息时如何进行业务处理
业务背景 跟第三方系统做对接,双方通过ActiveMQ进行通信,消息之间是有内在关联的,也就是消息本来应该是有业务顺序的,但由于一些原因,现在收到消息是乱序的,这种情况下做业务处理就有一点小问题了 方 ...
- 【KAWAKO】模型的压缩、扩张,计算模型的各种成本
目录 模型压缩 量化 稀疏化训练 剪枝 知识蒸馏 自蒸馏 集成 使用精细化模型结构 模型扩张 深度 宽度 输入图像的分辨率 深度.宽度.分辨率联合扩张 使用精细化模型结构 计算模型的各种成本 参数量 ...
- RabbitMQ基础和解疑
一.基础概念 1. Producer:生产者,就是投递消息的一方 消息一般可以包含2个部分:消息体和标签(Label).消息体也可以称之为payload,在实际应用中,消息体一般是一个带有业务逻辑结构 ...