Jasmine.js比较数组

2020/10/15 21:21 · javascript ·  · 0评论

jasmine.js中是否可以检查两个数组是否相等,例如:

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

似乎都不起作用。

刚刚进行了测试,它可以与 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()确保它们是完全相同的对象。

如果数组具有某些值,则可以像下面提到的那样比较数组

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

但是,如果从某个函数返回的数组具有多个元素,并且所有元素均为零,则使用

expect(mockArray[0]).toBe(0);

仅出于记录目的,您始终可以使用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]));

都是米的味道,这也适用于复杂的文字对象

我有一个类似的问题,其中一个数组被修改。我将其用于$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);
});
本文地址:http://javascript.askforanswer.com/jasmine-jsbijiaoshuzu.html
文章标签: ,  
版权声明:本文为原创文章,版权归 javascript 所有,欢迎分享本文,转载请保留出处!

文件下载

老薛主机终身7折优惠码boke112

上一篇:
下一篇:

评论已关闭!