assert.notDeepEqual(actual, expected[, message])
严格断言模式
assert.notDeepStrictEqual() 的别名。
【An alias of assert.notDeepStrictEqual().】
遗留断言模式
稳定性: 3 - 传统:请改用
assert.notDeepStrictEqual()。测试任何深层不平等。与assert.deepEqual()相反。
【Tests for any deep inequality. Opposite of assert.deepEqual().】
import assert from 'node:assert';
const obj1 = {
a: {
b: 1,
},
};
const obj2 = {
a: {
b: 2,
},
};
const obj3 = {
a: {
b: 1,
},
};
const obj4 = Object.create(obj1);
assert.notDeepEqual(obj1, obj1);
// AssertionError: { a: { b: 1 } } notDeepEqual { a: { b: 1 } }
assert.notDeepEqual(obj1, obj2);
// OK
assert.notDeepEqual(obj1, obj3);
// AssertionError: { a: { b: 1 } } notDeepEqual { a: { b: 1 } }
assert.notDeepEqual(obj1, obj4);
// OKconst assert = require('node:assert');
const obj1 = {
a: {
b: 1,
},
};
const obj2 = {
a: {
b: 2,
},
};
const obj3 = {
a: {
b: 1,
},
};
const obj4 = Object.create(obj1);
assert.notDeepEqual(obj1, obj1);
// AssertionError: { a: { b: 1 } } notDeepEqual { a: { b: 1 } }
assert.notDeepEqual(obj1, obj2);
// OK
assert.notDeepEqual(obj1, obj3);
// AssertionError: { a: { b: 1 } } notDeepEqual { a: { b: 1 } }
assert.notDeepEqual(obj1, obj4);
// OK如果值是深度相等的,将抛出一个 AssertionError,其 message 属性设置为 message 参数的值。如果 message 参数未定义,将分配一个默认的错误消息。如果 message 参数是 Error 的一个实例,那么将抛出该实例,而不是 AssertionError。
【If the values are deeply equal, an AssertionError is thrown with a
message property set equal to the value of the message parameter. If the
message parameter is undefined, a default error message is assigned. If the
message parameter is an instance of an Error then it will be thrown
instead of the AssertionError.】