参数化释义
什么是参数化?从字面上去理解的话,就是事先准备好数据(广义上来说,可以是具体的数据值,也可以是数据生成规则),而非在脚本中写死,脚本执行时从准备好的数据中取值。
参数化:是自动化测试脚本的一种常用技巧,可将脚本中的某些输入使用参数来代替,如登录时利用GET/POST请求方式传递参数的场景,在脚本运行时指定参数的取值范围和规则。
脚本在运行时,根据需要选取不同的参数值作为输入,该方式称为数据驱动测试(Data Driven Test),而参数的取值范围被称为数据池(Data Pool)。
在JMeter里我们可以通过配置元件来完成参数化实现某一场景运行
参数化实现
1.CSV Data Set Config(CSV数据文件设置)
CSV可以从指定的文件中逐行提取文本内容,根据所设置的分割符拆解本行内容并自动关联内容与变量名,取样器可以引用这些变量
CSV使用:线程组右键→添加→配置元件→CSV Data Set Config
各项参数详解如下:
名称 脚本显示的这个元件的描述性名称
文件名 待读取文件的名称。可以写入绝对路径,也可以写入相对路径(相对于Jmeter bin目录),如果直接写文件名,则该文件要放在bin目录中。对于分布式测试,主机和远程机中相应目录下应该有相同的CSV文件
文件编码 文件读取时的编码格式,不填则使用操作系统的编码格式
变量名称 多个变量名之间必须用间隔符分割。如果该项为空,则文件首行会被读取并解析为列名列表
是否忽略首行 如果CSV文件中没有表头,则选择false
分割符 将一行数据分割成多个变量,默认为逗号,也可以使用“\t”.如果一行数据分割后的值比变量名称中定义的变量 少,这些变量将保留以前的值(如果有值的话)
是否允许使用双引号 允许的话,变量将可以在双引号内,并且这些变量名可以包含分割符
线程共享模式
线程共享模式,是指多个线程对文件数据取值顺序模式,JMeter提供了3种模式:
所有线程 如果脚本有多个线程组,在这种模式下,各线程组的所有线程也要依次唯一顺序取值。例如,脚本有2个线程组,各有2个线程,文件内有5行数据,脚本运行时,将如下图一样循环往复取值:
当前线程组 各个线程组之间隔离,线程组内的线程顺序唯一取值。
当前线程。这种模式下,每个线程独立,顺序唯一取值。
上面写的线程共享模式多看两遍其实就懂了 我就不演示了
这里我写一个CSV用来验证一下 JMeter里的参数化使用
用WPS写一个CSV(当然你用notepad++也行 我是个人习惯)
在JMeter里添加CSV(CSV要放在你要使用的脚本前面)
写好变量名称(我这里用的是user pwd)
登录脚本里的消息体数据里的内容也要换成刚刚设置的变量名称 (你要用 参数传值就该参数里的)
改一下线程发一下试试(我只提前注册了4个账号 所以这里也只用了4个线程数 发的时候用管理员账户关闭发帖时的图片验证码)
看下结果
OK用户数据被读取到了 发帖成功
补一其他几种参数化方法:
2.用户参数:
创建方式:HTTP请求上右键→添加→前置处理器(Pre processors)–>用户参数。
通过添加变量(user pwd)→添加用户
发一下试试
ok(没test5用户- -忘了 请忽略)
3.用户定义的变量
创建方式:线程组上右键→配置元件→用户定义的变量
【用户定义的变量】一般并非用来做HTTP请求参数化,而是用来定义全局变量,比如参数化文件路径、host、url等。
【用户定义的变量】创建在【线程组】上,则在线程组内生效,如果创建在【Test Plan】上,则对所有线程组生效。
4.随机数
创建方式:工具→函数助手对话框→选择一个功能→Random
这个脚本用不上 我网上找个图给大家瞅一下吧
运行脚本,察看结果树,可以看到效果:
这种方式适用于值在一定区间无规律随机取值的变量参数化,例如价格、数量等,并不适用于有较强规则的变量进行参数化,例如手机号。