亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Node.js assert斷言原理與用法分析

 更新時間:2019年01月04日 08:37:05   作者:司馬懿字仲達  
這篇文章主要介紹了Node.js assert斷言原理與用法,結合實例形式分析了assert模塊斷言函數(shù)與使用技巧,需要的朋友可以參考下

本文實例講述了Node.js assert斷言原理與用法。分享給大家供大家參考,具體如下:

node.js官方API中文版 http://nodeapi.ucdok.com/#/api/assert.html

assert 模塊主要用于編寫程序的單元測試時使用,通過斷言可以提早發(fā)現(xiàn)和排查出錯誤。

class : assert
- assert.fail(actual, expected, message, operator)
- assert(value, message), assert.ok(value, [message])
- assert.equal(actual, expected, [message])
- assert.notEqual(actual, expected, [message])
- assert.deepEqual(actual, expected, [message])
- assert.notDeepEqual(actual, expected, [message])
- assert.strictEqual(actual, expected, [message])
- assert.notStrictEqual(actual, expected, [message])
- assert.throws(block, [error], [message])
- assert.doesNotThrow(block, [message])
- assert.ifError(value)

console.log(assert);
/*
輸出如下
{ [Function: ok]
 AssertionError:
  { [Function: AssertionError]
   super_:
   { [Function: Error]
    captureStackTrace: [Function: captureStackTrace],
    stackTraceLimit: 10 } },
 fail: [Function: fail],
 ok: [Circular],
 equal: [Function: equal],
 notEqual: [Function: notEqual],
 deepEqual: [Function: deepEqual],
 notDeepEqual: [Function: notDeepEqual],
 strictEqual: [Function: strictEqual],
 notStrictEqual: [Function: notStrictEqual],
 throws: [Function],
 doesNotThrow: [Function],
 ifError: [Function] }
 */

assert是個函數(shù),函數(shù)名為ok。javascript中函數(shù)是Function類的實例,也就是對象,所以可為其添加fail和equal等屬性。注意輸出結果第9行 ok:[Circular] 這個表述,這是指針循環(huán)的意思,即ok屬性指向了本身,所以調用assert.ok就相當于調用了assert本身。

測試如下:

var test = function ok() {
  console.log('test ok');
}
//輸出 undefined
test.ok = test;
//輸出 { [Function: ok] ok: [Circular] }
test.fail = function fail() {
  console.log('test fail');
}
//輸出 [Function: fail]
console.log(test);
//輸出 {[Function: ok] ok: [Circular], fail: [Function: fail] }

比較相等操作符 ‘==' 會根據(jù)前面的參數(shù)進行類型轉換。

true == 1;  // true
1 == true;  // true
true == 2;  // false
2 == true;  // false
'' == false; // true
false == ''; // true
1 == '1';  // true

全等操作符 ‘===' 會先比較元素的類型,只有類型和值都一樣才算相等。

true === 1; // false
1 === '1'; // false

轉回正題:

注意:如果不設置message,就會將value打印出來。

assert.fail(actual, expected, message, operator)

在不檢查任何條件的情況下使斷言失敗。如果有錯誤信息則輸出錯誤信息,否則輸出actual和expected,中間用operator隔開。

assert.fail(1, 1);
//輸出 AssertionError: 1 undefined 1
assert.fail(1, 1, undefined, '==');
//輸出 AssertionError: 1 == 1
assert.fail(1, 2, undefined, '>');
//輸出 AssertionError: 1 > 2
assert.fail(1, 2, 'whoops', '>');
//輸出 AssertionError: whoops

assert(value, message), assert.ok(value, [message])

assert(true, 'message');
//輸出 undefined
assert(false, 'message');
//輸出 AssertionError: message
assert.ok(true, 'message');
//輸出 undefined
assert.ok(false, 'message');
//輸出 AssertionError: message

assert.equal(actual, expected, [message])

和比較操作符(==)的判斷結果相同。當兩邊都是基本變量的時候轉化為同一類型的變量再進行比較;如果是引用類型的變量,則直接比較其內存地址。

assert.equal(1, 1, 'message');
//輸出 undefined
assert.equal(1, '1', 'message');
//輸出 AssertionError: message

assert.strictEqual(actual, expected, [message])

Tests strict equality, as determined by the strict equality operator ( === )
嚴格相等,和全等符號(===)的判斷結果相同。

assert.strictEqual(1, 1, 'message');
//輸出 undefined
assert.strictEqual(1, '1', 'message');
//輸出 AssertionError: message
assert.strictEqual(1, '1', 'message');
//輸出 AssertionError: message

assert.deepEqual(actual, expected, [message])

當比較的雙方均為基本類型時,等價于euqal()。
當比較的雙方均為引用類型時,即將引用類型中的每一個屬性用equal()進行比較。

assert.equal(1, '1');
//輸出 undefined
assert.deepEqual(1, '1');
//輸出 undefined
assert.strictEqual(1, '1');
//輸出 assert.strictEqual(1, '1');
assert.equal({a:1}, {a:'1'});
//輸出 AssertionError: { a: 1 } == {a: '1'}
assert.deepEqual({a:1}, {a:'1'});
//輸出 undefined
assert.strictEqual({a:1}, {a:'1'});
//輸出 AssertionError: { a: 1 } == {a: '1'}

assert.throws(block, [error], [message])

