文章目录
- 前言
- 八、Jmeter常用逻辑控制器
- 8.1 如果(if)控制器
- 8.2 循环控制器
- 8.3 ForEach控制器
- 九、Jmeter关联
- 9.1 正则表达式提取器
- 9.2 xpath提取器
- 9.3 JSON提取器
- 十、跨越线程组传值
- 10.1 高并发
- 10.2 高频率
- 10.3 分布式
- 总结
前言
八、Jmeter常用逻辑控制器
通过参数化可以实现单个接口的功能测试,而接口测试过程中,除了单个接口的功能测试之外,还会测试 接口业务实现,所谓业务,就是一套完整的业务逻辑或流程,这就必须要使用到逻辑控制和关联。
8.1 如果(if)控制器
(1)作用:
if控制器用来控制它下面的测试元素是否运行。
(2)位置:
测试计划->线程组->逻辑控制器->IF控制器。
图示说明:
举实例说明:
需求:测试计划中定义一个 http 请求访问百度官网,但是该请求不是无条件执行的,声明一个用户定义的变量,如果变量是 itcast 才执行,否则就不执行。实现步骤:1、搭框架,测试计划,线程组,结果树,声明一个用户定义的变量2、核心:添加 if 控制器,子级添加取样器 (和之前实现不同,控制器和取样器存在父子级关系)步骤一:声明一个用户定义的变量
步骤二:添加 if 控制器,子级添加取样器
8.2 循环控制器
(1)作用:
控制下面的测试元素循环执行一次或多次
(2)位置:
测试计划->线程组->逻辑控制器->循环控制器
图示说明:
举实例说明:
需求:循环访问学生管理系统10次实现步骤:1、搭框架,测试计划,线程组,结果树2、添加循环控制器,子级添加取样器 (和之前实现不同,控制器和取样器存在父子级关系)
步骤一:添加循环控制器
8.3 ForEach控制器
(1)作用:
一般和用户自定义变量或者正则表达式提取器一起使用,读取返回结果中一系列相关的变量值。该控制器下的所有取样器都会被执行一次或多次,每次读取不同的变量值
(2)位置:
测试计划->线程组->逻辑控制器->ForEach控制器
(3)图示说明:
(4)参数说明:
举实例说明:
需求:有一组关键字 [hello,python,测试] (使用用户定义的变量存储)要依次取出,并在百度搜索实现步骤:1、搭框架,测试计划,线程组,结果树,声明一个用户定义的变量,存储一组数据2、添加 forEach 控制器,子级添加取样器 (和之前实现不同,控制器和取样器存在父子级关系)3、百度搜索关键字步骤一:声明一个用户定义的变量,存储一组数据
步骤二:添加 forEach 控制器
步骤三:在请求中使用,在百度搜索关键字
第一个变量Java:
九、Jmeter关联
(1)定义:
当请求之间有依赖关系,比如一个请求的入参是另一个请求返回的数据,这时候就需要用到关联处理
(2)常用的关联方法:
- 正则表达式提取器
- XPath提取器
- JSON提取器
- JMeter属性
9.1 正则表达式提取器
(1)使用场景:
任意格式的响应数据,都可以使用正则表达式提取器进行提取
(2)使用步骤:
- 添加线程组
- 添加HTTP请求1
- 在后置处理器添加正则表达式提取器设置参数
- 添加HTTP请求2,引用正则表达式中的引用名称。如:用${title}引用它
- 添加查看结果树
知识点解惑:
正则表达式:就是一个公式,或者一套规则,使用这套规则可以从任意字符串中提取出想要的数据内容。
公式格式:左边界(匹配符号)右边界:可以提取出想要获取的数据内容
.:是通配符,可以代表任意字符(除换行回车)
*: 代表前面的字符出现0次或者多次
.*匹配规则:找到左边界值后,往右查找有边界,找到最后面的右边界,中间的所有数据都被记录下来
?: 代表非贪婪匹配,找到左边界后,往右查找匹配右边界,只要有匹配的右边界就停止继续查找;再次查找左边界和右边界
公式格式:左边界(.*?)右边界
(1)图示说明:
(2)参数说明:
举实例说明:
需求:两个请求,请时求A查询所有学院信息,请求B访问百度,从请求A中提取出第一个学院的学院名称, 把名称放在百度上搜索实现步骤:1、搭框架,编写两个请求,查询所有学院信息 + 百度搜索2、核心:从学院查询中提取学院名称3、传递给百度,调用格式: ${变量名}
步骤一:搭框架,编写两个请求,查询所有学院信息 + 百度搜索
步骤二:从学院查询中提取学院名称
步骤三:传递给百度,调用格式: ${变量名}
步骤四:查看结果树
9.2 xpath提取器
(1)使用场景:
针对HTML格式的响应结果数据进行提取。
(2)使用步骤:
- 添加线程组
- 添加HTTP请求1
- 在后置处理器添加xpath提取器设置参数
- 添加HTTP请求2,引用正则表达式中的引用名称。如:用${title}引用它
- 添加查看结果树
(1)图示说明:
(2)参数说明:
- Use Tidy (tolerant parser):当需要处理的页面是HTML格式时,必须选中该选项;当需要处理的页面是XML或XHTML格式时,取消选中该选项
- 引用名称:存放提取出的值的参数名称
- XPath Query:用于提取值的XPath表达式
- 匹配数字:如果XPath路径查询出许多结果,则可以选择提取哪个
- 0:表示随机,-1:表示提取所有结果,1表示第一个值
- 缺省值:参数的默认值
举实例说明:
需求:两个http请求,请求A访问传智播客官网,请求B访问百度 ,请求A将传智播客官网源码中的 title 标 签的值取出,传递给请求B,在请求B中作为关键字搜索这个 title 值实现步骤:1、搭框架,编写两个请求,传智播客 + 百度搜索2、核心: 取出传智播客页面源码的 title 值3、传递给百度:${变量名} 的方式传值
步骤一:搭框架,编写两个请求,传智播客 + 百度搜索
步骤二:核心: 取出传智播客页面源码的 title 值
步骤三:传递给百度,调用格式: ${变量名}
9.3 JSON提取器
(1)使用场景:
针对JSON格式的响应数据进行提取
(2)使用步骤:
- 添加线程组
- 添加HTTP请求1
- 在后置处理器中选择添加JSON提取器设置参数
- 添加HTTP请求2,引用正则表达式中的引用名称。如:用${title}引用它
- 添加查看结果树
(1)图示说明:
(2)参数说明:
- Names of created variables:存放提取出的值的参数名称。如:cit
- JSON Path expressions:用于提取值的JSON路径表达式
- Match No:0表示随机;-1表示提取的所有结果,1表示第一个值
- Default Values:参数的默认值
十、跨越线程组传值
变量作用域局限于当前线程组,其他线程组不可以直接调用。
可以将请求A中提取的结果导出到公共空间 (可以被不同线程组共享),请求B再从公开空间调用该变量,相当于全局变量。
实现步骤:
1、将请求A的数据导出到公共空间( __setProperty)2、把代码放在beanshell取样器中3、请求B从公共空间调用数据 (__property)
图示说明:beanshell取样器
步骤一:将请求A的数据导出到公共空间( __setProperty)
步骤二:把代码放在beanshell取样器中
步骤三:请求B从公共空间调用数据 (__property)
10.1 高并发
性能测试定义:模拟各种正常的、峰值的测试环境,检测程序的各项性能指标是否能够达标。
JMeter 中内置了 定时器,可以实现时间模式相关的性能测试
高并发举实例说明:
需求:同一时刻 100 个同学去访问学生管理系统的查询所有学院信息功能,统计高并发情况下平均响应时 间以及错误率(高并发)实现步骤:1、搭框架,测试计划,线程组,取样器,结果树(局限性),指定线程组的线程数属性值为 1002、添加定时器 synchronizing timer(集合点组件)3、运行并查看结果查看:聚合报告组件,可以对结果汇总分析
步骤一:指定线程组的线程数属性值为 100
步骤二:添加定时器 synchronizing timer(集合点组件)
步骤三:运行并查看结果查看:聚合报告组件,可以对结果汇总分析
10.2 高频率
高频率举实例说明:
需求:一个用户以 20QPS ( == 20 次/s) 的频率访问学生管理系统服务器,持续15秒,统计服务器的平均 响应时间QPS: Query per Seconds 每秒查询数(查询率),每秒访问多少次服务器实现步骤:1、搭框架,测试计划,线程组,取样器,聚合报告,根据题干计算数据:循环次数 = 访问频率 * 持续时间2、添加QPS访问频率控制的相关组件:访问频率 = 每分钟访问次数 * 60
步骤一:搭框架,测试计划,线程组,取样器,聚合报告,
步骤二:添加QPS访问频率控制的相关组件
由访问频率 = 每分钟访问次数 * 60可以得知:访问频率为1200.
10.3 分布式
(1)定义:多台机协作,以集群的方式完成测试任务,可以提高测试效率。
(2)图示实现说明:
(3)环境搭建:1、不同的测试机上安装 Jmeter2、配置基础环境(统一操作系统、JDK、Jmeter .... )3、核心: 控制机如何与执行机通信? 关键点:端口号4、控制机中设置执行机的 IP%JMETER_HOME%/bin/jmeter.properties ----> remote_hosts=执行机A的IP:端口号, 执行机B的IP:端 口号, .....3-3、控制机和执行机都得设置远程访问相关属性:server.rmi.ssl.disable=true