使用Mocha进行Javascript测试时assert.equal和assert.deepEqual之间的区别?

时间:2012-11-05 02:37:15

标签: javascript arrays testing mocha

我正在使用Mocha来测试Express.js应用程序中的一个小模块。在这个模块中,我的一个函数返回一个数组。我想测试数组对于给定输入是否正确。我是这样做的:

suite('getWords', function(){
    test("getWords should return list of numbers", function() {
        var result = ['555', '867', '5309'];
        assert.equal(result, getWords('555-867-5309'));
    });
});

运行时,我收到以下断言错误:

AssertionError: ["555","867","5309"] == ["555","867","5309"]

但是,当我将测试更改为assert.deepEqual时,测试通过正常。我想知道这是== vs ===的情况,但如果我输入

[1,2,3] === [1,2,3]

进入node.js命令行,我仍然得到假。

为什么数组不能与其他值的比较(例如1 == 1)? assert.equal和assert.deepEqual之间有什么区别?

1 个答案:

答案 0 :(得分:134)

  

为什么数组不能与其他值的比较(例如1 == 1)

数字,字符串,布尔值,nullundefined是值,并按照您的预期进行比较。 1 == 1'a' == 'a',依此类推。在值的情况下=====之间的差异是==将首先尝试执行类型转换,这就是'1' == 1'1' === 1

另一方面,数组是对象。在这种情况下,=====并不表示操作数在语义上相等,而是引用同一个对象

  

assert.equal和assert.deepEqual之间有什么区别?

assert.equal的行为如上所述。如果参数为!=,它实际上会失败,您可以看到in the source。因此,对于数字字符串数组,它会失败,因为尽管它们本质上是等价的,但它们不是同一个对象。

另一方面,深度(又称结构)等式不测试操作数是否是同一个对象,而是它们是等价的。从某种意义上说,你可以说它强迫对象进行比较,就好像它们是价值一样。

var a = [1,2,3]  
var b = a              // As a and b both refer to the same object
a == b                 // this is true
a === b                // and this is also true

a = [1,2,3]            // here a and b have equivalent contents, but do not
b = [1,2,3]            // refer to the same Array object.
a == b                 // Thus this is false.

assert.deepEqual(a, b) // However this passes, as while a and b are not the 
                       // same object, they are still arrays containing 1, 2, 3

assert.deepEqual(1, 1) // Also passes when given equal values

var X = function() {}
a = new X
b = new X
a == b                 // false, not the same object
assert.deepEqual(a, b) // pass, both are unadorned X objects
b.foo = 'bar'
assert.deepEqual(a, b) // fail!