jmeter参数化

一、参数化

参数化:简单的来理解一下,我们录制了一个脚本,这个脚本中有登录操作,需要输入用户名和密码,假如系统不允许相同的用户名和密码同时登录,或者想更好的模拟多个用户来登录系统。

这个时候就需要对用户名和密码进行参数化,使每个虚拟用户都使用不同的用户名和密码进行访问。

前提:

假如,我们录制好了一个脚本(可以用badboy工具录制),在jmeter中打开,找到有用户名和密码的页面。如下:


1、我们需要“参数化”的数据,这里我用记事本写了五个用户名和密码,保存为.dat格式的文件。


我将这个文件放在了我的( D:\test.dat  )路径下。关于如何得到成百上千的用户名和密码,首先要在数据库中创建这些数据,将数据导出,整理保存,这里就不深究。

2.好,我们要编写函数来调用这个test.dat文件,怎么弄,

点击菜单栏“选项”—->函数助手对话框,看下图。

.dat文件第一列从0开始取得



3.把我们写好的函数复制到“登录”页面用户名和密码胡位置。


好了,现在我们的参数化设置完成,在脚本的时候,会调用我们D盘下面的test.dat文件,第一列是用户,第二列是密码。

注意用户名和密码是一一对应的,中间用户逗号(,)隔开。

二、检查点(断言)

检查点:简单的来理解一下,上一章讲到,我们对用户名和密码进行了参数化,那么怎样来判断jmeter有没有正确调用test.dat里面的文件呢。当然,我们可以从结果图表中查看。但我还是想在“登录”这个地方进行一下检查。

jmeter里面的检查点通过添加断言来完成。

1.

右键点击我们的“登录”页面—->添加—->断言—->响应断言


来设置一下断言页面,我们想断言什么呢?调用的用户名和密码是不是我们test.dat文件里的用户名和密码,怎样来进行呢。

3.

这里我们需要分别准备两个文件,一个放用户名,一个放密码。


下面编写函数来调用这两个文件,如何编写先看我上一篇文章。

在响应断言页面添加两个“模式”


(可以直接调用原来test.dat的数据进行检查)

4.

添加一个断言结果

右键点击我们的“登录”页面—->添加—->监听器—->断言结果

还可以再添加一个“查看结果树” 右键点击我们的“登录”页面—->添加—->监听器—->查看结果树



在线程组中设置5个用户,点击运行运行。

查看断言结果:


查看结果树:


好了,检查点添加成功!

三、集合点

集合点:简单来理解一下,虽然我们的“性能测试”理解为“多用户并发测试”,【(但真正的并发是不存在的,为了更真实的实现并发这感念,我们可以在需要压力的地方设置集合点,)对原文的纠正:Ramp-Up Period(in-seconds)代表隔多长时间执行,0代表同时并发;】

还拿那个用户和密码的地方,每到输入用户名和密码登录的地方,所有的虚拟用户都相互之间等一等,然后,一起访问。(红军排长说:等一等!大家一起冲啊!这样给敌人的压力是很大的。嘻嘻!)

1.

接着之前创建的脚本,右键点击 step1—->定时器—->Synchronizing Timer


(录制的step1控制器,是“简单控制器”)这样子就添加了一个“集合点”,下面来设置一下集合点。


2.

我们添加完之后的列表是这个样子的,


发现了没,我们集合点的位置不对,应该在登录的前面才对。怎么弄呢?

2.11版本以后,直接拖动,放到想要的位置


原文:

http://www.cnblogs.com/fnng/archive/2011/07/28/2119896.html

http://www.cnblogs.com/fnng/archive/2011/07/28/2119921.html

http://www.cnblogs.com/fnng/archive/2011/07/28/2119941.html


        </div>用Markdown编辑器写博客

本Markdown编辑器使用StackEdit修改而来,用它写博客,将会带来全新的体验哦:

  • Markdown和扩展Markdown简洁的语法
  • 代码块高亮
  • 图片链接和图片上传
  • LaTex数学公式
  • UML序列图和流程图
  • 离线写博客
  • 导入导出Markdown文件
  • 丰富的快捷键

快捷键

  • 加粗 Ctrl + B
  • 斜体 Ctrl + I
  • 引用 Ctrl + Q
  • 插入链接 Ctrl + L
  • 插入代码 Ctrl + K
  • 插入图片 Ctrl + G
  • 提升标题 Ctrl + H
  • 有序列表 Ctrl + O
  • 无序列表 Ctrl + U
  • 横线 Ctrl + R
  • 撤销 Ctrl + Z
  • 重做 Ctrl + Y

Markdown及扩展

Markdown 是一种轻量级标记语言,它允许人们使用易读易写的纯文本格式编写文档,然后转换成格式丰富的HTML页面。 —— [ 维基百科 ]

使用简单的符号标识不同的标题,将某些文字标记为粗体或者斜体,创建一个链接等,详细语法参考帮助?。

本编辑器支持 Markdown Extra ,  扩展了很多好用的功能。具体请参考Github.

表格

Markdown Extra 表格语法:

项目价格
Computer$1600
Phone$12
Pipe$1

可以使用冒号来定义对齐方式:

项目价格数量
Computer1600 元5
Phone12 元12
Pipe1 元234

定义列表

Markdown Extra 定义列表语法: 项目1 项目2
定义 A
定义 B
项目3
定义 C

定义 D

定义D内容

代码块

代码块语法遵循标准markdown代码,例如:

@requires_authorization
def somefunc(param1='', param2=0):
    '''A docstring'''
    if param1 > param2: # interesting
        print 'Greater'
    return (param2 - param1 + 1) or None
class SomeClass:
    pass
