公共接口
先找一个公共的Web Services接口,比如天气预报的:
天气预报Web服务数据来源于中国气象局 http://www.cma.gov.cn/ ,数据每2.5小时左右自动更新一次,准确可靠。
包括 340 多个中国主要城市和 60 多个国外主要城市三日内的天气预报数据。实例
WSDL: http://www.webxml.com.cn/WebServices/IpAddressSearchWebService.asmx?wsdl
Endpoint: http://www.webxml.com.cn/WebServices/WeatherWebService.asmx Disco: http://www.webxml.com.cn/WebServices/WeatherWebService.asmx?disco WSDL: http://www.webxml.com.cn/WebServices/WeatherWebService.asmx?wsdl
调试工具
- 浏览器插件wizdler
- SoapUI
- SoapUI IDEA插件版
1. 浏览器插件wizdler
在线安装:https://chrome.google.com/webstore/detail/wizdler/oebpmncolmhiapingjaagmapififiakb
如果网络被墙,请手工下载安装
2.SoapUI
SoapUI是一个开源的,跨平台的测试工具。它可以自动操作功能、回归、合规以及SOAP和REST web服务的负载测试。它配备了一个易于使用的图形界面,并支持行业领先的技术和标准,以模拟和鼓励web服务的行为。
主要特征
- 以一种Project、TestSuite、TestCase或LoadTest水平提供可打印,可导出,和基于HTML的报告。
- 自带集成Hudson、Bamboo、Maven、ANT和JUnit。
- 允许开发自己的一套功能作为SoapUI插件。
- 记录、监视和显示所有数据。
- 支持WS-Security和SSL解密。
3. SoapUI提供IDEA插件,更加方便
file->settings->plugins->marketplace 搜索soapUI,安装即可。
如果网络问题,无法搜索,请手工下载:
https://plugins.jetbrains.com/plugin/7485-soapui-intellij-plugin/versions
使用方式
tools->SoapUI 使用即可。
SoapUI使用方式
1.打开SoapUI软件>File>New SOAP Project,新建工程
2.填入工程名和WSDL地址,WSDL地址为:http://www.webxml.com.cn/webservices/ChinaTVprogramWebService.asmx?wsdl
构选上“Create Requests”项目会根据WSDL文件创建接口请求文件;构选上“Create TestSuite”就会给WSDL创建一个测试套件
3.点击OK后就已经创建好一个工程了,自动添加WSDL里面有的接口,根据Soap 的版本不同提供了两种接口,如下图所示:
接口业务:
getAreaDataSet:获得支持的省市(地区) 和分类电视列表
getTVstationDataSet:通过省市ID 或分类电视ID 获得电视台列表
getTVchannelDataSet :通过电视台ID 获得该电视台频道列表
getTVprogramDataSet : 通过频道ID 获得该频道节目列表
在此处需要注意的是:除getAreaDataSet接口不需要入参,最后三个接口是需要输入参数的,接口getTVstationDataSet的请求中“?”表示要入参,如下图所示:
若不入参,运行会出错,会出现如下所示错误信息:
运行单个请求
1.选择getAreaDataSet下的Request1,双击,点击运行按钮,就会出现右侧面板中的结果,获得到支持的省市(地区) 和分类电视列表,如下图所示:
2.选择getTVstationDataSet下的Request1,双击,把中间面板中的?替换成省市ID或分类电视ID18,点击运行按钮,就会出现右侧面板中的结果,获得电视台列表,如下图所示:
3.选择getTVchannelDataSet 下的Request1,双击,把中间面板中的?替换成电视台ID98,点击运行按钮,就会出现右侧面板中的结果,获得频道列表,如下图所示:
4.选择getTVprogramDataSet 下的Request1,双击,把中间面板中的?替换成频道ID292,点击运行按钮,就会出现右侧面板中的结果,获得该频道节目列表
构建测试用例
1.创建测试套件:选择项目“CTV”右键点击“New TestSuite”,可输入测试名,如下图所示
2.创建测试用例Test case,选择测试套件“TestSuite 1”右键点击“New TestCase”,如下图所示:
创建好之后,新建的TestCase中包含三个部分:
测试步骤:Test Steos
负载测试:Load Tests
安全测试:Security Tests
3.把请求添加到测试用例中:选择一个请求,然后右键点击“Add to TestCase”,然后在弹出窗口中选择我们刚才新建的”TestSuite 1”即可,如下图所示:
执行操作后,就已经创建好了一条测试用例,如下图所示:
4.运行测试:打开TestCase窗口,点击绿色运行按钮即可,绿色表示运行成功,运行结果在右面板下方,如下图所示:
5.增加检查点
①在测试步骤中打开服务求请求,如下图所示:
②点击+号,添加检查点,选择Recently used>Contains>Add,如下图所示:
③输入检查的内容,如下图所示:
④然后运行服务请求,在“Assertions”窗口中可以看到“Contains - VALID”说明检查点是有效的,如下图所示:
接口之间传递参数,组织测试步骤
getAreaDataSet:获得支持的省市(地区) 和分类电视列表
getTVstationDataSet:通过省市ID 或分类电视ID 获得电视台列表
getTVchannelDataSet :通过电视台ID 获得该电视台频道列表
getTVprogramDataSet : 通过频道ID 获得该频道节目列表
依次加入到TestCase 1 的测试步骤中去,然后组织测试步骤获取“湖南金鹰卡通”的节目列表
具体的测试步骤为:
①获得“湖南省”的分类ID “18 ”
②获取“湖南省”类别中的“湖南电视台”ID :“98 ”
③获取“湖南电视台”的频道“湖南金鹰卡通 ”ID :“292 ”
④获取“湖南金鹰卡通”频道的节目列表
1.先将请求依次添加到用例中,如下图所示:
2.添加入参操作,用于两个服务请求间的交互,如下图所示:
将服务请求getAreaDataSet 结果中的“湖南省”ID“18 ”作为服务请求getTVstationDataSet 入参
创建好之后,双击,弹出如下图所示界面,输入参数值:
右侧面板上部分中输入如下代码,//并不是注释,只是表相对路径,(getAreaDataSet 结果)
declare namespace diffgr=”urn:schemas-microsoft-com:xml-diffgram-v1”;
//diffgr:diffgram/Area/AreaList[22]/areaID[1]
右侧面板下部分中输入如下代码(getTVstationDataSet 入参)
declare namespace web=”http://WebXml.com.cn/“;
//web:getTVstationDataSet/web:theAreaID[1]
点击运行,即可看到是否成功,成功如下图所示:
获取上述代码的方法:
上半部分getAreaDataSet 结果获取:
下半部分getTVstationDataSet 入参获取:
其它两个交互方法一样,稍微更改即可
将服务请求getTVstationDataSet结果中的“湖南电视台”ID“98 ”作为服务请求getTVchannelDataSet入参
右侧面板上部分中输入如下代码(getTVstationDataSet 结果)
declare namespace diffgr=”urn:schemas-microsoft-com:xml-diffgram-v1”;
//diffgr:diffgram/Station/TvStation[5]/tvStationID[1]
右侧面板下部分中输入如下代码(getTVchannelDataSet 入参)
declare namespace web=”http://WebXml.com.cn/“;
//web:getTVchannelDataSet/web:theTVstationID[1]
获取上述代码的方法:
上半部分getTVstationDataSet结果获取:
下半部分getTVchannelDataSet入参获取:
将服务请求getTVchannelDataSet 结果中的“湖南金鹰卡通”ID“292 ”作为服务请求getTVprogramDataSet 入参
右侧面板上部分中输入如下代码(getTVchannelDataSet结果)
declare namespace diffgr=”urn:schemas-microsoft-com:xml-diffgram-v1”;
//diffgr:diffgram/Channe/TvChanne[4]/tvChannelID[1]
右侧面板下部分中输入如下代码(getTVprogramDataSet入参)
declare namespace web=”http://WebXml.com.cn/“;
//web:getTVprogramDateSet/web:theTVchannelID[1]
获取上述代码的方法:
上半部分getTVchannelDataSet结果获取:
下半部分getTVprogramDataSet入参获取:
运行测试
1.整个测试步骤设置好之后,打开“TestCase 1”运行测试,全部绿色表示测试通过,如下图所示:
2.在TestCase Log中还可以看到接口之间传递的参数值,如下图所示:
3.运行结束后,再打开接口请求,可以看到请求显示的就是所传递的值,如下图所示:
4.还可以在请求中设置检查点,来检查是否通过,检查点的设置方法已在构建测试用例中介绍