PandaJS 使用说明(1.9):编写测试
PanadaJS 的测试库是在 junit 3 的基础上修改而成的,界面上使用的是 swing,我已经将修改后的 junit 工程放在 svn 上了:
https://pandajs.googlecode.com/svn/trunk/junit/
接下来,就让我们为 scripts/app 目录下的文件编写测试吧。
编写测试案例(DBO)
与用 java 编写的 junit3 测试案例相似,PandaJS 的一个测试案例包含 setup(),tearDown(),和若干个 textXXX() 测试方法。同时,还需要一个获取案例名称的 name() 方法。
这些案例可以直接用 test(...) 执行,也可以将多个测试案例组成测试案例集后用 test(...) 执行。测试案例集是可以嵌套的。
以 dbo.users 的测试案例为例,在 setUp() 方法中进行清理和初始化,在 tearDwon 中再次进行清理,在 testXXX(...) 方法中执行调用测试的方法并使用 Assert 进行验证。
执行测试案例时,所有以 "test" 开头的方法都将被执行, setUp() 方法在每次执行 testXXX(...) 之前执行,tearDown(...) 方法在每次执行 testXXX(...) 之后执行。
Assert 的用法与 junit3 中是一样的。
主要代码如下:
scripts/test/app/dbo/users.js
// dbo.users 的测试案例
testDBOUsers = {
// 测试案例的名称
name: function() {
return "DBO Users Test";
},
// 每次执行测试方法之前都进行数据清理和初始化
// 清空测试数据库并插入新数据
setUp: function() {
clear();
init();
},
// 每次执行测试方法之前都进行数据清理
// 清空测试数据库
tearDown: function() {
clear();
},
// 测试 init 方法,略
testInit: function() { ... },
// 测试 dbo.users.list() 方法,逐一验证返回结果
testList: function() {
var users = dbo.users.list();
Assert.assertEquals(2, users.length, 0);
Assert.assertEquals("user1", users[0].name);
Assert.assertEquals("desc1", users[0].desc);
Assert.assertEquals("user2", users[1].name);
Assert.assertEquals("desc2", users[1].desc);
},
// 测试 dbo.users.save(...) 方法,验证 users 集合的变化
testSaveAsAdd: function() {
dbo.users.save({ name: 'xxx', desc: 'yyy' });
var users = getUsers();
Assert.assertEquals(3, users.length, 0);
Assert.assertEquals("xxx", users[2].name);
Assert.assertEquals("yyy", users[2].desc);
},
// 以下省略
};
dbo 对象的测试案例集如下(不过目前仅包含 dbo.users 的测试案例):
scripts/test/app/dbo.js
testDBO = {
name: function() {
return "DBO Test";
},
suite: function() {
return [ testDBOUsers ];
}
};
编写测试案例(PAGE)
接下来看看 page 对象的测试案例。
我们先执行 page.index,然后获取测试数据库中的 users 列表; users 列表的数据应该包含在返回结果中,因此可以逐一进行验证。
scripts/test/app/page.js
testPage = {
name: function() {
return "Page Test";
},
setUp: function() {
clear();
init();
},
tearDown: function() {
clear();
},
testIndex: function() {
var ret = page.index();
var users = getUsers();
Assert.assertTrue(ret.indexOf(users[0].name) >= 0);
Assert.assertTrue(ret.indexOf(users[0].desc) >= 0);
Assert.assertTrue(ret.indexOf(users[1].name) >= 0);
Assert.assertTrue(ret.indexOf(users[1].desc) >= 0);
}
};
编写测试案例(API)
api 对象的测试案例包括 testAPIHello 和 testAPIUsers,这里仅以 testAPIUsers 为例。
scripts/test/app/api/users.js
testAPIUsers = {
name: function() {
return "API Users Test";
},
setUp: function() {
clear();
init();
},
tearDown: function() {
clear();
},
testSave: function() {
api.users.save({ name: 'xxx', desc: 'yyy' });
var users = getUsers();
Assert.assertEquals(3, users.length, 0);
Assert.assertEquals("xxx", users[2].name);
Assert.assertEquals("yyy", users[2].desc);
},
testRemove: function() {
api.users.remove("user1");
var users = getUsers();
Assert.assertEquals(1, users.length, 0);
Assert.assertEquals("user2", users[0].name);
Assert.assertEquals("desc2", users[0].desc);
},
testExists: function() {
Assert.assertTrue(dbo.users.exists("user1"));
Assert.assertFalse(dbo.users.exists("xxx"));
}
};
api 对象的测试案例的主要代码如下:
scripts/test/app/api.js
testAPI = {
name: function() {
return "API Test";
},
suite: function() {
return [ testAPIHello, testAPIUsers ];
}
};
测试案例集汇总并执行
接下来讲以上测试案例集进行汇总。首先需要创建几个空的对象,然后通过 load(...) 方法加载必要的 js 文件;
接着将测试案例集组成数组,通过 test(...) 执行。主要代码如下:
dbo = {};
api = {};
page = {};
proxy = {};
load("scripts/test/test.js");
load("scripts/test/app/config.js");
// 加载其他 js 文件,略
test({
name: function() {
return "APP Test Suite";
},
suite: function() {
return [ testDBO, testAPI, testPage ];
}
});
此外,还有 views 对象的测试案例,位于 scripts/test/both/views.js ,这里就先省略了。
运行测试案例集
首先通过命令行启动 mongod,然后在 Luncher.java 上点击鼠标右键 -> Run Configurations...,在 arguments 中填写 scripts/test/app/testAll.js:
点击 Run,可以看到 junit3 的 swing UI:
也可以选择特定测试案例并执行:
也可以在 Arguments中填写 scripts/test/both/views.js 并执行,以测试 views 对象。
分享到:
相关推荐
Ping Monster 是一款免费软件 ping 监控工具,带有一些警报操作,包括电子邮件和声音警报以及 HTTP 发布。 版本 1.9
RetrofitDemo 针对Retrofit所做的Demo,可用于后期开发直接提取相关文件
重新上传 脚本黑客通过访问令牌登录Facebook
赠送jar包:zt-exec-1.9.jar; 赠送原API文档:zt-exec-1.9-javadoc.jar; 赠送源代码:zt-exec-1.9-sources.jar; ...人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。
赠送jar包:hawtbuf-1.9.jar; 赠送原API文档:hawtbuf-1.9-javadoc.jar; 赠送源代码:hawtbuf-1.9-...人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。 双语对照,边学技术、边学英语。
赠送jar包:jersey-json-1.9.jar; 赠送原API文档:jersey-json-1.9-javadoc.jar;...人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。 双语对照,边学技术、边学英语。
Magento Url隐藏默认语言的code. 本人1.9.2.4版本测试通过 Magento Url隐藏默认语言的code. 本人1.9.2.4版本测试通过
赠送jar包:jersey-server-1.9.jar; 赠送原API文档:jersey-server-1.9-javadoc.jar; 赠送源代码:jersey-server-1.9-sources.jar;...人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。
更新 (1.9): 1.9 版本对最终逆向运动...- 已在新版 Oculus Quest 硬件上测试 VRIK。 - 更新的文档。 请参阅发行说明来了解全部更新细节。 Final IK 1.9 与 PuppetMaster 0.9 和 Unity 2017/2018/2019 版本完全兼容。
赠送jar包:jersey-client-1.9.jar; 赠送原API文档:jersey-client-1.9-javadoc.jar; 赠送源代码:jersey-client-1.9-sources.jar;...人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。
使用Django1.9开发博客(1) - 入门篇 使用Django1.9开发博客(2) - 模型 使用Django1.9开发博客(3) - 部署 使用Django1.9开发博客(4) - 三部曲 使用Django1.9开发博客(5) - 页面美化 使用Django1.9开发博客...
赠送jar包:commons-codec-1.9.jar; 赠送原API文档:commons-codec-1.9-javadoc.jar; 赠送源代码:commons-codec-1.9-sources.jar;...人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。
赠送jar包:commons-codec-1.9.jar; 赠送原API文档:commons-codec-1.9-javadoc.jar;...人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。 双语对照,边学技术、边学英语。
赠送jar包:commons-text-1.9.jar; 赠送原API文档:commons-text-1.9-javadoc.jar;...人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。 双语对照,边学技术、边学英语。
赠送jar包:jersey-core-1.9.jar; 赠送原API文档:jersey-core-1.9-javadoc.jar; 赠送源代码:jersey-core-1.9-sources.jar;...人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。
ZeroBraneStudio1.9和lua脚本测试代码 ZeroBrane Studio下载地址1: 官网下载:https://studio.zerobrane.com/ GitHub下载:https://github.com/pkoretic/ZeroBraneStudio/releases ZeroBrane Studio是一个免费、...
Learning with Small DataLearning with Small DataFigure 1.9: Example inputs from
EasySNS 1.9 更新日志:2018-04-09 用户条款和隐私同意插件:添加标签和消息的布局;特色文章:页面小标题已添加;自定义表单域布局路径简化;Com_contact:联系人姓名字段移出联系信息块;自定义模块:改进前端编辑;...
lstf lstf通过Linux netlink打印host flows (到相同源或目标端口的聚合网络连接流),并使您能够简单地掌握localhost与其他主机之间的网络关系。 朋友: ...10.0.1.9:many -- > 10.0.1.11:3306