·LR中的关联函数详解。
在LR中,用于关联的函数一般有以下四个:
web_reg_save_param 是通过字符串查找的方式来查找获取数据。
web_reg_save_param_ex 是通过字符串查找的方式来查找获取数据。新版本的函数。
web_reg_save_param_regexp 是通过正则表达式的方式来查找获取数据。
web_reg_save_param_xpath 是通过xpath的方式来查找获取数据。

在LR中,web表示该类函数只能用于web类型的脚本。lr开头的就表示是lr内置函数,适用于所有协议。

reg关键字表示该函数是注册型函数,要求放在请求之前。它是运行在其后第一个请求函数之后的。

save_param表示该函数的功能和作用。

·web_reg_save_param_ex详解:
·Parameter Name:参数名称,由用户自己定义,有意义即可。

·Left Boundary:左边界,即要获取的动态数据的左边的字符串。

·Right Boundary:右边界,即要获取的动态数据的右边的字符串。

PS:
·左右边界本身一般是具有唯一性的。。是指组合的唯一性。
·不论是字符串查找还是正则查找,一般采取的都是非贪婪的模式。即采取的是最小匹配原则。
·示例:假设服务器响应回的字符串是“a1ba2ba3ba4b”
设置左边界LB=a,右边界RB=b,则最终符合条件的数据是:1、2、3、4这四个字符串。而不会是"1ba2"这样的字符串。

·如果左右边界中出现双引号,则需要进行转义操作。

·Ordinal:又叫ORD属性,老版本叫instance,该选项可以填的是正整数N 或者 字符串 “all”.
·正整数N:表示将第N次符合条件的数据存入参数。默认值为1.

·all:则表示将所有符合条件的数据以类似于数组的方式存入参数数组(以参数名命名的数组)。
效果为:ParamName_1=Value1,ParamName_2=Value2,......,ParamName_N=ValueN
与之同时,会生成一个参数叫ParamName_count=N。

通常来说,当ordinal=all时,就意味着我们需要随机或者遍历数据。
·随机:
一般来说,会用到函数lr_paramarr_random(),核心代码如下:
lr_save_string(lr_paramarr_random("outboundFlight"),"myflight");//表示从数组outboundFlight中随机获取一个值,并且赋值给参数myflight。

·遍历:
核心代码如下:
int i,num;
关联函数;
请求;
num=atoi(lr_eval_string("{outboundFlight_count}"));

for(i=1;i<=num;i++){
//表示把数组outboundFlight下标为i的元素的值提取,并且保存赋值到参数myflight。
lr_save_string(lr_paramarr_idx("outboundFlight",i),"myflight");

需要遍历使用数据的请求(......,value="{myflight}",......)

}

·offset:偏移量。是指实际存入参数的数据将从左边界向右偏移N个字符开始计算。
·length:长度,是指实际存入参数的数据的长度。

·在LR中,变量VS参数

·相同点:
都可以用来存储值,并且被调用。

·不同点:
·变量默认是局部变量,只在当前action有效。
参数是从起效的时候,在任何位置都有效的。

·定义问题:
变量必须定义才能使用。而且必须在所有的代码之前进行定义。
参赛不需要定义。

·赋值问题:
一般来说,参数赋值通常使用的是函数lr_save_string()这一系列的函数。

变量赋值,一般使用的是sprintf。

·调用问题:
变量一般来说要求在双引号之外调用,直接使用名称。
参数要求在双引号内调用,并且使用参数调用的格式。

一般来说,我们可以通过两个函数实现变量和参数状态的转换。
lr_eval_string("{参数名}") 表示将参数的值读取出来,整个函数等同于一个变量

lr_save_string(变量,"参数名") 表示将指定的变量赋值给指定的参数,从而实现变量到参数的转换。

