`
rensanning
  • 浏览: 3518551 次
  • 性别: Icon_minigender_1
  • 来自: 大连
博客专栏
Efef1dba-f7dd-3931-8a61-8e1c76c3e39f
使用Titanium Mo...
浏览量:37585
Bbab2146-6e1d-3c50-acd6-c8bae29e307d
Cordova 3.x入门...
浏览量:604664
C08766e7-8a33-3f9b-9155-654af05c3484
常用Java开源Libra...
浏览量:678533
77063fb3-0ee7-3bfa-9c72-2a0234ebf83e
搭建 CentOS 6 服...
浏览量:87575
E40e5e76-1f3b-398e-b6a6-dc9cfbb38156
Spring Boot 入...
浏览量:400063
Abe39461-b089-344f-99fa-cdfbddea0e18
基于Spring Secu...
浏览量:69133
66a41a70-fdf0-3dc9-aa31-19b7e8b24672
MQTT入门
浏览量:90649
社区版块
存档分类
最新评论

使用Titanium做单元测试

阅读更多
官方文档中什么也没有提到,单元测试中可以使用喜欢的Javascript测试框架。因为不依赖浏览器,所以只要能确认Log输出的即可。

总之,为了在Titanium的控制台输出Log,Titanium.API.info和Titanium.API.error等能测试输出就可以了。

这回我们试着使用Unit系中流行的QUnit和BDD系的Jasmine。

使用QUnit

Titanium使用的Adapter已经在GitHub上公开了。
lukaso/qunit – GitHub

在自己的Project使用的时候,Resources文件夹下保存一下文件就可以了。

* runner.js
* qunit/qunit.js
* qunit/titanium_adaptor.js
* test/tests_to_run.js

然后,在test/tests_to_run.js中写测试内容。 在app.js的任何位置把runner.js文件include后运行即可。

查看titanium_adaptor.js的内容,我们可以看到,它做的事情就是利用QUnit的Logging处理把Log输出到Titanium的控制台上。
所以想输出的时候,按照喜欢的改写也是不难的事情。

在app.js中添加代码确认动作

app.js_snippet中,Tabgroup中追加单元测试用的Tab,只是简单的确认,单纯的在app.js的末尾追加一下行即可测试动作:

Titanium.include('runner.js');


确认动作的test/tests_to_run.js

为了确认动作,什么测试也没有写,只是测试QUnit的动作的例子代码:
module("QUnit on Titanium");
test("OK test(pass)", function () {
    ok(true);
  }
);

test("equal test(no pass)", function () {
    equal('hogehoge', 'hige');
  }
);


动作结果会很好的输出到Titanium的控制台上。
顺便说一下,由于结果中包含了HTML代码,很难理解。使用QUnit-TAP不是很好。

使用Jasmine

Jasmine中,能够自定义测试出力的Reporter,所以可以做成Titanium用的Reporter。

jasmine.js中,提供了基本的Reporter类,可以根据它做成自己的Reporter类。
实际编码的时候可以参考Jasmine官方发布版本中的jasmin-html.js和jasmine.console_reporter.js

包含了很好出力的Reporter的Jasmine Titanium也已经公开了。

在app.js中添加代码确认动作

还没有任何测试内容,只是确认Jasmine动作的例子代码。
前提是在Resorses/jasmine中,jasmine.js和jasmine-titanium.js(上边的TitaniumReporter)
Ti.include('jasmine/jasmine.js');
Ti.include('jasmine/jasmine-titanium.js');

describe("Jasmine Sample", function() {
    it("pass!", function() {
        var foo = 2;
        expect(foo).toEqual(2);
      }
    );
});

describe("Second Jasmine Sample", function() {
    it("fail!", function() {
        var foo = 1;
        expect(foo).toEqual(2);
      }
    );
});
jasmine.getEnv().addReporter(new jasmine.TitaniumReporter());
jasmine.getEnv().execute();


执行结束后,就能看到失败的测试和合计结果。
实际的开发中,应该把测试代码统一放在spec文件夹中比较好。
注:
没有spec文件夹或者文件夹为空是不能启动的。

【原文】Titaniumでユニットテスト
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics