百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

性能测试—LoadRunner异步函数 异步import

yuyutoo 2024-10-13 09:14 1 浏览 0 评论

本章节主要讲解性能测试,LodRunner异步函数的内容,头条号每天都会更新技术好文,大家一定要收藏我们以防走失哦。

LoadRunner中关于异步通信的API函数主要包括:

web_reg_async_attributes、web_stop_async、web_sync、web_util_set_request_url和web_util_set_request_boby。

在本章节中将详细介绍web_reg_async_attributes和web_stop_async这两个异步通信API。

一、web_reg_async_attributes

异步通信API函数web_reg_async_attributes的格式如下:

int web_reg_async_attributes("ID=id","URL[/RE][/IC]=URL_or_RegEx_Pattern",

["Pattern=None|Push|Poll|LongPoll", ["PollIntervalMs=integer"]],

["XMLHttpRequest=No|Async|Sync",] ["CrossStep=No|Yes",]

["RequestCB=function_name",] ["ResponseBodyBufferCB=function_name",]

["ResponseCB=function_name",] LAST);

参数说明:

ID:会话ID。

URL:表示URL地址。

Pattern:设置异步通信的方式。

PollIntervalMs:在另一个实例开始之前,等待多久结束轮询实例。

XMLHttpRequest:设置是否处理javascript中的XML HTTP请求,以及处理其它任务的异步信息。

CrossStep:设置服务器是否等待完成指定URL的响应。

RequestCB:用户编码的用于回调功能的函数名称。

ResponseBodyBufferCB:用户编码的用于回调功能的函数名称,但针对的内容为缓存中接收的内容。

ResponseCB:用户编码的用于回调功能的函数名称,在会话结束后调用。

LAST:结束参数标志。

1) ID

LAST:结束参数标志。

标识一个异步会话的ID,一个异步会话是由一系列的请求任务,包括所有的请求和重定向任务。会话是从请求获得了所需要的服务器响应开始,包括所有的请求和响应,当期望响应被覆盖或是一系列的会话被取消,ID在整个Vuer脚本中必须是唯一的。

一个会话ID命名规则应该遵循以下规则:

  • 不能是空字符串;
  • 不能以下划线开始;
  • ID名中第一个字符和最后一个字符不能为空格;
  • 不能包含控制字符,字符从0x00到ox1F;
  • 不能包含描述性能控制字符,如\r、\t和\n等。
  • 会话ID不区分大小写,如:

“www.host.com/Path?Query”可以匹配“www.host.com/PATH?Query”。

会话ID对空格是敏感的,即一个空格不可以匹配多个空格,如“AA A”不能匹配“AA A”。

如果使用URL做为会话ID,那么将URL字符都会转换成小写字符,但并不对其再做其它的操作。如没有解决的URL转义码、没有添加或去除默认端口号,“http://www.abcd.com:80 ≠ http://www.abcd.com”。

2) URL

  • 表示URL地址,如果设置为“/RE”表示URL可以使用正则表达式匹配;如果设置为“/IC”表示不区分大小写。

3) Pattern

  • 设置异步通信的方式,通常异步包括堆、轮询和长轮询三种,可以设置为None、Push、Poll和LongPoll中的一种。

4) PollIntervalMs

  • 在另一个实例开始之前,等待多久结束轮询实例,单位为毫秒。

5) XMLHttpRequest

  • 设置是否处理javascript中的XML HTTP请求,以及处理其它任务的异步信息,有三个可选项设置:No、Async或Sync。
  • 如果Pattern选项设置为None或Push,那么该选项应该设置为No。
  • 如果Pattern选项设置为Poll或LongPoll,那么该选项应该设置为Async。

6) CrossStep

  • 设置服务器是否等待完成指定URL的响应,如果设置为“Yes”,那么将不等待服务器返回指定URL请求,可设置项为“Yes”或“No”,对于所有的Pattern选项内容其默认设置为“Yes”(除Pattern选项设置为None)。

7) RequestCB

  • 用户编码的用于回调功能的函数名称,这个回调在发送请求之前被执行。

8) ResponseBodyBufferCB

  • 用户编码的用于回调功能的函数名称,但针对的内容为缓存中接收的内容,如果响应的内容涉及到缓存数据,则会触发该回调函数。

9) ResponseCB

  • 用户编码的用于回调功能的函数名称,在异步会话结束时,回调该函数。
  • 在录制完成后,VuGen会扫描脚本中是否有异步的会话,如果发现有异步会话,那么VuGen会在web_reg_async_attributes函数中添加回调函数来匹配异步信息,主要包括RequestCB、ResponseBodyBufferCB和ResponseCB三个回调函数,这些回调函数存储在AsyncCallbacks.c文件中(该文件保存在脚本的根目录下)。
  • 在web_reg_async_attributes函数中回调函数的内容如图6-68所示

