在《测试工程师的自我修养--理解WebService》一文中[1],对WebService的概念及其相关名词进行了阐述,并引入了一个测试案例:天气预报WebService服务[2]。
本文将围绕如上测试需求,对LoadRunner基于WSDL的WebService测试方法进行详细介绍。需要说明的是,本文只针对测试脚本的开发展开描述,对测试场景的设计暂不进行讨论。 本文中采用的LoadRunner版本为V11.0,不同版本可能会存在一定差异。 1、选择Web Services协议 采用Loadrunner测试WebService时,在单协议里面选择Web Services即可。当然,这并不意味着Loadrunner测试WebService只能采用Web Services协议,在后续的文章中将向大家介绍如何通过HTTP协议来测试WebService。 2、导入WebService的描述信息WSDL WSDL 是基于 XML 的用于描述 WebService 以及如何访问 WebService 的语言,它对具体的 WebService 进行了描述,规定了服务的位置,以及此服务所提供的操作(或方法,或服务调用接口API)。如果你熟悉WSDL的文档结构,可以直接阅读WSDL获取相关信息。 然而,当你尝试直接去阅读WSDL文档时,你会发现这是一件十分痛苦的事情,毕竟WSDL的设计出发点是供程序阅读的,其文档结构对人员的阅读体验不是很好。 值得庆幸的是,采用LoadRunner测试WebService时,测试人员无需和原始的WSDL文档打交道,只需要在LoadRunner中导入WSDL后,即可对其中定义的函数接口进行调用。 导入WSDL主要采用两种方式:
通过WSDL的URL地址进行导入时,操作方式如下图所示。 需要说明的是,填写的URL地址末尾必须包含?WSDL。换句话说,只有在以?WSDL结尾时才能对应到WSDL文件的路径。大家可以在浏览器中对WSDL的URL地址进行访问,查看WSDL当前是否有效。 如果选择直接导入本地WSDL文件的方式,则需要先将WebService对应的WSDL文件下载至本地。下载时,只需将WebService的地址末尾加上 '?WSDL' 后在浏览器中进行访问,然后对网页进行保存时将文件另存为'.wsdl'的文件即可。如下图所示。 获取到WSDL文件以后,便可在LoadRunner中以文件的进行导入,操作方式如下图所示。
两种导入方式效果都是一样的,采用任意一种方式都能将WebService的描述信息导入至LoadRunner供其调用。 当然,两种导入方式也存在一定的差异。
明白了两种导入方式的特点之后,大家可以根据实际需求进行选择。 3、查看WebService服务接口 在成功导入WSDL以后,在【Operation】栏目下即可看到所有可供调用的接口。值得注意的是,在本测试案例中,每个接口均包含2个Port Name,这是因为该WebService为每个服务接口提供了SOAP1.1和SOAP1.2两个版本的SOAP调用方式。 对比下图可知,这和网页上展示的接口是一致的。 4、创建调用函数web_service_call 在LoadRunner中导入WSDL之后,便可以对WebService接口进行调用。 LoadRunner提供的调用函数为web_service_call。调用该函数时,可以根据其说明文档直接在Editor里面进行编辑,不过更简单且更不易出错的方式还是通过【Add Service Call】进行可视化编辑。帮助文档里对此也有进行说明。
点击【Add Service Call】后进入Web Service Call的可视化编辑界面,如下图所示。 在【Add Service Call】的可视化界面中,对所需调用的Service、Port Name和Operation进行选择。在Operation列表中,可以看到存在5个可供调用的方法,对于每一个Operation,在Port Name下拉框中均可以选择WeatherWebServiceSoap和WeatherWebServiceSoap12,这和上一步骤在【Operations】中查看到的完全一致。 根据本文首部的测试需求,我们在Operation中选择接口getWeatherbyCityName;而由于开发人员未交代SOAP版本信息,因此我们需要对两个版本分别进行测试;在这里我们先选择WeatherWebServiceSoap。 在【Add Service Call】的可视化界面中可以看出,接口getWeatherbyCityName只有一个输入参数,即theCityName。而该接口则是通过城市名来获取指定城市的天气预报信息。 因此,使用getWeatherbyCityName函数接口时我们需对其传入参数theCityName。具体操作时,选中Input Arguments中的参数名theCityName,勾选其右侧的“Include argument in call”,在Value中输入城市名称即可,此处我们输入的是“广州”,如下图所示。 若需要调用getWeatherbyCityName函数的返回结果,则需要事先将其返回结果保存至参数里面。具体操作时,选中Output Arguments中的参数名getWeatherbyCityNameResult,勾选其右侧的“Save returned value in parameter”,在Parameter中输入参数名即可。如下图所示。 完成对Input Arguments和Output Arguments的设置后,点击【OK】按钮,便可看见脚本中新增了一个web_service_call函数,如下图所示。 通过上图可知,之前我们在可视化界面的所有设置均已转换至web_service_call函数。 5、回放脚本,查看结果 在“Run-time Settings”中打开日志“Extended log”,勾选“Parameter substitution”和“Data returned by server”。运行脚本后,查看“Replay Log”,如下图所示。 在输出日志中,可以获得详细的返回信息theWeatherInfo。 在浏览器访问该WebService,查询“广州”时得到结果如下图所示。 通过对比LoadRunner的Replay Log和浏览器的返回页面可知,LoadRunner对Web Service进行了正确的调用。 6、完善脚本 脚本虽已调试成功,可以得到正确的结果。但若要进行性能测试,我们还需对脚本进行参数化,如下图所示。 或者,如果我们是只想利用返回报文的一小部分,而不是全部。在这种情况下,我们可以指定将某部分保存至参数,以便后续的使用。
例如,我们只想获得某个城市当天的最低温度和最高温度。通过返回报文可知,该字段是输出结果中的第6个字段。那么,我们便可以将该字段保存至一个参数,这里指定为Lowest_Highest_Temperature,如下图所示。 生成脚本如下所示: 运行结果如下图所示。 当然,此处只是列举了一个简单的例子。通过对web_service_call函数的灵活应用,可以实现更多复杂、强大的功能。 参考资料 [1] 【概念解析】测试工程师的自我修养--理解WebService: http:///posts/concept-about-webservice.html [2] 天气预报WebService服务: http://webservice./WebServices/WeatherWebService.asmx [3] 52testorg: http:// |
|
来自: 昵称37651083 > 《webservice》