axios + axios-mock-adapter + redux-mock-store + redux-thunk +单元测试案例

问题描述

我正在为axios api编写测试。 这是我的方法

const getEmployees = () => (dispatch) => {
  dispatch(showLoader())
  console.log(' ------------ calling ------- ')
  return axios
    .get('http://localhost:4000/api/employees')
    .then((res) => {
      console.log(' ------------ calling ----success--- ')
      responseHandler(dispatch,res,getEmployeesAction)
      // dispatch(getEmployeesAction(res.data))
    })
    .catch((error) => {
      console.log(' ------------ calling ----failure--- ')
      apiErrorHandler(dispatch,error)
    })
}

和我的单元测试相同的方法

import configureMockStore from 'redux-mock-store'
import thunk from 'redux-thunk'
import axios from 'axios'
import MockAdapter from 'axios-mock-adapter'

import { getEmployees } from '../../api/employees.api'
import { getEmployeesAction } from '../../actions/employees.action'

const middlewares = [thunk]
const mockStore = configureMockStore(middlewares)
let store = mockStore({})
const mock = new MockAdapter(axios)

describe('In employees.api.js ',() => {
  beforeEach(() => {
    store.clearactions()
    mock.restore()
    // mock.reset()
    // mock.resetHistory()
  })

  it('fetches successfully employees',async () => {
    mock.onGet('http://localhost:4000/api/employees').reply(200,{
      response: {
        data: 'abcde'
      }
    })
    console.log(' === 1 --- ')
    store.dispatch(getEmployees()).then(() => {
      console.log(' ---- 2 ----- ')
      let expectedActions = [getEmployeesAction({ sample: 'sample data' })]
      expect(store.getActions()).toEqual(expectedActions)
    })
  })
})

在上述情况下,在测试文件中,在情况下没有控制台。它总是通过我添加的期望。我不确定thunk和axios的正确书写方式。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...