Commit c4ff2d70 authored by Scott Hampton's avatar Scott Hampton

Clean up `test_coverage_table_spec` file

Use more mock data in the test coverage table
spec file. Also refactor how we handle mock
apollo queries.
parent 0a45fdb9
export const defaultTestCoverageTable = {
allCoverageData: [],
allProjectsSelected: false,
hasError: false,
isLoading: false,
projectIds: {},
};
export const projects = [
{
fullPath: 'test/test',
name: 'test',
id: 1,
repository: {
rootRef: 'master',
},
codeCoveragePath: '#',
codeCoverageSummary: {
averageCoverage: '1.45',
coverageCount: '1',
lastUpdatedOn: '2021-01-30T20:34:14.302Z',
},
},
];
...@@ -3,9 +3,10 @@ import VueApollo from 'vue-apollo'; ...@@ -3,9 +3,10 @@ import VueApollo from 'vue-apollo';
import TestCoverageTable from 'ee/analytics/repository_analytics/components/test_coverage_table.vue'; import TestCoverageTable from 'ee/analytics/repository_analytics/components/test_coverage_table.vue';
import getGroupProjects from 'ee/analytics/repository_analytics/graphql/queries/get_group_projects.query.graphql'; import getGroupProjects from 'ee/analytics/repository_analytics/graphql/queries/get_group_projects.query.graphql';
import getProjectsTestCoverage from 'ee/analytics/repository_analytics/graphql/queries/get_projects_test_coverage.query.graphql'; import getProjectsTestCoverage from 'ee/analytics/repository_analytics/graphql/queries/get_projects_test_coverage.query.graphql';
import { useFakeDate } from 'helpers/fake_date';
import createMockApollo from 'helpers/mock_apollo_helper'; import createMockApollo from 'helpers/mock_apollo_helper';
import waitForPromises from 'helpers/wait_for_promises'; import waitForPromises from 'helpers/wait_for_promises';
import { getTimeago } from '~/lib/utils/datetime_utility';
import { defaultTestCoverageTable, projects } from './mock_data';
import Api from '~/api'; import Api from '~/api';
jest.mock('~/api.js'); jest.mock('~/api.js');
...@@ -13,9 +14,8 @@ jest.mock('~/api.js'); ...@@ -13,9 +14,8 @@ jest.mock('~/api.js');
const localVue = createLocalVue(); const localVue = createLocalVue();
describe('Test coverage table component', () => { describe('Test coverage table component', () => {
useFakeDate();
let wrapper; let wrapper;
let fakeApollo; const timeago = getTimeago();
const findEmptyState = () => wrapper.find('[data-testid="test-coverage-table-empty-state"]'); const findEmptyState = () => wrapper.find('[data-testid="test-coverage-table-empty-state"]');
const findLoadingState = () => wrapper.find('[data-testid="test-coverage-loading-state"'); const findLoadingState = () => wrapper.find('[data-testid="test-coverage-loading-state"');
...@@ -26,70 +26,32 @@ describe('Test coverage table component', () => { ...@@ -26,70 +26,32 @@ describe('Test coverage table component', () => {
const findProjectCountById = (id) => wrapper.find(`[data-testid="${id}-count"`); const findProjectCountById = (id) => wrapper.find(`[data-testid="${id}-count"`);
const findProjectDateById = (id) => wrapper.find(`[data-testid="${id}-date"`); const findProjectDateById = (id) => wrapper.find(`[data-testid="${id}-date"`);
const mockQueryDataNode = { const createMockApolloProvider = () => {
fullPath: 'test/test',
name: 'test',
id: 1,
repository: {
rootRef: 'master',
},
codeCoverageSummary: {
averageCoverage: '1.45',
coverageCount: '1',
lastUpdatedOn: new Date().toISOString(),
},
};
const createComponent = ({ data = {}, mountFn = shallowMount } = {}) => {
wrapper = mountFn(TestCoverageTable, {
localVue,
data() {
return {
allCoverageData: [],
allProjectsSelected: false,
hasError: false,
isLoading: false,
projectIds: {},
...data,
};
},
mocks: {
$apollo: {
queries: {
projects: {
query: jest.fn().mockResolvedValue(),
},
},
},
},
});
};
const createComponentWithApollo = ({
data = {},
mountFn = shallowMount,
queryData = {},
glFeatures = {},
} = {}) => {
localVue.use(VueApollo); localVue.use(VueApollo);
fakeApollo = createMockApollo([
return createMockApollo([
[getGroupProjects, jest.fn().mockResolvedValue()], [getGroupProjects, jest.fn().mockResolvedValue()],
[getProjectsTestCoverage, jest.fn().mockResolvedValue(queryData)], [
getProjectsTestCoverage,
jest.fn().mockResolvedValue({
data: { projects: { nodes: projects } },
}),
],
]); ]);
};
const createComponent = (options = {}) => {
const { glFeatures = {}, mockApollo, mockData = {}, mountFn = shallowMount } = options;
wrapper = mountFn(TestCoverageTable, { wrapper = mountFn(TestCoverageTable, {
localVue, localVue,
data() { data() {
return { return {
allCoverageData: [], ...defaultTestCoverageTable,
allProjectsSelected: false, ...mockData,
hasError: false,
isLoading: false,
projectIds: {},
...data,
}; };
}, },
apolloProvider: fakeApollo, apolloProvider: mockApollo,
provide: { provide: {
glFeatures, glFeatures,
}, },
...@@ -104,13 +66,14 @@ describe('Test coverage table component', () => { ...@@ -104,13 +66,14 @@ describe('Test coverage table component', () => {
describe('when code coverage is empty', () => { describe('when code coverage is empty', () => {
it('renders empty state', () => { it('renders empty state', () => {
createComponent(); createComponent();
expect(findEmptyState().exists()).toBe(true); expect(findEmptyState().exists()).toBe(true);
}); });
}); });
describe('when query is loading', () => { describe('when query is loading', () => {
it('renders loading state', () => { it('renders loading state', () => {
createComponent({ data: { isLoading: true } }); createComponent({ mockData: { isLoading: true } });
expect(findLoadingState().exists()).toBe(true); expect(findLoadingState().exists()).toBe(true);
}); });
...@@ -118,36 +81,15 @@ describe('Test coverage table component', () => { ...@@ -118,36 +81,15 @@ describe('Test coverage table component', () => {
describe('when code coverage is available', () => { describe('when code coverage is available', () => {
it('renders coverage table', () => { it('renders coverage table', () => {
const fullPath = 'gitlab-org/gitlab'; const {
const id = 'gid://gitlab/Project/1'; id,
const name = 'GitLab'; name,
const rootRef = 'master'; codeCoverageSummary: { averageCoverage, coverageCount, lastUpdatedOn },
const averageCoverage = '74.35'; } = projects[0];
const coverageCount = '5';
const yesterday = new Date();
yesterday.setDate(yesterday.getDate() - 1);
createComponent({ createComponent({
data: { mockData: {
allCoverageData: [ allCoverageData: projects,
{ projectIds: { [id]: true },
fullPath,
id,
name,
repository: {
rootRef,
},
codeCoveragePath: '#',
codeCoverageSummary: {
averageCoverage,
coverageCount,
lastUpdatedOn: yesterday.toISOString(),
},
},
],
projectIds: {
[id]: true,
},
}, },
mountFn: mount, mountFn: mount,
}); });
...@@ -156,35 +98,35 @@ describe('Test coverage table component', () => { ...@@ -156,35 +98,35 @@ describe('Test coverage table component', () => {
expect(findProjectNameById(id).text()).toBe(name); expect(findProjectNameById(id).text()).toBe(name);
expect(findProjectAverageById(id).text()).toBe(`${averageCoverage}%`); expect(findProjectAverageById(id).text()).toBe(`${averageCoverage}%`);
expect(findProjectCountById(id).text()).toBe(coverageCount); expect(findProjectCountById(id).text()).toBe(coverageCount);
expect(findProjectDateById(id).text()).toBe('1 day ago'); expect(findProjectDateById(id).text()).toBe(timeago.format(lastUpdatedOn));
}); });
it('sorts the table by the most recently updated report', () => { it('sorts the table by the most recently updated report', () => {
const today = new Date(); const project = projects[0];
const yesterday = new Date(); const today = '2021-01-30T20:34:14.302Z';
yesterday.setDate(yesterday.getDate() - 1); const yesterday = '2021-01-29T20:34:14.302Z';
const allCoverageData = [
{
...mockQueryDataNode,
name: 'should be last',
codeCoverageSummary: {
...mockQueryDataNode.codeCoverageSummary,
lastUpdatedOn: yesterday.toISOString(),
},
},
{
...mockQueryDataNode,
name: 'should be first',
id: 2,
codeCoverageSummary: {
...mockQueryDataNode.codeCoverageSummary,
lastUpdatedOn: today.toISOString(),
},
},
];
createComponent({ createComponent({
data: { mockData: {
allCoverageData, allCoverageData: [
{
...project,
name: 'should be last',
id: 1,
codeCoverageSummary: {
...project.codeCoverageSummary,
lastUpdatedOn: yesterday,
},
},
{
...project,
name: 'should be first',
id: 2,
codeCoverageSummary: {
...project.codeCoverageSummary,
lastUpdatedOn: today,
},
},
],
projectIds: { projectIds: {
1: true, 1: true,
2: true, 2: true,
...@@ -199,32 +141,22 @@ describe('Test coverage table component', () => { ...@@ -199,32 +141,22 @@ describe('Test coverage table component', () => {
}); });
it('renders the correct link', async () => { it('renders the correct link', async () => {
const id = 1; const {
const fullPath = 'test/test'; id,
const rootRef = 'master'; fullPath,
repository: { rootRef },
} = projects[0];
const expectedPath = `/${fullPath}/-/graphs/${rootRef}/charts`; const expectedPath = `/${fullPath}/-/graphs/${rootRef}/charts`;
createComponentWithApollo({ createComponent({
data: { mockApollo: createMockApolloProvider(),
mockData: {
projectIds: { [id]: true }, projectIds: { [id]: true },
}, },
queryData: {
data: {
projects: {
nodes: [
{
...mockQueryDataNode,
fullPath,
id,
repository: {
rootRef,
},
},
],
},
},
},
mountFn: mount, mountFn: mount,
}); });
// We have to wait for apollo to make the mock query and fill the table before
// we can click on the project link inside the table. Neither `runOnlyPendingTimers`
// nor `waitForPromises` work on their own to accomplish this.
jest.runOnlyPendingTimers(); jest.runOnlyPendingTimers();
await waitForPromises(); await waitForPromises();
...@@ -235,25 +167,14 @@ describe('Test coverage table component', () => { ...@@ -235,25 +167,14 @@ describe('Test coverage table component', () => {
describe('with usage metrics', () => { describe('with usage metrics', () => {
describe('with :usageDataITestingGroupCodeCoverageProjectClickTotal enabled', () => { describe('with :usageDataITestingGroupCodeCoverageProjectClickTotal enabled', () => {
it('tracks i_testing_group_code_coverage_project_click_total metric', async () => { it('tracks i_testing_group_code_coverage_project_click_total metric', async () => {
const id = 1; const { id } = projects[0];
createComponentWithApollo({ createComponent({
data: { glFeatures: { usageDataITestingGroupCodeCoverageProjectClickTotal: true },
mockApollo: createMockApolloProvider(),
mockData: {
projectIds: { [id]: true }, projectIds: { [id]: true },
}, },
queryData: {
data: {
projects: {
nodes: [
{
...mockQueryDataNode,
id,
},
],
},
},
},
mountFn: mount, mountFn: mount,
glFeatures: { usageDataITestingGroupCodeCoverageProjectClickTotal: true },
}); });
// We have to wait for apollo to make the mock query and fill the table before // We have to wait for apollo to make the mock query and fill the table before
// we can click on the project link inside the table. Neither `runOnlyPendingTimers` // we can click on the project link inside the table. Neither `runOnlyPendingTimers`
...@@ -271,25 +192,14 @@ describe('Test coverage table component', () => { ...@@ -271,25 +192,14 @@ describe('Test coverage table component', () => {
describe('with :usageDataITestingGroupCodeCoverageProjectClickTotal disabled', () => { describe('with :usageDataITestingGroupCodeCoverageProjectClickTotal disabled', () => {
it('does not track i_testing_group_code_coverage_project_click_total metric', async () => { it('does not track i_testing_group_code_coverage_project_click_total metric', async () => {
const id = 1; const { id } = projects[0];
createComponentWithApollo({ createComponent({
data: { glFeatures: { usageDataITestingGroupCodeCoverageProjectClickTotal: false },
mockApollo: createMockApolloProvider(),
mockData: {
projectIds: { [id]: true }, projectIds: { [id]: true },
}, },
queryData: {
data: {
projects: {
nodes: [
{
...mockQueryDataNode,
id,
},
],
},
},
},
mountFn: mount, mountFn: mount,
glFeatures: { usageDataITestingGroupCodeCoverageProjectClickTotal: false },
}); });
// We have to wait for apollo to make the mock query and fill the table before // We have to wait for apollo to make the mock query and fill the table before
// we can click on the project link inside the table. Neither `runOnlyPendingTimers` // we can click on the project link inside the table. Neither `runOnlyPendingTimers`
...@@ -303,33 +213,4 @@ describe('Test coverage table component', () => { ...@@ -303,33 +213,4 @@ describe('Test coverage table component', () => {
}); });
}); });
}); });
describe('when selected project has no coverage', () => {
it('does not render the table', async () => {
const id = 1;
createComponentWithApollo({
data: {
projectIds: { [id]: true },
},
queryData: {
data: {
projects: {
nodes: [
{
...mockQueryDataNode,
id,
codeCoverageSummary: null,
},
],
},
},
},
mountFn: mount,
});
jest.runOnlyPendingTimers();
await waitForPromises();
expect(findTable().exists()).toBe(false);
});
});
}); });
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment