-
Notifications
You must be signed in to change notification settings - Fork 8.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Lens] Visualization validation and better error messages #81439
Changes from 8 commits
1bed7c0
bb93701
0aea6c5
d389d85
4c48b23
91a700a
b1d71dd
be2312d
c64603a
8e77401
64a22ef
7089b2f
86cc058
4e0c179
6672302
ee80a6b
f1127f4
95f9daf
ce7f857
d88d55d
694757b
0277aa5
822a23e
957bd98
7bfabd1
2fd7a90
4464285
e039c4f
a84fad2
d06f099
135c40d
b12a320
9f5d951
f984d5d
5e265ae
4b3c36a
c7fdd61
d0bce6b
cb0214e
d3fabc2
6c27723
9437162
4ac3bd8
6798112
8d31435
97dc1ae
33b71fa
0a0f5d3
37dca5a
fa32b19
1a440a9
cdb7054
11caf4a
8ccd1d4
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -115,4 +115,9 @@ export const metricVisualization: Visualization<State> = { | |
removeDimension({ prevState }) { | ||
return { ...prevState, accessor: undefined }; | ||
}, | ||
|
||
getErrorMessage(state, frame) { | ||
// Is it possible to break it? | ||
return undefined; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm fine with requiring the function, but why There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The type system has a distinction between
|
||
}, | ||
}; |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
/* | ||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one | ||
* or more contributor license agreements. Licensed under the Elastic License; | ||
* you may not use this file except in compliance with the Elastic License. | ||
*/ | ||
|
||
import { pieVisualization } from './visualization'; | ||
import { PieVisualizationState } from './types'; | ||
import { createMockDatasource, createMockFramePublicAPI } from '../editor_frame_service/mocks'; | ||
import { DatasourcePublicAPI, FramePublicAPI } from '../types'; | ||
|
||
jest.mock('../id_generator'); | ||
|
||
const LAYER_ID = 'l1'; | ||
|
||
function exampleState(): PieVisualizationState { | ||
return { | ||
shape: 'pie', | ||
layers: [ | ||
{ | ||
layerId: LAYER_ID, | ||
groups: [], | ||
metric: undefined, | ||
numberDisplay: 'percent', | ||
categoryDisplay: 'default', | ||
legendDisplay: 'default', | ||
nestedLegend: false, | ||
}, | ||
], | ||
}; | ||
} | ||
|
||
function mockFrame(): FramePublicAPI { | ||
return { | ||
...createMockFramePublicAPI(), | ||
addNewLayer: () => LAYER_ID, | ||
datasourceLayers: { | ||
[LAYER_ID]: createMockDatasource(LAYER_ID).publicAPIMock, | ||
}, | ||
}; | ||
} | ||
|
||
// Just a basic bootstrap here to kickstart the tests | ||
describe('pie_visualization', () => { | ||
describe('#getErrorMessage', () => { | ||
it('returns undefined if no error is raised', () => { | ||
const datasource: DatasourcePublicAPI = { | ||
...createMockDatasource('l1').publicAPIMock, | ||
getOperationForColumnId(_: string) { | ||
return { | ||
id: 'a', | ||
dataType: 'number', | ||
isBucketed: false, | ||
label: 'shazm', | ||
}; | ||
}, | ||
}; | ||
const frame = { | ||
...mockFrame(), | ||
datasourceLayers: { l1: datasource }, | ||
}; | ||
|
||
const error = pieVisualization.getErrorMessage(exampleState(), frame); | ||
|
||
expect(error).not.toBeDefined(); | ||
}); | ||
}); | ||
}); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't like the way this message is presented for anything but error messages. I would strongly prefer that we split this into 3 states, not 2:
2b. Error state with expanded details