zoukankan      html  css  js  c++  java
  • Jmeter学习笔记(十五)——常用的4种参数化方式

    一、Jmeter参数化概念

          当使用JMeter进行测试时,测试数据的准备是一项重要的工作。若要求每次迭代的数据不一样时,则需进行参数化,然后从参数化的文件中来读取测试数据。

         参数化是自动化测试脚本的一种常用技巧。简单来说,参数化的一般用法就是将脚本中的某些输入使用参数来代替,在脚本运行时指定参数的取值范围和规则;

         这样,脚本在运行时就可以根据需要选取不同的参数值作为输入。这种方式通常被称为数据驱动测试(Data Driven Test),参数的取值范围被称为数据池(Data Pool)

    二、JMeter参数化方式之使用场景对比

    参数化方式使用场景
    User Parameters(用户参数) 适用于参数取值范围很小的时候使用  
    CSV Data Set Config(CSV数据控件) 适用于参数取值范围较大的时候使用,该方法具有更大的灵活性  
    User Defined Variables(用户自定义变量) 一般用于Test Plan中不需要随请求迭代的参数设置,如:Host、Port Number  
    Function Helper(函数助手) 可作为其他参数化方式的补充项,如:随机数生成的函数${__Random(,,)}  

    三、各种方式演示

    1、User Parameters(用户参数)

    (1)在线程组下面添加用户参数

    添加->前置处理器->用户参数,并且设置参数项和参数值

     (2)添加http请求

    请求参数的值使用用户参数

     (3)设置线程数

    设置线程数=2,即2个虚拟用户数,对应User Parameters中设置的2个用户

    注意这里只能设置线程数2,如果是循环次数设置为2,那么指的是拿用户1循环。

     (4)执行结果

     

     2、CSV Data Set Config(CSV数据控件)

    (1)新建数据文件

    (2)在http请求上添加CSV Data Set Config

    添加->配置元件->CVS数据文件设置,设置文件存在路径、文件编码、变量名称

    Configure the CSV Data Source配置项&功能:

    配置项取值or选择项
    Filename(文件名) 参数化文件的读取位置,即保存参数化数据的文件目录。可为绝对路径,也可为相对路径。在分布式测试中,还是利用相对路径比较方便,因为有的机器可能安装路径不一样,同时可避免脚本迁移时需要修改路径
    File Encoding(文件编码) 编码格式,选择utf-8
    Variable Names(变量名称) 变量名称。这里定义的变量名称,后面就可以直接用来引用了。(多个变量名称以逗号隔开,例如username,passwd。参数化文件中同样有对应的两列数据。)
    Ignore first line(忽略第一行) 忽略第一行数据(类似LR中第一行数据是变量名称,如果你的配置文件中为了记忆第一行也是变量名,可以选择是忽略该行数据)
    Delimiter(分隔符) Variable Names中的参数分隔符,默认为英文逗号
    Allow quoted data?(是否允许带引号) 是否允许引用数据,默认false。选项为“true”时对全角字符的处理可能会出现乱码
    Recycle on EOF?(遇到文件结束符再次循环) 是否循环读取参数文件内容;因为CSV Data Set Config一次读入一行,分割后存入若干变量中交给一个线程,如果线程数超过文本的记录行数,那么可以选择从头再次读入
    Stop thread on EOF?(遇到文件结束符停止线程) 当Recycle on EOF为False时(读取文件到结尾),停止进程,当Recycle on EOF为True时,此项无意义
    Sharing mode(共享模式) 共享模式,即参数文件的作用域:All Threads;Current Thread Group;Current Thread

    (3)设置http请求的参数

     (4)设置线程

    设置线程数3或者设置循环次数3都可以

     (5)执行结果

     

     

     3、User Defined Variables(用户自定义变量)

    (1)添加用户自定义变量

    添加->配置元件->用户定义的变量

     (2)http请求的参数设置

     (3)执行结果

     4、Function Helper(函数助手)

    (1)打开函数助手对话框,选择需要的函数并配置

     (2)http请求参数设置

    复制函数助手生成的函数字符串

     (3)执行结果

    每次执行传的参数都不一样

  • 相关阅读:
    MySQL与PostgreSQL对比
    Elastic Job3.0
    Nacos Config动态刷新值
    clickhouse数据类型
    字符串和整数之间的转换
    STL之优先队列 priority_queue
    c++智能指针
    springcloud gateway: discovery: locator: enabled: true 解释
    工具资源下载链接 webstorm
    技术链接汇总
  • 原文地址:https://www.cnblogs.com/pachongshangdexuebi/p/11654974.html
Copyright © 2011-2022 走看看