171 lines
3.9 KiB
JavaScript
171 lines
3.9 KiB
JavaScript
import MockAdapter from 'axios-mock-adapter';
|
|
import testAction from 'helpers/vuex_action_helper';
|
|
import { TEST_HOST } from 'helpers/test_constants';
|
|
import axios from '~/lib/utils/axios_utils';
|
|
import {
|
|
setEndpoint,
|
|
requestReports,
|
|
fetchReports,
|
|
stopPolling,
|
|
clearEtagPoll,
|
|
receiveReportsSuccess,
|
|
receiveReportsError,
|
|
openModal,
|
|
setModalData,
|
|
} from '~/reports/store/actions';
|
|
import state from '~/reports/store/state';
|
|
import * as types from '~/reports/store/mutation_types';
|
|
|
|
describe('Reports Store Actions', () => {
|
|
let mockedState;
|
|
|
|
beforeEach(() => {
|
|
mockedState = state();
|
|
});
|
|
|
|
describe('setEndpoint', () => {
|
|
it('should commit SET_ENDPOINT mutation', done => {
|
|
testAction(
|
|
setEndpoint,
|
|
'endpoint.json',
|
|
mockedState,
|
|
[{ type: types.SET_ENDPOINT, payload: 'endpoint.json' }],
|
|
[],
|
|
done,
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('requestReports', () => {
|
|
it('should commit REQUEST_REPORTS mutation', done => {
|
|
testAction(requestReports, null, mockedState, [{ type: types.REQUEST_REPORTS }], [], done);
|
|
});
|
|
});
|
|
|
|
describe('fetchReports', () => {
|
|
let mock;
|
|
|
|
beforeEach(() => {
|
|
mockedState.endpoint = `${TEST_HOST}/endpoint.json`;
|
|
mock = new MockAdapter(axios);
|
|
});
|
|
|
|
afterEach(() => {
|
|
mock.restore();
|
|
stopPolling();
|
|
clearEtagPoll();
|
|
});
|
|
|
|
describe('success', () => {
|
|
it('dispatches requestReports and receiveReportsSuccess ', done => {
|
|
mock
|
|
.onGet(`${TEST_HOST}/endpoint.json`)
|
|
.replyOnce(200, { summary: {}, suites: [{ name: 'rspec' }] });
|
|
|
|
testAction(
|
|
fetchReports,
|
|
null,
|
|
mockedState,
|
|
[],
|
|
[
|
|
{
|
|
type: 'requestReports',
|
|
},
|
|
{
|
|
payload: { data: { summary: {}, suites: [{ name: 'rspec' }] }, status: 200 },
|
|
type: 'receiveReportsSuccess',
|
|
},
|
|
],
|
|
done,
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('error', () => {
|
|
beforeEach(() => {
|
|
mock.onGet(`${TEST_HOST}/endpoint.json`).reply(500);
|
|
});
|
|
|
|
it('dispatches requestReports and receiveReportsError ', done => {
|
|
testAction(
|
|
fetchReports,
|
|
null,
|
|
mockedState,
|
|
[],
|
|
[
|
|
{
|
|
type: 'requestReports',
|
|
},
|
|
{
|
|
type: 'receiveReportsError',
|
|
},
|
|
],
|
|
done,
|
|
);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('receiveReportsSuccess', () => {
|
|
it('should commit RECEIVE_REPORTS_SUCCESS mutation with 200', done => {
|
|
testAction(
|
|
receiveReportsSuccess,
|
|
{ data: { summary: {} }, status: 200 },
|
|
mockedState,
|
|
[{ type: types.RECEIVE_REPORTS_SUCCESS, payload: { summary: {} } }],
|
|
[],
|
|
done,
|
|
);
|
|
});
|
|
|
|
it('should not commit RECEIVE_REPORTS_SUCCESS mutation with 204', done => {
|
|
testAction(
|
|
receiveReportsSuccess,
|
|
{ data: { summary: {} }, status: 204 },
|
|
mockedState,
|
|
[],
|
|
[],
|
|
done,
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('receiveReportsError', () => {
|
|
it('should commit RECEIVE_REPORTS_ERROR mutation', done => {
|
|
testAction(
|
|
receiveReportsError,
|
|
null,
|
|
mockedState,
|
|
[{ type: types.RECEIVE_REPORTS_ERROR }],
|
|
[],
|
|
done,
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('openModal', () => {
|
|
it('should dispatch setModalData', done => {
|
|
testAction(
|
|
openModal,
|
|
{ name: 'foo' },
|
|
mockedState,
|
|
[],
|
|
[{ type: 'setModalData', payload: { name: 'foo' } }],
|
|
done,
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('setModalData', () => {
|
|
it('should commit SET_ISSUE_MODAL_DATA', done => {
|
|
testAction(
|
|
setModalData,
|
|
{ name: 'foo' },
|
|
mockedState,
|
|
[{ type: types.SET_ISSUE_MODAL_DATA, payload: { name: 'foo' } }],
|
|
[],
|
|
done,
|
|
);
|
|
});
|
|
});
|
|
});
|