ass*_*ler 9 javascript testing reactjs jestjs redux
我正在使用jest进行测试.我正在使用react和redux,我有这个动作:
function getData(id, notify) {
return (dispatch, ...) => {
dispatch(anotherFunction());
Promise.all(['resource1', 'resource2', 'resource3'])
.then(([response1,response2,response3]) => {
... handle responses
})
.catch(error => { dispatch(handleError(error)); }
};
}
Run Code Online (Sandbox Code Playgroud)
我一直在寻找如何为此操作设置测试的jest文档,但我无法找到方法.我尝试过这样的事情:
it('test description', (done) => {
const expectedActions = [{type: {...}, payload: {...}},{type: {...}, payload: {...}},...];
fetchMock.get('resource1', ...);
fetchMock.get('resource2', ...);
fetchMock.get('resource3', ...);
... then the rest of the test calls
});
Run Code Online (Sandbox Code Playgroud)
不成功.那我该怎么办呢?
要使用,Promise.all
您可以执行以下操作
test('Testing Stuff', async (done) => {
const expectedActions = [{ foo: {...}, bar: {...} }, { foo: {...}, bar: {...} }];
// we pass the index to this function
const asyncCall = async (index) => {
// check some stuff
expect(somestuff).toBe(someOtherStuff);
// await the actual stuff
const response = await doStuff( expectedActions[index] );
// check the result of our stuff
expect(response).toBe(awesome);
return response;
};
// we put all the asyncCalls we want into Promise.all
const responses = await Promise.all([
asyncCall(0),
asyncCall(1),
...,
asyncCall(n),
]);
// this is redundant in this case, but wth
expect(responses).toEqual(awesome);
done();
});
Run Code Online (Sandbox Code Playgroud)
您可以通过在回调中返回 Promise 来告诉 Jest 等待 Promise 解决。请参阅此处的本节以获取更多信息。
it('should fetch some food', () => {
const fetchItem1 = () => fetchData1().then(data => {
expect(data).toBe('peanut butter');
})
const fetchItem2 = () => fetchData2().then(data => {
expect(data).toBe('boiled egg');
})
const fetchItem3 = () => fetchData3().then(data => {
expect(data).toBe('fried salad');
})
return Promise.all([fetchItem1(), fetchItem2(), fetchItem3()])
.then(() => runOtherTests());
});
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
4162 次 |
最近记录: |