【性能测试】性能测试工具 - LoadRunner,VuGen - 参数化,VuGen - 关联。全md文档笔记(已分享文档代码)

本系列文章md笔记(已分享)主要讨论性能测试相关知识。入门阶段:认识性能测试分类-(负载测试、压力测试、并发测试、稳定性测试),常用性能测试指标-(吞吐量、并发数、响应时间、点击数...),性能测试工具选择。性能脚本:1. LoadRunner介绍,2. 脚本录制、运行、参数化,3. 关联、检查点、事务、集合点。性能场景:1. 场景分类、场景设计、场景运行策略,2. 资源监控、SLA、IP Wizard应用。性能分析:1. 摘要报告、事务图表、图表合并,2. 交叉结果、拐点分析、Web项目资源分析。

全套笔记和代码自取移步gitee仓库: gitee仓库获取完整文档和代码

感兴趣的小伙伴可以自取哦,欢迎大家点赞转发~


共 5 章,25 子模块

性能测试工具-LoadRunner

学习目标

python 1. 理解基于VuGen的脚本录制 2. 掌握参数化的使用方法 3. 掌握关联的使用方法 4. 掌握检查点的使用方法 5. 掌握事务的使用方法 6. 掌握集合点的应用

VuGen-参数化

目标
  1. 理解参数化的使用场景

  2. 掌握参数化的使用方式
一、什么是参数化

根据需求动态的获取数据的过程

二、为什么要参数化?
  1. 减少重复代码

  2. 数据代码进行分离,方便维护

需求1

python 说明:由于虚拟机运行速度原因,我们使用 lr_output_message() 函数,来学习如何使用参数化 要求:输出 我要去北京;我要去上海;我要去广州;我要去深圳;

三、参数化操作
3.1 打开参数化菜单

参数化

python 选中要参数化的文本 -> 鼠标右键 -> Replace with a Parameter 或者 菜单 Insert -> New Parameter...

3.2 Replace with a Parameter 打开的窗口

参数化

```python 1. Parameter name:参数化引用名称(参数化时使用) 2. Parameter type:File 【推荐】 3. Properties:属性-点击此按钮,可直接设置参数化引用名称对应的值;【点击】

提示: 1). 点击OK;参数化引用名称具体的值,需要再次设置; ```

3.3 Properties 设置面板

参数化

```python 1. Parameter type: 参数类型 File 【重点】 2. File:参数保存的文件类型及位置,一般为txt;【推荐】 3. Add Row:添加行,在当前表格编辑数据;【可选】 4. Edit with Notepad:在记事本内编辑数据;【推荐】 5. Select next row:运行或迭代时对行的选择方式 6. Update value on:运行或迭代时对值的选取方式

提示: 1). 其中5.Select next row 与 6.Update value on为组合关系,不同组合效果不同,我们单独来学习 ```

需求1 解决方案
  1. 创建指定路径及txt文本格式 如:C:\lr11\scripts\city.txt
  2. 使用 Edit with Notepad 编辑数据:北京、上海、广州、深圳
  3. 编写脚本
  4. 迭代次数 4

问题

python lr_output_message(“str”):函数为把str字符串输出到日志,但它自身并不能解析读取参数;

函数(设置参数、读取参数)
  1. lr_save_string()
  2. lr_eval_string()
1. lr_save_string()

把字符串保存到指定的参数中

格式:lr_save_string("字符串","参数名")

示例:lr_save_string("北京","city");

2. lr_eval_string()

读取变量的值,并以Char类型返回;

格式:lr_eval_string("{参数名}");

示例:lr_eval_string("{city}");

python 提示: 1). 参数名称使用花括号{}包括 2). 参数使用双引号包括

需求1 代码示例

python Action() { lr_output_message("我要去%s",lr_eval_string("{NewParam}")); return 0; }

3.4 Select next row 与 Update value on
Select next row

读取参数文件行的方式

方式:

python 1. Sequential:顺序,按照行的顺序读取数据,如果迭代次数大于行数,再次从第一行开始读取 2. Random:随机,随机读取行 3. Unique:唯一,每次读取唯一行,不重复; 4. Same line as xxx 取参数同行(需要两个以上参数,才能显示和使用)

