我们本篇文章演示在请求中,以Json形式的数据格式,实现JMeter参数化。

我们以小项目学院管理系统为例,下载地址:点击下载,里面有详细的启动配置说明和API接口文档。

接口文档如下:

学院-新增
1) 请求方法:POST
2) 请求地址:http://127.0.0.1:8000/api/departments/
3) 请求JOSN报文:(需要Content-Type=application/json)
4) 调用传入的json串如下(可新增多条,之间用,隔开):
{
"data": [
{
"dep_id":"T01",
"dep_name":"Test学院",
"master_name":"Test-Master",
"slogan":"Here is Slogan"
}
]
}
5) 新增成功返回报文:
{
"already_exist": {
"results": [],
"count": 0
},
"create_success": {
"results": [
{
"dep_id": "T02",
"dep_name": "Java学院",
"master_name": "Java-Master",
"slogan": "java"
}
],
"count": 1
}
}
6) 新增失败id已存在-返回报文:
{
"already_exist": {
"results": [
{
"dep_id": "T01",
"dep_name": "Test学院",
"master_name": "Test-Master",
"slogan": "Here is Slogan"
}
],
"count": 1
},
"create_success": {
"results": [],
"count": 0
}
}
7) 新增失败json格式错误:
{
"status_code": 400,
"detail": "请求体参数格式错误。"
}

1、使用“CSV数据文件设置”组件实现参数化

例如:现在有一个需求,实现批量添加学院信息。

(1)测试计划中的元件

添加元件操作步骤

  1. 创建测试计划。
  2. 创建线程组:选中“测试计划”右键 —> 添加 —> 线程(用户) —> 线程组
  3. 在线程组中,添加配置元件"HTTP信息头管理器"组件:选中“线程组”右键 —> 添加 —> 配置元件 —> HTTP信息头管理器
  4. 在线程组中,添加配置元件CSV Data Set Config组件:选中“线程组”右键 —> 添加 —> 配置元件 —> CSV数据文件设置
  5. 在线程组中,添加取样器“HTTP请求”组件:选中“线程组”右键 —> 添加 —> 取样器 —> HTTP请求
  6. 在线程组中,添加监听器“察看结果树”组件:查看结果,选中“线程组”右键 —> 添加 —> 监听器 —> 察看结果树

最终测试计划中包含的元件如下:

点击运行按钮,会提示你先保存该脚本,脚本保存完成后会直接自动运行该脚本。

(2)数据文件内容

先用Excel表格编辑所需的请求参数,内容如下:

我们需要把该文件保存为.csv格式。

然后使用Notepad++打开该文件,点击“编码” —> 转为UTF-8编码,防止中文乱码。

最终所得到的.csv格式文件的内容如下:

(3)线程组元件内容

如果需要使用CSV文件中所有的数据,需要设置线程组元件的线程数或循环次数。

因为在CSV数据文件设置组件中,有Recycle on EOFStop thread on EOF选项的关系,所以设置线程数和循环次数都可以实现,使用数据文件中的每一组数据进行测试。

(4)HTTP信息头管理器组件内容

因为我们要使用Post请求发送Json数据,所以需要在请求头中设置Content-Type=application/json

如果我们不在请求头中进行设置,默认请求头的Content-Type值为text/plain,(这在前面的Post请求文章中有详细的说明),并且在接口文档中也有明确的要求说明。

如下图所示:

(5)CSV数据文件设置组件内容

如下图所示:

我一般常用操作,简单说明:

  • 文件名:就直接浏览选择文件即可,也就是使用数据文件的绝对路径。
  • 文件编码选择UTF-8
  • 变量名称:就是把数据文件的每个变量名都填写上,中间用逗号分割。
  • 忽略首行:选择True,如果CSV文件中首行写的是变量名称,选择忽略首行。
  • 分隔符:如果CSV文件中的数据,使用的是逗号隔开,就是默认值。如果是制表符,就用\t表示。
  • 是否允许带引号?:如果变量值中有引号就选择True,没有则默认False即可。
  • 其他一般默认选择。如果需求看上面说明中写的很详细,按工作中实际情况选择。

