JMeter的使用——傻瓜式学习【中】

目录

前言

1、JMeter参数化

1.1、什么是参数化

1.2、用户定义的变量

1.2.1、什么时候使用用户定义的变量

1.2.2、使用“用户定义的变量”进行参数化的步骤:

1.2.3、案例

1.3、用户参数

1.3.1、什么时候使用用户参数?

1.3.2、使用“用户参数”进行参数化的步骤:

1.3.3、案例

1.4、CSV数据文件设置

1.4.1、什么时候使用CSV数据文件设置

1.4.2、使用“CSV数据文件设置”进行参数化的步骤?

1.4.3、案例

1.5、函数——随机数据

1.5.1、使用场景

1.5.2、使用“counter函数”进程参数化的步骤:

1.5.3、案例

1.6、4种参数化方式对比

2、JMeter断言

2.1、响应断言

2.2.1、参数认识:

2.1.2、案例: 

2.2、JSON断言

2.2.1、参数认识:

2.2.2、案例:

2.3、持续时间断言

2.3.1、参数说明

2.3.2、案例:

3、JMeter关联

3.1、正则表达式提取器

3.1.1、介绍正则表达式

案例使用一:

案例二:

3.1.2、正则表达式提取器

案例:

3.2、Xpath提取器

案例:

3.3、JSON提取器

案例:


前言

        小白同学,可以先看这篇哦:http://t.csdnimg.cn/geQnl


1、JMeter参数化

1.1、什么是参数化

        定义:使用不同的测试数据,调用相同的测试方法进行测试

        本质:实现测试数据与测试方法的分离

        实现方式举例:

  • 用户定义的变量——全局变量【JMeter有】
  • 用户参数——为每个用户分配不同的参数值【Jmeter有】
  • CSV数据文件设置——文件方式参数化【Jmeter有】
  • 函数——随机数据【JMeter有】
  • 数据库

下面我们来看看JMeter中的几种参数化:

1.2、用户定义的变量

1.2.1、什么时候使用用户定义的变量

        定义全局变量

1.2.2、使用“用户定义的变量”进行参数化的步骤:

  1. 添加线程组
  2. 添加用户定义的变量。格式为变量名 - 变量值
  3. 添加http请求,引用定义的变量名。格式:${变量名}
  4. 添加察看结果树

1.2.3、案例

步骤一:添加线程组

步骤二:添加用户定义的变量

步骤三:添加http请求

http中可以这样填: 

也可以这样填:

步骤四:添加察看结果树

查看运行结果:

1.3、用户参数

1.3.1、什么时候使用用户参数?

        针对同一组参数,当不同的用户来访问时,可以获取到不同的值

1.3.2、使用“用户参数”进行参数化的步骤:

  1. 添加线程组,设置线程数为n(模拟的用户数)
  2. 添加用户参数:第一列添加多个变量名;后续每一列为一组用户数据【看案例】
  3. 添加http请求,引用定义的变量名。格式:${变量名}
  4. 添加查看结果树

1.3.3、案例

步骤一:添加线程组

和上面一样,记得设置线程数,例:2

步骤二:添加用户参数

步骤三:添加http请求

同第一个案例

步骤四:添加察看结果树

同第一个案例

查看运行结果:

 

1.4、CSV数据文件设置

1.4.1、什么时候使用CSV数据文件设置

        当不同的用户,或者同一个用户多次循环时,都可以获取到不同的值

1.4.2、使用“CSV数据文件设置”进行参数化的步骤?

  1. 定义CSV数据文件
  2. 添加线程组
  3. 添加CSV数据文件设置
  4. 添加http请求,引用定义的变量名。格式${变量名}
  5. 添加查看结果树

1.4.3、案例

步骤一:定义CSV数据文件

 

步骤二:添加线程组

同案例1,设置循环次数,例:2

步骤三:添加CSV数据文件设置

 

步骤四:添加http请求

步骤五:添加察看结果树

同案例1 

查看运行结果:

1.5、函数——随机数据

1.5.1、使用场景

        自动生成不重复的数据,让每个用户循环都能取到不同的数据,且不需要提前定义

