首先先引入斷言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" );