使用loadrunner進行壓力測試主要分兩步,第一步是編寫腳本(比較重點),第二步執行測試(配置都是在界面上點點就好了,固然我只的是比較簡單的,能知足平常須要的),第三步分析結果(這一步比較高深,可是對於我來講能看懂簡單的性能指標就OK了)。因此這裏就說一下腳本的編寫,給將來再用到作參考。
1.HTTP的GET請求
這裏以訪問百度爲例,地址http://www.baidu.com/s?wd=mobile,表示在百度上搜索mobile。具體腳本以下(有註釋)
html
Action() 數組
{ socket
int status; ide
lr_start_transaction("send"); 性能
web_reg_find("Search=Body",//這裏說明在Body的範圍內查找 測試
"SaveCount=ret_Count",//這裏表示把返回值的個數放在變量ret_Count裏 url
"Text=mobile",//這裏表示查找的內容是「mobile」 spa
LAST); 調試
status=web_url("Baidu_Search",
"URL= http://www.baidu.com/s?wd=mobile",
"TargetFrame=Main",
"Resource=0",
"RecContentType=text/html",
"Mode=http",
LAST );
lr_output_message("Request Status:%d",status);
lr_output_message("查找到的返回值個數:%d",atoi(lr_eval_string("{ret_Count}")));
if (atoi(lr_eval_string("{ret_Count}")) > 0){//這裏判斷檢查到的個數
lr_output_message("Rec successful.");
lr_end_transaction("send", LR_PASS);
}
else{
lr_error_message("Rec failed");
lr_end_transaction("send", LR_FAIL);
}
return 0;
}
2.HTTP POST請求
這個是在咱們項目中用到的,發送POST請求,進行天然語言識別的,腳本以下:
Action()
{
int status;
lr_start_transaction("send");
web_reg_find("Search=Body",//這裏說明在Body的範圍內查找
"SaveCount=ret_Count",//這裏表示把返回值的個數放在變量ret_Count裏
"Text=t",//這裏表示查找的內容是「t」
LAST);
status=web_submit_data("trs",
"Action=http://192.168.77.185:9002/recognizeText",//地址
"Method=POST",//POST請求
"RecContentType=text/html",
"Mode=HTML",
ITEMDATA,
"Name=usercontent","Value=gprs",ENDITEM,//這一行表示傳入一個參數usercontent,值爲gprs
"Name=Accept","Value=text/plain",ENDITEM,
LAST);
lr_output_message("Request Status:%d",status);
if (atoi(lr_eval_string("{ret_Count}")) > 0){//這裏判斷檢查到的個數
lr_output_message("Rec successful.");
lr_end_transaction("send", LR_PASS);
}
else{
lr_error_message("Rec failed");
lr_end_transaction("send", LR_FAIL);
}
return 0;
}
3.WebService請求
webservice請求的腳本建議經過可視化的方式添加
1)引入webservice,注意wsdl後綴
2)給入參填值
3)給返回值指定存儲到的變量中
4)結果檢查
這個與其它模式同樣,很少說了
我這裏添加的是網上公用的天氣預報webservice,地址是:http://www.webxml.com.cn/WebServices/WeatherWebService.asmx
詳細腳本以下:
Action()
{
int status;
lr_start_transaction("send");
status=web_service_call( "StepName=getSupportCity_102",
"SOAPMethod=WeatherWebService|WeatherWebServiceSoap|getSupportCity",//這裏是我已經引用了webservice的名稱及調用方法
"ResponseParam=response",
"Service=WeatherWebService",
"ExpectedResponse=SoapResult",
"Snapshot=t1353067092.inf",
BEGIN_ARGUMENTS,
"byProvinceName=安徽",//這裏是入參,參數名稱:byProvinceName,值:安徽。入參和返回值的名稱均可以再引用裏看見
END_ARGUMENTS,
BEGIN_RESULT,
"getSupportCityResult=result",//這裏是返回值,名稱:getSupportCityResult,把它放到變量result中
END_RESULT,
LAST);
lr_output_message("Request Status:%d",status);
lr_output_message("Result:%s",lr_eval_string("{result}"));//這裏把返回值輸出,調試webservice的時候用
if(strstr(lr_eval_string("{result}"),"合肥")>0){//這裏是判斷返回值中是否包含「合肥」
lr_end_transaction("send",LR_PASS);
}else{
lr_end_transaction("send",LR_AUTO);
}
return 0;
}
4.Socket請求
我這裏指的是簡單的Socket請求,端鏈接,發送接收的都是一個字符串。比較複雜的Socket請求,本身錄製腳本。若是不知道,本身去查。
詳細腳本以下,另外還包含一個data.ws文件,用來聲明發送和接收的字節數組及其長度的,並指定要發送的內容(發送的內容同樣能夠參數化的)
#include "lrs.h"
Action()
{
char *recvbuf;
int recvlen=0;
int rc;
lrs_startup(257);
lr_start_transaction("Trans_1");
lr_start_transaction("Conn_1");
rc=lrs_create_socket("socket0", "TCP", "RemoteHost=192.168.1.101:8888", LrsLastArg);//建立Socket鏈接
if (rc != 0 ) {
lr_end_transaction("Conn_1", LR_FAIL);
lr_end_transaction ("Trans_1", LR_FAIL);
return 0;
}
lr_end_transaction("Conn_1", LR_PASS); //判斷socket是否連接成功的事務,0表示建立成功
lrs_send("socket0", "buf0", LrsLastArg); //發送buf0,buf0爲在data.ws中定義的發送變量
lrs_receive("socket0", "buf1", LrsLastArg); //接收消息,存放在buf1中,buf1是在data.ws中定義的接收數組,注意數組長度必定要大於等於實際接收長度
lrs_get_last_received_buffer("socket0",&recvbuf,&recvlen);//把Socket最後接收的字節數組,長度放在recvlen中,內容放在recvbuf中
lr_output_message("Received:%s",lr_eval_string(recvbuf));
if(recvlen>3)
lr_end_transaction("Trans_1", LR_PASS);
else
lr_end_transaction ("Trans_1", LR_FAIL);
lrs_disable_socket("socket0", DISABLE_SEND_RECV);
lrs_close_socket("socket0");
return 0;
}
//data.ws
;WSRData 2 1
send buf0 32
"hehehehe"
recv buf1 50
-1