Loadrunner模擬JSON接口請求進行測試

一、loadrunner腳本創建

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

2.填入相應參數

3.生成腳本,並修改如下(參數中的引號"前需要加斜槓\轉譯)

 

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.捕獲頁面返回值

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

將光標移動到腳本頂部,插入關聯點insert-new step-service-web_reg_save_param

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

 

web_reg_save_param("user_tags",

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

"RB=\"]}",

LAST);

在腳本尾部,加入輸出日誌驗證是否獲取成功

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

 

5.對我們的接口做自動化功能測試,寫驗證腳本如下:

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.參數化腳本

 

運行腳本,重要日誌輸出如下:

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區別

web_custom_request方法可以發送POST和GET類型的請求;

web_submit_data只能發送POST類型的請求;

所有web_submit_data方法發送的請求都可以使用web_custom_request來實現 

web_custom_request可以實現web_submit_data無法實現的請求,比如“查詢所有郵件並刪除”這個案例中,查詢時我們使用關聯把所有郵件對應的標識抓取成一個數組,如果使用web_submit_data來完成這個刪除的請求,需要很多個web_submit_data請求才能完成,但使用web_custom_request就可以通過一個請求完成,方法是自己寫代碼拼一個web_custom_request 方法POST請求的Body值。

 

1. web_submit_data

請求中提交的數據格式:“Name=屬性名稱,”,“Value=屬性值”

例如:

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

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

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

如果想提交的某個屬性包含包含多個值(比如說批量刪除),單個web_submit_data就無法處理了,只能通過多個web_submit_data來處理。

 

2. web_custom_request

提交的數據(body)格式:“Body=屬性名稱=屬性值&屬性名稱=屬性值&……”

 

下面是一個典型的web_submit_data和web_custom_request請求,可以看到web_custom_request中提交的數據(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請求會被LoadRunner錄製爲web_custom_request:

1.   上文提到的批量提交多條同屬性名稱的數據的請求
2.   header屬性x-requested-by值爲XMLHttpRequest的POST請求

這兩種實現請求的方法還有一個需要注意的地方就是web_custom_request中body中的屬性值如果包含一些特殊字符,必須通過URL編碼,否則Web服務器會返回500錯誤,一個典型的例子是如果Body中包含ViewState,ViewState中常常有“=”之類的特殊字符,此時必須通過URL編碼,LoadRuner中提供了一個這樣的編碼轉換函數:

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

 

3. web_custom_request函數詳解

A.語法:

int web_custom_request( const char *RequestName, ,
[EXTRARES, ,] LAST );

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

C.參數:

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

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

a.URL:頁面地址。

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

c.TargetFrame:當前鏈接或資源所在Frame的名稱。參見List of Attributes的同名參數。

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

_BLANK:打開一個空窗口。

_PARENT:把最新更改過的的Frame替換爲它的上級。

_SELF:替換最新更改過的的Frame。

_TOP:替換整個頁面。

d.EncType:編碼類型。

e. RecContentType:響應頭的內容類型。參見List of Attributes的同名參數。

f. Referer:參見List of Attributes的同名參數。

g. Body:請求體。參見List of Attributes的同名參數。

h. RAW BODY:參見List of Attributes的同名參數。

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

j. Resource、ResourceByteLimit、Snapshot、Mode:參見List of Attributes的同名參數。

k. ExtraResBaseDir:參見List of Attributes的同名參數。

l. UserAgent:用戶代理,它是一個HTTP頭的名字,用來標識應用程序,通常是瀏覽器,它呈現的是用戶和服務器的交互。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章