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

  组里正在做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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏微信终端开发团队的专栏

Android N混合编译与对热补丁影响解析

首先非常抱歉Tinker没有按期内测,这主要因为开源的代码需要通过公司内部审核与评测,这项工作大约还需要一个月左右。当前Tinker已经在公司内部开源,我们会努...

2678
来自专栏携程技术中心

干货 | Android工程模块化平台的设计

1203
来自专栏北京马哥教育

Pipenv:官方推荐的python包管理工具

Pipenv - 官方推荐的的python包管理工具。 Pipenv是一款旨在将所有包管理工具(如bundler, composer, npm, cargo...

3647
来自专栏数据小魔方

左手用R右手Python系列——多进程/线程数据抓取与网页请求

这一篇涉及到如何在网页请求环节使用多进程任务处理功能,因为网页请求涉及到两个重要问题:一是多进程的并发操作会面临更大的反爬风险,所以面临更严峻的反爬风险,二是抓...

3229
来自专栏林德熙的博客

win10 uwp 应用转后台清理内存

我在写小说阅读器,把每个打开的文件的内容读到内存,因为小说都很小,所以放在内存不怕太大,但是我如果打开了一本小说,再打开一本,我不会把先打开的小说的内容清除掉,...

552
来自专栏木子昭的博客

微信小程序通过ip获取用户所在城市

2683
来自专栏何俊林

美团猫眼电影Android模块化实战总结

首先一句话概括:我想把这几个月做的事情记录下来,并且希望尽量详细,希望读者读了这篇文章能够知道项目进行模块化,项目改业务框架可能会遇到哪些问题,具体每个步骤都做...

1602
来自专栏木头编程 - moTzxx

微信小程序Ⅰ [关于微信支付的一点思路]

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011415782/article/de...

1343
来自专栏Vamei实验室

Python标准库——走马观花

Python有一套很有用的标准库(standard library)。标准库会随着Python解释器,一起安装在你的电脑中的。它是Python的一个组成部分。这...

1776
来自专栏IMWeb前端团队

sChart.js:一个小型简单的图表库

本文作者:IMWeb 林鑫 原文出处:IMWeb社区 未经同意,禁止转载 介绍 sChart.js 作为一个小型简单的图表库,没有过多的图表类型,只包...

18710

扫码关注云+社区