>>> message = '''interpreter
... prompt'''

脚注

生成一个脚注1.

目录

[TOC]来生成目录:

数学公式

使用MathJax渲染LaTex 数学公式,详见math.stackexchange.com.

  • 行内公式,数学公式为: Γ(n)=(n1)!nN Γ ( n ) = ( n − 1 ) ! ∀ n ∈ N
  • 块级公式:

x=b±b24ac2a x = − b ± b 2 − 4 a c 2 a

更多LaTex语法请参考 这儿.

UML 图:

可以渲染序列图:

Created with Raphaël 2.1.2 张三 张三 李四 李四 嘿,小四儿, 写博客了没? 李四愣了一下,说: 忙得吐血,哪有时间写。

或者流程图:

Created with Raphaël 2.1.2 开始 我的操作 确认? 结束 yes no
  • 关于 序列图 语法,参考 这儿,
  • 关于 流程图 语法,参考 这儿.

离线写博客

即使用户在没有网络的情况下,也可以通过本编辑器离线写博客(直接在曾经使用过的浏览器中输入write.blog.youkuaiyun.com/mdeditor即可。Markdown编辑器使用浏览器离线存储将内容保存在本地。

用户写博客的过程中,内容实时保存在浏览器缓存中,在用户关闭浏览器或者其它异常情况下,内容不会丢失。用户再次打开浏览器时,会显示上次用户正在编辑的没有发表的内容。

博客发表后,本地缓存将被删除。 

用户可以选择 把正在写的博客保存到服务器草稿箱,即使换浏览器或者清除缓存,内容也不会丢失。

注意:虽然浏览器存储大部分时候都比较可靠,但为了您的数据安全,在联网后,请务必及时发表或者保存到服务器草稿箱

浏览器兼容

  1. 目前,本编辑器对Chrome浏览器支持最为完整。建议大家使用较新版本的Chrome。
  2. IE9以下不支持
  3. IE9,10,11存在以下问题
    1. 不支持离线功能
    2. IE9不支持文件导入导出
    3. IE10不支持拖拽文件导入


  1. 这里是 脚注内容.
### JMeter 参数化测试实现方法 #### 参数化测试简介 参数化测试是一种测试方法,它允许使用不同的数据集多次运行相同的测试逻辑。JMeter 提供了多种实现参数化的方式,可以根据具体需求选择合适的实现方式。 #### 参数化实现方式 1. **CSV Data Set Config** - CSV Data Set Config 是 JMeter 中最常用的参数化方式,适用于参数取值范围较大的情况。它能够从 CSV 文件中读取数据并生成变量,供 JMeter 脚本引用。 - 使用 CSV Data Set Config 时,需要指定文件名、变量名以及是否循环读取等参数。通过这种方式,可以轻松实现数据驱动测试,避免每次修改用例时都需要重新编辑 JMeter 脚本 [^2]。 2. **User Parameters** - User Parameters 适用于参数取值范围较小的情况。可以在测试计划中直接定义参数及其取值,这些参数可以在整个测试计划中被引用 [^3]。 3. **User Defined Variables** - User Defined Variables 通常用于测试计划中不需要随请求迭代的参数设置。可以在测试计划的任何地方定义这些变量,并在整个测试计划中使用它们 [^3]。 4. **FunctionHelper 中的函数** - FunctionHelper 提供了一些内置函数,可以作为其他参数化方式的补充。例如,可以使用 `${__Random(,)}` 函数生成随机数,为测试增加更多的不确定性 [^3]。 #### 数据驱动测试的实现 为了实现数据驱动测试,可以将测试用例的数据存储在外部文件(如 CSV 文件)中,然后通过 JMeter 的配置元件读取这些数据并执行测试。这种方法的好处在于,当需要增加或修改用例时,只需修改外部文件,而无需重新编辑 JMeter 脚本,大大简化了用例的维护工作 [^4]。 ##### 示例:使用 CSV 文件进行数据驱动测试 1. **准备 CSV 文件** - 创建一个 CSV 文件,其中包含测试所需的参数数据。例如,假设有一个登录接口,需要用户名和密码作为参数,CSV 文件可以如下所示: ``` username,password user1,pass1 user2,pass2 user3,pass3 ``` 2. **配置 CSV Data Set Config** - 在 JMeter 中添加一个 CSV Data Set Config 元件,并配置以下参数: - **Filename**: 指定 CSV 文件的路径。 - **Variable Names**: 指定变量名,如 `username,password`。 - **Delimiter**: 指定分隔符,默认为逗号。 - **Recycle on EOF?**: 是否在文件末尾循环读取。 - **Stop thread on EOF?**: 是否在文件末尾停止线程。 3. **使用参数** - 在 HTTP 请求中使用 `${username}` 和 `${password}` 变量来引用 CSV 文件中的数据。 4. **执行测试** - 运行测试时,JMeter 会自动从 CSV 文件中读取数据,并为每行数据执行一次请求。 #### 示例代码 ```python # 假设有一个简单的 Python 脚本用于生成 CSV 文件 import csv data = [ ["username", "password"], ["user1", "pass1"], ["user2", "pass2"], ["user3", "pass3"] ] with open('test_data.csv', 'w', newline='') as csvfile: writer = csv.writer(csvfile) writer.writerows(data) ``` #### 总结 JMeter 提供了多种参数化测试的实现方式,可以根据具体的测试需求选择合适的方法。对于大规模的参数化测试,推荐使用 CSV Data Set Config,因为它具有更大的灵活性和可维护性。而对于小规模的参数化测试,User Parameters 或 User Defined Variables 可能更加简单直接。FunctionHelper 中的函数则可以作为补充,提供额外的功能,如生成随机数等 [^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值