我正在学习此处的 Redux 教程。
在我创建的应用程序中,我有一个具有副作用的操作,就像在调用 Date.now() 的 receivePosts 函数中显示的操作一样。
异步功能完成后会触发副作用。在我自己的应用程序中遵循此异步测试时。我得到的回复如下所示:
actual:
{
type: 'REQUEST_LEAGUE_SUCCESS',
receivedAt: 1453991947254,
league: 'Div 3',
resultsTable: [ [Object], [Object] ]
},
expected:
{
type: 'REQUEST_LEAGUE_SUCCESS',
league: 'Div 3',
receivedAt: 1453991947235,
resultsTable: [ [Object], [Object] ]
}
我的预期操作日期不等于实际操作的日期。在我的预期操作中,我有以下内容:
receivedAt: Date.now()
我的代码结构与 Redux 教程中的代码完全相同,除了我的动作创建器具有此副作用。
我的问题归结为:我如何处理这些副作用以使我的测试通过?
依赖于抓取当前时间的测试代码不是一个好主意。 你需要重写一些东西,以便你可以模拟或注入一个日期。 在(单元测试,如何编写可测试代码及其重要性)中执行此操作的一些很好的例子。该文章基于 C#,但相同的概念适用于此处。
你可以像这样模拟 Date.now() 函数:
describe('>>> Test Name', () => {
const literallyJustNow = Date.now();
const realDateNow = Date.now.bind(global.Date);
const dateNowStub = jest.fn(() => literallyJustNow);
beforeEach(() => {
global.Date.now = dateNowStub;
});
afterEach(() => {
global.Date.now = realDateNow;
});
it('... your tests ...', () => { ... });
});
我认为您需要在测试中建立一些容忍度,因为在调度操作和接收响应之间不可避免地会经过一些时间。即使你伪造了它,执行时间仍然会有差异。您实际如何执行此操作取决于您的断言库。