Node.js——assert断言模块

assert断言模块

在Node.js中,可以利用assert模块进行断言处理,即书写一些判断用测试代码,如果判断结果为假,则抛出AssertionError异常。接下来,我们对assert模块中的所有方法进行详细介绍。

1、equal()和notEqual()

注意:equal方法与notEqual方法仅对两个值进行比较判断,并不连同两个值的数据类型一起判断。例如,对值1与"1"进行判断时,判断结果为真。

equal方法用于判断两个值是否相等,在Node.js内部使用"=="操作符进行判断,使用方式如下所示:

js 复制代码
assert.equal(actual, expected, [message])
  • actual:实际值
  • expected:预期值
  • message:可选,指定自定义异常信息
js 复制代码
const assert = require('assert');
console.log(assert.equal(1, '2'));
复制代码
AssertionError [ERR_ASSERTION]: 1 == '2'
    at Object.<anonymous> (/Users/acton_zhang/前端/vscodeworkspace/node/demo/index.js:2:20)
    at Module._compile (internal/modules/cjs/loader.js:1118:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:1138:10)
    at Module.load (internal/modules/cjs/loader.js:982:32)
    at Function.Module._load (internal/modules/cjs/loader.js:875:14)
    at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:71:12)
    at internal/main/run_main_module.js:17:47 {
  generatedMessage: true,
  code: 'ERR_ASSERTION',
  actual: 1,
  expected: '2',
  operator: '=='
}

notEqual方法的作用与equal方法的作用相反,用于判断两个值是否不相等,在Node.js内部使用"!="操作符进行判断,使用方式如下所示。

js 复制代码
assert.notEqual(actual, expected, [message])
  • actual:实际值
  • expected:预期值
  • message:可选,指定自定义异常信息
js 复制代码
const assert = require('assert');
console.log(assert.notEqual(1, '1'));
复制代码
    at Object.<anonymous> (/Users/acton_zhang/前端/vscodeworkspace/node/demo/index.js:2:20)
    at Module._compile (internal/modules/cjs/loader.js:1118:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:1138:10)
    at Module.load (internal/modules/cjs/loader.js:982:32)
    at Function.Module._load (internal/modules/cjs/loader.js:875:14)
    at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:71:12)
    at internal/main/run_main_module.js:17:47 {
  generatedMessage: true,
  code: 'ERR_ASSERTION',
  actual: 1,
  expected: '1',
  operator: '!='
}

2、strictEqual()与notStrictEqual()

如果需要对两个值及其数据类型是否相等进行判断,则需要使用strictEqual方法(在Node.js内部使用"==="操作符进行判断)​,代码如下所示:

js 复制代码
assert.strictEqual(actual, expected, [message])
  • actual:实际值
  • expected:预期值
  • message:可选,指定自定义异常信息
js 复制代码
const assert = require('assert');
console.log(assert.strictEqual(1, '1'));
js 复制代码
    at Object.<anonymous> (/Users/acton_zhang/前端/vscodeworkspace/node/demo/index.js:2:20)
    at Module._compile (internal/modules/cjs/loader.js:1118:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:1138:10)
    at Module.load (internal/modules/cjs/loader.js:982:32)
    at Function.Module._load (internal/modules/cjs/loader.js:875:14)
    at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:71:12)
    at internal/main/run_main_module.js:17:47 {
  generatedMessage: true,
  code: 'ERR_ASSERTION',
  actual: 1,
  expected: '1',
  operator: 'strictEqual'
}

notStrictEqual方法的作用与strictEqual方法的作用相反,用于判断两个值及其数据类型是否不等,Node.js内部使用"!=="操作符进行判断,使用方式如下所示。

js 复制代码
assert.notStrictEqual(actual, expected, [message])
  • actual:实际值
  • expected:预期值
  • message:可选,指定自定义异常信息
js 复制代码
const assert = require('assert');
console.log(assert.notStrictEqual(1, 1));
js 复制代码
    at Object.<anonymous> (/Users/acton_zhang/前端/vscodeworkspace/node/demo/index.js:2:20)
    at Module._compile (internal/modules/cjs/loader.js:1118:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:1138:10)
    at Module.load (internal/modules/cjs/loader.js:982:32)
    at Function.Module._load (internal/modules/cjs/loader.js:875:14)
    at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:71:12)
    at internal/main/run_main_module.js:17:47 {
  generatedMessage: true,
  code: 'ERR_ASSERTION',
  actual: 1,
  expected: 1,
  operator: 'notStrictEqual'
}

