Loadrunner模拟JSON接口请求进行测试

2018/11/10 15:47
阅读数 10

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头的名字,用来标识应用程序,通常是浏览器,它呈现的是用户和服务器的交互。

展开阅读全文
打赏
0
0 收藏
分享
加载中
更多评论
打赏
0 评论
0 收藏
0
分享
返回顶部
顶部