javascript - 测试 jest 和 new Date()

标签 javascript jestjs

我正在尝试测试类似的功能:

function foo() {
    return {
        key_a: "val_a",
        key_b: new Date()
};

如何为这种情况制作预期的测试对象?

const expectedObject = {
    key_a: "val_a",
    key_b: new Date()
}
expect(foo()).toEqual(expectedObject)?
- Expected
+ Received
- "key_b": 2019-01-23T14:04:03.060Z,
+ "key_b": 2019-01-23T14:04:03.061Z,

最佳答案

对此有多种方法,许多在 this thread 中进行了讨论。 .

在这种情况下,最简单干净的方法可能是监视 Date 并使用 mockFn.mock.instances 获取从 new Date() 返回的内容像这样:

function foo() {
  return {
    key_a: "val_a",
    key_b: new Date()
  };
}

test('foo', () => {
  const spy = jest.spyOn(global, 'Date');  // spy on Date
  const result = foo();  // call foo
  const date = spy.mock.instances[0];  // get what 'new Date()' returned
  const expectedObject = {
    key_a: "val_a",
    key_b: date  // use the date in the expected object
  };
  expect(result).toEqual(expectedObject);  // SUCCESS
})

关于javascript - 测试 jest 和 new Date(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54329398/

相关文章:

javascript - 窗口.matchMedia ("(max-width: 1700px)");不起作用?

javascript - 如何过滤具有多个参数的javaScript数组

javascript - 如果未正确加载,则隐藏 iframe

javascript - 独立的 VUE 应用程序

javascript - 类型错误 : Cannot read property 'equal' of undefined

javascript - 重写 CSS 计算样式问题(错误的页面布局)

Reactjs - Jest 快照测试嵌套 redux "connected"组件

javascript - 编写测试以使用 jest 和 react-testing-library 检查本地 setState 调用

reactjs - 使用 Luxon : how do I mock . setZone ('local' 进行 Jest 单元测试

javascript - 检查使用包含 'synthetic event' 的对象调用的监视函数时, Jest 测试会导致 'currentTarget' 错误