Commit d53a10aa authored by Ezekiel Kigbo's avatar Ezekiel Kigbo

Fetch duration data for active stages only

parent 3a47e385
...@@ -20,27 +20,23 @@ export const receiveDurationDataError = ({ commit }) => { ...@@ -20,27 +20,23 @@ export const receiveDurationDataError = ({ commit }) => {
createFlash(__('There was an error while fetching value stream analytics duration data.')); createFlash(__('There was an error while fetching value stream analytics duration data.'));
}; };
export const fetchDurationData = ({ dispatch, rootGetters, rootState }) => { export const fetchDurationData = ({ dispatch, rootGetters }) => {
dispatch('requestDurationData'); dispatch('requestDurationData');
const { const { cycleAnalyticsRequestParams, activeStages, currentGroupPath } = rootGetters;
stages,
selectedGroup: { fullPath },
} = rootState;
const { cycleAnalyticsRequestParams } = rootGetters;
return Promise.all( return Promise.all(
stages.map(stage => { activeStages.map(stage => {
const { slug } = stage; const { slug } = stage;
return Api.cycleAnalyticsDurationChart(fullPath, slug, cycleAnalyticsRequestParams).then( return Api.cycleAnalyticsDurationChart(
({ data }) => ({ currentGroupPath,
slug, slug,
selected: true, cycleAnalyticsRequestParams,
data, ).then(({ data }) => ({
}), slug,
); selected: true,
data,
}));
}), }),
) )
.then(data => dispatch('receiveDurationDataSuccess', data)) .then(data => dispatch('receiveDurationDataSuccess', data))
...@@ -56,23 +52,18 @@ export const receiveDurationMedianDataError = ({ commit }) => { ...@@ -56,23 +52,18 @@ export const receiveDurationMedianDataError = ({ commit }) => {
}; };
export const fetchDurationMedianData = ({ dispatch, rootState, rootGetters }) => { export const fetchDurationMedianData = ({ dispatch, rootState, rootGetters }) => {
const { const { startDate, endDate } = rootState;
stages, const { cycleAnalyticsRequestParams, activeStages, currentGroupPath } = rootGetters;
selectedGroup: { fullPath },
startDate,
endDate,
} = rootState;
const { cycleAnalyticsRequestParams } = rootGetters;
const offsetValue = getDayDifference(new Date(startDate), new Date(endDate)); const offsetValue = getDayDifference(new Date(startDate), new Date(endDate));
const offsetCreatedAfter = getDateInPast(new Date(startDate), offsetValue); const offsetCreatedAfter = getDateInPast(new Date(startDate), offsetValue);
const offsetCreatedBefore = getDateInPast(new Date(endDate), offsetValue); const offsetCreatedBefore = getDateInPast(new Date(endDate), offsetValue);
return Promise.all( return Promise.all(
stages.map(stage => { activeStages.map(stage => {
const { slug } = stage; const { slug } = stage;
return Api.cycleAnalyticsDurationChart(fullPath, slug, { return Api.cycleAnalyticsDurationChart(currentGroupPath, slug, {
...cycleAnalyticsRequestParams, ...cycleAnalyticsRequestParams,
created_after: dateFormat(offsetCreatedAfter, dateFormats.isoDate), created_after: dateFormat(offsetCreatedAfter, dateFormats.isoDate),
created_before: dateFormat(offsetCreatedBefore, dateFormats.isoDate), created_before: dateFormat(offsetCreatedBefore, dateFormats.isoDate),
......
...@@ -20,16 +20,23 @@ import { shouldFlashAMessage } from '../../../helpers'; ...@@ -20,16 +20,23 @@ import { shouldFlashAMessage } from '../../../helpers';
const selectedGroup = { fullPath: group.path }; const selectedGroup = { fullPath: group.path };
const [stage1, stage2] = stages; const [stage1, stage2] = stages;
const hiddenStage = { ...stage1, hidden: true, id: 3, slug: 3 };
const activeStages = [stage1, stage2];
const rootState = { const rootState = {
startDate, startDate,
endDate, endDate,
stages: [stage1, stage2], stages: [stage1, stage2, hiddenStage],
selectedGroup, selectedGroup,
featureFlags: { featureFlags: {
hasDurationChart: true, hasDurationChart: true,
hasDurationChartMedian: true, hasDurationChartMedian: true,
}, },
getters,
rootGetters: {
...rootGetters,
activeStages,
},
}; };
describe('DurationChart actions', () => { describe('DurationChart actions', () => {
...@@ -49,59 +56,54 @@ describe('DurationChart actions', () => { ...@@ -49,59 +56,54 @@ describe('DurationChart actions', () => {
mock.onGet(endpoints.durationData).reply(200, [...rawDurationData]); mock.onGet(endpoints.durationData).reply(200, [...rawDurationData]);
}); });
it("dispatches the 'receiveDurationDataSuccess' action on success", () => { it("dispatches the 'requestDurationData' and 'receiveDurationDataSuccess' actions on success", () => {
const dispatch = jest.fn(); return testAction(
actions.fetchDurationData,
return actions null,
.fetchDurationData({ { activeStages },
dispatch, [],
rootState, [
rootGetters, { type: 'requestDurationData' },
}) {
.then(() => { type: 'receiveDurationDataSuccess',
expect(dispatch).toHaveBeenCalledWith( payload: transformedDurationData,
'receiveDurationDataSuccess', },
transformedDurationData, ],
); );
});
}); });
it("dispatches the 'requestDurationData' action", () => { it('does not request hidden stages', () => {
const dispatch = jest.fn(); const dispatch = jest.fn();
return actions return actions
.fetchDurationData({ .fetchDurationData({
dispatch, dispatch,
rootState, ...rootState,
rootGetters,
}) })
.then(() => { .then(() => {
expect(dispatch).toHaveBeenNthCalledWith(1, 'requestDurationData'); const requestedUrls = mock.history.get.map(({ url }) => url);
expect(requestedUrls).not.toContain(
`/groups/foo/-/analytics/value_stream_analytics/stages/${hiddenStage.id}/duration_chart`,
);
}); });
}); });
it("dispatches the 'receiveDurationDataError' action when there is an error", () => { describe('receiveDurationDataError', () => {
const brokenRootState = { beforeEach(() => {
...rootState, mock.onGet(endpoints.durationData).reply(404);
stages: [ });
{
id: 'oops',
},
],
};
const dispatch = jest.fn();
return actions it("dispatches the 'receiveDurationDataError' action when there is an error", () => {
.fetchDurationData({ const dispatch = jest.fn();
dispatch,
getters, return actions
rootState: brokenRootState, .fetchDurationData({
rootGetters, dispatch,
}) ...rootState,
.then(() => { })
expect(dispatch).toHaveBeenCalledWith('receiveDurationDataError'); .then(() => {
}); expect(dispatch).toHaveBeenCalledWith('receiveDurationDataError');
});
});
}); });
}); });
...@@ -292,42 +294,41 @@ describe('DurationChart actions', () => { ...@@ -292,42 +294,41 @@ describe('DurationChart actions', () => {
}); });
it('dispatches the receiveDurationMedianDataSuccess action on success', () => { it('dispatches the receiveDurationMedianDataSuccess action on success', () => {
const dispatch = jest.fn(); return testAction(
actions.fetchDurationMedianData,
return actions null,
.fetchDurationMedianData({ { ...rootState, activeStages },
dispatch, [],
rootState, [
rootGetters,
})
.then(() => {
expect(dispatch).toHaveBeenCalledWith(
'receiveDurationMedianDataSuccess',
transformedDurationMedianData,
);
});
});
it('dispatches the receiveDurationMedianDataError action when there is an error', () => {
const brokenRootState = {
...rootState,
stages: [
{ {
id: 'oops', type: 'receiveDurationMedianDataSuccess',
payload: transformedDurationMedianData,
}, },
], ],
}; );
const dispatch = jest.fn(); });
return actions describe('receiveDurationMedianDataError', () => {
.fetchDurationMedianData({ beforeEach(() => {
dispatch, mock.onGet(endpoints.durationData).reply(404);
rootState: brokenRootState, });
rootGetters,
}) it('dispatches the receiveDurationMedianDataError action when there is an error', () => {
.then(() => { const dispatch = jest.fn();
expect(dispatch).toHaveBeenCalledWith('receiveDurationMedianDataError'); return actions
}); .fetchDurationMedianData({
dispatch,
rootState,
rootGetters: { activeStages },
})
.then(() => {
const requestedUrls = mock.history.get.map(({ url }) => url);
expect(requestedUrls).not.toContain(
`/groups/foo/-/analytics/value_stream_analytics/stages/${hiddenStage.id}/duration_chart`,
);
expect(dispatch).toHaveBeenCalledWith('receiveDurationMedianDataError');
});
});
}); });
}); });
......
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