一、参数化概述
1、参数化概念
参数化就是动态的获取并设置数据,当执行批量操作时,如批量插入或批量删除,之前每执行完一次就需要修改一次,效率太低,参数化可以代替人工获取并设置数据,安全且高效!
2、Jmeter参数化组件
- CSV Data Set Config----CSV数据设置组件
- 用户参数
- 用户定义的变量
- 函数
二、参数化实现之CSV Data Set Config
1、概述
CSV Data Set Config----CSV数据设置组件,是参数化的实现组件之一,通过这个组件可以动态获取并设置数据,实现批量操作,如:批量添加操作(执行一次,将多条数据插入到数据库)。
2、实例1:参数化登录账号
我们录制的脚本,内容都是固定的,比如手机号、验证码都是我们再录制过程中输入的,如果我们希望模拟不同用户登陆,那么我们并不需要录制很多个脚本,而只要将脚本中的用户名、密码变成变量,而线程执行时,不同线程取得不同的变量值即可。
下面我们就举例说明如何参数化登陆账号。
(1)测试登录接口:如下图,新建登陆的HTTP请求并运行,确保登录接口运行正常。
(2)创建一个文本文档,标准的CSV格式文件,如下图包括3条数据,每一行数据对应一条登录信息,不同字段之间使用英文逗号分隔。
(3)线程组右键---添加---配置元件---CSV Data Set Config----CSV,创建一个CSV组件,并声明数据源、编码集以及解析格式,如下图所示:
(4)设置线程组的线程数为3(因为文件中有三条登录数据),并修改HTTP请求中的参数值,调用CSV数据文件设置中定义的变量,调用格式${变量名},如下图所示:
(5)运行测试计划,查看结果树的运行结果,如下图所示:
3、实例2:批量添加
实现思想:
实现步骤:
(1)创建CSV 数据文件设置,如下图所示:
(2)创建HTTP请求,并在请求中调用CSV中定义的变量
(3)编辑文本文档,存储要添加的三条数据
(4)设置线程组循环次数为3,并运行测试计划,查看察看结果树显示。
三、参数化之用户参数
1、用户参数与CSV参数化的区别
用户参数和CSV都是将数据设置进第三方,然后循环读取数据,区别在于:CSV是将数据设置进外部的文本文档,而用户参数是将数据设置进Jmeter内置组件。
2、实现流程
(1)搭建框架:创建测试计划、线程组、HTTP请求(请求的JSON数据先不设置)。注意:执行次数是3次(不是设置循环次数,而是设置线程数)
(2)创建Jmeter内置组件存储要插入的数据:测试计划右键----添加----前置处理器----用户参数,在用户参数组件界面添加4个变量、3个用户,如下图所示:
注意:因为此处添加的是用户,每个用户对应一个线程 ,添加几个用户就应该设置几个线程,所以这里设置的是线程组而不是循环次数。
(3)将用户参数组件中的变量名称设置进HTTP请求的Json数据格式中,调用格式:${变量名},如下图所示:
(4)运行测试计划,查看察看结果树。
四、参数化之用户定义的变量
1、需求
当系统执行增删改查操作时,资源路径不一定相同,但存在部分相同,如:都是/api/departments/开头,为了提高编写路径的效率,可以将公共路径定义成变量,然后再在路径中使用${变量名}调用变量。注:一般定义、存储全局使用的变量。
2、实现过程
(1)将公共的路径数据提取出来使用一个组件存储,如:/api/departments/。测试计划右键----添加----配置元件----用户定义的变量,创建用户定义的变量组件,添加自定义变量,如下图所示:
(2)分别创建HTTP请求,在路径中公共部分调用定义的路径变量,非公共部分路径与原来一致,如下图所示:
(3)运行测试计划,查看结果树。
五、参数化之函数
1、需求
函数是程序中最基本的封装单元,封装了一些常用的功能,比如计数器。在实际应用中当我们需要循环10次查询信息时,结果数的请求名称都是一样的,我们可以使用计数函数添加标号以示区分。
2、实现流程
(1)打开Jmeter内置的函数组件,一共有三种方式:
- 选项+函数助手对话框
- ctrl+shift+F1
- 工具栏倒数第二个图标
(2)选择要使用的函数,给函数传参,并用Jmeter生成调用格式,如下图:
注:__counter函数的参数:true,每一个用户单独一个计数器;false,所有用户共用一个计数器.
(3)在需要调用函数的位置使用Jmeter生成的调用格式:${_函数名(参数)}
(4)运行测试计划,查看结果树,如下图所示:
六、总结
1、参数化----CSV Data Set Config
概念:动态获取并设置数据,操作数据高效安全(程序代替人工)
实现思想+具体流程:
2、参数化----用户参数
实现思想:将数据单独存储,然后再将数据读取到http请求的JSON 数据中
实现流程:
- 设置执行次数(用户数)
- 添加组件用户参数存储多条记录
- 读取数据格式: ${变量名 )
3、参数化----用户定义的变量
作用:存储全局性数据
添加格式:添加用户定义的变量组件-----键和值
调用格式:${变量名}
4、参数化----函数
概念:程序中的功能单元,封装了部分实现
实现:
- 打开函数功能模块
- 选择要调用的函数+设置参数+生成调用格式
- 在需要使用的位置调用即可
5、四种参数化方案比较
- CSV和用户参数使用思想一致,流程上后者更简单,但是实际应用中,使用CSV居多,因为数据量大时,CSV更方便
- 用户定义的变量一般用来存储全局变量,但是使用场景较少
- 函数实现更为灵活且内置了好多实现。
总结:最常用的是参数化方法是:CSV+函数