(6)HTTP请求组件内容

在JMeter中使用参数化变量的格式:${变量名}

编辑添加学院接口内容,如下图所示:

我们可以看到${变量名}中的引用变量名,是以CSV数据文件设置组件中变量名称中定义变量名为准。如果不在变量名称栏中定义任何内容,就以数据文件中的标题列名为引用变量名。

(7)脚本运行结果

该测试脚本运行结果如下图所示:

可以看到四个学院都成功添加到数据库中了。

我们再去数据库中查看一下,如下图所示:

这样就说明我们的JMeter测试脚本实现成功了。

2、使用“用户参数”组件实现参数化

接下来我们使用“用户参数”组件,来实现上面的接口。

(1)添加元件操作步骤

  1. 创建测试计划。
  2. 创建线程组:选中“测试计划”右键 —> 添加 —> 线程(用户) —> 线程组
  3. 在线程组中,添加配置元件"HTTP信息头管理器"组件:选中“线程组”右键 —> 添加 —> 配置元件 —> HTTP信息头管理器
  4. 在线程组中,添加取样器“HTTP请求”组件:选中“线程组”右键 —> 添加 —> 取样器 —> HTTP请求
  5. 在取样器中,添加前置处理器“用户参数”组件:选中“取样器”右键 —> 添加 —> 前置处理器 —>用户参数
  6. 在线程组中,添加监听器“察看结果树”组件:查看结果,选中“线程组”右键 —> 添加 —> 监听器 —> 察看结果树

最终测试计划中的元件,如下图所示:

(2)元件中的内容介绍

其实就是把上面示例中,CSV数据文件设置组件删除掉,然后在取样器请求的下一级,添加一个用户参数组件。

其他元件的内容都没有任何的改动。

所以这里指展示用户参数组件中的内容,其他组件看上面配置就好。

用户参数组件内容如下:

测试结果也是完全通过,数据能够直接存储到数据库中。

数据库中,如下图所示:

说明我们上面的JMeter脚本执行成功了。

最新文章

  1. 警惕!高版本VS发布时预编译导致Mono中Razor找不到视图
  2. 条款19:设计class犹如设计type
  3. design philosophy
  4. Windows Azure HandBook (7) 基于Azure Web App的企业官网改造
  5. 开启MySQL日志
  6. asp.net中验证控件的使用方法
  7. Java 时间和字符换的处理
  8. 配置sonar、jenkins进行持续审查
  9. 奇怪的电梯(HDU1548) (Dijkstra)或者(BFS)
  10. Auto Updating the exe from a network location when application starts z
  11. (原创)LAMP教程5-配置VirtualBox虚拟机中centos6.4的网卡
  12. 新年Uber司机端换新装啦!
  13. axis2 webservices 411错误解决办法
  14. Python正则表达式指南(转载)
  15. hdu 4741 Save Labman No.004(2013杭州网络赛)
  16. Windows下Nginx的安装与使用(一):配置端口转发
  17. 有关conv_std_logic_vector和conv_integer
  18. K:正则表达式之基础简介
  19. javascript函数大全
  20. Mahout推荐算法之SlopOne

热门文章

  1. Springboot+Vue前后端分离的博客项目
  2. 批处理打造MySQLCleaner
  3. hdu3074 线段树求区间乘积(单点更新)
  4. Win64 驱动内核编程-25.X64枚举和隐藏内核模块
  5. Intel汇编语言程序设计学习-第一章 基本概念
  6. 还在一个模块打天下嘛?你知道引入Jetpack架构后,你的App会发生哪些奇妙的变化吗?
  7. (CV学习笔记)看图说话(Image Captioning)-2
  8. Ravindrababu Ravula老师的数据结构与算法
  9. Redis数据结构—链表与字典
  10. vue中v-if与v-show的区别以及使用场景