學(xué)習(xí)node.js 斷言的使用詳解
assert模塊提供了一組簡(jiǎn)單的斷言測(cè)試,分嚴(yán)格模式(strict)和遺留模式(legacy),嚴(yán)格模式下,對(duì)比的方式比較嚴(yán)格,比如說(shuō),0與'0'比較,會(huì)報(bào)錯(cuò),但在遺留模式下是可以通過(guò)的。官方推薦使用嚴(yán)格模式, 所以本文基于strict模式下學(xué)習(xí)。
如何使用嚴(yán)格模式
const assert = require('assert').strict; // 嚴(yán)格模式
assert.equal(0, '0') // error
全局使用strict模式后,assert.equal() 與assert.strictEqual()的效果是一樣的。
如果不想全局使用的話,可以直接使用帶strict的方法。
const assert = require('assert') // 遺留模式
assert.equal(0, '0') // success
assert.strictEqual(0, '0') // error
assert.AssertionError
Error的子類(lèi),表示斷言失敗,assert模塊拋出的錯(cuò)誤都是AssertionError的實(shí)例。
類(lèi)似于下面這個(gè)class,實(shí)際上的AssertionError是由ES5寫(xiě)的,下面這個(gè)只是方便理解傳入的參數(shù)
interface IOptions {
message?: string; // 設(shè)置錯(cuò)誤的信息
actual?: any; // 設(shè)置錯(cuò)誤實(shí)例上的實(shí)際值
expected?: any; // 設(shè)置錯(cuò)誤實(shí)例上的期望值
operator?: string; // 設(shè)置用于比較的操作或觸發(fā)錯(cuò)誤的斷言函數(shù)
stackStartFn(): any; // 生成的堆棧跟蹤將移除所有幀直到提供的函數(shù)
}
class AssertionError extends Error {
constructor(options: IOptions) {
// ...
}
}
assert(value: any, message?: string | Error)
檢測(cè)是否為真值,是assert.ok的別名。
assert.ok(value: any, message?: string | Error)
檢測(cè)value是否為真值。
如果不為真值,拋出屬性message為message參數(shù)值的AssertionError,如果未定義,為默認(rèn)錯(cuò)誤信息。
如果是Error的實(shí)例,則拋出Error實(shí)例。(以下關(guān)于message的使用都一樣)
assert.strictEqual(actual: any, expected: any, message?: string | Error)
檢測(cè) actual參數(shù)和expected參數(shù)之間的嚴(yán)格相等性,使用sameValue比較。
assert.deepStrictEqual(actual: any, expected: any, message?: string | Error)
檢測(cè)actual參數(shù)和expected參數(shù)之間的深度嚴(yán)格相等性,深度比較意味著子對(duì)象的可枚舉的自身屬性也通過(guò)以下規(guī)則進(jìn)行遞歸計(jì)算。
assert.notStrictEqual(actual: any, expected: any, message?: string | Error)
檢測(cè) actual參數(shù)和expected參數(shù)之間的嚴(yán)格不相等性,使用sameValue比較。
assert.notDeepStrictEqual(actual: any, expected: any, message?: string | Error)
檢測(cè)actual參數(shù)和expected參數(shù)之間的深度嚴(yán)格不相等性,深度比較意味著子對(duì)象的可枚舉的自身屬性也通過(guò)以下規(guī)則進(jìn)行遞歸計(jì)算。
assert.fail(message?: string | Error = 'failed')
使用提供的錯(cuò)誤消息或默認(rèn)錯(cuò)誤消息拋出 AssertionError。
assert.throws(fn: function, error?: regExp | function | object | Error, message?: string)
檢測(cè)fn函數(shù)拋出的錯(cuò)誤是否與預(yù)期的錯(cuò)誤error一樣。
fn為一個(gè)會(huì)拋出錯(cuò)誤的函數(shù)
error可以為多種類(lèi)型,作為與拋出的錯(cuò)誤對(duì)比的樣本。
為regExp時(shí),可以匹配拋出的錯(cuò)誤。
assert.throws(() => {
throw new Error('it is a error')
}, /^Error: it is a error$/);
為function時(shí),可以自定義驗(yàn)證函數(shù)
assert.throws(() => {
throw new Error('it is a error')
}, (err) => {
if ((err instanceof Error) && /error/.test(err)) {
return true;
}
});
為object時(shí),將僅測(cè)試驗(yàn)證對(duì)象error上的屬性。
const err = new TypeError('錯(cuò)誤值');
err.code = 404;
err.foo = 'bar';
err.info = {
nested: true,
baz: 'text'
};
err.reg = /abc/i; // 正則表達(dá)式只有當(dāng)驗(yàn)證對(duì)象包含相同的正則表達(dá)式時(shí)才通過(guò)。
assert.throws(() => {
throw err;
}, {
name: 'TypeError',
message: '錯(cuò)誤值'
info: {
nested: true,
baz: 'text'
// 使用嵌套對(duì)象需要存在所有屬性。
// 否則驗(yàn)證將失敗。
// 無(wú)法對(duì)嵌套屬性使用正則表達(dá)式!
}
});
為Error時(shí),用instanceof檢測(cè)是否是該實(shí)例。
注意, error 不能是字符串。 如果提供了一個(gè)字符串作為第二個(gè)參數(shù),則假定 error 被忽略,而字符串將用于 message。
assert.reject(asyncFn: function | promise, error?: regExp | function | object | Error, message?: string)
assert.throws的異步版本。
asyncFn為一個(gè)function時(shí)
立即執(zhí)行該函數(shù),如果該函數(shù)不返回promise,則返回一個(gè)被拒絕(reject)的 Promise。
如果該函數(shù)同步拋出一個(gè)錯(cuò)誤,返回一個(gè)帶有該錯(cuò)誤的被拒絕的 Promise。
asyncFn為一個(gè)Promise時(shí)
等待Promise執(zhí)行,檢測(cè)是否被拒絕。
assert.ifError(value: any)
如果value不為null或者undefined就將value作為錯(cuò)誤拋出。
在回調(diào)中測(cè)試error參數(shù)時(shí),這很有用。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
nodejs 中模擬實(shí)現(xiàn) emmiter 自定義事件
這篇文章主要介紹了Nodejs中自定義事件實(shí)例,比較簡(jiǎn)單的一個(gè)例子,需要的朋友可以參考下。2016-02-02
Node.js基礎(chǔ)入門(mén)之緩存區(qū)與文件操作詳解
Node.js是一個(gè)基于Chrome?V8引擎的JavaScript運(yùn)行時(shí)。類(lèi)似于Java中的JRE,.Net中的CLR。本文將詳細(xì)為大家介紹Node.js中的緩存區(qū)與文件操作,感興趣的可以了解一下2022-03-03
nodejs遍歷文件夾下并操作HTML/CSS/JS/PNG/JPG的方法
這篇文章主要介紹了nodejs遍歷文件夾下并操作HTML/CSS/JS/PNG/JPG的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-11-11
Node.js在child_process域和錯(cuò)誤冒泡及捕獲實(shí)踐
這篇文章主要為大家介紹了Node.js在child_process域和錯(cuò)誤冒泡及捕獲實(shí)踐示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
Nodejs+express+html5 實(shí)現(xiàn)拖拽上傳
文件上傳是一個(gè)比較常見(jiàn)的功能,傳統(tǒng)的選擇方式的上傳比較麻煩,需要先點(diǎn)擊上傳按鈕,然后再找到文件的路徑,然后上傳。給用戶體驗(yàn)帶來(lái)很大問(wèn)題。html5開(kāi)始支持拖拽上傳的需要的api。nodejs也是一個(gè)最近越來(lái)越流行的技術(shù),這也是自己第一次接觸nodejs。2014-08-08

