我的Node.js学习之路(四)--单元测试 |
本文标签:Node.js,单元测试 通过NPM安装: npm install nodeunit -g 支持命令行,浏览器运行. 各种断言 。 在node.js下模块化对于方法导出exports, 如果是对象导出module.exports,模块儿是单元测试的基础,看下面的node.js代码: var fs = require(fs), global=require(./global.js); var utils = { startWith: function(s1, s) { if (s == null || s == "" || this.length == 0 || s.length > this.length) return false; if (s1.substr(0, s.length) == s) return true; else return false; return true; }, /* Generate GUID */ getGuid: function() { var guid = ""; for (var i = 1; i <= 32; i++) { var n = Math.floor(Math.random() * 16.0).toString(16); guid += n; } return guid; }, /* add log information */ writeLog: function(log) { if(!log) return; var text = fs.readFileSync(global.logFile, "utf-8"), _newLog = text ? (text + "\r\n" + log) : log; fs.writeFile(global.logFile, _newLog, function(err){ if(err) throw err; }); } }; exports.utils=utils; ./global.js是一个本地全局变量文件,现在我们对以上代码使用NodeUnit做测试的node.js代码: var utils=new require(./utils.js); this.TestForUtils = { TestgetGuid: function (test) { var guid=utils.utils.getGuid(); test.ok(!!guid, getGuid should not be null.); test.done(); }, TestWritelog: function (test) { var flag=false; utils.utils.writeLog("test message"); flag=true; test.ok(flag,writeLog); test.done(); }, TestStartWithWords: function (test) { var name="ad_123"; test.ok(utils.utils.startWith(name, "ad_"),"startwith method should be ok"); test.done(); } }; test.ok也是通常我们说的断言 。对于NodeUnit的单元测试程序,也可以使用node-inspector来调试 |