首页 > 解决方案 > 测试使用 Immutable.js 更改多个属性的 reducer

问题描述

我正在尝试将 React/Redux 应用程序迁移到Immutable.JS并有关于测试的问题。

给定一个做这样的事情的减速器:

export default (state = initialState, action) => {
  switch (action.type) {

  case RUN_ENDED:
    return state.set('isRunning', false)
                .set('roundResult', action.data)
  default:
   return state
}

我想测试这两个属性是否已正确设置。

我的旧测试看起来像这样:

it('should handle the RUN_ENDED action', () => {

  const action = {
    type: RUN_ENDED,
    data: {
      winnerId: 0
    }
  }

  const result = simulatorReducer(undefined, action)

  expect(result).to.deep.equal({
    isRunning: false,
    roundResult: action.data
  })

})

对于 Immutable,我似乎无法以完全相同的方式进行这些比较。我可以明确地检查每个值resultresult.get('theProperty')但如果我有 5-6 个值,这似乎有点费力。

有什么方法可以用 Immutable 做到这一点吗?

标签: testingreduximmutable.js

解决方案


你可以使用https://www.npmjs.com/package/jest-immutable-matchers

例如: expect(result).toEqualImmutable(Immutable.Map({isRunning: false, ...}));


推荐阅读