3、assert()与ok()

ok方法是一种简洁的判断方法,用于直接判断某个值是否为真,如果为假,则抛出AssertionError异常,使用方式如下所示:

js 复制代码
assert.ok(value, [message])
  • value:断言的值
  • message:可选,自定义异常
js 复制代码
const assert = require('assert');
console.log(assert.ok(1));
console.log(assert.ok(false));
js 复制代码
    at Object.<anonymous> (/Users/acton_zhang/前端/vscodeworkspace/node/demo/index.js:3:20)
    at Module._compile (internal/modules/cjs/loader.js:1118:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:1138:10)
    at Module.load (internal/modules/cjs/loader.js:982:32)
    at Function.Module._load (internal/modules/cjs/loader.js:875:14)
    at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:71:12)
    at internal/main/run_main_module.js:17:47 {
  generatedMessage: true,
  code: 'ERR_ASSERTION',
  actual: false,
  expected: true,
  operator: '=='
}

另外,可以使用assert方法来代替assert.ok方法,使用方式如下所示:

js 复制代码
assert(value, [message])
  • value:断言的值
  • message:可选,自定义异常
js 复制代码
const assert = require('assert');
console.log(assert(1));
console.log(assert(false));
js 复制代码
    at Object.<anonymous> (/Users/acton_zhang/前端/vscodeworkspace/node/demo/index.js:3:13)
    at Module._compile (internal/modules/cjs/loader.js:1118:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:1138:10)
    at Module.load (internal/modules/cjs/loader.js:982:32)
    at Function.Module._load (internal/modules/cjs/loader.js:875:14)
    at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:71:12)
    at internal/main/run_main_module.js:17:47 {
  generatedMessage: true,
  code: 'ERR_ASSERTION',
  actual: false,
  expected: true,
  operator: '=='
}

4、deepEqual()与notDeepEqual()

在Node.js中,可以使用deepEqual方法进行深层次的比较,使用方法如下所示:

js 复制代码
assert.deepEqual(actual, expected, [message])
  • actual:实际值
  • expected:预期值
  • message:可选,指定自定义异常信息

比较规则如下:

  1. 如果对两个简单类型的值进行比较(字符串、数值、布尔值、null与undefined),则内部使用"=="操作符进行判断。
  2. 如果对两个数组进行比较,则内部使用"==="操作符进行判断。
  3. 如果对两个对象进行比较,则将它们的属性长度和属性值进行比较。
  4. 如果对两个缓存区对象进行比较,则先比较它们的长度,然后逐字节比较缓存区中的内容。
js 复制代码
const assert = require('assert');
console.log(assert.deepEqual([1, 2, 3], [1, 2, 3]));
console.log(assert.deepEqual({name: 'tom', age: 18}, {name: 'tom', age: 17}));
js 复制代码
    at Object.<anonymous> (/Users/acton_zhang/前端/vscodeworkspace/node/demo/index.js:3:20)
    at Module._compile (internal/modules/cjs/loader.js:1118:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:1138:10)
    at Module.load (internal/modules/cjs/loader.js:982:32)
    at Function.Module._load (internal/modules/cjs/loader.js:875:14)
    at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:71:12)
    at internal/main/run_main_module.js:17:47 {
  generatedMessage: true,
  code: 'ERR_ASSERTION',
  actual: [Object],
  expected: [Object],
  operator: 'deepEqual'
}

notDeepEqual方法的作用与deepEqual方法相反,它用于深层判断两个值是否不等,比较规则与deepEqual方法使用的比较规则相同,使用方式如下所示。

js 复制代码
assert.notDeepEqual(actual, expected, [message])
  • actual:实际值
  • expected:预期值
  • message:可选,指定自定义异常信息
