2021-09-21 14:11:18 -04:00
|
|
|
import MockAdapter from 'axios-mock-adapter';
|
2021-09-15 14:11:29 -04:00
|
|
|
import testAction from 'helpers/vuex_action_helper';
|
2021-09-21 14:11:18 -04:00
|
|
|
import createFlash from '~/flash';
|
2021-09-15 14:11:29 -04:00
|
|
|
import * as actions from '~/header_search/store/actions';
|
|
|
|
import * as types from '~/header_search/store/mutation_types';
|
|
|
|
import createState from '~/header_search/store/state';
|
2021-09-21 14:11:18 -04:00
|
|
|
import axios from '~/lib/utils/axios_utils';
|
2021-11-22 16:10:35 -05:00
|
|
|
import { MOCK_SEARCH, MOCK_AUTOCOMPLETE_OPTIONS_RES } from '../mock_data';
|
2021-09-21 14:11:18 -04:00
|
|
|
|
|
|
|
jest.mock('~/flash');
|
2021-09-15 14:11:29 -04:00
|
|
|
|
|
|
|
describe('Header Search Store Actions', () => {
|
|
|
|
let state;
|
2021-09-21 14:11:18 -04:00
|
|
|
let mock;
|
|
|
|
|
|
|
|
const flashCallback = (callCount) => {
|
|
|
|
expect(createFlash).toHaveBeenCalledTimes(callCount);
|
|
|
|
createFlash.mockClear();
|
|
|
|
};
|
2021-09-15 14:11:29 -04:00
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
state = createState({});
|
2021-09-21 14:11:18 -04:00
|
|
|
mock = new MockAdapter(axios);
|
2021-09-15 14:11:29 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
state = null;
|
2021-09-21 14:11:18 -04:00
|
|
|
mock.restore();
|
|
|
|
});
|
|
|
|
|
|
|
|
describe.each`
|
2021-11-22 16:10:35 -05:00
|
|
|
axiosMock | type | expectedMutations | flashCallCount
|
|
|
|
${{ method: 'onGet', code: 200, res: MOCK_AUTOCOMPLETE_OPTIONS_RES }} | ${'success'} | ${[{ type: types.REQUEST_AUTOCOMPLETE }, { type: types.RECEIVE_AUTOCOMPLETE_SUCCESS, payload: MOCK_AUTOCOMPLETE_OPTIONS_RES }]} | ${0}
|
|
|
|
${{ method: 'onGet', code: 500, res: null }} | ${'error'} | ${[{ type: types.REQUEST_AUTOCOMPLETE }, { type: types.RECEIVE_AUTOCOMPLETE_ERROR }]} | ${1}
|
2021-09-21 14:11:18 -04:00
|
|
|
`('fetchAutocompleteOptions', ({ axiosMock, type, expectedMutations, flashCallCount }) => {
|
|
|
|
describe(`on ${type}`, () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
mock[axiosMock.method]().replyOnce(axiosMock.code, axiosMock.res);
|
|
|
|
});
|
|
|
|
it(`should dispatch the correct mutations`, () => {
|
|
|
|
return testAction({
|
|
|
|
action: actions.fetchAutocompleteOptions,
|
|
|
|
state,
|
|
|
|
expectedMutations,
|
|
|
|
}).then(() => flashCallback(flashCallCount));
|
|
|
|
});
|
|
|
|
});
|
2021-09-15 14:11:29 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
describe('setSearch', () => {
|
|
|
|
it('calls the SET_SEARCH mutation', () => {
|
|
|
|
return testAction({
|
|
|
|
action: actions.setSearch,
|
|
|
|
payload: MOCK_SEARCH,
|
|
|
|
state,
|
|
|
|
expectedMutations: [{ type: types.SET_SEARCH, payload: MOCK_SEARCH }],
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|