JMeter中如何实现参数化(CSV)
1、参数化的定义
参数化是自动化测试脚本的一种常用技巧,可将脚本中的某些参数使用变量来代替。例如登录操作时,利用GET/POST请求方式传递参数的场景,可在脚本运行时指定参数的取值范围和规则。
脚本在运行时,根据需要选取不同的参数值作为输入,该方式称为数据驱动测试(Data Driven Test),而参数的取值范围被称为数据池(Data Pool)。
2、什么情况下需要用到参数化
测试数据的准备阶段我们需要用到参数化。
使用场景:
- 若需求每次访问某一个接口的数据不一样时,需要用到参数化,更好地模拟用户情况,常用于压力测试。
- 需要多次获取同一数据 ,则可以用一个参数化来代替,在需要的地方使用这一个变量就可以了。
3、JMeter实现参数化的方式
JMeter提供了多种参数化方式,常用的4种方式如下:
- CSV数据文件设置(
CSV Data Set Config
):这种方式是通常所指的参数化。数据存储在文件中,该种参数化方式取值范围大,灵活性强,适用于大量测试数据时的使用。 - 用户参数(
User Parameter
):适用于参数取值范围很小,需要少量测试数据时使用。 - 用户自定义变量(
User Defined Variables
):更多用于设置全局变量,常用于数据库地址,测试环境、开发环境地址等常量配置。 - 函数助手:可使用函数生成随机数字和随机字符串实现参数化。
在JMeter中使用参数化变量的方式:${变量名}
。
4、CSV数据文件设置界面详细说明
CSV数据文件设置(CSV Data Set Config
)是一个配置元件(Config Element
),用来提供对静态数据配置的支持,可以为取样器提供需要的变量。
CSV数据文件设置组件,在它所在层级的元件中是第一个执行。即在最开始被执行,在相同范围内的任何取样器之前执行。
CSV数据文件设置组件能够在文件中读取一行数据,根据特定的符号,切割成一个或多个变量放入内存中。相比于JMeter函数助手中提供的 __CSVRead()
、__StringFromFile()
等函数,CSV数据文件设置组件使用更加简便。
JMeter支持数据被双引号括起,被双引号括起的数据允许包含分隔符,例如:a,b,"c,d"
。这行数据被逗号分隔后将产生三个变量值:a
、b
、c,d
。
JMeter支持读取具有标题行(标题行内容如Excel的列名称)的CSV文件。
(1)CSV数据文件设置组件界面说明
添加CSV数据文件设置组件的操作:选中“线程组”右键 —> 添加 —> 配置元件 —> CSV数据文件设置
。
CSV数据文件设置组件界面如下:
参数详解:
Name
):脚本中显示的该元件的描述性名称,必须填写。Comments
):对该元件的说明信息。(非必填写)Filename
):待读取文件的名称。可以写入绝对路径,也可以写入相对路径(相对于bin
目录或者脚本文件所在目录),如果直接写文件名,则该文件一定要放在bin
目录中。对于分布式测试,主机和远程机中相应目录下应该有相同的CSV文件,必须填写。(建议填写相对路径,避免脚本迁移时需要修改路径)File Encoding
):文件读取时的编码格式,不填则使用操作系统的编码格式。(非必填写,下拉菜单可选,一般情况下选择UTF-8
即可)Variable Names
):变量名列表。对应参数文件每列的变量名,类似Excel文件的文件头,起到标示作用,同时也是后续引用的标识符,建议采用有意义的英文标示。例如:
eid,name
可以被用变量名来引用:${eid},${name}
。多个变量名之间必须用分隔符分隔。如果该项为空,则文件首行会被读取并解析为列名。(非必填写)
Ignore first line
):是否忽略首行,如果CSV文件中没有表头,则选择False,必须填写。Delimiter
):参数分隔符,将一行数据分隔成多个变量,默认为逗号,也可以使用\t
。如果一行数据分隔后的所获得的变量数,比Vairable Names
中定义的变量少,这些变量将保留以前的值(如果有值的话),必须填写。Allow quoted data?
):是否允许变量使用双引号,允许的话,变量将可以括在双引号内,并且这些变量名可以包含分隔符。(非必填写)Recycle on EOF?
):是否循环读取CSV文件内容,默认为 True,必须填写。因为
CSV Data Set Config
组件一次读入一行,分割后存入若干变量中交给一个线程组,如果线程数超过文本的记录行数,那么可以选择从头再次读入;1)为True时,当已读取完参数文件内的测试用例数据,还需继续获取用例数据时,此时会循环读取参数文件数据(即:读取文件到结尾时,再重头读取文件);
2)为False时,若已至文件末尾,则不再继续读取测试数据;通常在“线程组的线程数“或者”线程组的循环次数“>参数文件组数时,选用False(即:读取文件到结尾时,停止读取文件);
Stop thread on EOF?
):如果线程数超过了数据文件中的变量,是否停止,默认为 False。当Recycle on EOF
为True时,此项无意义。Sharing mode
):共享模式,即参数文件的作用域。如果希望每个线程拥有自己独立的值集合,那么就需要创建一系列数据文件,为每个线程准备一个数据文件,如test1.csv
、test2.csv
等,使用文件的方式test${__threadNum}.csv
,并将Sharing mode
设置为Current thread
。1)所有线程
All threads
(默认):文件在所有线程间共享。即当前测试计划中的所有线程组中的所有的线程都有效。2)当前线程组
Current thread group
:每个文件会针对每个线程组打开一次。即:对当前线程组中的线程有效。3)当前线程
Current thread
:每个文件会针对每个线程单独打开。即:对当前线程有效。Jmeter高级性能测试实战https://edu.csdn.net/course/detail/35834
(2)补充说明:Recycle on EOF
和Stop thread on EOF
的关系
Recycle on EOF?
:遇到文件结束符再次循环?(相当于是否循环读取文件中的每组数据)
Stop thread on EOF?
:遇到文件结束符停止线程?(停止线程的时机,看下面)
解释:
Recycle on EOF
选择True时,Stop thread on EOF
选择True和False无任何意义,因为既然前面已经设置了文件是不停的循环读取,后面的控制停止线程就相当于失效;Recycle on EOF
选择False时,Stop thread on EOF
选择True,则当线程数超过文件里的参数的个数时,实际请求数为参数的个数。如果线程数少于参数个数,则实际请求数以设置的线程数为准;(此状态也是循环读取文件中的数据)Recycle on EOF
选择False时,Stop thread on EOF
选择Flase,当线程数超过文件里参数的个数时,实际请求次数为线程数,但当线程数超过参数次数时,由于没有参数,所以结果仍然是失败的。如果线程数少于参数个数,则实际请求数以设置的线程数为准。(此状态也是循环读取文件中的数据)5、使用CSV数据文件设置组件实现参数化
示例:批量实现用户的登陆操作。
(1)测试计划内包含的元件
添加元件操作步骤:
- 创建测试计划。
- 创建线程组:
选中“测试计划”右键 —> 添加 —> 线程(用户) —> 线程组
。 - 在测试计划(也可以是线程组)里面添加配置元件
CSV Data Set Config
组件:选中“线程组”右键 —> 添加 —> 配置元件 —> CSV 数据文件设置
。 - 在线程组里面,添加取样器“HTTP请求”组件:
选中“线程组”右键 —> 添加 —> 取样器 —> HTTP请求
。 - 在线程组里面,添加监听器“察看结果树”组件:查看结果,
选中“线程组”右键 —> 添加 —> 监听器 —> 察看结果树
。
最终测试计划中的元件如下:
击运行按钮,会提示你先保存该脚本,脚本保存完成后会直接自动运行该脚本。
(2)数据文件内容
先用Excel表格编辑所需的请求参数,内容如下:
我们需要把该文件保存为.csv
格式。
然后使用Notepad++
打开该文件,点击“编码” —> 转为UTF-8编码,防止中文乱码。
最终所得到的.csv
格式文件的内容如下:
(3)线程组元件内容
如果需要使用CSV文件中所有的数据,需要设置线程组元件的线程数或循环次数。
因为在CSV数据文件设置组件中,有Recycle on EOF
和Stop thread on EOF
选项的关系,所以设置线程数和循环次数都可以实现,使用数据文件中的每一组数据进行测试。
(4)CSV数据文件设置组件内容
设置好的CSV数据文件设置组件界面如下:
我一般常用操作,简单说明:
UTF-8
。\t
表示。(5)HTTP请求组件内容
编辑登录接口内容,如下图所示:
在JMeter中使用参数化变量的格式:${变量名}
。
(6)脚本运行结果
该测试脚本运行结果如下图所示:
我们可以看到数据文件中的每个用户都进行了登陆操作。
以上就完成了在JMeter中使用“CSV数据文件设置”组件实现参数化的示例。
Jmeter高级性能测试实战https://edu.csdn.net/course/detail/35834
来源:传说三哥