Node.js - assert.deepEqual() 函数



NodeJS assert.deepEqual() 函数将在其 actual 参数和 expected 参数上测试深度相等性。每当两个参数相似时,该函数都不会抛出 AssertionError。如果两个参数不相似,则它将向输出抛出 AssertionError。此函数是 assert.deepStrictEqaul() 函数的别名。

Node.js assert.deepEqual() 函数是 Node.js 的 assert 模块的内置函数。

语法

以下是 assert.deepEqual() 函数的语法Node.js -


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

参数

此函数接受三个参数。下面将对此进行描述。

  • actual − (必填) 将评估此参数中传入的值。该值可以是任何类型。
  • expected − (必填)此参数中传入的值将与 actual 值进行比较。该值可以是任何类型。
  • message − (可选) 字符串或错误类型可以作为输入传递给此参数。

返回值

如果 actual expected 都不匹配,则此函数将在终端上返回 AssertionError。

在下面的示例中,我们正在执行两个数字的加法和乘法并存储结果。然后,我们将 actual 结果和 expected ​​​​​​​结果传递给Node.js assert.deepEqual() 函数,并将文本传递给 message  参数。


const assert = require('assert');
var x = 10, y = 5, z = 6;
var add = x + z;
var mul = y * x;
assert.deepEqual(add, mul, 'Both the values are not similar');

输出

当我们编译并运行代码时,该函数会将 AssertionError 和消息抛出到输出中,因为 actual expected ​​​​​​​都不匹配。

assert.js:79
throw new AssertionError(obj);
^

AssertionError [ERR_ASSERTION]: Both the values are not similar
at Object.<anonymous> (/home/cg/root/639c16a06de3d/main.js:7:8)
at Module._compile (internal/modules/cjs/loader.js:702:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:713:10)
at Module.load (internal/modules/cjs/loader.js:612:32)
at tryModuleLoad (internal/modules/cjs/loader.js:551:12)
at Function.Module._load (internal/modules/cjs/loader.js:543:3)
at Function.Module.runMain (internal/modules/cjs/loader.js:744:10)
at startup (internal/bootstrap/node.js:238:19)
at bootstrapNodeJSCore (internal/bootstrap/node.js:572:3)

在下面的示例中,我们正在创建两个具有某些属性的对象。然后,我们将 actual 对象和 expected ​​​​​​​对象都传递给Node.js assert.deepEqual() 函数,并将文本传递给 message ​​​​​​​参数。


const assert = require('assert');
var obj1 = {'name': 'Jay', 'age': 21};
var obj2 = {'name': 'Vikram', 'age': 51};
assert.deepEqual(obj1, obj2, 'Both the objects are not identical');

输出

当我们编译并运行代码时,该函数会将 AssertionError 和消息抛出到输出中,因为 actual expected ​​​​​​​并不相同。

assert.js:79
throw new AssertionError(obj);
^

AssertionError [ERR_ASSERTION]: Both the objects are not identical
at Object.<anonymous> (/home/cg/root/639c16a06de3d/main.js:6:8)
at Module._compile (internal/modules/cjs/loader.js:702:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:713:10)
at Module.load (internal/modules/cjs/loader.js:612:32)
at tryModuleLoad (internal/modules/cjs/loader.js:551:12)
at Function.Module._load (internal/modules/cjs/loader.js:543:3)
at Function.Module.runMain (internal/modules/cjs/loader.js:744:10)
at startup (internal/bootstrap/node.js:238:19)
at bootstrapNodeJSCore (internal/bootstrap/node.js:572:3)

在下面的示例中,我们正在创建两个整数数组,并且两个数组都是相似的。然后,我们将两个数组作为 actual 数组和 expected ​​​​​​​数组传递给Node.js assert.deepEqual() 函数,并将文本传递给 message ​​​​​​​ 参数。


const assert = require('assert');
var array1 = [1, 2, 3, 4, 5];
var array2 = [1, 2, 3, 4, 5];
assert.deepEqual(array1, array2, 'Both the arrays identical');

输出

当我们编译并运行代码时,该函数不会向输出抛出任何 AssertionError,因为 actual expected ​​​​​​​都是相同的。相反;该函数不会向输出返回任何内容。

// Returns nothing