(assertion)断言
断言就是用于检查程序运行时是否满足期望。
demo如下:
var assert= require('assert');
assert.equal(Math.max(10,100),100);
一旦assert。equal()不满足期望,将会抛出异常,整个程序将会停止执行。(错误示范如下)
assert.equal(Math.max(10,100),10);
//输出
{ [AssertionError [ERR_ASSERTION]: 100 == 10]
generatedMessage: true,
name: 'AssertionError [ERR_ASSERTION]',
code: 'ERR_ASSERTION',
actual: 100,
expected: 10,
operator: '==' }
在断言规范中,还有如下几种检测方法。
1.ok():判断结果是否为真。
2.equal():判断实际值与期望值是否相等;
3.notEqual():判断实际值和期望值是否不相等;
4.deepEqual():判断实际值和期望值是深度相等(对象或数组的元素是否相等);
5.notDeepEqual():判断实际值和期望值是否深度不相等;
6.strictEqual():判断实际值和期望值是否严格相等(=== );
7.notStrictEqual():判断实际值和期望值是否严格不相等(!==);
8.throws():判断代码块是否抛出异常;
9.doseNotthrows():判断代码块是否没有抛出异常;
10.ifError():判断实际值是否为一个假值,如果实际值为真,抛出异常;
should.js也是居于assert模块进行封装和扩展的断言库
var a=1,b=0,c=null;
assert.ok(a);
assert.ok(b);
//输出
{ [AssertionError [ERR_ASSERTION]: 0 == true]
generatedMessage: true,
name: 'AssertionError [ERR_ASSERTION]',
code: 'ERR_ASSERTION',
actual: 0,
expected: true,
operator: '==' }
assert.ifError(a);
assert.ifError(c);
//输出
{ [AssertionError [ERR_ASSERTION]: ifError got unwanted exception: 1]
generatedMessage: false,
name: 'AssertionError [ERR_ASSERTION]',
code: 'ERR_ASSERTION',
actual: 1,
expected: null,
operator: 'ifError' }