fleet/frontend/components/queries/QueryPageWrapper/QueryPageWrapper.tests.jsx
Zach Wasserman 0670db66c4
Migrate JS tests to Jest and update libraries (#74)
- Move from Mocha to Jest for JS testing (Jest seems to have better support for
 'watching' tests and a more active community these days).
- Codemod existing tests to Jest syntax (using https://github.com/skovhus/jest-codemods)
- Fix some errors in tests that were previously hidden.
- Update Babel.
2020-12-01 10:15:12 -08:00

54 lines
1.6 KiB
JavaScript

import { mount } from 'enzyme';
import nock from 'nock';
import { connectedComponent, reduxMockStore } from 'test/helpers';
import helpers from 'components/queries/QueryPageWrapper/helpers';
import QueryPageWrapper from 'components/queries/QueryPageWrapper';
import mocks from 'test/mocks';
const { queries: queryMocks } = mocks;
const bearerToken = 'abc123';
const storeWithoutQuery = {
entities: {
queries: {
data: {},
},
},
};
describe('QueryPageWrapper - component', () => {
beforeEach(() => {
global.localStorage.setItem('KOLIDE::auth_token', bearerToken);
});
afterEach(() => {
nock.cleanAll();
});
describe('/queries/:id', () => {
const queryID = '10';
const locationProp = { params: { id: queryID } };
it('dispatches an action to get the query when there is no query', () => {
queryMocks.load.valid(bearerToken, queryID);
const mockStore = reduxMockStore(storeWithoutQuery);
mount(connectedComponent(QueryPageWrapper, { mockStore, props: locationProp }));
const dispatchedActions = mockStore.getActions().map((action) => { return action.type; });
expect(dispatchedActions).toContainEqual('queries_LOAD_REQUEST');
});
it('calls the fetchQuery helper function', () => {
queryMocks.load.valid(bearerToken, queryID);
const fetchQuerySpy = jest.spyOn(helpers, 'fetchQuery');
const mockStore = reduxMockStore(storeWithoutQuery);
mount(connectedComponent(QueryPageWrapper, { mockStore, props: locationProp }));
expect(fetchQuerySpy).toHaveBeenCalled();
});
});
});