上期讲到LoadRunner性能测试异步技术。这期我们一起来学习LoadRunner性能测试异步函数。
异步函数
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。
1.web_reg_async_attributes
异步通信API函数
web_reg_async_attributes的格式如下:
intweb_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
不能包含描述性能控制字符,如 、 和 等。
会话ID不区分大小写,如:
“www.host.com/Path?Query”
可以匹配“www.host.com/PATH?Query”。
会话ID对空格是敏感的,即一个空格不可以匹配多个空格,如“AA A”不能匹配“AAA”。
如果使用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函数中回调函数的内容如图所示。
AsyncCallbacks.c文件中的内容如下:
intPoll_0_RequestCB(){//enteryour implementationforRequestCB() 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 examplesforUnknown_Poll_0_1: _token=67228, _token=72210, _token=19725, _token=24410, lr_save_string("67228","Unknown_Poll_0_1");//onceall parameters have been assigned, copy them to the updated url,//andcall 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");//callweb_util_set_request_body() here to modify request body://web_util_set_request_body("<request body>");returnWEB_ASYNC_CB_RC_OK;}intPoll_0_ResponseBodyBufferCB( const char * aLastBufferStr,intaLastBufferLen, const char * aAccumulatedStr,intaHttpStatusCode){//enteryour implementationforResponseBodyBufferCB() herereturnWEB_ASYNC_CB_RC_OK;}intPoll_0_ResponseCB( const char * aResponseHeadersStr,intaResponseHeadersLen, const char * aResponseBodyStr,intaResponseBodyLen,intaHttpStatusCode){//enteryour implementationforResponseCB() herereturnWEB_ASYNC_CB_RC_OK;}
在实际测试过程中可以对RequestCB回调包进行修改,通常修改的方法有以下两种:
1.在RequestCB回调包中修改请求的URL信息
在轮询和长轮询会话过程中,每次轮询迭代时请求的URL信息经常会发生改变,这些变化通常是由客户端逻辑决定的,通常是由JavaScript通过浏览器来执行的。URL主要是由一些相关的参数组成,如果会话ID,要修改异步会话请求的URL信息使用的函数为web_util_set_request_url。
A.web_util_set_request_url函数格式如下:
web_util_set_request_url ( const char * aUrlStr);
aUrlStr是指请求URL字符串。
写在AsyncCallbacks.c文件中的int Push_0_RequestCB回调函数中,代码如下:
intPush_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>");returnWEB_ASYNC_CB_RC_OK;}
如会话中的URL请求内容如图所示。
B.web_util_set_request_url函数内容如图所示。
2.在RequestCB回调包中修改请求的body信息
如果在异步会话中在发送请求点需要修改请求的body内容,那么需要使用web_util_set_request_body函数来修改body内容,并在每一次轮询前进行修改。
A.web_util_set_request_body函数格式如下:
web_util_set_request_body ( const char * aUrlStr);
aUrlStr是指请求URL字符串。
写在AsyncCallbacks.c文件中的int Push_0_RequestCB回调函数中,代码如下:
intPush_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>");returnWEB_ASYNC_CB_RC_OK;}
B. 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的使用方法。