AsyncCallbacks.c文件中的内容如下:

int Poll_0_RequestCB()

{

//enter your implementation for RequestCB() here

//call web_util_set_request_url() here to modify polling url

//url is expected to be of the form:

//http://flight.qunar.com/twell/flight/tags/onewayflight_groupdata.jsp?&departureCity=%e6%b7%b1%e5%9c%b3&arrivalCity=%e5%8d%97%e6%98%8c&departureDate=2013-04-12&returnDate=2013-04-12&nextNDays=0&searchType=OneWayFlight&searchLangs=zh&locale=zh&from=qunarindex&queryID=192.168.0.19%3a63ab0de2%3a13df30a3fd7%3a-597b&serverIP=l-tw6.f.cn1.qunar.com%2f192.168.0.19&status={TimeStamp_Poll_0_0}&_token={Unknown_Poll_0_1}&deduce=true

//the following parameters must be assigned:

web_save_timestamp_param("TimeStamp_Poll_0_0",LAST);

//TODO - implement parameter of type unknown: Unknown_Poll_0_1.

//Known examples for Unknown_Poll_0_1: _token=67228, _token=72210,

_token=19725, _token=24410,

lr_save_string("67228","Unknown_Poll_0_1");

//once all parameters have been assigned, copy them to the updated url,

//and call web_util_set_request_url() with the updated url:

web_util_set_request_url("http://flight.qunar.com/twell/flight/tags/onewayflight_groupdata.jsp?&departureCity=%e6%b7%b1%e5%9c%b3&arrivalCity=%e5%8d%97%e6%98%8c&departureDate=2013-04-12&returnDate=2013-04-12&nextNDays=0&searchType=OneWayFlight&searchLangs=zh&locale=zh&from=qunarindex&queryID=192.168.0.19%3a63ab0de2%3a13df30a3fd7%3a-597b&serverIP=l-tw6.f.cn1.qunar.com%2f192.168.0.19&status={TimeStamp_Poll_0_0}&_token={Unknown_Poll_0_1}&deduce=true");

//call web_util_set_request_body() here to modify request body:

//web_util_set_request_body("");

return WEB_ASYNC_CB_RC_OK;

}

int Poll_0_ResponseBodyBufferCB(

const char * aLastBufferStr,

int aLastBufferLen,

const char * aAccumulatedStr,

int aHttpStatusCode)

{

//enter your implementation for ResponseBodyBufferCB() here

return WEB_ASYNC_CB_RC_OK;

}

int Poll_0_ResponseCB(

const char * aResponseHeadersStr,

int aResponseHeadersLen,

const char * aResponseBodyStr,

int aResponseBodyLen,

int aHttpStatusCode)

{

//enter your implementation for ResponseCB() here

return WEB_ASYNC_CB_RC_OK;

}

在实际测试过程中可以对RequestCB回调包进行修改,通常修改的方法有以下两种:

1) 在RequestCB回调包中修改请求的URL信息

在轮询和长轮询会话过程中,每次轮询迭代时请求的URL信息经常会发生改变,这些变化通常是由客户端逻辑决定的,通常是由JavaScript通过浏览器来执行的。URL主要是由一些相关的参数组成,如果会话ID,要修改异步会话请求的URL信息使用的函数为web_util_set_request_url。

web_util_set_request_url函数格式如下:

web_util_set_request_url ( const char * aUrlStr);

aUrlStr是指请求URL字符串。

写在AsyncCallbacks.c文件中的int Push_0_RequestCB回调函数中,代码如下:

int Push_0_RequestCB()

{

//enter your implementation for RequestCB() here

//call web_util_request_set_url() here to modify request url:

web_util_set_request_url("");

//call web_util_set_request_body() here to modify request body:

web_util_set_request_body("");

return WEB_ASYNC_CB_RC_OK;

}

如会话中的URL请求内容如图6-69所示

web_util_set_request_url函数内容如图6-70所示

2) 在RequestCB回调包中修改请求的body信息

如果在异步会话中在发送请求点需要修改请求的body内容,那么需要使用web_util_set_request_body函数来修改body内容,并在每一次轮询前进行修改。

web_util_set_request_body函数格式如下:

web_util_set_request_body ( const char * aUrlStr);

aUrlStr是指请求URL字符串。

写在AsyncCallbacks.c文件中的int Push_0_RequestCB回调函数中,代码如下:

int Push_0_RequestCB()

{

//enter your implementation for RequestCB() here

//call web_util_request_set_url() here to modify request url:

web_util_set_request_url("<request url>");

//call web_util_set_request_body() here to modify request body:

web_util_set_request_body("<request body>");

return WEB_ASYNC_CB_RC_OK;

}

