在LoadRunner中使用windows socket協議
這兩天寫了一個winsocket的腳本,沒有通過錄制的方式,是直接手寫的。下面貼出來和大家分享: 腳本的寫法很簡單,大體說來,就像把大象放進冰箱一樣,總共分三步: 第一步:把冰箱門打開。 //建立到服務端的連接 rc = lr s_create_socket("socket0", "TCP", "
這兩天寫了一個winsocket的腳本,沒有通過錄制的方式,是直接手寫的。下面貼出來和大家分享:
腳本的寫法很簡單,大體說來,就像把大象放進冰箱一樣,總共分三步:
第一步:把冰箱門打開。
//建立到服務端的連接
rc =
lrs_create_socket("socket0", "TCP", "LocalHost=0", "RemoteHost=128.64.64.23:8988", LrsLastArg);
if (rc==0)
lr_output_message("Socket was su
clearcase/" target="_blank" >ccessfully created ");
else
lr_output_message("An error occurred while creating the socket, Error Code: %d", rc);
第二步:把大象裝進去。
lrs_send("socket0", "buf0", LrsLastArg); //往"socket0"發送"buf0"中的數據
lrs_receive("socket0", "buf1", LrsLastArg);//將"socke0"中返回的數據存放到"buf1"中
第三步:把冰箱門帶上。
//關閉連接
lrs_close_socket("socket0");
大家肯定已經看出來了,整個關鍵是在第二步,要把這么一頭大象裝到冰箱里可不是件容易的事情,我們要對傳送的數據做一些處理才行。如果大家有進行過winsocket協議的腳本錄制就會知道,
LR會把你發送的數據包內容寫到data.ws這個文件中,那么我們在此也同樣應該把數據寫到data.ws中去。假設我要發送的是“00100312303456”這一串字符,那么我就直接把它寫到data.ws中,腳本如下:
;WSRData 2 1
send buf0 10
"00100312303456" //注意要加""
recv buf1 128
-1
運行腳本,可以看到執行成功。在
日志信息中可以打印出發送的BUFFER和接收到的BUFFER內容。
接下來,我們要對發送的字符串進行參數化,讓腳本每次發送的字符串都不一樣,怎么做呢?
方法有兩種:
1、直接參數化。在data.ws中是可以直接進行參數化的,具體操作我就不多說了。要注意的是默認的參數名稱符號是尖括號(<>),和HTTP協議的大括號({})不同(搞不懂為什么LR要把不同協議的默認參數名稱符號設成不一樣,這不是折騰人嘛)。腳本如下:
send buf0 106
"<string>" //string是自定義的參數名
這種方法最簡單,也容易理解。
原文轉自:http://www.anti-gravitydesign.com