2013年10月17日

    在近期的某性能测试项目中,使用LR 11做测试,遇到了一个问题:在录制的脚本中,许多请求都带有EXTRARES,如:
     web_submit_data("clientlog.jspx_23", 
"Action=https://gaa-ad.pp2.shanghaionstar.com:8101/Advisor/faces/xAdvisorWeb/bundles/gaacommon/jsf/clientlog.jspx?message=Alerts%20refresh%20completed&clientTime=1466056941075", 
"Method=POST", 
"RecContentType=text/html", 
"Referer=https://gaa-ad.pp2.shanghaionstar.com:8101/Advisor/xAdvisorWeb/desktop/desktop.jsp", 
"Snapshot=t57.inf", 
"Mode=HTML", 
ITEMDATA, 
EXTRARES, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1712&y=854&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1713&y=854&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1715&y=854&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1714&y=854&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1712&y=855&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1713&y=855&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1714&y=855&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1715&y=855&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1712&y=856&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1713&y=856&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1714&y=856&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1715&y=856&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1712&y=857&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1713&y=857&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1714&y=857&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1715&y=857&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1712&y=858&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1713&y=858&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1714&y=858&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1715&y=858&z=11", "Referer=", ENDITEM, 
LAST);
     这些EXTRARES资源请求实际上是在上一个页面请求时发起,并通过异步的方式返回的一些地图数据。由于在录制脚本的过程中,上一步操作未能等到这些数据全部返回便开始了下一步的操作,因此在随后的脚本中,LR将这些请求作为EXTRARES
资源附在了这些请求之后。如此一来就造成了一个问题:这些请求的响应时间变长,但对于真实的用户而言,这些请求的响应时间却并没有那么长(因为这些地图数据在后台加载,用户感受不到)。表面上看来,似乎LR测试得到的结果与实际“不一致”了。而另一方面,这些资源请求又是真实存在的,对于服务器产生了压力,所以也不能简单粗暴地直接在脚本中去掉。
    最后,我们采取的办法是:将这些地图数据的加载单独写成一个web_url,使它对服务器产生真实的负载,并把它放在定义的事务之外。脚本如下:
     web_url("map",
"URL=http://10.16.93.182:22002/maptile/maptile?x=1711&y=854&z=11",
EXTRARES, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1711&y=854&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1712&y=854&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1713&y=854&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1714&y=854&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1715&y=854&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1711&y=855&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1712&y=855&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1714&y=855&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1713&y=855&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1715&y=855&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1711&y=856&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1712&y=856&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1713&y=856&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1714&y=856&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1715&y=856&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1711&y=857&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1712&y=857&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1713&y=857&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1714&y=857&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1715&y=857&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1711&y=858&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1712&y=858&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1713&y=858&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1714&y=858&z=11", "Referer=", ENDITEM, 
"Url=http://10.16.93.182:22002/maptile/maptile?x=1715&y=858&z=11", "Referer=", ENDITEM, 
LAST);
    同时,将后续脚本中的EXTRARES资源请求删除。

    这样一来,就既模拟了服务器端真实的负载场景,又避免了客户端实际响应时间不一致的问题。
         


posted @ 2016-07-08 12:54 xingcyx 阅读(1381) | 评论 (0)编辑 收藏
 
LoadRunner 12录制的脚本在LoadRunner 11的controller上无法运行,提示该VUSER类型没有license。
原因:LR12的VUSER type是Mobile。
解决方法:
用文本编辑器打开脚本的.usr文件,如03_HandEmergencyCall.usr,
AdditionalTypes=Mobile
ActiveTypes=Mobile
GenerateTypes=Mobile
RecordedProtocols=
修改为:
AdditionalTypes=QTWeb
ActiveTypes=QTWeb
GenerateTypes=QTWeb
RecordedProtocols=QTWeb
posted @ 2016-06-30 15:17 xingcyx 阅读(1588) | 评论 (0)编辑 收藏
 
    大多数情况下,在LoadRunner的脚本中设置参数还是比较简单的,但是正所谓人在江湖飘,哪能不挨刀?有的时候我们也会遇到一些特殊的情况,对脚本中的参数需要做一些特殊的处理。比如我最近在几个项目的性能测试脚本编写过程中,就遇到了这种情况。
    第一个项目其实是我同事遇到的。他们的系统报文中有一个参数的限制条件:要求必须是数字型,且长度为9位,如果不足9位,需要在后面补齐空格,而且还需要保证参数值唯一。我们暂且不去追究为啥这个系统会设置这么坑爹的一个限制,在这里的重点是说明在这样的情况下,我们该如何去设置参数?由于这个系统要求参数值唯一,所以我首先想到的还是利用LoadRunner的参数类型去控制,因为只有这样才能在并发的情况下,保证参数值的唯一性。
    总体思路拢共分三步:1、设置一个类型为unique number的参数类型,转换为字符型;2、根据字符串的长度,补齐空格为9位;3、将字符串转换为参数并替换
    具体的代码如下:
    

char str[10];
 int len;

 int num;
 int i;


//获取参数的长度 

 len=strlen(lr_eval_string("{old_param}"));

 
num=9-len;


 strcpy(str,lr_eval_string("{old_param}"));

 for(i=1;i<=num;i++)
 {
  //在字符串后面加上空格
  strcat(str," ");
 }


//转换为参数
lr_param_sprintf("new_param",str);


     第二个项目的情况相对比较好理解一些。要测试的是一个批量提交的业务,用户在页面上选择10笔数据后,作为一个批次一起提交。需要参数化的参数有两个:客户编号(custid)和业务编号(loanid),需要从参数文件中每次取10个参数。并拼接成需要的报文格式,以逗号分隔开。做法与上一个项目大同小异,只不过这里的参数类型要设置成file型。需要注意的是,由于参数文件中的custid和loanid是一行一笔数据,而我们每次需要使用的是10笔数据,因此在update values那里需要设置成每次出现时更新参数值。


    代码示例如下:
   //获取批次的custid和loanid,每批次取10笔数据
 for (i=1;i<=9;i++)
 {
  strcpy(scustid,lr_eval_string("{custid}"));
  strcat(bat_custid,scustid);
   //custid间用“,”分隔
  strcat(bat_custid,",");

  strcpy(sloanid,lr_eval_string("{loanid}"));
  strcat(bat_loanid,sloanid);
  //loanid间用“,”分隔
  strcat(bat_loanid,",");
  
 }

 strcat(bat_custid,lr_eval_string("{custid}"));
 strcat(bat_loanid,lr_eval_string("{loanid}"));

 //转换成LR的参数
 lr_param_sprintf("p_custid",bat_custid);
 lr_param_sprintf("p_loanid",bat_loanid);


    
posted @ 2014-01-08 20:35 xingcyx 阅读(3590) | 评论 (0)编辑 收藏
 
软件测试泰斗传道解惑 Google软件测试精髓完美呈现 《Google软件测试之道》
posted @ 2013-10-17 20:05 xingcyx 阅读(991) | 评论 (0)编辑 收藏