请选择 进入手机版 | 继续访问电脑版
对Web Services进行接口测试时,其实主要是通过web_service_call这个函数向服务器发送请求,在这个章节中将详细阐述web_service_call函数的使用。
int web_service_call( const char *StepName, [URL,] ExpectedResponse, <List of specifications>, [BEGIN_ARGUMENTS, Arguments, END_ARGUMENTS,] [Send Attachments, ][BEGIN_RESULT, Results, END_RESULT,] [Receive Attachments, ] LAST );
参数说明:
StepName:步骤的名称,它显示在测试树中。可以使用任何文本。
ExpectedResponse:要接受的响应的类型。ExpectedResponse有三种模式,见表。
LoadRunner WebService接口测试(三)---Web_service_call函数-1.jpg
URL:要加载的Web服务的URL(统一资源定位符)。
List ofspecifications:规范列表格式“Specification = value”的逗号分隔列表。常见的列表参数如下:
1) 1
要调用的WebService方法,包括服务名称,端口名称和方法名称。 SOAPMethod无法参数化。见以下实例:
SOAPMethod=EnglishChinese|EnglishChineseSoap|TranslatorString
EnglishChinese:是服务器名。
EnglishChineseSoap:是端口名。
TranslatorString:本次测试的方法名。
2) Service
在WSDL中定义的服务的名称。
3) WSDL
标识WSDL文档的位置。无法对WSDL及其参数进行参数化。
4) Snapshot
包含步骤快照的.inf文件的名称。此参数由服务测试记录。手动输入步骤时,不要添加。如果记录,不要编辑它。
5) ResponseParam
服务器响应的输出信息的参数名。
6) RecordedBuffer
用于保存录制期间缓存区的信息。不要编辑此参数或手动输入。
7) ClientEmulation
此参数是采用工具包(DotNet或Axis)的名称或记录的关键字,如果设置此参数意味着将记录的缓冲区将被重放。 ClientEmulation是可选的。如果存在,它将覆盖运行时设置。
8) SOAPAction
在WSDL中指定的HTTP头。从LoadRunner版本8.0以后,这是由服务测试记录。对于以前的脚本可以手动输入这个值。
9) UseWSDLCopy
此可选参数确定在测试运行期间是否读取全局WSDL或本地副本。如果值为1,则使用本地副本。如果值为0,则使用全局WSDL。默认是读取全局WSDL。
10) AsyncEvent
表示随后调用web_service_wait_for_event时要使用事件的名称。如果web_service_call调用包含非空的AsyncEvent参数,则调用发送请求,立即运行测试,而并不等待响应。直到web_service_wait_for_event调用时停止。此参数是可选的。
11) WSAAction
要在目标服务器上执行的操作。
12) WSAReplyTo
设置一个响应的IP地址用于存储WS的地址,该值通常是负载生成器的文本IP地址,当指定“WSAReplyTo = autodetect”时,要求服务可以使用DNS将负载生成器的主机名转换为IP。并且在运行时检测负载生成器的IP。 Autodetect .NET和Axis工具包支持WS-Addressing。此参数是可选的。
13) JMSSendQueueName
发送队列的JNDI名称。它指向可以通过JNDI查找操作找到的队列名称。使用JMS传输时,此值不能为空。如果不使用JMS传输,则不传递此参数。
14) JMSReceiveQueueName
使用JMS传输时接收队列的JNDI名称。它指向可以通过JNDI查找操作找到的队列名称。如果此值缺失或为空,将使用临时队列进行接收。如果不使用JMS传输,则不传递此参数。
User Handler Arguments:用户处理参数,关于用户处理参数常见的有以下几种:
1) UserHandlerFunction
在脚本中定义函数的名称。
2) UserHandlerName
用户处理程序的名称和脚本外部定义DLL处理程序。如果指定在脚本中定义为UserHandlerFunction的处理函数,那么将忽略UserHandlerName。
3) UserHandlerArgs
处理程序的配置参数的列表。使用处理程序的GetArguments方法来检索处理程序中的参数。
4) UserHandlerOrder:
请求中处理用户处理程序的顺序。BeforeSecurity、AfterSecurity、AfterAttachments或ReplaceTransport。
Sending attachments:设置待发送附件的参数。需要发送附件时可以ATTACHMENTS_FORMAT_DIME或ATTACHMENTS_FORMAT_MIME来指定消息的格式。
在发送附件时,需要使用ATTACHMENT_ADD来设置,如果只发送一个附件那么这个参数只要写一次,如果发送多次附件就重复写多个,关于ATTACHMENT_ADD的参数设置如下:
Ø FileName:文件名,可以使用绝对路径来表示也可以使用相当路径来表示。
Ø ParamName:包含附件的内容或者数据的参数名。
Ø ContentType (可选): 表示MIME(多用途互联网邮件扩展类型)的类型,如果不设置这个参数,将会自动检测其类型。
Ø ID (可选):指定附件的ID值,如果没有设置那么会自动生成ID值。
下面是一个上传附件的实例:
web_service_call( "StepName=DimeUploadFile",
"ExpectedResponse=AnySoap",
"SOAPMethod=MyService|MyServiceSoap|DimeUploadFile",
  "SOAPHeader=<SoapHeader><e>jb2018</e></SoapHeader>",
"WSDL=http://myServer/DimeGen/MyDimeService.asmx?WSDL",
"UseWSDLCopy=1",
"Snapshot=t118574494.inf",
BEGIN_ARGUMENTS,
"file_name=d:\\test\\Uploaded.txt",
END_ARGUMENTS,
ATTACHMENTS_FORMAT_DIME,
ATTACHMENT_ADD,
"FiLeNaMe=d:/test/http://attachment.in",//"ContentType=text/plain",
BEGIN_RESULT,
END_RESULT,
LAST );
上面介绍的是上传附件,如果需要将附件下载下来,那么可以使用ATTACHMENT_SAVE_ALL或ATTACHMENT_SAVE_BY_INDEX来实现。
ATTACHMENT_SAVE_ALL的属性如下:
ParamNamePrefix:设置保存附件名参数的前缀,在保存附件名时,除了前面的那个前缀外,后面还有一个后缀,其最后保存的形式是 “ParamNamePrefix_index”,index是一些数字,例如“ParamNamePrefix_1”。
例如以下设置:
ATTACHMENT_SAVE_ALL, "ParamNamePrefix=myParam"
ATTACHMENT_SAVE_ INDEX的属性如下:
Index:保存从服务器返回的附件中的第几个附件,index表示附件的索引号。
ParamName:保存这个附件的名称。
例如以下设置,保存第一个附件:
ATTACHMENT_SAVE_BY_INDEX, "Index=1", "ParamName=myNameParam1"
分享到 :
0 人收藏

3 个回复

倒序浏览
蛊惑  中级会员 | 4 天前
写得很细致
失心  高级会员 | 4 天前
很有帮助
这次懂了
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|翁笔

© 2001-2018 Wengbi.com

返回顶部