1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-01 00:08:27 +01:00

Fix: time to production (#7835) (#7848)

- filter out time to production data points of `0 days to production`
- allow for gathering data for quickly enabled feature flags
This commit is contained in:
Tymoteusz Czech 2024-08-13 10:43:55 +02:00 committed by GitHub
parent bf9ac497ab
commit 067d0b15c7
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 45 additions and 6 deletions

View File

@ -1,4 +1,4 @@
import { useMemo, type VFC } from 'react'; import { useMemo, type FC } from 'react';
import 'chartjs-adapter-date-fns'; import 'chartjs-adapter-date-fns';
import type { InstanceInsightsSchema } from 'openapi'; import type { InstanceInsightsSchema } from 'openapi';
import { import {
@ -21,7 +21,7 @@ interface ITimeToProductionChartProps {
isLoading?: boolean; isLoading?: boolean;
} }
export const TimeToProductionChart: VFC<ITimeToProductionChartProps> = ({ export const TimeToProductionChart: FC<ITimeToProductionChartProps> = ({
projectFlagTrends, projectFlagTrends,
isAggregate, isAggregate,
isLoading, isLoading,
@ -35,9 +35,20 @@ export const TimeToProductionChart: VFC<ITimeToProductionChartProps> = ({
[projectsDatasets, isLoading], [projectsDatasets, isLoading],
); );
const filteredProjectsDatasets = useMemo(
() => ({
...projectsDatasets,
datasets: projectsDatasets.datasets.map((dataset) => ({
...dataset,
data: dataset.data.filter((item) => item.timeToProduction),
})),
}),
[projectsDatasets],
);
const aggregatedPerDay = useMemo(() => { const aggregatedPerDay = useMemo(() => {
const result = medianTimeToProduction( const result = medianTimeToProduction(
Object.values(projectsDatasets.datasets).flatMap( Object.values(filteredProjectsDatasets.datasets).flatMap(
(item) => item.data, (item) => item.data,
), ),
); );
@ -60,9 +71,9 @@ export const TimeToProductionChart: VFC<ITimeToProductionChartProps> = ({
}, },
], ],
}; };
}, [JSON.stringify(projectsDatasets), theme]); }, [JSON.stringify(filteredProjectsDatasets), theme]);
const data = isAggregate ? aggregatedPerDay : projectsDatasets; const data = isAggregate ? aggregatedPerDay : filteredProjectsDatasets;
const placeholderData = usePlaceholderData(); const placeholderData = usePlaceholderData();
return ( return (
<LineChart <LineChart

View File

@ -23,4 +23,31 @@ describe('calculate average time to production', () => {
expect(timeToProduction).toBe(21); expect(timeToProduction).toBe(21);
}); });
test('should return more than 0 if feature was enabled almost instantly', () => {
const timeToProduction = calculateAverageTimeToProd([
{
created: new Date('2024-11-11T09:11:11.111Z'),
enabled: new Date('2024-11-11T09:11:11.112Z'),
},
{
created: new Date('2024-12-12T09:12:11.121Z'),
enabled: new Date('2024-12-12T09:12:12.122Z'),
},
]);
expect(timeToProduction).toBe(0.1);
});
test('should return more than 0 if feature was enabled instantly', () => {
const created = new Date('2024-11-11T09:11:11.111Z');
const timeToProduction = calculateAverageTimeToProd([
{
created,
enabled: created,
},
]);
expect(timeToProduction).toBe(0.1);
});
}); });

View File

@ -12,8 +12,9 @@ export const calculateAverageTimeToProd = (
const timeToProdPerFeature = calculateTimeToProdForFeatures(items); const timeToProdPerFeature = calculateTimeToProdForFeatures(items);
if (timeToProdPerFeature.length) { if (timeToProdPerFeature.length) {
const sum = timeToProdPerFeature.reduce((acc, curr) => acc + curr, 0); const sum = timeToProdPerFeature.reduce((acc, curr) => acc + curr, 0);
const avg = sum / Object.keys(items).length;
return Number((sum / Object.keys(items).length).toFixed(1)); return Number(avg.toFixed(1)) || 0.1;
} }
return 0; return 0;