注意:

python 使用 Unique 选项时会激活 When out of values: 1) Abort Vuser:中止虚拟用户 2) Continue in a cyclic manner:以循环的方式继续 3) Continue with last value:继续使用最后一个值

Update value on

参数值更新的方式

方式:

python 1. Each iteration:每次迭代以后更新 2. Each occurrence:每次出现参数时更新 3. Once:每出现一个虚拟用户(线程)更新一次

组合
  1. 行顺序 + 每次迭代更新值 Sequential + Each iteration
  2. 行顺序 + 每次参数出现更新值 Sequential + Each occurrence
  3. 行顺序 + 更新一次(单用户) Sequential + Once

说明:

python 1. 组合我们在这里就不穷举了,以行的顺序配合值的3种更新方式做演示 2. 因为组合内含occurrence,所以必须要两个Action,我们新增两个(Action1、Action2)两个代码相同

代码

```python Action1() { lr_output_message("我要去%s",lr_eval_string("{NewParam}")); return 0; }

Action2() { lr_output_message("我要去%s",lr_eval_string("{NewParam}")); return 0; } ```

Sequential + Each iteration

行为顺序,值为迭代更新一次;

预期:

python 1. 第一次迭代:Action1:北京;Action2:北京 2. 第二次迭代:Action1:上海;Action2:上海 3. 第三次迭代:Action1:广州;Action2:广州 4. 第四次迭代:Action1:深圳;Action2:深圳

Sequential + Each occurrence

行为顺序,值为出现一次更新一次

预期:

python 1. 第一次迭代:Action1:北京;Action2:上海 2. 第二次迭代:Action1:广州;Action2:深圳 3. 第三次迭代:Action1:北京;Action2:上海 4. 第四次迭代:Action1:广州;Action2:深圳

Sequential + Once

行为顺序,值为单用户只更新一次

预期:

python 1. 第一次迭代:Action1:北京;Action2:北京 2. 第二次迭代:Action1:北京;Action2:北京 3. 第三次迭代:Action1:北京;Action2:北京 4. 第四次迭代:Action1:北京;Action2:北京

批量获取参数时,如果保证参数不重复?(扩展)

python 思路:添加时间戳 说明:web_save_timestamp_param("time_stamp",LAST) 为时间戳函数,返回:1970到现在的毫秒数; (time_stamp:参数为获取值后保存的参数名称,被引用时使用)

示例:

python Action() { web_save_timestamp_param("time_stamp",LAST); lr_output_message("我要去%s",lr_eval_string("{NewParam}_{time_stamp}")); return 0; }

其他常用参数类型(了解)

python parameter type: 1. Date/Time 2. Random Number

VuGen-关联

目标

  1. 理解关联的概念

  2. 掌握关联函数的使用

  3. 了解LR自动关联的使用

一、为什么要学习关联?

关联

```python 1. 获取动态加载的数据,例如:Session ID(会话ID) 2. 测试的时候需要获取页面上指定的数据,注意是获取,而不是查找

说明: Session ID:客户端与服务器交互时,服务器生成的一个唯一标识码; (通过标识码服务器可以区分多次交互对象是否同一客户端,浏览器只要不关闭标识码就不变) ```

二、什么是关联(correlation)?

动态获取指定的数据,并把获取的数据通过参数化的方式在另一处引用

三、LoadRunner 常用的关联方式

  1. 手动关联【推荐】

  2. 自动关联【了解】
3.1 手动关联【重点】

手动关联就是直接调用关联函数;

关联函数 web_reg_save_param()

python 1). 执行顺序:LR中函数内含reg为注册函数,注册函数是在下一个Action Function完成时执行。 2). 函数位置:注册函数【必须】放到下一个Action Function(要进行关联数据所在的函数)函数之前; 3). 如果关联的参数值超过256个字符,需要先调用 web_set_max_html_param_len("1024") 改变参数长度;

案例 1

关联

使用 web_reg_save_param() 函数把红框选中内容关联给Welcome参数

