Bootstrap

【JMeter接口测试工具】第二节.JMeter基本功能介绍(下)【进阶篇】

文章目录

  • 前言
  • 八、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)使用步骤:

  1. 添加线程组
  2. 添加HTTP请求1
  3. 在后置处理器添加正则表达式提取器设置参数
  4. 添加HTTP请求2,引用正则表达式中的引用名称。如:用${title}引用它
  5. 添加查看结果树

知识点解惑:

正则表达式:就是一个公式,或者一套规则,使用这套规则可以从任意字符串中提取出想要的数据内容。

公式格式:左边界(匹配符号)右边界:可以提取出想要获取的数据内容

.:是通配符,可以代表任意字符(除换行回车)

*: 代表前面的字符出现0次或者多次

.*匹配规则:找到左边界值后,往右查找有边界,找到最后面的右边界,中间的所有数据都被记录下来

?: 代表非贪婪匹配,找到左边界后,往右查找匹配右边界,只要有匹配的右边界就停止继续查找;再次查找左边界和右边界

公式格式:左边界(.*?)右边界

(1)图示说明:

(2)参数说明:

举实例说明:

需求:
两个请求,请时求A查询所有学院信息,请求B访问百度,从请求A中提取出第一个学院的学院名称, 把名称放在百度上搜索
实现步骤:
1、搭框架,编写两个请求,查询所有学院信息 + 百度搜索
2、核心:从学院查询中提取学院名称
3、传递给百度,调用格式: ${变量名}

步骤一:搭框架,编写两个请求,查询所有学院信息 + 百度搜索


步骤二:从学院查询中提取学院名称


步骤三:传递给百度,调用格式: ${变量名}


步骤四:查看结果树


9.2 xpath提取器

(1)使用场景:

针对HTML格式的响应结果数据进行提取。

(2)使用步骤:

  1. 添加线程组
  2. 添加HTTP请求1
  3. 在后置处理器添加xpath提取器设置参数
  4. 添加HTTP请求2,引用正则表达式中的引用名称。如:用${title}引用它
  5. 添加查看结果树

(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)使用步骤:

  1. 添加线程组
  2. 添加HTTP请求1
  3. 在后置处理器中选择添加JSON提取器设置参数
  4. 添加HTTP请求2,引用正则表达式中的引用名称。如:用${title}引用它
  5. 添加查看结果树

(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、搭框架,测试计划,线程组,取样器,结果树(局限性),指定线程组的线程数属性值为 100
2、添加定时器 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、不同的测试机上安装 Jmeter
2、配置基础环境(统一操作系统、JDK、Jmeter .... )
3、核心: 控制机如何与执行机通信? 关键点:端口号
4、控制机中设置执行机的 IP
%JMETER_HOME%/bin/jmeter.properties ----> remote_hosts=执行机A的IP:端口号, 执行机B的IP:端 口号, .....
3-3、控制机和执行机都得设置远程访问相关属性:
server.rmi.ssl.disable=true

总结

;