Loadrunner模擬JSON接口請(qǐng)求進(jìn)行測(cè)試

一、loadrunner腳本創(chuàng)建

1.Insert - New step -選擇Custom Request - web_custom_request

2.填入相應(yīng)參數(shù)

3.生成腳本,并修改如下(參數(shù)中的引號(hào)"前需要加斜杠\轉(zhuǎn)譯)

Action()

{

web_custom_request("web_custom_request",

"URL=http://urlhead/CpcService.ashx?Method=checkXXXed",

"Method=POST",

"Resource=0",

"RecContentType=application/json",

"Referer=",

"Mode=HTTP",

"EncType=application/json",

"Body={\"user\":{\"uid\":\"C8-9C-DC-70-BD-B2\"}}",

LAST);

return 0;

}

4.捕獲頁(yè)面返回值

返回格式{"IsError":0,"ErrorMsg":"","user_tags":["0"]}

將光標(biāo)移動(dòng)到腳本頂部,插入關(guān)聯(lián)點(diǎn)insert-new step-service-web_reg_save_param

在腳本頂部,插入并修改腳本如下

web_reg_save_param("user_tags",

"LB=user_tags\":[\"",

"RB=\"]}",

LAST);

在腳本尾部,加入輸出日志驗(yàn)證是否獲取成功

lr_message ("user_tags:%s", lr_eval_string("{user_tags}"));

5.對(duì)我們的接口做自動(dòng)化功能測(cè)試,寫(xiě)驗(yàn)證腳本如下:

if (atoi(lr_eval_string("{user_tags}"))==0)

lr_output_message("user_tags:%s,succeed!",(lr_eval_string("{user_tags}")));

else if(atoi(lr_eval_string("{user_tags}"))==1)

lr_output_message("user_tags:%s,failed!",(lr_eval_string("{user_tags}")));

else

lr_output_message("user_tags:%s,unknow!",(lr_eval_string("{user_tags}")));

6.參數(shù)化腳本

運(yùn)行腳本,重要日志輸出如下:

Action.c(24): [C8-9C-DC-70-BD-B2]0,succeed!

Action.c(26): [C8-9C-DC-70-BD-B3]1,failed!

---------------------------------------END---------------------------------------

二、web_custom_request和web_submit_data區(qū)別

web_custom_request方法可以發(fā)送POST和GET類(lèi)型的請(qǐng)求;

web_submit_data只能發(fā)送POST類(lèi)型的請(qǐng)求;

所有web_submit_data方法發(fā)送的請(qǐng)求都可以使用web_custom_request來(lái)實(shí)現(xiàn)

web_custom_request可以實(shí)現(xiàn)web_submit_data無(wú)法實(shí)現(xiàn)的請(qǐng)求,比如“查詢(xún)所有郵件并刪除”這個(gè)案例中,查詢(xún)時(shí)我們使用關(guān)聯(lián)把所有郵件對(duì)應(yīng)的標(biāo)識(shí)抓取成一個(gè)數(shù)組,如果使用web_submit_data來(lái)完成這個(gè)刪除的請(qǐng)求,需要很多個(gè)web_submit_data請(qǐng)求才能完成,但使用web_custom_request就可以通過(guò)一個(gè)請(qǐng)求完成,方法是自己寫(xiě)代碼拼一個(gè)web_custom_request 方法POST請(qǐng)求的Body值。

1. web_submit_data

請(qǐng)求中提交的數(shù)據(jù)格式:“Name=屬性名稱(chēng),”,“Value=屬性值”

例如:

"Name=username″,"Value=12044″, ENDITEM,

"Name=password″,"Value=123456″, ENDITEM,

"Name=typeId″,"Value=1″, ENDITEM,

如果想提交的某個(gè)屬性包含包含多個(gè)值(比如說(shuō)批量刪除),單個(gè)web_submit_data就無(wú)法處理了,只能通過(guò)多個(gè)web_submit_data來(lái)處理。

2. web_custom_request

提交的數(shù)據(jù)(body)格式:“Body=屬性名稱(chēng)=屬性值&屬性名稱(chēng)=屬性值&……”

下面是一個(gè)典型的web_submit_data和web_custom_request請(qǐng)求,可以看到web_custom_request中提交的數(shù)據(jù)(body)是以這樣的方式存在的,如下:

web_submit_data("searchRecvOrgsname",

"Action=http://{url}/searchRecvOrgsname",

"Method=POST",

"TargetFrame=",

"RecContentType=text/html",

"Referer=http://{url}/login_wj;jsessionid={jsessionid}",

"Snapshot=t18.inf",

"Mode=HTML",

ITEMDATA,

"Name=orgsId", "Value={orgsId}", ENDITEM,

"Name=code", "Value={order_end_station_code}", ENDITEM,

LAST);

web_custom_request("searchVehiclePopUp",

"URL=http://{url}/searchVehiclePopUp",

"Method=POST",

"TargetFrame=",

"Resource=0",

"RecContentType=text/html",

"Referer=http://{url}/login_wanjia;jsessionid={jsessionid}",

"Snapshot=t19.inf",

"Mode=HTML",

"EncType=application/x-www-form-urlencoded; charset=UTF-8",

"Body=&orgsId={orgsId}&order_start_station_id={order_start_station_id}&targetcode=order_truck_no&targetname=order_truck_name&targetid=order_truck_id",

LAST);

兩種情況下的POST請(qǐng)求會(huì)被LoadRunner錄制為web_custom_request:

1.上文提到的批量提交多條同屬性名稱(chēng)的數(shù)據(jù)的請(qǐng)求

2.header屬性x-requested-by值為XMLHttpRequest的POST請(qǐng)求

這兩種實(shí)現(xiàn)請(qǐng)求的方法還有一個(gè)需要注意的地方就是web_custom_request中body中的屬性值如果包含一些特殊字符,必須通過(guò)URL編碼,否則Web服務(wù)器會(huì)返回500錯(cuò)誤,一個(gè)典型的例子是如果Body中包含ViewState,ViewState中常常有“=”之類(lèi)的特殊字符,此時(shí)必須通過(guò)URL編碼,LoadRuner中提供了一個(gè)這樣的編碼轉(zhuǎn)換函數(shù):

web_convert_param(“vs1″, “SourceEncoding=HTML”,“TargetEncoding=URL”, LAST);

3. web_custom_request函數(shù)詳解

A.語(yǔ)法:

int web_custom_request( const char *RequestName, ,

[EXTRARES, ,] LAST );

B.返回值:返回LR_PASS(0)代表成功,LR_FAIL(1)代表失敗。

C.參數(shù):

(1)RequestName:步驟的名稱(chēng),VuGen中樹(shù)形視圖中顯示的名稱(chēng)。

(2)List of Attribute:屬性列表,支持的屬性有以下幾種:

a.URL:頁(yè)面地址。

b.Method:頁(yè)面的提交方式,POST或GET。

c.TargetFrame:當(dāng)前鏈接或資源所在Frame的名稱(chēng)。參見(jiàn)List of Attributes的同名參數(shù)。

除了Frame的名字,還可以指定下面的參數(shù):

_BLANK:打開(kāi)一個(gè)空窗口。

_PARENT:把最新更改過(guò)的的Frame替換為它的上級(jí)。

_SELF:替換最新更改過(guò)的的Frame。

_TOP:替換整個(gè)頁(yè)面。

d.EncType:編碼類(lèi)型。

e. RecContentType:響應(yīng)頭的內(nèi)容類(lèi)型。參見(jiàn)List of Attributes的同名參數(shù)。

f. Referer:參見(jiàn)List of Attributes的同名參數(shù)。

g. Body:請(qǐng)求體。參見(jiàn)List of Attributes的同名參數(shù)。

h. RAW BODY:參見(jiàn)List of Attributes的同名參數(shù)。

i. BodyFilePath:作為請(qǐng)求體傳送的文件的路徑。它不能與下面的屬性一起使用:Body,或者其他Body屬性或Raw Body屬性包括BodyBinary,BodyUnicode,RAW_BODY_START或Binary=1。

j. Resource、ResourceByteLimit、Snapshot、Mode:參見(jiàn)List of Attributes的同名參數(shù)。

k. ExtraResBaseDir:參見(jiàn)List of Attributes的同名參數(shù)。

l. UserAgent:用戶(hù)代理,它是一個(gè)HTTP頭的名字,用來(lái)標(biāo)識(shí)應(yīng)用程序,通常是瀏覽器,它呈現(xiàn)的是用戶(hù)和服務(wù)器的交互。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容