Тестирование аксиальных звонков с помощью Sinon, Redx и Karma

Здравствуйте, в документации по избыточности для тестирования у них есть этот пример для проверки вызовов API:

import configureMockStore from 'redux-mock-store'
import thunk from 'redux-thunk'
import * as actions from '../../actions/counter'
import * as types from '../../constants/ActionTypes'
import nock from 'nock'

const middlewares = [ thunk ]
const mockStore = configureMockStore(middlewares)

describe('async actions', () => {
  afterEach(() => {
    nock.cleanAll()
  })

  it('creates FETCH_TODOS_SUCCESS when fetching todos has been done', (done) => {
    nock('http://example.com/')
      .get('/todos')
      .reply(200, { body: { todos: ['do something'] }})

    const expectedActions = [
      { type: types.FETCH_TODOS_REQUEST },
      { type: types.FETCH_TODOS_SUCCESS, body: { todos: ['do something']  } }
    ]
    const store = mockStore({ todos: [] }, expectedActions, done)
    store.dispatch(actions.fetchTodos())
  })
})

Я использую среду тестирования кармы и думаю, что не могу использовать nock для проверки этого. Поэтому я пытался проверить это с помощью Sinon. Проблема в том, что я не понимаю, как бы я мог это проверить, так как я не передаю обратный вызов в вызов функции API. Я использую axios для вызова моего внешнего API.

2 ответа

Для этого вам следует использовать axios-mock-adapter

Пример:

import MockAdapter from 'axios-mock-adapter';
import axios from 'axios';
import thunk from 'redux-thunk';
import configureMockStore from 'redux-mock-store';
import * as actionTypes from './userConstants';
import * as actions from './userActions';


const mockAxios = new MockAdapter(axios);
const mockStore = configureMockStore(middlewares);

describe('fetchCurrentUser', () => {
  afterEach(() => {
    mockAxios.reset();
  });

  context('when request succeeds', () => {
    it('dispatches FETCH_CURRENT_USER_SUCCESS', () => {
      mockAxios.onGet('/api/v1/user/current').reply(200, {});

      const expectedActions = [
        { type: actionTypes.SET_IS_FETCHING_CURRENT_USER },
        { type: actionTypes.FETCH_CURRENT_USER_SUCCESS, user: {} }
      ];

      const store = mockStore({ users: Map() });

      return store.dispatch(actions.fetchCurrentUser()).then(() =>
        expect(store.getActions()).to.eql(expectedActions)
      );
    });
  });

Я не эксперт по асинхронным действиям, так как в своем приложении я тестирую все эти вещи отдельно (создатель действий, API-вызовы с nock, насмехаясь над сервисом, асинхронное поведение благодаря saga, однако в коде RedDox выглядит так:

    const store = mockStore({ todos: [] })

    return store.dispatch(actions.fetchTodos())
      .then(() => { // return of async actions
        expect(store.getActions()).toEqual(expectedActions)
      })

Таким образом, диспетчер возвращает ваше асинхронное действие, и вы должны пройти тест в функции, которая будет выполнена, когда ваше асинхронное действие разрешится. Nock'ing конечная точка должна работать просто отлично.

Другие вопросы по тегам