javascript - 使用 Jasmine toEqual 未定义预期对象

标签 javascript angularjs object jasmine

我创建了一个服务来屏蔽数据并编写了一个 Jasmine 测试来比较实际对象和预期对象。 当我运行测试时,我在从服务返回的 actual 对象上得到了 undefined 。虽然当我控制台记录它时 console.log(JSON.stringify(maskedData)); 定义了 maskedData

LOG LOG: '{"handle":"#######@#####.com","displayName":"####ane","iss":"####:###.###.##.#"}'
Expected undefined to equal <jasmine.objectContaining(Object({ handle: '#######@#####.com', displayName: '####ane' }))>.

问题:

为什么服务返回对象在测试中评估为未定义但在控制台日志中定义?

我确实认为这可能是一个异步错误,因此在测试期间出现未定义的值,但由于控制台记录该值有效,我不这么认为。

这是相关测试的要点:

const mockAddUserAction = {
    type: 'AddUser',
    payload: {
      handle: 'tedjane@five.com',
      displayName: 'tedJane',
      iss: 'http:192.168.12.1',
    },
  };

it('should mask PII user action.payload data with nested properties', async () => {
    const maskedData = service.maskPiiData(mockAddUserAction);
    console.log(JSON.stringify(maskedData));
    expect(maskedData.payload).toEqual(
      jasmine.objectContaining({
        handle: '#######@#####.com',
        displayName: '####ane',
      }),
    );
  });

最佳答案

expect 指令在服务返回结果之前被调用。您需要同步异步服务调用。尝试将 await 添加到您调用服务的行。

const maskedData = await service.maskPiiData(mockAddUserAction);

关于javascript - 使用 Jasmine toEqual 未定义预期对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58759227/

相关文章:

javascript - 仅显示一组 sibling 中的两个 <br>

javascript - 在单引号内返回 @Html.DropDownListFor 内的 ViewBag

javascript - 自定义 CSS 属性,为什么不呢?

javascript - Angular.js 动态构造指令的 templateURL

Java - 如何遍历 ArrayList 以添加元素?

Java缓存和平等

javascript - 通过可见性隐藏和显示元素 :hidden/visible

javascript - 动态更改 ng-repeat 元素的宽度

javascript - Twig 日期过滤器不起作用( Angular 问题?)

javascript - JS - 在函数中覆盖 'this'