先说明一下,本人是开发,对测试不是特别熟悉,但因工作的需要,也做过一些性能测试方面的东西。比较久之前很简单的用过,最近又用到了,熟悉一下。现做一个总结。
使用loadrunner进行压力测试主要分两步,第一步是编写脚本(比较重点),第二步执行测试(配置都是在界面上点点就行了,当然我只的是比较简单的,能满足日常需要的),第三步分析结果(这一步比较高深,但是对于我来说能看懂简单的性能指标就OK了)。所以这里就说一下脚本的编写,给未来再用到做参考。
1.HTTP的GET请求
这里以访问百度为例,地址http://www.baidu.com/s?wd=mobile,表示在百度上搜索mobile。具体脚本如下(有注释)
Lr script代码
1. Action()
2. {
3. int status;
4. "send");
5.
6. "Search=Body",//这里说明在Body的范围内查找
7. "SaveCount=ret_Count",//这里表示把返回值的个数放在变量ret_Count里
8. "Text=mobile",//这里表示查找的内容是“mobile”
9. LAST);
10.
11. "Baidu_Search",
12. "URL= http://www.baidu.com/s?wd=mobile",
13. "TargetFrame=Main",
14. "Resource=0",
15. "RecContentType=text/html",
16. "Mode=http",
17. LAST );
18.
19. "Request Status:%d",status);
20. "查找到的返回值个数:%d",atoi(lr_eval_string("{ret_Count}")));
21.
22.
23. "{ret_Count}")) > 0){//这里判断检查到的个数
24. "Rec successful.");
25. "send", LR_PASS);
26. }
27. else{
28. "Rec failed");
29. "send", LR_FAIL);
30. }
31.
32. 0;
33. }
2.HTTP POST请求
这个是在我们项目中用到的,发送POST请求,进行自然语言识别的,脚本如下:
Lr script代码
1. Action()
2. {
3. int status;
4.
5. "send");
6.
7. "Search=Body",//这里说明在Body的范围内查找
8. "SaveCount=ret_Count",//这里表示把返回值的个数放在变量ret_Count里
9. "Text=t",//这里表示查找的内容是“t”
10. LAST);
11.
12. "trs",
13. "Action=http://192.168.77.185:9002/recognizeText",//地址
14. "Method=POST",//POST请求
15. "RecContentType=text/html",
16. "Mode=HTML",
17. ITEMDATA,
18. "Name=usercontent","Value=gprs",ENDITEM,//这一行表示传入一个参数usercontent,值为gprs
19. "Name=Accept","Value=text/plain",ENDITEM,
20. LAST);
21.
22. "Request Status:%d",status);
23.
24. "{ret_Count}")) > 0){//这里判断检查到的个数
25. "Rec successful.");
26. "send", LR_PASS);
27. }
28. else{
29. "Rec failed");
30. "send", LR_FAIL);
31. }
32.
33. 0;
34. }
3.WebService请求
webservice请求的脚本建议通过可视化的方式添加
1)引入webservice,注意wsdl后缀
2)给入参填值
3)给返回值指定存储到的变量中
4)结果检查
这个与其它模式一样,不多说了
我这里添加的是网上公用的天气预报webservice,地址是:http://www.webxml.com.cn/WebServices/WeatherWebService.asmx
详细脚本如下:
Lr script代码
1. Action()
2. {
3. int status;
4.
5. "send");
6.
7. "StepName=getSupportCity_102",
8. "SOAPMethod=WeatherWebService|WeatherWebServiceSoap|getSupportCity",//这里是我已经引用了webservice的名称及调用方法
9. "ResponseParam=response",
10. "Service=WeatherWebService",
11. "ExpectedResponse=SoapResult",
12. "Snapshot=t1353067092.inf",
13. BEGIN_ARGUMENTS,
14. "byProvinceName=安徽",//这里是入参,参数名称:byProvinceName,值:安徽。入参和返回值的名称都可以再引用里看见
15. END_ARGUMENTS,
16. BEGIN_RESULT,
17. "getSupportCityResult=result",//这里是返回值,名称:getSupportCityResult,把它放到变量result中
18. END_RESULT,
19. LAST);
20.
21. "Request Status:%d",status);
22. "Result:%s",lr_eval_string("{result}"));//这里把返回值输出,调试webservice的时候用
23.
24.
25. "{result}"),"合肥")>0){//这里是判断返回值中是否包含“合肥”
26. "send",LR_PASS);
27. }else{
28. "send",LR_AUTO);
29. }
30.
31. 0;
32. }
4.Socket请求
我这里指的是简单的Socket请求,端连接,发送接收的都是一个字符串。比较复杂的Socket请求,自己录制脚本。如果不知道,自己去查。
详细脚本如下,另外还包含一个data.ws文件,用来声明发送和接收的字节数组及其长度的,并指定要发送的内容(发送的内容一样可以参数化的)
Lr script代码
1. #include "lrs.h"
2. Action()
3. {
4. char *recvbuf;
5. 0;
6. int rc;
7.
8. 257);
9.
10. "Trans_1");
11. "Conn_1");
12.
13. "socket0", "TCP", "RemoteHost=192.168.1.101:8888", LrsLastArg);//创建Socket连接
14.
15. 0
16. "Conn_1", LR_FAIL);
17. "Trans_1", LR_FAIL);
18. 0;
19. }
20. "Conn_1", LR_PASS); //判断socket是否链接成功的事务,0表示创建成功
21.
22. "socket0", "buf0", LrsLastArg); //发送buf0,buf0为在data.ws中定义的发送变量
23.
24. "socket0", "buf1", LrsLastArg); //接收消息,存放在buf1中,buf1是在data.ws中定义的接收数组,注意数组长度一定要大于等于实际接收长度
25.
26. "socket0",&recvbuf,&recvlen);//把Socket最后接收的字节数组,长度放在recvlen中,内容放在recvbuf中
27.
28. "Received:%s",lr_eval_string(recvbuf));
29.
30. 3)
31. "Trans_1", LR_PASS);
32. else
33. "Trans_1", LR_FAIL);
34.
35.
36. "socket0", DISABLE_SEND_RECV);
37.
38. "socket0");
39. 0;
40. }
1. #include "lrs.h"
2. Action()
3. {
4. char *recvbuf;
5. 0;
6. int rc;
7.
8. 257);
9.
10. "Trans_1");
11. "Conn_1");
12.
13. "socket0", "TCP", "RemoteHost=192.168.1.101:8888", LrsLastArg);//创建Socket连接
14.
15. 0
16. "Conn_1", LR_FAIL);
17. "Trans_1", LR_FAIL);
18. 0;
19. }
20. "Conn_1", LR_PASS); //判断socket是否链接成功的事务,0表示创建成功
21.
22. "socket0", "buf0", LrsLastArg); //发送buf0,buf0为在data.ws中定义的发送变量
23.
24. "socket0", "buf1", LrsLastArg); //接收消息,存放在buf1中,buf1是在data.ws中定义的接收数组,注意数组长度一定要大于等于实际接收长度
25.
26. "socket0",&recvbuf,&recvlen);//把Socket最后接收的字节数组,长度放在recvlen中,内容放在recvbuf中
27.
28. "Received:%s",lr_eval_string(recvbuf));
29.
30. 3)
31. "Trans_1", LR_PASS);
32. else
33. "Trans_1", LR_FAIL);
34.
35.
36. "socket0", DISABLE_SEND_RECV);
37.
38. "socket0");
39. 0;
40. }
1. //data.ws
2. ;WSRData 2 1
3.
4. send buf0 32
5. "hehehehe"
6.
7. recv buf1 50
8.
9.
10.
11. -1
结束的话:
这里介绍的测试脚本,我觉得开发测试人员都需要会,因为开发弄出来的东西,自己要了解个大概的性能吧。如果测试的专业人员,这些都要熟知,再如果想要了解的更多,请转到51testing上去。