1.5.2、使用“counter函数”进程参数化的步骤:

  1. 添加线程组,设置虚拟用户数和循环次数
  2. 生成_counter函数
  3. 添加http请求,使用_counter函数。格式:${_counter(FALSE,)}
  4. 添加察看结果树

1.5.3、案例

步骤一:添加线程组

同上,设置线程数2,循环次数2

步骤二:生成_counter函数

参数:

  • 第一个参数

    • True,每个用户(线程)的计数器保持独立,每个用户(线程)计数从1开始计数。
    • False,全局计数器,所以用户(线程)统一从1开始计数。
  • 第二个参数

    • 将计数器函数生成的值赋值给新变量。比如,新变量名称为number,后续可以通过参数化方式${number}引用计数器的值。

步骤三:添加http请求

步骤四:添加察看结果树

同上

查看运行结果:

1.6、4种参数化方式对比

  • 用户定义的变量:作用:定义全局变量;局限性:每次取值(无论是否相同的用户)都是固定值
  • 用户参数:作用:保证不同的用户针对同一组参数,可以取到不同的值;局限性:同一个用户在多次循环中,取到相同的值
  • CSV数据文件设置:作用:保证不同的用户及同一用户多次循环时,都可以取到不同的值;局限性:需要手动进行设置测试数据
  • 函数:作用:保证不同的用户多次循环时,都可以取到不同的值,不需要提前设置;局限性:输入数据有特定的业务要求时无法使用

2、JMeter断言

        断言就是让程序判断预期结果与实际结果是否一致

JMeter中常用的断言:

  1. 响应断言
  2. JSON断言
  3. 持续时间断言

2.1、响应断言

2.2.1、参数认识:

各个参数说明:

1:

  • 响应文本:来自服务器的响应文本,即主体
  • 响应代码:响应的状态码,例如200
  • 响应信息: 响应的信息,例如OK
  • response headers:相应头部
  • request Headers:请求头部
  • request Data:请求数据
  • URL样本:请求的URL
  • Document(text):响应的整个文档
  • Ignore Status:忽略返回的响应状态码

2:

  • 包括:文本包含指定的正则表达式(正则表达式后面会简单介绍一下,现在就理解为包含一个字符串就可以了)
  • 匹配:整个文本匹配指定的正则表达式
  •  Equals:整个返回结果的文本等于指定的字符串(区分大小写)
  • Substring:返回结果的文本包含指定字符串(区分大小写)
  • 否:取反。就是指符合刚才的断言即为错,不符合为对
  • 或者:多个测试模式,有一个满足即为通过。默认是且,所有通过才为通过

2.1.2、案例: 

断言:

添加一个断言结果:

http请求:

运行后,查看结果:

2.2、JSON断言

2.2.1、参数认识:

参数说明:

  • Assert JSON Path exists:用于断言的JSON元素的路径(实际结果)
  • Additionally assert value:如果您想要用某个值生成断言,请选择复选框 
  • Match as regular expression:使用正则表达式断言
  • Expected Value:期望值
  • Expect null:希望为空,则勾选复选框
  • Invert assertion(will fail if above conditions met):反转断言(如果满足上述条件则失败)

2.2.2、案例:

http请求:

JSON断言:

上述的JSON的路径,就是这个值在json格式下对应的位置,$.data.gender对应如下:

运行后,看断言:

 

2.3、持续时间断言

就是用来检查http请求的响应时间是否超出要求范围

2.3.1、参数说明

参数:

  • 持续时间(毫秒):请求允许的最大响应时间,超过则认为失败~

2.3.2、案例:

断言:

http请求同上一个案例相同~

运行,查看断言结果:


3、JMeter关联

        关联:当请求之间有依赖关系,比如一个请求的入参是另一个请求的返回数据。这时就需要用到关联处理

JMeter中常用的关联方法:

  • 正则表达式提取器
  • Xpath提取器
  • JSON提取器

3.1、正则表达式提取器

