性能测试|电商业务性能测试(二): Jmeter 参数化功能实现注册登录的数据驱动

简介: 性能测试|电商业务性能测试(二): Jmeter 参数化功能实现注册登录的数据驱动

1. 前置条件

此例使用的是 GitHub 上一个开源的电商项目 mall,需要的可以去 GitHub 上下载部署,有详细的部署教程:

2. 场景抽离

在这里插入图片描述

首先我们需要对测试的场景进行抽离,明确场景的接口、参数和比例。通过查看API文档,我们抽离除了如下注册的业务流程:

在这里插入图片描述
总结如下:

  • 业务流程 :验证码->注册->登录,
  • 接口比例 :这三个接口场景的比例为1:1:1关系
  • 数据传递 :获取的鉴权信息需保存后未后续的请求做数据支持

3. 实操演示

3.1 IP + 端口的数据驱动

在每一个接口请求中,都需要输入请求的ip和端口,这样费事费力。因此 jmeter 提供了 CSV Data Set Config 来将数据从外部文件读取, HTTP Request Defaults 设置请求默认值,这两种方法配合使用便可完成 IP + 端口 的数据驱动

CSV Data Set Config从外部文件读取数据

1、如下图位置选择

在这里插入图片描述

2、设置 CSV Data Set Config
首先创建好需要导入的数据文件,这里需要的是 IP 和端口:

在这里插入图片描述

设置 CSV Data Set Config

在这里插入图片描述

设置说明:

  • Filename :填入你需要导入的文件地址
  • File encoding :选择编码方式,特别是有中文的时候记得要选 UTF-8
  • Variable Names :设置变量名,要和数据文件中的格式一一对应
  • Ignore first line :是否忽视第一行,有时候我们数据文件的第一行可能是个说明 title ,并不是我们实际需要的数据,这个时候就可以在此选择 true ,将其忽略
  • Delimiter(use '\t' for tab) :如果你的数据文件的数据之间使用 tab 进行分割的,这里就填\t用来说明是tab分割,如果是用逗号 , 分割的,那么就直接填入逗号 , 即可

HTTP Request Defaults设置请求默认值

1、选择 HTTP Request Defaults

在这里插入图片描述

2、设置 HTTP Request Defaults 参数化

将请求的ip和端口进行参数化,格式是${参数};参数要与 CSV Data Set Config 中设置的保持一致,这样设置好以后,后面所有的请求都可以不用再填写ip和端口了
在这里插入图片描述

3.2 前置处理器JSR223 PreProcessor

查看项目API文档,知道了获取验证码的接口需要传电话号码作为参数,而性能测试需要很多并发,所以电话号码肯定是通过参数传递进入,且不可重复;

在这里插入图片描述
为了解决上述问题,我们可以引入前置处理器 JSR223 PreProcessor ,他可以在其中写入Java代码运行,这样就很方便造数据了:
在这里插入图片描述
另外在login接口返回值需要获取token,将获取的token存入指定文件中,以备后面的请求使用
在这里插入图片描述
在这里插入图片描述

3.3 返回值获取传递

JSON Extractor

在上述接口中,会返回验证码用于注册;同样的在登录接口中会返回token用于鉴权;那么就可以利用 JSON Extractor 来完成

1、添加 JSON Extractor

在这里插入图片描述

2、设置变量名和json路径

在这里插入图片描述

3.4 结果调试

有时候想看下脚本对不对,可以利用 Debug Sampler 来进行调试

在这里插入图片描述
可以看到所有的变量值,最终完成脚本调试,顺利通过。

在这里插入图片描述

相关文章
|
7月前
|
测试技术
自动化测试登录后的功能
在自动化测试的时候,往往许多功能需要登录以后才可以进行操作的,在这里我介绍一种方法,在登录以后将Cookies信息存入本地文件,在测试登录以后操作的时候再从本地文件把信息调出来存入Cookies
142 4
|
存储 安全 API
认证服务---OAuth2.0基本介绍,微博登录测试【上篇】
这篇文章是关于OAuth2.0的介绍和微博登录测试的教程,详细解释了OAuth2.0的基本概念和授权流程,并指导读者如何在新浪微博开放平台进行应用创建、设置回调地址,以及使用Postman工具进行授权测试,为实现第三方微博登录功能做准备。
认证服务---OAuth2.0基本介绍,微博登录测试【上篇】
|
JSON 前端开发 API
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
913 5
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
|
前端开发 JavaScript 测试技术
使用ChatGPT生成登录产品代码的测试用例和测试脚本
使用ChatGPT生成登录产品代码的测试用例和测试脚本
422 35
|
JavaScript 前端开发 Java
使用ChatGPT生成关于登录产品代码的单元测试代码
使用ChatGPT生成关于登录产品代码的单元测试代码
254 16
|
搜索推荐 测试技术 API
探秘电商API:从测试到应用的深度解析与实战指南
电商API是电子商务背后的隐形引擎,支撑着从商品搜索、购物车更新到支付处理等各个环节的顺畅运行。它通过定义良好的接口,实现不同系统间的数据交互与功能集成,确保订单、库存和物流等信息的实时同步。RESTful、GraphQL和WebSocket等类型的API各自适用于不同的应用场景,满足多样化的需求。在测试方面,使用Postman、SoapUI和jMeter等工具进行全面的功能、性能和安全测试,确保API的稳定性和可靠性。未来,随着人工智能、大数据和物联网技术的发展,电商API将进一步智能化和标准化,为用户提供更个性化的购物体验,并推动电商行业的持续创新与进步。
718 5
|
人工智能 供应链 安全
AI辅助安全测试案例某电商-供应链平台平台安全漏洞
【11月更文挑战第13天】该案例介绍了一家电商供应链平台如何利用AI技术进行全面的安全测试,包括网络、应用和数据安全层面,发现了多个潜在漏洞,并采取了有效的修复措施,提升了平台的整体安全性。
814 4
|
JavaScript 前端开发 数据库
测试开发之路--Flask 之旅 (四):登录与权限控制
本文介绍了如何使用 Flask-Security 和 Flask-Login 实现权限管理和用户登录功能。首先讲解了 Flask 的消息闪现功能,用于向模板传递信息。接着介绍了如何利用 Flask-Security 的 `roles_required` 和 `roles_accepted` 装饰器保护页面,并展示了如何通过 `current_user` 获取当前用户信息。最后提到了使用 Flask-Login 时应避免升级至 0.4.0 版本,以防出现兼容性问题。通过这些技术,搭建了一个基本的用户权限管理系统。
725 6
测试开发之路--Flask 之旅 (四):登录与权限控制
|
测试技术 数据安全/隐私保护
北邮人论坛登录页面测试用例
北邮人论坛登录页面测试用例
305 1
|
监控 搜索推荐 测试技术
电商API的测试与用途:深度解析与实践
在电子商务蓬勃发展的今天,电商API成为连接电商平台、商家、消费者和第三方开发者的重要桥梁。本文深入探讨了电商API的核心功能,包括订单管理、商品管理、用户管理、支付管理和物流管理,并介绍了有效的测试技巧,如理解API文档、设计测试用例、搭建测试环境、自动化测试、压力测试、安全性测试等。文章还详细阐述了电商API的多样化用途,如商品信息获取、订单管理自动化、用户数据管理、库存同步、物流跟踪、支付处理、促销活动管理、评价管理、数据报告和分析、扩展平台功能及跨境电商等,旨在为开发者和电商平台提供有益的参考。
399 0
下一篇
开通oss服务