From d4a6bc03f2620ca1ab917e2f86f160deba60e64c Mon Sep 17 00:00:00 2001 From: Bartlomiej Plotka Date: Sun, 7 Jan 2024 19:59:20 +0100 Subject: [PATCH] Merge pull request #13371 from kevinmingtarja/fix-isHeatmapData ui: fix handling of scalar and string in isHeatmapData --- .../src/pages/graph/DataTable.test.tsx | 4 +- .../react-app/src/pages/graph/DataTable.tsx | 2 +- .../pages/graph/GraphHeatmapHelpers.test.ts | 66 +++++++++++++++++++ .../src/pages/graph/GraphHeatmapHelpers.ts | 8 ++- 4 files changed, 74 insertions(+), 6 deletions(-) create mode 100644 web/ui/react-app/src/pages/graph/GraphHeatmapHelpers.test.ts diff --git a/web/ui/react-app/src/pages/graph/DataTable.test.tsx b/web/ui/react-app/src/pages/graph/DataTable.test.tsx index d6974cf906..1252b5bfcf 100755 --- a/web/ui/react-app/src/pages/graph/DataTable.test.tsx +++ b/web/ui/react-app/src/pages/graph/DataTable.test.tsx @@ -338,7 +338,7 @@ describe('DataTable', () => { const dataTableProps: DataTableProps = { data: { resultType: 'string', - result: 'string', + result: [1572098246.599, 'test'], }, useLocalTime: false, }; @@ -346,7 +346,7 @@ describe('DataTable', () => { it('renders a string row', () => { const table = dataTable.find(Table); const rows = table.find('tr'); - expect(rows.text()).toEqual('stringt'); + expect(rows.text()).toEqual('stringtest'); }); }); }); diff --git a/web/ui/react-app/src/pages/graph/DataTable.tsx b/web/ui/react-app/src/pages/graph/DataTable.tsx index 901d7bb48d..1885c7a80f 100644 --- a/web/ui/react-app/src/pages/graph/DataTable.tsx +++ b/web/ui/react-app/src/pages/graph/DataTable.tsx @@ -24,7 +24,7 @@ export interface DataTableProps { } | { resultType: 'string'; - result: string; + result: SampleValue; }; useLocalTime: boolean; } diff --git a/web/ui/react-app/src/pages/graph/GraphHeatmapHelpers.test.ts b/web/ui/react-app/src/pages/graph/GraphHeatmapHelpers.test.ts new file mode 100644 index 0000000000..26c44be68b --- /dev/null +++ b/web/ui/react-app/src/pages/graph/GraphHeatmapHelpers.test.ts @@ -0,0 +1,66 @@ +import { DataTableProps } from './DataTable'; +import { isHeatmapData } from './GraphHeatmapHelpers'; + +describe('GraphHeatmapHelpers', () => { + it('isHeatmapData should return false for scalar and string resultType', () => { + let data = { + resultType: 'scalar', + result: [1703091180.125, '1703091180.125'], + } as DataTableProps['data']; + expect(isHeatmapData(data)).toBe(false); + + data = { + resultType: 'string', + result: [1704305680.332, '2504'], + } as DataTableProps['data']; + expect(isHeatmapData(data)).toBe(false); + }); + + it('isHeatmapData should return false for a vector and matrix if length < 2', () => { + let data = { + resultType: 'vector', + result: [ + { + metric: { + __name__: 'my_gauge', + job: 'target', + }, + value: [1703091180.683, '6'], + }, + ], + } as DataTableProps['data']; + expect(isHeatmapData(data)).toBe(false); + + data = { + resultType: 'matrix', + result: [ + { + metric: {}, + values: [[1703091180.683, '6']], + }, + ], + } as DataTableProps['data']; + expect(isHeatmapData(data)).toBe(false); + }); + + it('isHeatmapData should return true for valid heatmap data', () => { + const data = { + resultType: 'matrix', + result: [ + { + metric: { + le: '100', + }, + values: [[1703091180.683, '6']], + }, + { + metric: { + le: '1000', + }, + values: [[1703091190.683, '6.1']], + }, + ], + } as DataTableProps['data']; + expect(isHeatmapData(data)).toBe(true); + }); +}); diff --git a/web/ui/react-app/src/pages/graph/GraphHeatmapHelpers.ts b/web/ui/react-app/src/pages/graph/GraphHeatmapHelpers.ts index d564959cb8..d8b249c308 100644 --- a/web/ui/react-app/src/pages/graph/GraphHeatmapHelpers.ts +++ b/web/ui/react-app/src/pages/graph/GraphHeatmapHelpers.ts @@ -1,10 +1,12 @@ +import { DataTableProps } from './DataTable'; import { GraphProps, GraphSeries } from './Graph'; -export function isHeatmapData(data: GraphProps['data']) { - if (!data?.result?.length || data?.result?.length < 2) { +export function isHeatmapData(data: DataTableProps['data']) { + if (data?.resultType === 'scalar' || data?.resultType === 'string' || !data?.result?.length || data?.result?.length < 2) { return false; } - const result = data.result; + // Type assertion to prevent TS2349 error. + const result = data.result as GraphProps['data']['result']; const firstLabels = Object.keys(result[0].metric).filter((label) => label !== 'le'); return result.every(({ metric }) => { const labels = Object.keys(metric).filter((label) => label !== 'le');