二、web_stop_async

当异步会话结束后需要取消异步会话,web_stop_async用于结束异步会话,函数格式如下:

web_stop_async( "ID=id", LAST);

当异步会话结束后需要取消异步会话,web_stop_async用于结束异步会话,函数格式如下:

ID:是指异步会话ID,指明需要结束的异步会话;

LAST:结束标识符;

如以下结束异步会话代码:

web_stop_async( "ID=Poll_0", LAST);

本章节主要介绍了在编辑脚本的过程中常用的技术,首先介绍了检查点技术,需要注意如何使用检查点来判断事务是否成功;接着介绍了Block块技术,通过Block块技术如何处理一些业务流程;再次介绍了如何参数化,参数化是性能测试脚本编辑过程最重要的技术之一,一定要明白参数化中每个策略设置项的含义;最后阐述了关联技术,关联技术是必须掌握的,并且需要明白关联的原理和关联函数,使用关联函数如何处理业务等。异步通信应该了解异步通信的方式,如何使用web_reg_async_attributes函数来处理异步通信数据以及异步处理函数web_reg_async_attributes的使用方法。

相关推荐

jQuery VS AngularJS 你更钟爱哪个?

在这一次的Web开发教程中,我会尽力解答有关于jQuery和AngularJS的两个非常常见的问题,即jQuery和AngularJS之间的区别是什么?也就是说jQueryVSAngularJS?...

Jquery实时校验,指定长度的「负小数」,小数位未满末尾补0

在可以输入【负小数】的输入框获取到焦点时,移除千位分隔符,在输入数据时,实时校验输入内容是否正确,失去焦点后,添加千位分隔符格式化数字。同时小数位未满时末尾补0。HTML代码...

如何在pbootCMS前台调用自定义表单?pbootCMS自定义调用代码示例

要在pbootCMS前台调用自定义表单,您需要在后台创建表单并为其添加字段,然后在前台模板文件中添加相关代码,如提交按钮和表单验证代码。您还可以自定义表单数据的存储位置、添加文件上传字段、日期选择器、...

编程技巧:Jquery实时验证,指定长度的「负小数」

为了保障【负小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【负小数】的方法。HTML代码<inputtype="text"class="forc...

一篇文章带你用jquery mobile设计颜色拾取器

【一、项目背景】现实生活中,我们经常会遇到配色的问题,这个时候去百度一下RGB表。而RGB表只提供相对于的颜色的RGB值而没有可以验证的模块。我们可以通过jquerymobile去设计颜色的拾取器...

编程技巧:Jquery实时验证,指定长度的「正小数」

为了保障【正小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【正小数】的方法。HTML做成方法<inputtype="text"class="fo...

jquery.validate检查数组全部验证

问题:html中有多个name[],每个参数都要进行验证是否为空,这个时候直接用required:true话,不能全部验证,只要这个数组中有一个有值就可以通过的。解决方法使用addmethod...

Vue进阶(幺叁肆):npm查看包版本信息

第一种方式npmviewjqueryversions这种方式可以查看npm服务器上所有的...

layui中使用lay-verify进行条件校验

一、layui的校验很简单,主要有以下步骤:1.在form表单内加上class="layui-form"2.在提交按钮上加上lay-submit3.在想要校验的标签,加上lay-...

jQuery是什么?如何使用? jquery是什么功能组件

jQuery于2006年1月由JohnResig在BarCampNYC首次发布。它目前由TimmyWilson领导,并由一组开发人员维护。jQuery是一个JavaScript库,它简化了客户...

django框架的表单form的理解和用法-9

表单呈现...

jquery对上传文件的检测判断 jquery实现文件上传

总体思路:在前端使用jquery对上传文件做部分初步的判断,验证通过的文件利用ajaxFileUpload上传到服务器端,并将文件的存储路径保存到数据库。<asp:FileUploadI...

Nodejs之MEAN栈开发(四)-- form验证及图片上传

这一节增加推荐图书的提交和删除功能,来学习node的form提交以及node的图片上传功能。开始之前需要源码同学可以先在git上fork:https://github.com/stoneniqiu/R...

大数据开发基础之JAVA jquery 大数据java实战

上一篇我们讲解了JAVAscript的基础知识、特点及基本语法以及组成及基本用途,本期就给大家带来了JAVAweb的第二个知识点jquery,大数据开发基础之JAVAjquery,这是本篇文章的主要...

推荐四个开源的jQuery可视化表单设计器

jquery开源在线表单拖拉设计器formBuilder(推荐)jQueryformBuilder是一个开源的WEB在线html表单设计器,开发人员可以通过拖拉实现一个可视化的表单。支持表单常用控件...

取消回复欢迎 发表评论: