Commit ae0d4796 authored by Simon Knox's avatar Simon Knox

Merge branch '260388-sort-metrics-reports-in-widget' into 'master'

Sort changed metrics first in metrics reports MR widget

See merge request gitlab-org/gitlab!54729
parents 4379607b 2bb6b1c0
...@@ -26,12 +26,14 @@ Consider the following examples of data that can use Metrics Reports: ...@@ -26,12 +26,14 @@ Consider the following examples of data that can use Metrics Reports:
## How it works ## How it works
Metrics are read from the metrics report (default: `metrics.txt`). They are parsed and displayed in the MR widget. Metrics for a branch are read from the latest metrics report artifact (default filename: `metrics.txt`) as string values.
All values are considered strings and string compare is used to find differences between the latest available `metrics` artifact from: For an MR, the values of these metrics from the feature branch are compared to the values from the target branch. Then they are displayed in the MR widget in this order:
- `master` - Metrics that have been added by the MR. Marked with a **New** badge.
- The feature branch - Existing metrics with changed values.
- Existing metrics with unchanged values.
- Metrics that have been removed by the MR. Marked with a **Removed** badge.
## How to set it up ## How to set it up
......
...@@ -13,11 +13,14 @@ export default { ...@@ -13,11 +13,14 @@ export default {
state.isLoading = false; state.isLoading = false;
state.newMetrics = response.new_metrics || []; state.newMetrics = response.new_metrics || [];
state.existingMetrics = response.existing_metrics || []; state.existingMetrics = [
...(response.existing_metrics?.filter((metric) => metric?.previous_value) || []),
...(response.existing_metrics?.filter((metric) => !metric?.previous_value) || []),
];
state.removedMetrics = response.removed_metrics || []; state.removedMetrics = response.removed_metrics || [];
state.numberOfChanges = state.numberOfChanges =
state.existingMetrics.filter((metric) => metric.previous_value !== undefined).length + state.existingMetrics.filter((metric) => metric?.previous_value !== undefined).length +
state.newMetrics.length + state.newMetrics.length +
state.removedMetrics.length; state.removedMetrics.length;
}, },
......
---
title: Sort changed metrics first in metrics reports MR widget
merge_request: 54729
author:
type: changed
...@@ -37,12 +37,27 @@ describe('metrics reports mutations', () => { ...@@ -37,12 +37,27 @@ describe('metrics reports mutations', () => {
}; };
mutations[types.RECEIVE_METRICS_SUCCESS](mockState, data); mutations[types.RECEIVE_METRICS_SUCCESS](mockState, data);
expect(mockState.existingMetrics[0].name).toEqual(data.existing_metrics[0].name); expect(mockState.existingMetrics).toEqual(data.existing_metrics);
expect(mockState.existingMetrics[0].value).toEqual(data.existing_metrics[0].value);
expect(mockState.numberOfChanges).toEqual(0); expect(mockState.numberOfChanges).toEqual(0);
expect(mockState.isLoading).toEqual(false); expect(mockState.isLoading).toEqual(false);
}); });
it('should set metrics with a new metric', () => {
const data = {
new_metrics: [
{
name: 'name',
value: 'value',
},
],
};
mutations[types.RECEIVE_METRICS_SUCCESS](mockState, data);
expect(mockState.newMetrics).toEqual(data.new_metrics);
expect(mockState.numberOfChanges).toEqual(1);
expect(mockState.isLoading).toEqual(false);
});
it('should set metrics with one changes', () => { it('should set metrics with one changes', () => {
const data = { const data = {
existing_metrics: [ existing_metrics: [
...@@ -55,15 +70,38 @@ describe('metrics reports mutations', () => { ...@@ -55,15 +70,38 @@ describe('metrics reports mutations', () => {
}; };
mutations[types.RECEIVE_METRICS_SUCCESS](mockState, data); mutations[types.RECEIVE_METRICS_SUCCESS](mockState, data);
expect(mockState.existingMetrics[0].name).toEqual(data.existing_metrics[0].name); expect(mockState.existingMetrics).toEqual(data.existing_metrics);
expect(mockState.existingMetrics[0].value).toEqual(data.existing_metrics[0].value);
expect(mockState.existingMetrics[0].previous_value).toEqual(
data.existing_metrics[0].previous_value,
);
expect(mockState.numberOfChanges).toEqual(1); expect(mockState.numberOfChanges).toEqual(1);
expect(mockState.isLoading).toEqual(false); expect(mockState.isLoading).toEqual(false);
}); });
it('should put changed metrics before unchanged metrics', () => {
const unchangedMetrics = [
{
name: 'an unchanged metric',
value: 'one',
},
{
name: 'another unchanged metric metric',
value: 'four',
},
];
const changedMetric = {
name: 'changed metric',
value: 'two',
previous_value: 'three',
};
const data = {
existing_metrics: [unchangedMetrics[0], changedMetric, unchangedMetrics[1]],
};
mutations[types.RECEIVE_METRICS_SUCCESS](mockState, data);
expect(mockState.existingMetrics).toEqual([
changedMetric,
unchangedMetrics[0],
unchangedMetrics[1],
]);
});
}); });
describe('RECEIVE_METRICS_ERROR', () => { describe('RECEIVE_METRICS_ERROR', () => {
......
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