2020-06-23 00:09:42 +05:30
|
|
|
import MockAdapter from 'axios-mock-adapter';
|
|
|
|
import { shallowMount } from '@vue/test-utils';
|
2020-10-24 23:57:45 +05:30
|
|
|
import { GlAlert, GlIcon, GlDeprecatedDropdown, GlDeprecatedDropdownItem } from '@gitlab/ui';
|
2020-06-23 00:09:42 +05:30
|
|
|
import { GlAreaChart } from '@gitlab/ui/dist/charts';
|
|
|
|
|
2020-10-24 23:57:45 +05:30
|
|
|
import waitForPromises from 'helpers/wait_for_promises';
|
2020-06-23 00:09:42 +05:30
|
|
|
import axios from '~/lib/utils/axios_utils';
|
|
|
|
import CodeCoverage from '~/pages/projects/graphs/components/code_coverage.vue';
|
2020-07-28 23:09:34 +05:30
|
|
|
import { codeCoverageMockData, sortedDataByDates } from './mock_data';
|
2020-06-23 00:09:42 +05:30
|
|
|
import httpStatusCodes from '~/lib/utils/http_status';
|
|
|
|
|
|
|
|
describe('Code Coverage', () => {
|
|
|
|
let wrapper;
|
|
|
|
let mockAxios;
|
|
|
|
|
|
|
|
const graphEndpoint = '/graph';
|
|
|
|
|
|
|
|
const findAlert = () => wrapper.find(GlAlert);
|
|
|
|
const findAreaChart = () => wrapper.find(GlAreaChart);
|
2020-10-24 23:57:45 +05:30
|
|
|
const findAllDropdownItems = () => wrapper.findAll(GlDeprecatedDropdownItem);
|
2020-06-23 00:09:42 +05:30
|
|
|
const findFirstDropdownItem = () => findAllDropdownItems().at(0);
|
|
|
|
const findSecondDropdownItem = () => findAllDropdownItems().at(1);
|
|
|
|
|
|
|
|
const createComponent = () => {
|
|
|
|
wrapper = shallowMount(CodeCoverage, {
|
|
|
|
propsData: {
|
|
|
|
graphEndpoint,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
wrapper.destroy();
|
|
|
|
wrapper = null;
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when fetching data is successful', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
mockAxios = new MockAdapter(axios);
|
|
|
|
mockAxios.onGet().replyOnce(httpStatusCodes.OK, codeCoverageMockData);
|
|
|
|
|
|
|
|
createComponent();
|
|
|
|
|
|
|
|
return waitForPromises();
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
mockAxios.restore();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders the area chart', () => {
|
|
|
|
expect(findAreaChart().exists()).toBe(true);
|
|
|
|
});
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
it('sorts the dates in ascending order', () => {
|
|
|
|
expect(wrapper.vm.sortedData).toEqual(sortedDataByDates);
|
|
|
|
});
|
|
|
|
|
2020-06-23 00:09:42 +05:30
|
|
|
it('matches the snapshot', () => {
|
|
|
|
expect(wrapper.element).toMatchSnapshot();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('shows no error messages', () => {
|
|
|
|
expect(findAlert().exists()).toBe(false);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when fetching data fails', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
mockAxios = new MockAdapter(axios);
|
|
|
|
mockAxios.onGet().replyOnce(httpStatusCodes.BAD_REQUEST);
|
|
|
|
|
|
|
|
createComponent();
|
|
|
|
|
|
|
|
return waitForPromises();
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
mockAxios.restore();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders an error message', () => {
|
|
|
|
expect(findAlert().exists()).toBe(true);
|
|
|
|
expect(findAlert().attributes().variant).toBe('danger');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('still renders an empty graph', () => {
|
|
|
|
expect(findAreaChart().exists()).toBe(true);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when fetching data succeed but returns an empty state', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
mockAxios = new MockAdapter(axios);
|
|
|
|
mockAxios.onGet().replyOnce(httpStatusCodes.OK, []);
|
|
|
|
|
|
|
|
createComponent();
|
|
|
|
|
|
|
|
return waitForPromises();
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
mockAxios.restore();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders an information message', () => {
|
|
|
|
expect(findAlert().exists()).toBe(true);
|
|
|
|
expect(findAlert().attributes().variant).toBe('info');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('still renders an empty graph', () => {
|
|
|
|
expect(findAreaChart().exists()).toBe(true);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('dropdown options', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
mockAxios = new MockAdapter(axios);
|
|
|
|
mockAxios.onGet().replyOnce(httpStatusCodes.OK, codeCoverageMockData);
|
|
|
|
|
|
|
|
createComponent();
|
|
|
|
|
|
|
|
return waitForPromises();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders the dropdown with all custom names as options', () => {
|
2020-10-24 23:57:45 +05:30
|
|
|
expect(wrapper.contains(GlDeprecatedDropdown)).toBeDefined();
|
2020-06-23 00:09:42 +05:30
|
|
|
expect(findAllDropdownItems()).toHaveLength(codeCoverageMockData.length);
|
|
|
|
expect(findFirstDropdownItem().text()).toBe(codeCoverageMockData[0].group_name);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('interactions', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
mockAxios = new MockAdapter(axios);
|
|
|
|
mockAxios.onGet().replyOnce(httpStatusCodes.OK, codeCoverageMockData);
|
|
|
|
|
|
|
|
createComponent();
|
|
|
|
|
|
|
|
return waitForPromises();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('updates the selected dropdown option with an icon', async () => {
|
|
|
|
findSecondDropdownItem().vm.$emit('click');
|
|
|
|
|
|
|
|
await wrapper.vm.$nextTick();
|
|
|
|
|
|
|
|
expect(
|
|
|
|
findFirstDropdownItem()
|
|
|
|
.find(GlIcon)
|
|
|
|
.exists(),
|
|
|
|
).toBe(false);
|
|
|
|
expect(findSecondDropdownItem().contains(GlIcon)).toBe(true);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('updates the graph data when selecting a different option in dropdown', async () => {
|
|
|
|
const originalSelectedData = wrapper.vm.selectedDailyCoverage;
|
|
|
|
const expectedData = codeCoverageMockData[1];
|
|
|
|
|
|
|
|
findSecondDropdownItem().vm.$emit('click');
|
|
|
|
|
|
|
|
await wrapper.vm.$nextTick();
|
|
|
|
|
|
|
|
expect(wrapper.vm.selectedDailyCoverage).not.toBe(originalSelectedData);
|
|
|
|
expect(wrapper.vm.selectedDailyCoverage).toBe(expectedData);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|