码迷,mamicode.com
首页 > Web开发 > 详细

Developer - 如何自我保证Node.js模块质量

时间:2015-05-28 15:51:20      阅读:133      评论:0      收藏:0      [点我收藏+]

标签:

  组里正在做SaaS产品,其中一些模块(Module)是Node.js实现,这里我们主要使用Node.js实现Web Server来提供服务。

  在做SaaS项目之前,组里的开发模式是传统的Deverloper + QA的模式,这是传统的协作模式,Developer负责写代码开发,当然也会有基本的自测,QA负责测试,遇到问题,提Bug给Developer去修复,Developer修复Bug后,由QA来验证并记录Bug。但这样的协作模式已不适合SaaS产品的开发,SaaS产品更新迭代快,模块众多,这就要求要转变模式。Developer要负责自身模块更多的测试,单元测试要覆盖全。仅有少量的QA会负责集成测试。

  由此更多的模块质量要求Developer来保证。

  因为我刚好参与其中的Node.js模块,因为我小结了一些目前Node.js模块开发时如何自测。

  建议在项目目录中,新建为"test"的文件夹,存放测试用的脚本和数据。

  主要有三,如下。

 

一. 假数据(Mock Data)和写测试脚本(Script)

   Node.js做Server,通常要依赖其他模块,来获取数据或服务等。如果你做的模块OK了,但别人的模块往往不一定完全OK。所以接口十分重要。因此可以写一些脚本来自测,同时需要的其他模块数据,可以自己制造些假数据,放在JSON文件中,来调用。

   脚本可以是JS或Bash脚本等,根据实际。

   有了脚本和数据,就可以来测试自己的模块,测试接口是否OK等。

 

二. Benchmark

   在Node.js中,有一个NPM模块很流行,叫benchmark,它的作用是用来做性能分析和测试。它的GitHub官网是:https://github.com/bestiejs/benchmark.js

   它的使用场景,例如你有几种方法来实现同一个功能,但你又不知道哪种性能更好。它便可以帮你分析。

   例如下面官方提供的示例。

 1 var suite = new Benchmark.Suite;
 2 
 3 // add tests
 4 suite.add(‘RegExp#test‘, function() {
 5   /o/.test(‘Hello World!‘);
 6 })
 7 .add(‘String#indexOf‘, function() {
 8   ‘Hello World!‘.indexOf(‘o‘) > -1;
 9 })
10 // add listeners
11 .on(‘cycle‘, function(event) {
12   console.log(String(event.target));
13 })
14 .on(‘complete‘, function() {
15   console.log(‘Fastest is ‘ + this.filter(‘fastest‘).pluck(‘name‘));
16 })
17 // run async
18 .run({ ‘async‘: true });
19 
20 // logs:
21 // => RegExp#test x 4,161,532 +-0.99% (59 cycles)
22 // => String#indexOf x 6,139,623 +-1.00% (131 cycles)
23 // => Fastest is String#indexOf

  在这个测试例子中,分析比较了用正则表达式还是indeOf哪种方法的性能更高。最终indexOf胜出。

  因此Benchmark在Node.js模块中建议使用,用来做性能测试。

 

三. JSHint - 一款Javascript代码分析工具

   这个工具很常用,每次写完Javascript的代码,就可以通过这个工具来扫描下代码,如果有错误(Error)或者警告(Warning)提示,就可以用来发现代码中的问题和可优化的地方,可及时修改。

   同时JSHint提供对文本编辑器插件的各种支持,像我用的Vim就配置了JSHint,每次开发完,直接输入命令:JSHint,很好用,推荐。

   同时建议在Javascript代码文件首行增加"user strict;",这样是默认使用严格模式,更安全,更严谨。例如下例。

1 /* jshint strict: true, undef:true, unused:true, latedef: true, newcap: true, noempty: true, forin: true, 
2  freeze: true, node: true, curly:true, camelcase: true */
3 "use strict";

   JSHint官网:http://jshint.com/

 

目前根据自己的经验,只总结出以上三点。后面如果有更多的实践和总结,会及时更新在这里。谢谢

 

Kevin Song

2015-5-28

 

Developer - 如何自我保证Node.js模块质量

标签:

原文地址:http://www.cnblogs.com/KevinSong/p/4535977.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!