Loadrunner:性能测试浅析关联函数web_reg_save_param()

2024-06-09 01:18

本文主要是介绍Loadrunner:性能测试浅析关联函数web_reg_save_param(),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景:关联是性能测试中必不可少的技术点,即为了模拟真实场景而设计的,同样关联的接口测试亦是如此;首先介绍loadrunner工具的几个相关函数:大抵函数的参数部分,除了Ordinal不写就是默认Ordinal=1(取出第一个匹配的参数),写了Ordinal=All即为保存响应满足左右边界的所有参数,那此时{param_1}就不是一个正确的参数引用,而就是{param_1}字符串,下面来以web_reg_save_param_ex函数为例介绍:

web_reg_save_param("param_1",                                    "LB=class=\"",                                    "RB=\"",                                    "Ordinal=All",                                    LAST);// 正则表达式匹配动态参数
web_reg_save_param_regexp("ParamName=param_1","RegExp=class=\"(.*?)\"",               "Ordinal=All",                                      LAST);web_reg_save_param_ex("ParamName=param_1",               "LB/IC=class=\"",                                          "RB/IC=\"",                                          "Ordinal=All",                                          LAST);//代码中使用的变量必先申明
int i = 0;
char param_index[64];
web_reg_save_param_ex( "ParamName=goods_id_list",
"LB=goods_id\":\"",
"RB=\",\"miniapp_name",
"NotFound=warning",         
"Ordinal=All",
SEARCH_FILTERS,
LAST);         web_custom_request(){ //对关联参数相关的操作,需要放到包含该关联数据的请求函数之后         }for(i=1;i<=atoi(lr_eval_string("{goods_id_count}"));i++){
sprintf(param_index, "goods_id_%d}", i);
lr_message("goods_id %d:%s",i,lr_eval_string(param_index));}/* * atoi(lr_eval_string("{goods_id_count}")) 作用是获取匹配了多少个参数 sprintf(param_index, "{goods_id_%d}", i);是格式输出,并把格式中的值保存在变量param_index中,实际param_index 保存的值分别为:goods_id_1、goods_id_2 等等 */
//同上面for循环的效果         
int goods_count;
goods_count=atoi(lr_eval_string("{goods_id_count}"));         
i=1;         
char str[64];
while(i<=goods_count){ 
sprintf(str,"goods_id_%d}",i);
lr_save_string(lr_eval_string(str),"Value");
lr_message("goods_id_%d:%s",i,lr_eval_string(str));
i++;     
} 
//上面函数处理多个关联参数,尽数打印出来,但是要怎么随机取值呢,把上面字符串函数lr_eval_sting改成随机函数lr_paramarr_random("");示例(实际使用下面一个函数就可以了): lr_save_string(lr_paramarr_random("goods_id_list"), "goods_id_random");
lr_log_message("随机取值 %s",lr_eval_string("{goods_id_random}")); 
// lr_message("随机取值:%s",lr_eval_string("{goods_id_random}")); 
//对关联参数相关的操作,需要放到包含该关联数据的请求函数之后

2、上面的意图是通过关联函数,获取动态参数,再使用随机函数取值与下一个接口交互,用自带的机票订票系统来看效果:

Action(){web_set_max_html_param_len("12040");web_reg_save_param("userSession","LB=value=","RB=>","NotFound=ERROR","Search=Body","Ord=ALL",LAST);web_url("WebTours","URL=http://127.0.0.1:1080/WebTours/","Resource=0","RecContentType=text/html","Referer=","Snapshot=t1.inf","Mode=HTML",LAST);web_reg_find("Fail=NotFound","Search=Body","SaveCount=Success","Text=Welcome",LAST);web_custom_request( "Login.pl","URL=http://127.0.0.1:1080/WebTours/login.pl","Method=POST","Body=userSession={userSession}&username=jojo&password=bean&login.x=59&login.y=8&JSFormSubmit=off","Mode=HTML",LAST);lr_output_message("-----------------------token为:%s",lr_eval_string("{userSession}"));return 0;
}

3、web_reg_save_param()函数的Ord设置ALL,按F4设置log输出为Paramter subitution:

4、关联函数找到的参数userSession,就不再是可引用的变量,而是一个{userSession} 字符串,所以会报错检点失效;那么上面正确的值应该是{userSession_1},为了展示随机函数的使用效果;我们把脚本修改一下,设置循环5次就可以看效果:

// 加入一下代码:
lr_save_string(lr_paramarr_random("userSession"),"userSession_random");
lr_log_message("每次随机取值 %s",lr_eval_string("{userSession_random}")); 

5、F4设置run logic循环五次,这样看结果不直观,使用while循环看效果;

6、同上,关联函数都可以使用Ordinal参数,获取更多的参数,如果业务需要取自不同的数据关联,这很有效。 

这篇关于Loadrunner:性能测试浅析关联函数web_reg_save_param()的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1043850

相关文章

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

解决JavaWeb-file.isDirectory()遇到的坑问题

《解决JavaWeb-file.isDirectory()遇到的坑问题》JavaWeb开发中,使用`file.isDirectory()`判断路径是否为文件夹时,需要特别注意:该方法只能判断已存在的文... 目录Jahttp://www.chinasem.cnvaWeb-file.isDirectory()遇

JavaWeb-WebSocket浏览器服务器双向通信方式

《JavaWeb-WebSocket浏览器服务器双向通信方式》文章介绍了WebSocket协议的工作原理和应用场景,包括与HTTP的对比,接着,详细介绍了如何在Java中使用WebSocket,包括配... 目录一、概述二、入门2.1 POM依赖2.2 编写配置类2.3 编写WebSocket服务2.4 浏

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

Tomcat高效部署与性能优化方式

《Tomcat高效部署与性能优化方式》本文介绍了如何高效部署Tomcat并进行性能优化,以确保Web应用的稳定运行和高效响应,高效部署包括环境准备、安装Tomcat、配置Tomcat、部署应用和启动T... 目录Tomcat高效部署与性能优化一、引言二、Tomcat高效部署三、Tomcat性能优化总结Tom

MYSQL关联关系查询方式

《MYSQL关联关系查询方式》文章详细介绍了MySQL中如何使用内连接和左外连接进行表的关联查询,并展示了如何选择列和使用别名,文章还提供了一些关于查询优化的建议,并鼓励读者参考和支持脚本之家... 目录mysql关联关系查询关联关系查询这个查询做了以下几件事MySQL自关联查询总结MYSQL关联关系查询