Expects the function block to throw an error.
If specified, error can be a constructor, RegExp, or validation function.
If specified, message will be the message provided by the AssertionError if the block fails to throw.

assert.throws(
 () => {},
 Error
);
//輸出 AssertionError: Missing expected exception (Error)..
assert.throws(
 () => {throw new Error('Wrong value');},
 Error
);
//輸出 undefined
assert.throws(
 () => {throw new Error('Wrong value');},
 /Wrong/
);
//輸出 undefined
assert.throws(
 () => {throw new Error('Wrong value');},
 /wrong/
);
//輸出 Error: Wrong value
assert.throws(
 () => {throw new Error('Wrong value');},
 (err) => {
  if ((err instanceof Error) && /value/.test(err)) { return true;
  }
 },
 'unexpected error'
);
//輸出 undefined

Note that error can not be a string. If a string is provided as the second argument, then error is assumed to be omitted and the string will be used for message instead. This can lead to easy-to-miss mistakes:

注意:錯誤信息不能是一個字符串。如果字符串被作為第二個參數(shù),那么錯誤就會被假定為省略,并且字符串將會被用作提示信息,這樣很容易導致錯誤。

assert.throws(()=>{throw new Error('Wrong value');}, 'Wrong', 'did not throw with expected message');
//輸出 undefined
assert.throws(()=>{}, 'Wrong', 'did not throw with expected message');
//輸出 AssertionError: Missing expected exception. Wrong
assert.throws(()=>{}, /Wrong/, 'did not throw with expected message');
//輸出 AssertionError: Missing expected exception. did not with expected message.

assert.ifError(value)

Throws value if value is truthy. This is useful when testing the error argument in callbacks.

當值為真時,拋出AssertionError錯誤。該方法在測試回調函數(shù)的參數(shù)時非常有用。

assert.ifError(0);
//輸出 undefined
assert.ifError(1);
//輸出 1
assert.ifError('error');
//輸出 error
assert.ifError(new Error('there maybe wrong'));
//輸出 Error: there maybe wrong

希望本文所述對大家nodejs程序設計有所幫助。

相關文章

  • Nodejs實現(xiàn)多人同時在線移動鼠標的小游戲分享

    Nodejs實現(xiàn)多人同時在線移動鼠標的小游戲分享

    這篇文章主要介紹了Nodejs實現(xiàn)多人同時在線移動鼠標的小游戲分享,本文給出了服務器端和客戶端代碼以及運行方法,需要的朋友可以參考下
    2014-12-12
  • 詳解基于Node.js的HTTP/2 Server實踐

    詳解基于Node.js的HTTP/2 Server實踐

    HTTP/2目前已經逐漸的在各大網站上開始使用,這篇文章主要介紹了詳解基于Node.js的HTTP/2 Server實踐,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • Egret引擎開發(fā)指南之創(chuàng)建項目

    Egret引擎開發(fā)指南之創(chuàng)建項目

    Egret Engine(白鷺引擎)是一款使用TypeScript語言構建的開源免費的移動游戲引擎。白鷺引擎的核心定位是開放,高效,優(yōu)雅。通過它,你可以快速地創(chuàng)建HTML5類型的移動游戲,也可以將游戲項目編譯輸出成為目標移動平臺的原生游戲應用。
    2014-09-09
  • 在Node.js下運用MQTT協(xié)議實現(xiàn)即時通訊及離線推送的方法

    在Node.js下運用MQTT協(xié)議實現(xiàn)即時通訊及離線推送的方法

    這篇文章主要介紹了在Node.js下運用MQTT協(xié)議實現(xiàn)即時通訊及離線推送的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-01-01
  • 利用nvm管理多個版本的node.js與npm詳解

    利用nvm管理多個版本的node.js與npm詳解

    這篇文章主要給大家介紹了關于利用nvm管理多個版本的node.js與npm的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-11-11
  • NodeJs實現(xiàn)簡易WEB上傳下載服務器

    NodeJs實現(xiàn)簡易WEB上傳下載服務器

    這篇文章主要為大家詳細介紹了NodeJs實現(xiàn)一個簡易WEB上傳下載服務器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • Nodejs中使用captchapng模塊生成圖片驗證碼

    Nodejs中使用captchapng模塊生成圖片驗證碼

    本篇文章主要介紹了Nodejs中使用captchapng模塊實現(xiàn)圖片驗證碼,非常具有實用價值,需要的朋友可以參考下
    2017-05-05
  • 解決使用node命令提示:'node'不是內部或外部命令,也不是可運行的程序

    解決使用node命令提示:'node'不是內部或外部命令,也不是可運行的程序

    最近在工作中遇到了個常見的問題,分享給大家,這篇文章主要給大家介紹了關于如何解決使用node命令提示:'node'不是內部或外部命令,也不是可運行的程序的相關資料,需要的朋友可以參考下
    2023-02-02
  • 安裝node.js和npm的一些常見報錯

    安裝node.js和npm的一些常見報錯

    NVM(Node?Version?Manager)是一個用于在同一機器上同時安裝并管理多個Node.js版本的工具,這篇文章主要給大家介紹了關于安裝node.js和npm的一些常見報錯,需要的朋友可以參考下
    2023-06-06
  • Node Sass依賴問題排查思路解析

    Node Sass依賴問題排查思路解析

    這篇文章主要為大家介紹了Node Sass依賴問題排查思路解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04

最新評論