如何设计编写前端的测试(基于 Backbone)?
公司网站用的 Backbone, 遗留下来的代码基于命名空间, 没有形成模块化, 也没有留下测试方案,
现在新功能和 Bug 增改中遇到的意外 Bug 逐渐出现, 就想到要增加测试,
刚开始接触 SeaJS 和 Angular 之类前端测试, 但这和后端的 API 测试又不一样,
加上 JS 前端异步的调用较多, 关联 UI 的操作需要关心的也特多,,
我应该怎样设计和编写前端的测试?
backbone modular-programming 前端 测试
kent3
11 years, 3 months ago
Answers
为什么要基于backbone?一个好的测试应该是不依赖任何框架的。(除了测试框架)
比如Jasmine提供runs和waitsFor这对方法来测试异步。
describe("Asynchronous specs", function() {
var value, flag;
it("should support async execution of test
preparation and exepectations", function() {
runs(function() {
flag = false;
value = 0;
setTimeout(function() {
flag = true;
}, 500);
});
waitsFor(function() {
value++;
return flag;
}, "The Value should be incremented", 750);
runs(function() {
expect(value).toBeGreaterThan(0);
});
});
});
还有丰富的Matcher,甚至自定义Matcher。像这样,在运行一个测试之前添加它:
beforeEach(function() {
this.addMatchers({
toBeLessThan: function(expected) {
return this.actual < expected;
}
});
});
另外关于UI方面,推荐使用 seleniun ,这是一个Web自动测试工具,它可以模拟一段用户操作,然后在多浏览器上运行。支持浏览器情况:
- Google Chrome 12.0.712.0+
- Internet Explorer 6, 7, 8, 9 - 32 and 64-bit where applicable
- Firefox 3.0, 3.5, 3.6, 4.0, 5.0, 6, 7
- Opera 11.5+
- HtmlUnit 2.9
- Android – 2.3+ for phones and tablets (devices & emulators)
其他还有很多测试用的工具,比如 JavascriptTestDriver ,它可以捕获多个正在运行的服务器上的浏览器,自动运行测试页面。配合Jasmine( Jasmine的JSTD适配器 )或Qunit等测试框架使用。
泄矢诹访子
answered 11 years, 3 months ago