案例 1 脚本

python Action() { web_url("WebTours", "URL=http://127.0.0.1:1080/WebTours/", "TargetFrame=", "Resource=0", "RecContentType=text/html", "Referer=", "Snapshot=t1.inf", "Mode=HTML", LAST); return 0; }

案例1 操作分析

python 1. 在web_url函数之前插入关联函数 web_reg_save_param() 2. 调用 lr_eval_string() 来读取关联函数的参数引用名称,并通过 lr_output_message() 函数输出到日志

案例1 操作实施
1) 插入 web_reg_save_param()方法

关联

python 1. 在web_url函数之前空白行,点击鼠标右键 2. 选择Insert菜单 -> New Step

2) 输入要查找的函数:

关联

python 1). 图1:输入要查找函数的关键词或全称 2). 图2:找到匹配出的函数,双击或点击图3 3). 图3:选中图2,点击图3进行选中函数参数设置

3) 设置函数参数

关联

参数:

python 1). Parameter Name:参数名称(被引用时使用) 2). Left Boundary(LB):左边界 3). Right Boundary(RB):右边界 4). Not Found:关联失败时,处理方式 5). Search in:匹配搜索响应代码范围

注意:

python 单引号(')、双引号(")、反斜杠(\)、回车换行等需要转义字符,加上转义字符[\]

4) 如何查看页面元素响应代码?
  1. 通过LR查看响应代码

  2. 通过页面查看源代码
1). 通过LR查看 【注意:必须是录制脚本-手动编写脚本没有快照】

关联

提示:

python 1. 结构为Tree 2. url:为WebTours 3. 页面为/WebTours/home.html

2). 通过页面源代码查看 关联

地址:http://127.0.0.1:1080/WebTours/home.html 参数化并输出到日志

关联

代码:

```python Action() { web_reg_save_param("Webcome", "LB=\n", "RB=\n" "
", "NotFound=ERROR", "Search=All", LAST);

web_url("WebTours",
    "URL=http://127.0.0.1:1080/WebTours/",
    "TargetFrame=",
    "Resource=0",
    "RecContentType=text/html",
    "Referer=",
    "Snapshot=t1.inf",
    "Mode=HTML",
    LAST);

lr_output_message("Webcome值为:%s",lr_eval_string("{Webcome}"));

return 0;

} ```

3.2 自动关联 【了解】

python 1. 自动关联LoadRunner提供两种方式: 1). 录制时关联-在录制脚本的时候如果有符合关联规则的就自动进行关联; 注意:此种方式依赖于LR自带的规则或新建的自定义规则 2). 录制后关联-脚本录制完成并且运行完一次后,打开扫描工具,进扫描需要关联的数据进行关联; 注意: ① 利用扫描工具必须要先运行一遍脚本 ② 扫描关联:很多时候LR扫描不到需要关联的信息(比如手写的脚本),所以一般不推荐使用; 2. 自动关联调用的是关联函数 web_reg_save_param_ex(); (web_reg_save_param_ex与web_reg_save_param功能大致相同,它也可以使用正则表达式和过滤器)

1) 自动关联-启用自动关联设置

关联

启动自动关联位置:工具菜单(Tool) -> Recording Option

2) 自动关联-扫描工具

关联

  1. 启动:打开扫描工具-Ctrl+F8 或者菜单栏(Vuser) -> Scan Script for Correlations

  2. 扫描:扫描之前先运行一遍脚本

  3. 关联:图中个第二步Correlation Results内进行关联;
自动关联总结

python 1. 自动关联-录制时关联:采用自带或设定的规则在录制脚本的时候自动关联 2. 自动关联-录制后关联:前后运行两次,搜索两次不同之处为需要关联的数据,进行确认关联 3. 自动关联无论哪种方式,都是采用调用关联函数的方法,所以工具智能人更智能,因此推荐优先使用手动关联

未完待续, 同学们请等待下一期

全套笔记和代码自取移步gitee仓库: gitee仓库获取完整文档和代码

感兴趣的小伙伴可以自取哦,欢迎大家点赞转发~

  • 22
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值