性能测试基础---LR关联2的更多相关文章

  1. 性能测试基础---LR关联

    ·什么时候需要做关联?一般来说,在脚本运行出错的时候,我们就可能需要进行关联处理. ·脚本出错分为两种情况: ·直接回放出错(失败).通常来说,如果录制成功,回放失败,排除数据的唯一性约束之后,那就必 ...

  2. 性能测试基础---LR场景设置

    ·场景设置. 性能测试场景依托于性能测试脚本,但是又独立于脚本. 所谓场景(scenario),就是用来模拟多用户运行性能测试脚本的情形,是来源于我们对于业务场景的分析的. 性能测试对于业务场景的分析 ...

  3. 性能测试基础---LR参数化相关

    性能测试脚本的增强:·参数化·关联·事务·检查点·思考时间·集合点 ·参数化:模拟不同用户的不同请求. ·为什么要做参数化? ·功能:通常来说,系统的某些业务数据具有唯一性的要求. ·性能:一般来说, ...

  4. 性能测试基础---LR运行设置

    ·LR的运行时设置(Runtime settings): ·Run Logic:该选项是用来控制脚本的真正的运行逻辑. ·该选项会把脚本中的函数分别放入三个运行模块中:Init.Run.End ·默认 ...

  5. 对LR关联的一些理解

    从接触LR关联的迷茫,到现在略有感悟,小记期间的一些理解. 一开始认识关联是在LR自带学习例子,需要关联session,也知道了自动关联,手动关联以及边录制边关联. 在使用关联的过程中,也学习了web ...

  6. 性能测试基础---测试流程,LR安装

    ·性能测试流程详解: 一般来说,性能测试通常可以分为以下过程: ·前期分析.测试计划.测试方案.测试环境的搭建.测试数据的准备.测试脚本的开发.测试场景的设计.测试场景的实现和执行.资源的监控.分析结 ...

  7. 性能测试基础---jmeter参数化、关联、事物、检查的等

    ·Jmeter脚本增强·性能测试的脚本增强技术:参数化.关联.事务.检查点.思考时间和集合点. ·参数化:在Jmeter中,实现参数化的方式很多.本质上来说,参数化的实现方式有两种:·文件方式:一般建 ...

  8. 性能测试基础-开门篇3(LR常用函数介绍)

    LR常用的函数,协议不一样函数会不一样,这里简单的介绍下HTTP\WEBSERVICE\SOCKET协议常用函数: HTTP: web_set_max_html_param_len("102 ...

  9. LoadRunner性能测试基础知识问答

    Q1:什么是负载测试?什么是性能测试? A1:负载测试是通过逐步增加系统负载,测试系统性能的变化,并最终确定在满足性能指标的情况下,系统所能承受的最大负载量的测试,例如,访问一个页面的响应时间规定不超 ...

随机推荐

  1. 第01组 Alpha冲刺(5/6)

    队名:007 组长博客: https://www.cnblogs.com/Linrrui/p/11901035.html 作业博客: https://edu.cnblogs.com/campus/fz ...

  2. 【ASP.NET Core分布式项目实战】(六)Gitlab安装

    Gitlab GitLab是由GitLabInc.开发,使用MIT许可证的基于网络的Git仓库管理工具,且具有wiki和issue跟踪功能.使用Git作为代码管理工具,并在此基础上搭建起来的web服务 ...

  3. 第3课 auto类型推导(2)

    第3课 auto类型推导(2) 一.使用auto的优势 (一)避免使用未初始化变量 (二)可简化变量/对象类型的声明 (三) 在某些场合无法判断出类型时,可用auto自动推导(如lambda表达式) ...

  4. 1-7docke的网络模式

    1.Bridge模式 bridge 模式是 docker 的默认⽹络模式,不写 –net 参数,就是 bridge 模式.比如使⽤ docker run - p 时 工作模式从网上找了一个,如下 例子 ...

  5. VS2019 NetCore3.0找寻grpc模板

    今天研究Google的grpc框架的时候看到了https://www.cnblogs.com/yilezhu/p/10631420.html这哥们儿的博客 按照博客的内容找寻grpc模板,始终找不到A ...

  6. python数据分析4之自动采集数据

    1 数据采集的重要性 数据采集是数据挖掘的基础,没有数据,挖掘也没有意义.很多时候,我们拥有多少数据源,多少数据量,以及数据质量如何,将决定我们挖掘产出的成果会怎样 2 四类采集方式 3 如何使用开放 ...

  7. PG数据库CPU和内存满负荷运转优化案

    1.问题描述 某客户系统采用三层架构:数据库—应用服务—前端应用.其中数据库使用PostgreSQL 10.0作为数据库软件.自周四起,服务器的CPU与内存使用率持续处于过饱合状态,并因此导致了数次宕 ...

  8. storm杂记+性能调优

    1.默认情况下: 1个supervisor节点启动4个worker进程. 每一个topology默认占用一个worker进程. 每个worker会启动executor. 每个executor默认启动一 ...

  9. CSP2019-S游记

    目录 CSP2019-S游记 Day -2(UPDATE:2019-11-14) Day -1(UPDATE:2019-11-15) Day 1(UPDATE:2019-11-16) Day 2(UP ...

  10. SET QUOTED_IDENTIFIER选项对索引的影响

    早上来到公司,发现用于整理索引碎片的Job跑失败了,查看job history,发现以下错误消息: ALTER INDEX failed because the following SET optio ...