Node.js利用断言模块assert进行单元测试的方法


Posted in Javascript onSeptember 28, 2017

前言

对于NodeJS, assert模块提供了一系列的断言测试,其实这个模块主要倾向于内部使用,但是也能被用于项目中, 可以通过require(‘assert')的方式引入,下面本文将给大家介绍关于Node.js用断言模块assert进行单元测试的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

方法如下:

首先先引入断言assert模块

var assert = require('assert');

1.assert(value, message), assert.ok(value, [message])  //判断中值是否为true

 assert.ifError(value) //测试值是否不为 false,当为 true 时抛出。常用于回调中第一个 error 参数的检查。

var a = 0;
assert(a,'这里需要值为true'); //AssertionError: 这里需要值为true
assert.ok(a,'这里也要为true');
// AssertionError: 这里也要为true

2.assert.fail(actual, expected, message, operator) //抛出异常,有message时显示message,没有使用operator作为为分隔符

var a = 0;
assert.fail(a,1,'a!=1','<'); // AssertionError: a!=1
assert.fail(a,2,'','<');
// AssertionError: 0 < 2

3.assert.equal(actual, expected, [message])   //("=="判断)是否相等 相反:notEqual

 assert.strictEqual(actual, expected, [message])  //("==="判断)是否相等 相反:notStrictEqual

var a = 2;
var a='2';

assert.equal(a,b,'a,b不相等 ==')
assert.notEqual(a,b,'a,b相等')

// AssertionError: a,b相等
assert.strictEqual(a,b,'a,b不完全相等 ===') // AssertionError: a,b不完全相等 ===

4.assert.deepEqual(actual, expected[, message])、// 是否深度匹配  相反: notDeepEqual

var buf1 = new Buffer('abc');
var buf2 = new Buffer('abc');

assert.strictEqual(buf1, buf2, 'buf1和buf2不一样'); //AssertionError: buf1和buf2不一样
assert.notDeepEqual(buf1, buf2, 'buf1和buf2一样'); //AssertionError: buf1和buf2一样

5.assert.throws(block, [error], [message]) //声明一个block用于抛出错误,'error'可以是构造函数,验证函数或者正则表达式

    assert.doesNotThrow(block, [message])//声明模块不抛出错误

//构造函数
assert.throws(
 function() {
 throw new Error("Wrong value");
 },
 Error
);

//正则
assert.throws(
 function() {
 throw new Error("Wrong value");
 },
 /value/
);

//自定义错误
assert.throws(
 function() {
 throw new Error("Wrong value");
 },
 function(err) {
 if ( (err instanceof Error) && /value/.test(err) ) {
  return true;
 }
 },
 "unexpected error"
);

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
JavaScript CSS菜单功能 改进版
Dec 20 Javascript
Google Map Api和GOOGLE Search Api整合实现代码
Jul 18 Javascript
弹出层之1:JQuery.Boxy (一) 使用介绍
Oct 06 Javascript
JS打开层/关闭层/移动层动画效果的实例代码
May 11 Javascript
JavaScript中的字符串操作详解
Nov 12 Javascript
JavaScript中判断页面关闭、页面刷新的实现代码
Aug 27 Javascript
深入理解JavaScript系列(46):代码复用模式(推荐篇)详解
Mar 04 Javascript
javascript实现获取字符串hash值
May 10 Javascript
Javascript基于对象三大特性(封装性、继承性、多态性)
Jan 04 Javascript
React中ES5与ES6写法的区别总结
Apr 21 Javascript
Vue组件选项props实例详解
Aug 18 Javascript
JS关于刷新页面的相关总结
May 09 Javascript
详解基于vue-router的动态权限控制实现方案
Sep 28 #Javascript
node.js学习之断言assert的使用示例
Sep 28 #Javascript
vue-router+vuex addRoutes实现路由动态加载及菜单动态加载
Sep 28 #Javascript
node.js学习之事件模块Events的使用示例
Sep 28 #Javascript
es6中的解构赋值、扩展运算符和rest参数使用详解
Sep 28 #Javascript
JS获取日期的方法实例【昨天,今天,明天,前n天,后n天的日期】
Sep 28 #Javascript
jquery实现左右轮播图效果
Sep 28 #jQuery
You might like
php 智能404跳转代码,适合换域名没改变目录的网站
2010/06/04 PHP
PHP实现获取图片颜色值的方法
2014/07/11 PHP
thinkPHP查询方式小结
2016/01/09 PHP
PHP实现微信提现功能(微信商城)
2019/11/21 PHP
使用jscript实现二进制读写脚本代码
2008/06/09 Javascript
用js来获取上传的文件名纯粹是为了美化而用
2013/10/23 Javascript
Javascript中string转date示例代码
2013/11/01 Javascript
浅析JS中document对象的一些重要属性
2014/03/06 Javascript
JavaScript数组去重的3种方法和代码实例
2015/07/01 Javascript
JS实现可调整倒计时间代码分享
2015/08/18 Javascript
js实现下拉列表选中某个值的方法(3种方法)
2015/12/17 Javascript
基于javascript实现最简单的选项卡切换效果
2016/05/16 Javascript
JavaScript中的this使用详解
2016/07/27 Javascript
浅析jQuery操作select控件的取值和设值
2016/12/07 Javascript
js图片延迟加载(Lazyload)三种实现方式
2017/03/01 Javascript
vue实现一个移动端屏蔽滑动的遮罩层实例
2017/06/08 Javascript
webpack源码之loader机制详解
2018/04/06 Javascript
vue组件实现进度条效果
2018/06/06 Javascript
JavaScript引用类型Array实例分析
2018/07/24 Javascript
[03:44]2014DOTA2国际邀请赛 71专访:DK战队赛前讨论视频遭泄露
2014/07/13 DOTA
python生成1行四列全2矩阵的方法
2018/08/04 Python
python实现机器学习之多元线性回归
2018/09/06 Python
Python3实现的简单三级菜单功能示例
2019/03/12 Python
python实现经典排序算法的示例代码
2021/02/07 Python
python 爬取腾讯视频评论的实现步骤
2021/02/18 Python
CSS中的字体大小设置属性总结
2016/05/24 HTML / CSS
html5 touch事件实现触屏页面上下滑动(一)
2016/03/10 HTML / CSS
后勤人员自我评价怎么写
2013/09/19 职场文书
自荐信格式范文
2013/10/07 职场文书
初一地理教学反思
2014/01/16 职场文书
建筑工程技术专业求职信
2014/07/16 职场文书
小学安全汇报材料
2014/08/14 职场文书
2014坚持党风廉政建设思想汇报
2014/09/18 职场文书
北京故宫导游词
2015/01/31 职场文书
2015年教师见习期工作总结
2015/05/20 职场文书
职场新人刚入职工作总结该怎么写?
2019/05/15 职场文书