3.1.1、介绍正则表达式

        正则表达式:就是一个公式 ,或者说 一套规则 ,使用这套规则可以 从任意字符串中提取出想要的数据内
  • 公式格式:左边界(匹配符号)右边界:可以提取出想要获取的数据内容
  • .:是通配符,可以代表任意字符(除换行回车)
  • *: 代表前面的字符出现0次或者多次
  • .*匹配规则:找到左边界值后,往右查找有边界,找到最后面的右边界,中间的所有数据都被记录下来
  • ?: 代表非贪婪匹配,找到左边界后,往右查找匹配右边界,只要有匹配的右边界就停止继续查找;再次查找
  • 左边界和右边界

最终使用: 

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

案例使用一:

我们结合现在网站,来验证一下: 正则表达式在线测试 | 菜鸟工具

 内容:<title>百度一下,你就知道</title><title>百度一下,你就知道</title>

提取目标:<title>百度一下,你就知道</title>

正则表达式:套公式:左边界<title>,右边界:</title>

结果:

和我们预想的不太一样,预想的是:<title>百度一下,你就知道</title>

所以我们要加一个问号,表示非贪婪匹配:

这里是找到了两处,我们可以自己决定要哪一个~

案例二:

内容:

021-1234-1234
022-1234-1235
023-1234-1236
024-1234-1237
025-1234-1238
026-1234-1239
027-1234-1230

预计匹配:所有的号码

表达式错误示范:

正确匹配:

注:

  • 通过一个正则表达式可以提取出多组数据,每组数据设置对应的左边界和右边界即可
  • 每一组数据都可以有一个或者多个值 

3.1.2、正则表达式提取器

  1. 作用:任意格式的响应数据,都可以使用正则表达式提取器进行提取
  2. 添加:
  3. 参数说明:
  •  引用名称:存放提取出的值的参数名称,如填写title
  • 正则表达式:左边界(*?)右边界
  • 模板:用SS引用起来,表示解析出第几个()的值
  • 匹配数字: 1表示第1个值,-1表示所有取值,0表示随机
  • 缺省值:默认值。通常用于后续的逻辑判断,建议使用一些特殊含义的,比如0,NULL,ERROR等。
案例:

请求1:

正则表达式提取器:

请求2:

运行,查看结果树:

 这里的值为空,怎么办?

我们可以添加一个

 调试取样器,不用对里面的值更改,添加了就行:

添加一个查看结果树,运行,看结果:

我们可以看到gender变量确实为空,但下面的变量有值呀,所以我们修改请求2:

重新运行,查看:

3.2、Xpath提取器

  1. 作用:针对html格式的响应结果数据进行提取
  2. 添加位置:
  3. 参数说明:
  • Use Tidy(tolerant parser):当需要处理的页面是html格式时,需要勾选该选项;当需要处理的页面是XML或XHTML格式时,取消选中该选项
  • Quiet表示只显示需要的HTML页面
  • Report errors表示显示响应报错
  • Show warnings表示显示警告
  • Use Namespaces:如果启用该选项,后续的XML解析器将使用命名空间来分辨;
    Validate XML:根据页面元素模式进行检查解析
  • Ignore Whitespace:忽略空白内容
  • Fetch external DTDs:如果选中该项,外部将使用DTD规则来获取页面内容(一些XML元素具有属性,属性包含应用程序使用的信息,属性仅在程序对元素进行读、写操作时,提供元素的额外信息,这时候需要在DTDs中声明)
  • Return entire XPath fragment of text content:返回文本内容的整个XPath片段;
  • 引用名称:存放提取出的值的参数名称
  • Xpath Query:用户提取值的xpath表达式【和UI自动化定位元素一样】
  • 匹配数字:如果xpath路径可以查询出许多的结果,则可以选择提取哪个。0表示随机;-1表示所有;1表示第一个值
  • 缺省值:参数的默认值。可以不填写。通常用于后续的逻辑判断,建议使用一些特殊含义的,比如0,NULL,ERROR等。
案例:

请求1:

Xpath提取器:

http请求2:

添加一个调试取样器,不用对里面的值更改,添加了就行:

添加一个查看结果树,运行,看结果:

3.3、JSON提取器

作用:针对JSON格式的响应结果数据进行提取

添加位置:

参数介绍:

  • Names of create variables:存放提取出的值的参数名称
  • JSON Path Expression:JSON路径表达式
  • Match No:如果JSON路径匹配出许多结果,则可以选择提取哪个:0表示随机;-1表示所有;1表示第一个值
  • Default Value:参数的默认值
案例:

请求1:

JSON提取器:

请求2:

运行结果:

好啦,先到这里咯~~~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/124343.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C现代方法(第15章)笔记——编写大型程序

文章目录 第15章 编写大型程序15.1 源文件15.2 头文件15.2.1 #include指令15.2.2 共享宏定义和类型定义15.2.3 共享函数原型15.2.4 共享变量声明15.2.5 嵌套包含15.2.6 保护头文件15.2.7 头文件中的#error指令 15.3 把程序划分成多个文件15.4 构建多文件程序15.4.1 makefile15.…

10、设置视图组件的Head页面头部标签信息

export default {name: "IndexPage",head() {return {title: "中华小英雄电影第二部",bodyAttrs: {style: "background-color: red;",},meta: [// hid覆盖同名的meta信息{ hid: "description", name: "这是一个关于上学励志教育故…

JSON和Protobuf序列化

文章目录 一、粘包和拆包1、半包问题2、半包现象原理 二、JSON协议通信1、通用类库2、JSON传输的编码器和解码器 三、Protobuf协议通信1、一个简单的proto文件的实践案例2、生成POJO和Builder3、消息POJO和Builder的使用案例1&#xff09;构造POJO消息对象2&#xff09;序列化和…

LeetCode 面试题 16.06. 最小差

文章目录 一、题目二、C# 题解 一、题目 给定两个整数数组 a 和 b&#xff0c;计算具有最小差绝对值的一对数值&#xff08;每个数组中取一个值&#xff09;&#xff0c;并返回该对数值的差 示例&#xff1a; 输入&#xff1a;{1, 3, 15, 11, 2}, {23, 127, 235, 19, 8} 输出&…

基于时间的一次性密码 TOTP 详解

什么是基于时间的一次性密码 TOTP ? 基于时间的一次性密码 TOTP&#xff08;Time-Based One-Time Password&#xff09;&#xff0c;也被称为时间同步动态密码&#xff0c;是一种基于时间的一次性密码算法&#xff0c;通常用于两步验证和多因素身份验证&#xff0c;用于增强静…

【CSDN 每日一练 ★★☆】【二叉树/BSF】二叉树的层序遍历

【CSDN 每日一练 ★★☆】【二叉树/BSF】二叉树的层序遍历 二叉树 BSF 题目 给你一个二叉树&#xff0c;请你返回其按 层序遍历 得到的节点值。 &#xff08;即逐层地&#xff0c;从左到右访问所有节点&#xff09;。 示例&#xff1a; 二叉树&#xff1a;[3,9,20,null,nul…

Android Studio Giraffe 添加 maven { url “https://jitpack.io“ }报错

Android Studio Giraffe 添加 maven { url “https://jitpack.io” }报错 settings.gradle.kts:13:21: Unexpected tokens (use ; to separate expressions on the same line)解决方法 新版maven写法发生了改变&#xff1a; maven { url uri("https://jitpack.io"…

VScode 调试 linux内核

VScode 调试 linux内核 这里调试的 linux 内核是通过 LinuxSD卡(rootfs)运行的内核 gdb 命令行调试 编辑 /home/tyustli/.gdbinit 文件&#xff0c;参考 【GDB】 .gdbinit 文件 set auto-load safe-path /home/tyustli/code/open_source/kernel/linux-6.5.7/.gdbinit在 lin…

PFAF-Net

I 1 _1 1​和I 2 _2 2​是多模态图像&#xff0c;I F _F F​是融合图像。FT 1 _1 1​是基于空间注意力的融合&#xff0c;FT 2 _2 2​是基于通道注意力的融合 作者未提供代码

docker的安装部署nginx和mysql

小白自己整理&#xff0c;如有错误请指示&#xff01; 自我理解&#xff1a;docker就是把应用程序所用的依赖程序&#xff0c;函数库等相关文件打包成镜像文件&#xff0c;类似系统光盘&#xff0c;然后可以在任意电脑上安装使用&#xff08;方便运维人员部署程序&#xff09;…

jenkins+sonar

参考&#xff1a; 1、jenkins集成sonar 1&#xff09;jenkins集成sonar流水线部署 jenkins集成sonar流水线部署_sonar jenkins-CSDN博客 2&#xff09;jenkinssonar 实现代码检测 jenkinssonar 实现代码检测_jenkins sonar_dsdasun的博客-CSDN博客 2、配置&#xff1a;son…

论文阅读——RoBERTa

一、LM效果好但是各种方法之间细致比较有挑战性&#xff0c;因为训练耗费资源多、并且在私有的不同大小的数据集上训练&#xff0c;不同超参数选择对结果影响很大。使用复制研究的方法对BERT预训练的超参数和数据集的影响细致研究&#xff0c;发现BERT训练不够&#xff0c;提出…

《Effective Java》读书笔记(1-2章)

第一章 创建和销毁对象 1. 考虑用静态代替构造方法 想要获取一个类的实例&#xff0c;一种传统的方式是通过共有的构造器&#xff0c;当然还可以使用另一种技术&#xff1a;提供共有的静态工厂方法。 什么是静态工厂&#xff1f; public static Boolean valueOf(boolean b) …

Ansible的安装和部署

目录 1.Ansible的安装 2.构建Ansible清单 直接书写受管主机名或ip 设定受管主机的组[组名称] 主机规格的范围化操作 指定其他清单文件 ansible命令指定清单的正则表达式 3.Ansible配置文件参数详解 配置文件的分类与优先级 常用配置参数 4.构建用户级Ansible操作环…

Spring面试题:(一)IoC,DI,AOP和BeanFactory,ApplicationContext

IoC&#xff0c;DI&#xff0c;AOP思想 IOC就是控制反转&#xff0c;是指创建对象的控制权的转移。以前创建对象的主动权和时机是由自己把控的&#xff0c;而现在这种权力转移到Spring容器中&#xff0c;并由容器根据配置文件去创建实例和管理各个实例之间的依赖关系。对象与对…

Java的单元测试Testng和mock

目录 单元测试重要性 TestNG TestNG官网介绍 TestNG教程 TestNG注解: TestNG配置注解实例

结构体和联合体嵌套访问

在JSON项目中&#xff0c;使用了联合体和结构体之间的嵌套&#xff0c;但是在访问内部的联合体和结构体的时候出现了问题&#xff0c;这篇文章作为记录&#xff0c;也希望能帮助遇到相同问题的好伙伴。 struct lept_value {union {struct str{char *s;size_t len;};double n;}…

【系统架构】架构风格专题

目录 1、定义 2、通用架构风格分类 3、架构风格比较 4、示例&#xff1a;管道-过滤 VS 数据仓库&#xff09;比较因素分析 1、定义 架构风格&#xff1a;描述某一特定应用领域中系统组织方式的惯用模式&#xff0c;反映了领域中众多系统所共有的结构和语义特性&#xff0c…

c++设计模式三:工厂模式

本文通过一个例子简单介绍简单工厂模式、工厂模式和抽象工厂模式。 1.简单工厂&#xff08;静态&#xff09; 假如我想换个手机&#xff0c;换什么手机呢&#xff1f;可以考虑苹果或者华为手机&#xff0c;那我们用简单工厂模式来实现这个功能&#xff1a; 我们关注的产品是手…

Lambda表达式与“::“方法引用 判空包装类Optional

函数式接口 函数式接口&#xff08;Functional Interface&#xff09;就是有且仅有一个抽象方法&#xff0c;但是可以有多个非抽象方法的接口。函数式接口可以被隐式转换为Lambda表达式。 Lambda表达式与"::"方法引用 方法引用主要是对Lambda表达式的一种优化&…