Commit 8c91a769 authored by Ezekiel Kigbo's avatar Ezekiel Kigbo

Moves fetchTasksByTypeData request to actions

Updated specs to check that the correct error
message is displayed if the fetchTasksByTypeData
request fails.

Minor refactor specs
parent 101c9b24
<script> <script>
import { GlEmptyState, GlDaterangePicker, GlLoadingIcon } from '@gitlab/ui'; import { GlEmptyState, GlDaterangePicker, GlLoadingIcon } from '@gitlab/ui';
import { mapActions, mapState, mapGetters } from 'vuex'; import { mapActions, mapState, mapGetters } from 'vuex';
import { __ } from '~/locale';
import createFlash from '~/flash';
import { getDateInPast } from '~/lib/utils/datetime_utility'; import { getDateInPast } from '~/lib/utils/datetime_utility';
import { featureAccessLevel } from '~/pages/projects/shared/permissions/constants'; import { featureAccessLevel } from '~/pages/projects/shared/permissions/constants';
import glFeatureFlagsMixin from '~/vue_shared/mixins/gl_feature_flags_mixin'; import glFeatureFlagsMixin from '~/vue_shared/mixins/gl_feature_flags_mixin';
...@@ -110,23 +108,11 @@ export default { ...@@ -110,23 +108,11 @@ export default {
this.setCycleAnalyticsDataEndpoint(group.full_path); this.setCycleAnalyticsDataEndpoint(group.full_path);
this.setSelectedGroup(group); this.setSelectedGroup(group);
this.fetchCycleAnalyticsData(); this.fetchCycleAnalyticsData();
this.fetchGroupLabels(this.currentGroupPath)
.then(() => {
// TODO: Move this request into the `fetchCycleAnalyticsData` request, because we
// need to send the group labels, this request should fire after fetchGroupLablels is completed
// https://gitlab.com/gitlab-org/gitlab/merge_requests/18514
this.fetchTasksByTypeData();
})
.catch(err => {
createFlash(__('There was an error fetching data for the chart'));
throw err;
});
}, },
onProjectsSelect(projects) { onProjectsSelect(projects) {
const projectIds = projects.map(value => value.id); const projectIds = projects.map(value => value.id);
this.setSelectedProjects(projectIds); this.setSelectedProjects(projectIds);
this.fetchCycleAnalyticsData(); this.fetchCycleAnalyticsData();
this.fetchTasksByTypeData();
}, },
onStageSelect(stage) { onStageSelect(stage) {
this.hideCustomStageForm(); this.hideCustomStageForm();
......
...@@ -73,10 +73,12 @@ export const receiveCycleAnalyticsDataError = ({ commit }, { response }) => { ...@@ -73,10 +73,12 @@ export const receiveCycleAnalyticsDataError = ({ commit }, { response }) => {
export const fetchCycleAnalyticsData = ({ dispatch }) => { export const fetchCycleAnalyticsData = ({ dispatch }) => {
removeError(); removeError();
return dispatch('requestCycleAnalyticsData') return dispatch('requestCycleAnalyticsData')
.then(() => dispatch('fetchGroupLabels')) // fetch group label data .then(() => dispatch('fetchGroupLabels'))
.then(() => dispatch('fetchGroupStagesAndEvents')) // fetch stage data .then(() => dispatch('fetchGroupStagesAndEvents'))
.then(() => dispatch('fetchSummaryData')) // fetch summary data and stage medians .then(() => dispatch('fetchSummaryData'))
.then(() => dispatch('fetchTasksByTypeData'))
.then(() => dispatch('receiveCycleAnalyticsDataSuccess')) .then(() => dispatch('receiveCycleAnalyticsDataSuccess'))
.catch(error => dispatch('receiveCycleAnalyticsDataError', error)); .catch(error => dispatch('receiveCycleAnalyticsDataError', error));
}; };
...@@ -213,22 +215,23 @@ export const requestTasksByTypeData = ({ commit }) => commit(types.REQUEST_TASKS ...@@ -213,22 +215,23 @@ export const requestTasksByTypeData = ({ commit }) => commit(types.REQUEST_TASKS
export const fetchTasksByTypeData = ({ dispatch, state, getters }) => { export const fetchTasksByTypeData = ({ dispatch, state, getters }) => {
const endpoint = '/-/analytics/type_of_work/tasks_by_type'; const endpoint = '/-/analytics/type_of_work/tasks_by_type';
const { currentGroupPath } = getters; const {
currentGroupPath,
cycleAnalyticsRequestParams: { created_after, created_before, project_ids },
} = getters;
const { const {
tasksByType: { labelIds, subject }, tasksByType: { labelIds, subject },
selectedProjectIds,
startDate,
endDate,
} = state; } = state;
// dont request if we have no labels selected...for now // dont request if we have no labels selected...for now
if (labelIds.length) { if (labelIds.length) {
const params = { const params = {
group_id: currentGroupPath, group_id: currentGroupPath,
label_ids: `[${labelIds}]`, label_ids: `[${labelIds.join(',')}]`,
project_ids: selectedProjectIds || [], created_after,
created_after: dateFormat(startDate, dateFormats.isoDate), created_before,
created_before: dateFormat(endDate, dateFormats.isoDate), project_ids,
subject, subject,
}; };
......
...@@ -315,7 +315,7 @@ describe('Cycle Analytics component', () => { ...@@ -315,7 +315,7 @@ describe('Cycle Analytics component', () => {
fetchGroupLabels: { fetchGroupLabels: {
status: defaultStatus, status: defaultStatus,
endpoint: `/groups/${groupId}/-/labels`, endpoint: `/groups/${groupId}/-/labels`,
response: { ...mockData.groupLabels }, response: [...mockData.groupLabels],
}, },
fetchStageData: { fetchStageData: {
status: defaultStatus, status: defaultStatus,
...@@ -323,6 +323,11 @@ describe('Cycle Analytics component', () => { ...@@ -323,6 +323,11 @@ describe('Cycle Analytics component', () => {
endpoint: '/groups/foo/-/cycle_analytics/events/issue.json', endpoint: '/groups/foo/-/cycle_analytics/events/issue.json',
response: { ...mockData.issueEvents }, response: { ...mockData.issueEvents },
}, },
fetchTasksByTypeData: {
status: defaultStatus,
endpoint: '/-/analytics/type_of_work/tasks_by_type',
response: { ...mockData.tasksByTypeData },
},
...overrides, ...overrides,
}; };
...@@ -344,6 +349,13 @@ describe('Cycle Analytics component', () => { ...@@ -344,6 +349,13 @@ describe('Cycle Analytics component', () => {
}); });
const findFlashError = () => document.querySelector('.flash-container .flash-text'); const findFlashError = () => document.querySelector('.flash-container .flash-text');
const selectGroupAndFindError = msg => {
wrapper.vm.onGroupSelect(mockData.group);
return waitForPromises().then(() => {
expect(findFlashError().innerText.trim()).toEqual(msg);
});
};
it('will display an error if the fetchSummaryData request fails', () => { it('will display an error if the fetchSummaryData request fails', () => {
expect(findFlashError()).toBeNull(); expect(findFlashError()).toBeNull();
...@@ -356,14 +368,10 @@ describe('Cycle Analytics component', () => { ...@@ -356,14 +368,10 @@ describe('Cycle Analytics component', () => {
}, },
}); });
wrapper.vm.onGroupSelect(mockData.group); return selectGroupAndFindError(
return waitForPromises().then(() => {
expect(findFlashError().innerText.trim()).toEqual(
'There was an error while fetching cycle analytics summary data.', 'There was an error while fetching cycle analytics summary data.',
); );
}); });
});
it('will display an error if the fetchGroupLabels request fails', () => { it('will display an error if the fetchGroupLabels request fails', () => {
expect(findFlashError()).toBeNull(); expect(findFlashError()).toBeNull();
...@@ -375,14 +383,10 @@ describe('Cycle Analytics component', () => { ...@@ -375,14 +383,10 @@ describe('Cycle Analytics component', () => {
}, },
}); });
wrapper.vm.onGroupSelect(mockData.group); return selectGroupAndFindError(
return waitForPromises().then(() => {
expect(findFlashError().innerText.trim()).toEqual(
'There was an error fetching label data for the selected group', 'There was an error fetching label data for the selected group',
); );
}); });
});
it('will display an error if the fetchGroupStagesAndEvents request fails', () => { it('will display an error if the fetchGroupStagesAndEvents request fails', () => {
expect(findFlashError()).toBeNull(); expect(findFlashError()).toBeNull();
...@@ -395,13 +399,7 @@ describe('Cycle Analytics component', () => { ...@@ -395,13 +399,7 @@ describe('Cycle Analytics component', () => {
}, },
}); });
wrapper.vm.onGroupSelect(mockData.group); return selectGroupAndFindError('There was an error fetching cycle analytics stages.');
return waitForPromises().then(() => {
expect(findFlashError().innerText.trim()).toEqual(
'There was an error fetching cycle analytics stages.',
);
});
}); });
it('will display an error if the fetchStageData request fails', () => { it('will display an error if the fetchStageData request fails', () => {
...@@ -415,42 +413,21 @@ describe('Cycle Analytics component', () => { ...@@ -415,42 +413,21 @@ describe('Cycle Analytics component', () => {
}, },
}); });
wrapper.vm.onGroupSelect(mockData.group); return selectGroupAndFindError('There was an error fetching data for the selected stage');
return waitForPromises().then(() => {
expect(findFlashError().innerText.trim()).toEqual(
'There was an error fetching data for the selected stage',
);
});
}); });
it('will display an error if the fetchTasksByTypeData request fails', () => { it('will display an error if the fetchTasksByTypeData request fails', () => {
expect(findFlashError()).toBeNull(); expect(findFlashError()).toBeNull();
mock mockRequestCycleAnalyticsData({
.onGet('/groups/foo/-/labels') fetchTasksByTypeData: {
.replyOnce(httpStatusCodes.OK, [...mockData.groupLabels]) endPoint: '/-/analytics/type_of_work/tasks_by_type',
.onGet('/groups/foo/-/cycle_analytics') status: httpStatusCodes.BAD_REQUEST,
.replyOnce(httpStatusCodes.OK, { response: { response: { status: httpStatusCodes.BAD_REQUEST } },
...mockData.cycleAnalyticsData, },
response: { status: httpStatusCodes.OK },
})
.onGet('/groups/foo/-/cycle_analytics/events/issue.json')
.replyOnce(httpStatusCodes.OK, {
response: { events: mockData.issueEvents },
})
.onGet('/-/analytics/type_of_work/tasks_by_type')
.replyOnce(httpStatusCodes.BAD_REQUEST, {
response: { status: httpStatusCodes.BAD_REQUEST },
}); });
wrapper.vm.onGroupSelect(mockData.group); return selectGroupAndFindError('There was an error fetching data for the chart');
return waitForPromises().then(() => {
expect(findFlashError().innerText.trim()).toEqual(
'There was an error fetching data for the chart',
);
});
}); });
}); });
}); });
...@@ -17425,6 +17425,9 @@ msgstr "" ...@@ -17425,6 +17425,9 @@ msgstr ""
msgid "There was an error fetching data for the chart" msgid "There was an error fetching data for the chart"
msgstr "" msgstr ""
msgid "There was an error fetching data for the selected stage"
msgstr ""
msgid "There was an error fetching label data for the selected group" msgid "There was an error fetching label data for the selected group"
msgstr "" msgstr ""
......
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