219

jasmine.js 中有没有办法检查两个数组是否相等,例如:

arr = [1, 2, 3]
expect(arr).toBe([1, 2, 3])
expect(arr).toEqual([1, 2, 3])

两者似乎都不起作用。

4

4 回答 4

360

刚刚做了测试,它适用于toEqual

请找到我的测试:

http://jsfiddle.net/7q9N7/3/

describe('toEqual', function() {
    it('passes if arrays are equal', function() {
        var arr = [1, 2, 3];
        expect(arr).toEqual([1, 2, 3]);
    });
});

仅供参考:

toBe() 与 toEqual():toEqual() 检查等价性。另一方面,toBe() 确保它们是完全相同的对象。

于 2013-03-30T11:25:35.530 回答
1

You can compare an array like the below mentioned if the array has some values

it('should check if the array are equal', function() {
        var mockArr = [1, 2, 3];
        expect(mockArr ).toEqual([1, 2, 3]);
 });

But if the array that is returned from some function has more than 1 elements and all are zero then verify by using

expect(mockArray[0]).toBe(0);
于 2019-08-01T04:30:14.627 回答
-2

只是为了记录,您可以随时使用 JSON.stringify 进行比较

const arr = [1,2,3]; expect(JSON.stringify(arr)).toBe(JSON.stringify([1,2,3])); expect(JSON.stringify(arr)).toEqual(JSON.stringify([1,2,3]));

It's all meter of taste, this will also work for complex literal objects

于 2018-10-25T09:25:28.387 回答
-4

我有一个类似的问题,其中一个数组被修改了。我将它用于$httpBackend,从中返回的对象实际上是一个$promise包含数组的对象(不是Array对象)。

您可以通过创建一个toBeArray函数来创建一个茉莉花匹配器来匹配数组:

beforeEach(function() {
  'use strict';
  this.addMatchers({
    toBeArray: function(array) {
      this.message = function() {
        return "Expected " + angular.mock.dump(this.actual) + " to be array " + angular.mock.dump(array) + ".";
      };
      var arraysAreSame = function(x, y) {
         var arraysAreSame = true;
         for(var i; i < x.length; i++)
            if(x[i] !== y[i])
               arraysAreSame = false;
         return arraysAreSame;
      };
      return arraysAreSame(this.actual, array);
    }
  });
});

然后就像其他茉莉花匹配器一样在您的测试中使用它:

it('should compare arrays properly', function() {
  var array1, array2;
  /* . . . */
  expect(array1[0]).toBe(array2[0]);
  expect(array1).toBeArray(array2);
});
于 2014-10-22T08:20:55.277 回答