我正在尝试测试一个简单的减速器,它的日期属性设置为今天。
const today = new Date();
export const initialState = {
today
};
console.log(new Date().toDateString()); // <--- real date
export default function globalReducer(state = initialState, action) {
console.log(new Date().toDateString()); // <--- mocked date
switch (action.type) {
default:
return state;
}
}
用我的基本测试
import globalReducer from "./reducer";
describe("Global reducer", () => {
beforeAll(() => {
jest.useFakeTimers("modern");
jest.setSystemTime(new Date("2021-02-18"));
});
afterAll(() => {
jest.useRealTimers();
});
it("should return the mocked date", () => {
expect(globalReducer(undefined, {}).today).toEqual(new Date('2021-02-18'));
});
});
我注意到,mock 只在reducer 代码中起作用,但今天在其全局范围内总是返回真实日期而不是模拟日期。
如果我setSystemTime
在测试设置文件中调用,则today
正确模拟。
我在这里错过了什么吗?仅针对特定测试在全局范围内模拟日期的方法是什么?
如果您想查看https://github.com/dariospadoni/jestFakeTimersMock,这里有一个测试仓库
它发生的原因是因为在调用之前Date
实例化了。recucer.js
setSystemTime
这是一个如何避免这种情况的示例:
beforeAll(() => {
jest.setSystemTime(new Date("2021-02-18"));
});
describe("Global reducer", () => {
let globalReducer;
beforeAll(() => {
globalReducer = require("./reducer").default;
});
it("should return the mocked date", () => {
expect(globalReducer(undefined, {}).today).toEqual(new Date("2021-02-18"));
});
});
在这里,Date
一旦reducer.js
需要,对象将被实例化,这将是在setSystemTime
调用之后
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句