assert.rejects(asyncFn[, error][, message])
添加於:v10.0.0
參數
asyncFn
<Function> | <Promise>error
<RegExp> | <Function> | <Object> | <Error>message
<string>
等待 asyncFn
承諾,或者,如果 asyncFn
是一個函數,則立即調用該函數並等待返回的承諾完成。然後它將檢查承諾是否被拒絕。
如果asyncFn
是一個函數並且它同步拋出一個錯誤,那麽assert.rejects()
將返回一個帶有該錯誤的被拒絕的Promise
。如果函數沒有返回承諾,assert.rejects()
將返回一個被拒絕的 Promise
並帶有
錯誤。在這兩種情況下,都會跳過錯誤處理程序。ERR_INVALID_RETURN_VALUE
除了等待完成的異步性質外,其行為與
相同。assert.throws()
如果指定,error
可以是
、 Class
、驗證函數、將測試每個屬性的對象,或者將測試每個屬性以包含不可枚舉的錯誤實例 RegExp
message
和 name
屬性。
如果指定,如果asyncFn
拒絕失敗,message
將是由
提供的消息。AssertionError
import assert from 'node:assert/strict'; await assert.rejects( async () => { throw new TypeError('Wrong value'); }, { name: 'TypeError', message: 'Wrong value' } );
const assert = require('node:assert/strict'); (async () => { await assert.rejects( async () => { throw new TypeError('Wrong value'); }, { name: 'TypeError', message: 'Wrong value' } ); })();
import assert from 'node:assert/strict'; await assert.rejects( async () => { throw new TypeError('Wrong value'); }, (err) => { assert.strictEqual(err.name, 'TypeError'); assert.strictEqual(err.message, 'Wrong value'); return true; } );
const assert = require('node:assert/strict'); (async () => { await assert.rejects( async () => { throw new TypeError('Wrong value'); }, (err) => { assert.strictEqual(err.name, 'TypeError'); assert.strictEqual(err.message, 'Wrong value'); return true; } ); })();
import assert from 'node:assert/strict'; assert.rejects( Promise.reject(new Error('Wrong value')), Error ).then(() => { // ... });
const assert = require('node:assert/strict'); assert.rejects( Promise.reject(new Error('Wrong value')), Error ).then(() => { // ... });
error
不能是字符串。如果提供了字符串作為第二個參數,則假定 error
被省略,而該字符串將用於 message
。這可能導致easy-to-miss 錯誤。如果考慮使用字符串作為第二個參數,請仔細閱讀
中的示例。assert.throws()
相關用法
- Node.js assert.rejects()用法及代碼示例
- Node.js assert.notEqual(actual, expected[, message])用法及代碼示例
- Node.js assert.notDeepStrictEqual(actual, expected[, message])用法及代碼示例
- Node.js assert.fail(actual, expected[, message[, operator[, stackStartFn]]])用法及代碼示例
- Node.js assert.deepStrictEqual()用法及代碼示例
- Node.js assert.deepEqual(actual, expected[, message])用法及代碼示例
- Node.js assert.throws(fn[, error][, message])用法及代碼示例
- Node.js assert.equal()用法及代碼示例
- Node.js assert.ifError()用法及代碼示例
- Node.js assert.throws()用法及代碼示例
- Node.js assert.ok()用法及代碼示例
- Node.js assert.strictEqual()用法及代碼示例
- Node.js assert.fail()用法及代碼示例
- Node.js assert.strictEqual(actual, expected[, message])用法及代碼示例
- Node.js assert.doesNotThrow(fn[, error][, message])用法及代碼示例
- Node.js assert.notStrictEqual(actual, expected[, message])用法及代碼示例
- Node.js assert.deepStrictEqual(actual, expected[, message])用法及代碼示例
- Node.js assert.match()用法及代碼示例
- Node.js assert.notDeepStrictEqual()用法及代碼示例
- Node.js assert.doesNotThrow()用法及代碼示例
- Node.js assert.doesNotReject(asyncFn[, error][, message])用法及代碼示例
- Node.js assert.match(string, regexp[, message])用法及代碼示例
- Node.js assert.equal(actual, expected[, message])用法及代碼示例
- Node.js assert.ifError(value)用法及代碼示例
- Node.js assert.ok(value[, message])用法及代碼示例
注:本文由純淨天空篩選整理自nodejs.org大神的英文原創作品 assert.rejects(asyncFn[, error][, message])。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。