【SIP】OPEN API测试实战源代码
发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,上篇文字介绍了如何利用正交验证法来实现测试用例的设计。本篇文章将针对上篇文章介绍代码的实现。以授权用例一的Case4为例子。 首先需要准备测试数据,本文使用的是DBUNIT。首先准备xml文件如下:
千家信息网最后更新 2025年12月03日【SIP】OPEN API测试实战源代码上篇文字介绍了如何利用正交验证法来实现测试用例的设计。本篇文章将针对上篇文章介绍代码的实现。以授权用例一的Case4为例子。 首先需要准备测试数据,本文使用的是DBUNIT。首先准备xml文件如下: CONTROL_LEVEL = "1" API_URL = "http://apitest.alisoft.com:8080/isp-test/login" REQUIRE_TOKEN_TYPE ="0"
REQUIRE_TIMEOUT = "1000" STATUS = "0" API_TEST_URL ="http://apitest.alisoft.com:8080/isp-test/login"
FREQUENCY_VALVE = "6" API_TYPE ="0"
/>
app_no="test_app059" APP_SECRET="secret_app003" LEVEL_ID="alitest_level7"/>
ISV_ID="4082604" Status ="0" SUBSCRIBED_COUNT="0" AUTO_SIGN_ON_URL="http://www.sina.com.cn"
SERVICE_SCOPE = "1" GMT_CREATE ="2008-2-19 13:28:50" GMT_MODIFIED = "2008-2-19 13:28:50"
CREATOR = "1" MODIFIER ="1" IS_DELETED ="n" DESCRIPTION="测试部专用" STANDARD_PRICE="基本价12"
GMT_SERVICE_END="2009-12-19 13:28:50" PRICE_MODE="m" PRICE_URL="http://mall.alisoft.com/apps/shopwindow/appSubscibeAction!showSubscAppModel.jspa"
PRICE_CALC_CLASS="modelPriceService" LICENCE_NUM="100"
/>
LEVEL_DESC="阿里软件接口测试6" GMT_CREATE="2009-01-10 13:28:50" GMT_MODIFIED="2009-01-10 13:28:50"
/>
INCLUDE_ISPS="elbert_isp002,elbert_isp003" API_GROUP_DESC="阿里软件5.4API集合1" GMT_CREATE="2009-1-11 01:01:01" GMT_MODIFIED="2009-1-11 01:01:01"
/>
INCLUDE_ISPS="elbert_isp001" API_GROUP_DESC="阿里软件5.4API集合1" GMT_CREATE="2009-1-11 01:01:01" GMT_MODIFIED="2009-1-11 01:01:01"
/> 然后利用DBUNIT的方法,载入数据。在实战中这部分被分装成loadData函数如下: loadCaseData("testCase4_CORE.xml",coreSchemaName); 然后实现测试的主要部分,JUNIT编码的工作。代码如下: public class TestApiGroups extends TestBaseWS {
private static String udbSchemaName;
private static String coreSchemaName;
private String api_server = "http://10.2.226.19:8180/sip/rest";
static String mysql_url = "jdbc:mysql://10.2.226.19:3306/sip";
private String dir = "com\\alisoft\\aep\\sip\\core54";
public TestApiGroups() throws Exception {
super();
db = util.DBConnection.getDbUnit();
udbSchemaName = util.DBConnection.schemaMap.get("UDB");
coreSchemaName = util.DBConnection.schemaMap.get("CORE");
System.out.println("数据准备开始......");
loadCaseData("testCase2_CORE.xml",coreSchemaName);
loadCaseData("testCase3_CORE.xml",coreSchemaName);
loadCaseData("testCase4_CORE.xml",coreSchemaName);
loadCaseData("testCase5_CORE.xml",coreSchemaName);
loadCaseData("testCase6_CORE.xml",coreSchemaName);
util.SIPHelp.Crush_Sip();
System.out.println("数据准备完毕");
// TODO Auto-generated constructor stub
}
public void TestCase(Map map, String ExpXmlText,String EXPSTATUES,String EXPERROR,String sip_apiname,String AppKey)
throws Exception {
String sip_appkey =AppKey;// "test_app003";// app_id
String sip_appsecret = "secret_app003";
String sessionid = "123456789";
String url = util.SIPHelp.prepareUrl(sip_appkey, sip_apiname, sip_appsecret,
api_server, sessionid,map);
System.out.println(url);
WebConversation conversation = new WebConversation();
WebRequest request = new PostMethodWebRequest(url);
WebResponse response = conversation.getResponse(request);
String ActStatus = response.getHeaderField("sip_status");
String ActError = response.getHeaderField("sip_error_message");
System.out.println(ActStatus);
assertEquals(EXPSTATUES, ActStatus);
if (EXPSTATUES.equals("9999"))
{ assertEquals(null, ActError); }
else
{
assertEquals(EXPERROR, ActError);
}
String ActXmlTest = response.getText();
System.out.println(ActXmlTest);
assertEquals(ExpXmlText, ActXmlTest);
} /**
* SIP_APP_LEVEL中含API_GROUPS字段为多个字段,且API在Group中
* @throws Exception
*/
@Test
public void TestCase4() throws Exception {
String sip_apiname = "alitest.ali-54-test204";
//数据准备
String ExpXmlText = "not OK";
String sip_appkey = "test_app059";
TestCase(null,ExpXmlText,"9999",null, sip_apiname,sip_appkey);
}
REQUIRE_TIMEOUT = "1000" STATUS = "0" API_TEST_URL ="http://apitest.alisoft.com:8080/isp-test/login"
FREQUENCY_VALVE = "6" API_TYPE ="0"
/>
SERVICE_SCOPE = "1" GMT_CREATE ="2008-2-19 13:28:50" GMT_MODIFIED = "2008-2-19 13:28:50"
CREATOR = "1" MODIFIER ="1" IS_DELETED ="n" DESCRIPTION="测试部专用" STANDARD_PRICE="基本价12"
GMT_SERVICE_END="2009-12-19 13:28:50" PRICE_MODE="m" PRICE_URL="http://mall.alisoft.com/apps/shopwindow/appSubscibeAction!showSubscAppModel.jspa"
PRICE_CALC_CLASS="modelPriceService" LICENCE_NUM="100"
/>
/>
/>
/> 然后利用DBUNIT的方法,载入数据。在实战中这部分被分装成loadData函数如下: loadCaseData("testCase4_CORE.xml",coreSchemaName); 然后实现测试的主要部分,JUNIT编码的工作。代码如下: public class TestApiGroups extends TestBaseWS {
private static String udbSchemaName;
private static String coreSchemaName;
private String api_server = "http://10.2.226.19:8180/sip/rest";
static String mysql_url = "jdbc:mysql://10.2.226.19:3306/sip";
private String dir = "com\\alisoft\\aep\\sip\\core54";
public TestApiGroups() throws Exception {
super();
db = util.DBConnection.getDbUnit();
udbSchemaName = util.DBConnection.schemaMap.get("UDB");
coreSchemaName = util.DBConnection.schemaMap.get("CORE");
System.out.println("数据准备开始......");
loadCaseData("testCase2_CORE.xml",coreSchemaName);
loadCaseData("testCase3_CORE.xml",coreSchemaName);
loadCaseData("testCase4_CORE.xml",coreSchemaName);
loadCaseData("testCase5_CORE.xml",coreSchemaName);
loadCaseData("testCase6_CORE.xml",coreSchemaName);
util.SIPHelp.Crush_Sip();
System.out.println("数据准备完毕");
// TODO Auto-generated constructor stub
}
public void TestCase(Map
throws Exception {
String sip_appkey =AppKey;// "test_app003";// app_id
String sip_appsecret = "secret_app003";
String sessionid = "123456789";
String url = util.SIPHelp.prepareUrl(sip_appkey, sip_apiname, sip_appsecret,
api_server, sessionid,map);
System.out.println(url);
WebConversation conversation = new WebConversation();
WebRequest request = new PostMethodWebRequest(url);
WebResponse response = conversation.getResponse(request);
String ActStatus = response.getHeaderField("sip_status");
String ActError = response.getHeaderField("sip_error_message");
System.out.println(ActStatus);
assertEquals(EXPSTATUES, ActStatus);
if (EXPSTATUES.equals("9999"))
{ assertEquals(null, ActError); }
else
{
assertEquals(EXPERROR, ActError);
}
String ActXmlTest = response.getText();
System.out.println(ActXmlTest);
assertEquals(ExpXmlText, ActXmlTest);
} /**
* SIP_APP_LEVEL中含API_GROUPS字段为多个字段,且API在Group中
* @throws Exception
*/
@Test
public void TestCase4() throws Exception {
String sip_apiname = "alitest.ali-54-test204";
//数据准备
String ExpXmlText = "not OK";
String sip_appkey = "test_app059";
TestCase(null,ExpXmlText,"9999",null, sip_apiname,sip_appkey);
}
测试
软件
阿里
数据
准备
软件测试
上篇
代码
字段
文章
实战
例子
函数
多个
接口
文件
文字
方法
正交
编码
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
c 中链接数据库的文件
博拉网络技术水平
数据库查看某个表命令
亚马逊用哪个服务器
数据库字段名是否为空
大数据网络技术开发优化价格
数据库免费查询软件
湖南悟道互联网科技
和平精英海岛服务器开放时间
自己可以搭建简单服务器吗
域名被解析到别的服务器
软件开发文档表格序号
内部管理服务器进不去
云数据库安全保障方案
分析分析器与数据库的关系
外服深渊数据库
深圳南山教育软件开发商
达梦数据库导出结果集
网络安全日志审计条例
天融信服务器管理口登录
北京网络安全标准
黑龙江省ctf网络安全挑战赛
聊天软件开发价钱如何
如何成为企业微信服务器
福建政务软件开发定制
中华姓名数据库
浙江格网络技术有限公司
理解软件开发中的高级语言
信息技术教学视频教材全集数据库
王者荣耀服务器河洛一方