【发布时间】:2016-09-19 15:40:02
【问题描述】:
我有一个 React 和 Redux 项目,我正在尝试使用 Chai 测试框架进行单元测试。现在我正在为我拥有的reducer 编写一个测试,这个reducer 处理的几个动作调用了辅助方法。这是一个例子:
formsReducer.js:
import * as types from '../constants/actionTypes';
import objectAssign from 'object-assign';
import initialState from './initialState';
import formsHelper from '../utils/FormsHelper';
export default function formsReducer(state = initialState.forms, action) {
switch (action.type) {
case types.UPDATE_PRODUCT: {
let formBlueprints = formsHelper.getFormsByProductId(action.product.id);
formBlueprints = formsHelper.addOrRemoveMnDisclosure(formBlueprints, action.stateOfResidence.id);
return objectAssign({}, state, {blueprints: formBlueprints, instances: []});
}
}
}
如您所见,如果我测试此方法,我也依赖 formsHelper.getFormsByProductId 和 formsHelper.addOrRemoveMnDisclosure 方法通过。我应该如何测试这个减速器/动作?当某个 product.id 传递给这些方法时,我是否应该制作一组可以从这些方法返回的单独测试数据?
【问题讨论】:
-
你不能嘲笑他们吗?
标签: javascript unit-testing redux