Jmeter函数总结
第一章 前言
第二章 常用函数的介绍
2.1. timeShift函数
2.2. time函数
2.3. groovy函数
第三章 常用用法
3.1. Jmeter读取Excel
添加线程组
添加配置元件--》选择CSV Data Set Config
添加--》取样器--》选择BeanShell Sampler,使用vars.get方法获取Excel的值
添加--》取样器--》选择Debug Sampler,以便后面查看是否正常的获取了Excel中的数据
添加http请求,将Excel中获取的数据作为参数传递
添加一个查看结果树,以查看执行之后的结果
设置线程组
遇到问题
3.2. Jmeter读取txt
添加线程组
添加配置元件--》选择CSV Data Set Config
添加--》取样器--》选择BeanShell Sampler,使用vars.get方法获取Excel的值
添加--》取样器--》选择Debug Sampler,以便后面查看是否正常的获取了Excel中的数据
添加http请求,将Excel中获取的数据作为参数传递
添加一个查看结果树,以查看执行之后的结果、
设置线程组
第四章 常见问题
4.1. Jmeter请求参数时,中文出现乱码
第一章 前言
近期工作过程中使用Jmeter函数较多,初步使用,遇到问题只能依赖度娘解决,近期抽时间将遇到的问题梳理了一下,并附上了解决方法,希望可以对大家有所帮助。
第二章 常用函数的介绍
2.1. timeShift函数
背景:近期测试的一些业务的接口的传参需要传入与时间有关的一些数值
(比如需要毫秒级别的时间戳,比如1660270555043,对应的时间2022-08-12 10:15:55 ),
(再比如20220812101555848 对应的是2022-08-12 10:15:55),
使用 timeShift函数可以构造最新时间和指定时间戳。
示例:
场景
函数
结果
当前时间时间戳
(毫秒级)
${__timeShift(,,,,)}
1660270835790
2小时前时间戳
(毫秒级)
${__timeShift(,,-PT2H,,)}
1660263761872
指定格式,
输出当前时间
${__timeShift(yyyyMMddHHmmssSSS,,,,)}
20220812101555848
指定格式,
输出2小时前时间
${__timeShift(yyyyMMddHHmmssSSS,,-PT2H,,)}
20220812101555848
展开:
点击[函数助手/Function Helper]系统弹出函数助手页面,下拉选择timeShift
格式 - 将显示创建日期的格式。如果该值未被传递,则以毫秒为单位创建日期。
比如:
传入yyyyMMddHHmmssSSS,输出20220812101555848
传入yyyy-MM-dd HH:mm:ss 输出 2022-08-12 10:33:42
日期 - 这是日期值。用于如果要通过添加或减去特定天数,小时或分钟来创建特定日期的情况。如果参数值未通过,则使用当前日期。(没用对,自己打算再找找度娘)
移位 - 表示要从日期参数的值中添加或减去多少天,几小时或几分钟。如果该值未被传递,则不会将任何值减去或添加到日期参数的值中。不使用符号时为增加,使用+ -号实现加减
“P1DT2H4M5S” 解析为“添加1天2小时4分钟5秒”
“P-6H3M”解析为“-6小时+3分钟”
“-P6H3M”解析为“-6小时-3分钟”
“-P-6H + 3M”解析为“+6小时和-3分钟”
“P1d” 解析为增加一天
“PT2H” 解析为增加两小时
“PT30m”解析为增加30分钟
“PT40S”解析为增加40秒
“P1dT2H30m40s”解析为增加一天两小时三十分钟四十秒
区域设置 - 设置创建日期的显示语言。不是必填项
变量 - 创建日期的值将被分配给的变量的名称。不是必填项
2.2 time函数
time函数同timeShirt函数用法大致相同。
示例:
场景
函数
结果
当前时间时间戳
(毫秒级)
${__time(,)}
1660272941726
当前时间时间戳
(秒级)
${__time(/1000,)
1660272952
指定时间格式
${__time(yyyy-MM-dd,)}
2022-08-12
展开:
点击[函数助手/Function Helper]系统弹出函数助手页面,下拉选择time函数
格式 - 将显示创建日期的格式。如果该值未被传递,则以毫秒为单位创建日期。
比如:
传入yyyyMMddHHmmssSSS,输出20220812101555848
传入yyyy-MM-dd HH:mm:ss 输出 2022-08-12 10:33:42
变量 - 创建日期的值将被分配给的变量的名称。不是必填项
time函数与timeShift函数区别:
*time函数即可以生成秒级别、也可以毫秒级别的时间戳,timeShift函数仅可以生成毫秒级别的时间戳;
*timeShift函数比time函数多了几项传参,比如可以传入移位参数,构造几天前/几小时/几分钟对应时间值
推荐网址:(截图很全)
Jmeter高级性能测试实战https://edu.csdn.net/course/detail/35834
2.3. groovy函数
问题:我需要一个传参,将指定格式的时间转为时间戳(毫秒级别),试了好几个方法都不太合适,最后使用了同事提供的groovy函数
示例:比如将startDate的日期转为时间戳
指定日期
转为时间戳
输出
startDate=2022-07-19 12:30:10
${__groovy(new java.text.SimpleDateFormat('yyyy-MM-dd HH:mm:ss').parse('${startDate}').getTime(),)}
startTime=1658205010000
第三章 常用用法
3.1. Jmeter读取Excel
背景:近期需要使用接口构造100条数据,就计划使用excel存储数据,然后将每次读取的数据作为参数传递给接口。
步骤:
- 添加线程组
- 添加配置元件--》选择CSV Data Set Config
附上Excel表格
添加--》取样器--》选择BeanShell Sampler,使用vars.get方法获取Excel的值
添加--》取样器--》选择Debug Sampler,以便后面查看是否正常的获取了Excel中的数据
- 添加http请求,将Excel中获取的数据作为参数传递
- 添加一个查看结果树,以查看执行之后的结果
Fiddler接口抓包神器使用教程https://edu.csdn.net/course/detail/32782
- 设置线程组
比如循环次数设置5,系统会重复执行5次,依次读取第前5条数据作为传参,调用接口
- 遇到问题
Csv格式添加数据,但是无法保存设置的格式,比如设置的时间格式样式就丢失了
所以,最终未使用从excel中读取数据,而是计划从txt中读取数据
3.2. Jmeter读取txt
步骤基本上同章节3.1 Jmeter读取Excel 一致,也是六大步骤,仅附上与excel 不同的截图
添加线程组
添加配置元件--》选择CSV Data Set Config
附上txt内容
添加--》取样器--》选择BeanShell Sampler,使用vars.get方法获取Excel的值
添加--》取样器--》选择Debug Sampler,以便后面查看是否正常的获取了Excel中的数据
添加http请求,将Excel中获取的数据作为参数传递
添加一个查看结果树,以查看执行之后的结果、
设置线程组
第四章 常见问题
4.1. Jmeter请求参数时,中文出现乱码
问题描述:使用jmeter时,又遇到了在接口参数输入有带中文的时候,执行接口后,出现乱码的情况
解决方式:在请求中,content encoding写为:utf-8
Jmeter高级性能测试实战https://edu.csdn.net/course/detail/35834软件测试全栈系列课程https://edu.csdn.net/course/detail/30898
版权归原作者 传说三哥 所有, 如有侵权,请联系我们删除。