川石教育
全国咨询热线:136-9172-9932
  1. 首页 > 资讯与干货 > IT资讯

LoadRunner中API函数主要包括那些?

作者:川石学院 日期:2021-05-31 16:41:54 点击数:

  性能测试工具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。

LoadRunner中API函数主要包括那些?(图1)

  1、 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所示。  

LoadRunner中API函数主要包括那些?(图2)

  图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所示。  

LoadRunner中API函数主要包括那些?(图3)

  图6-69 变动的URL请求内容

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

LoadRunner中API函数主要包括那些?(图4)

  图6-70 web_util_set_request_url参数内容

  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("");

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

  web_util_set_request_body("");

  return WEB_ASYNC_CB_RC_OK;

  }

  1、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);

  今天关于“LoadRunner中API函数”的内容就学习完了,相信大家都已经掌握了,如果喜欢的话记得每天来这里和小编一起学习涨薪技能哦。(笔芯)

  附:川石信息全国校区最新开班时间,课程资料获取13691729932(微信同号)。  

LoadRunner中API函数主要包括那些?(图5)


相关文章
  • 亚马逊运营成功转行软件测试,薪资13K表示很满意!2021-05-31 16:41:54
  • 西安川石的兰朋友喊你来当他的学弟学妹啦!2021-05-31 16:41:54
  • 国外的月亮也不一定比国内测试猿的年薪美~2021-05-31 16:41:54
  • 建筑工程专业朱同学成功转行为软件测试人!2021-05-31 16:41:54
  • 财务管理专业转行软件测试月薪甩会计几条街!2021-05-31 16:41:54
  • 只有技术沉淀才能成功上岸,深圳就业薪资13K!2021-05-31 16:41:54
  • 薪资11K!实现自我价值,从掌握一门IT技术开始...2021-05-31 16:41:54
  • 文科生转行软件测试照样拿下高薪15K!2021-05-31 16:41:54
  • 恭喜罗同学喜提19.5K,成功入行软件测试!2021-05-31 16:41:54
  • 毕业1年,迷茫的他最终选择转行软件测试2021-05-31 16:41:54