js 复制代码
const assert = require('assert');
console.log(assert.notDeepEqual([1, 2, 3], [1, 2, 3]));
console.log(assert.notDeepEqual({name: 'tom', age: 18}, {name: 'tom', age: 17}));
js 复制代码
]
    at Object.<anonymous> (/Users/acton_zhang/前端/vscodeworkspace/node/demo/index.js:2:20)
    at Module._compile (internal/modules/cjs/loader.js:1118:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:1138:10)
    at Module.load (internal/modules/cjs/loader.js:982:32)
    at Function.Module._load (internal/modules/cjs/loader.js:875:14)
    at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:71:12)
    at internal/main/run_main_module.js:17:47 {
  generatedMessage: true,
  code: 'ERR_ASSERTION',
  actual: [Array],
  expected: [Array],
  operator: 'notDeepEqual'
}

5、throws()与doesNotThrow()

throws方法用于执行一个函数中的代码并判断该函数中是否会抛出一个异常,如果判断结果为真(函数中抛出异常)​,则不抛出AssertionError异常,如果判断为假(函数中不抛出异常)​,则抛出AssertionError异常。

js 复制代码
assert.throws(block, [error], [message])
  • block:一个函数,如果该函数中抛出异常,则不抛出AssertionError异常。如果该函数中不抛出异常,则throws方法抛出AssertionError异常。
  • error:可选,一个返回true或返回false的函数,用于控制是否抛出在第一个参数值函数中指定抛出的异常,如果第二个参数值返回false,则抛出该异常。
  • message:可选,自定义错误信息
js 复制代码
const assert = require('assert');
assert.throws(()=>{
     let i = 1 / 0;
     console.log("I'm an error");
}, ()=>{return false});
js 复制代码
    at Object.<anonymous> (/Users/acton_zhang/前端/vscodeworkspace/node/demo/index.js:2:8)
    at Module._compile (internal/modules/cjs/loader.js:1118:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:1138:10)
    at Module.load (internal/modules/cjs/loader.js:982:32)
    at Function.Module._load (internal/modules/cjs/loader.js:875:14)
    at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:71:12)
    at internal/main/run_main_module.js:17:47 {
  generatedMessage: false,
  code: 'ERR_ASSERTION',
  actual: undefined,
  expected: [Function (anonymous)],
  operator: 'throws'
}

doesNotThrow方法用于执行一个函数中的代码并判断该函数是否不会抛出一个异常,如果判断为真(函数中不抛出异常)​,则正常执行该函数,如果判断为假(函数中抛出异常)​,则抛出该异常或AssertionError异常(根据doesNotThrow方法中的第二个参数而定)​。

js 复制代码
assert.doesNotThrow(block, [error], [message])
  • block:一个函数,如果该函数中抛出异常,且不指定第二个参数及第三个参数,则抛出该异常
  • error:可选,一个返回true或false的函数,用于控制是抛出在第一个参数值函数中指定抛出的异常还是抛出AssertionError异常,如果第二个参数值返回false,则抛出该异常
  • message:可选,自定义错误信息
js 复制代码
const assert = require('assert');
assert.doesNotThrow(()=>{
     let i = 1 / 0;
     console.log("I'm an error");
}, ()=>{return false});
复制代码
I'm an error

doesNotThrow方法的第二个参数值也可以为正则表达式的验证函数(regex.test函数)​,如果验证结果为假,则抛出第一个参数值函数中指定抛出的异常。

相关推荐
用户1558319968142 天前
用Node写一个文件同步CLI工具
node.js
李白的天不白2 天前
webpack 压缩文件
前端·webpack·node.js
zzzzzz3102 天前
AI Agent 开发实战:从零构建智能代码助手
react.js·node.js
donecoding2 天前
用了多年 nvm,我终于找到 Python 的版本管理「答案」:uv
python·node.js·前端工程化
南城雨落2 天前
uni-app开发经验分享-跨端开发经验总结
javascript·vue.js·node.js
子兮曰3 天前
Node.js v26.1.0 深度解读:FFI、后量子密码与调试器的进化
前端·后端·node.js
大家的林语冰3 天前
Node 2026 发布,JS 三大新功能上线,最后一个奇偶版本
前端·javascript·node.js
Aolith3 天前
从裸奔到加固:我的校园论坛网络安全实战
node.js·全栈
晓杰'4 天前
Balatro后端进阶(1):自定义NestJS WebSocket Adapter实现消息拦截
后端·websocket·typescript·node.js·游戏开发·nestjs·wsadapter
zyl837214 天前
Express快速上手
https·node.js·express