断言
稳定等级:3 –已锁定
Node.js可以使用该模块编写测试用例进行测试。可以通过require(‘assert’)引入模块。然而,建议使用用户态断言库来替代它。
assert(value, [message]), assert.ok(value,[message])
测试结果是否为真(true),相当于 assert.equal(true, !!value, message);
assert.deepEqual(actual, expected, [message])
深度匹配。原始值(actual)和期望值(expected)的比较,相当于(==)
该操作只考虑可枚举属性。不能测试对象原型,附加标示,和不可枚举属性。改操作可能会导致一些出乎意料的结果。例如,下面的例子不会抛出断言错误,因为error对象的属性是不可枚举的:
// WARNING: This does not throw an AssertionError!
assert.deepEqual(Error('a'), Error('b'));
assert.deepStrictEqual(actual, expected, [message])
严格匹配。相当于(===);
assert.doesNotThrow(block, [error], [message])
声明模块不抛出错误,详见 assert.throws
assert.equal(actual, expected[, message])
浅测试,等同于使用’==’进行相等判断
assert.fail(actual, expected, message, operator)
抛出一个异常,显示用例的实际值(actual)和期望值(expected),通过分隔符(operator)隔开。
assert.ifError(value)
测试值是否不为 false,当为 true 时抛出。常用于回调中第一个 error 参数的检查。
assert.notDeepEqual(actual, expected[, message])
非深度匹配测试
assert.notDeepStrictEqual(actual, expected[, message])
不严格相等测试,等同于使用’!==’判断不匹配
assert.notEqual(actual, expected[, message])
浅测试,等同于使用’!=’进行不相等判断
assert.notStrictEqual(actual, expected[, message])
不严格相等测试,等同于使用’!==’判断不匹配
assert.strictEqual(actual, expected[, message])
严格匹配。相当于(===);
assert.throws(block[, error][, message])
声明一个block用于抛出错误,’error’可以是构造函数,验证函数或者正则表达式
用构造函数验证实例
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"
);