forked from elastic/kibana
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[Maps] Support categorical styling for numbers and dates (elastic#57908)
- Loading branch information
1 parent
88d21df
commit 87c05d9
Showing
18 changed files
with
320 additions
and
183 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
82 changes: 82 additions & 0 deletions
82
x-pack/legacy/plugins/maps/public/layers/sources/es_agg_source.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,82 @@ | ||
/* | ||
* 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 { AbstractESAggSource } from './es_agg_source'; | ||
import { IField } from '../fields/field'; | ||
import { IESAggField } from '../fields/es_agg_field'; | ||
import _ from 'lodash'; | ||
import { AGG_TYPE } from '../../../common/constants'; | ||
import { AggDescriptor } from '../../../common/descriptor_types'; | ||
|
||
jest.mock('ui/new_platform'); | ||
|
||
const sumFieldName = 'myFieldGettingSummed'; | ||
const metricExamples = [ | ||
{ | ||
type: AGG_TYPE.SUM, | ||
field: sumFieldName, | ||
label: 'my custom label', | ||
}, | ||
{ | ||
// metric config is invalid beause field is missing | ||
type: AGG_TYPE.MAX, | ||
}, | ||
{ | ||
// metric config is valid because "count" metric does not need to provide field | ||
type: AGG_TYPE.COUNT, | ||
label: '', // should ignore empty label fields | ||
}, | ||
]; | ||
|
||
class TestESAggSource extends AbstractESAggSource { | ||
constructor(metrics: AggDescriptor[]) { | ||
super({ type: 'test', id: 'foobar', indexPatternId: 'foobarid', metrics }, []); | ||
} | ||
} | ||
|
||
describe('getMetricFields', () => { | ||
it('should add default "count" metric when no metrics are provided', async () => { | ||
const source = new TestESAggSource([]); | ||
const metrics = source.getMetricFields(); | ||
expect(metrics.length).toBe(1); | ||
|
||
expect(metrics[0].getName()).toEqual('doc_count'); | ||
expect(await metrics[0].getLabel()).toEqual('count'); | ||
}); | ||
|
||
it('should remove incomplete metric configurations', async () => { | ||
const source = new TestESAggSource(metricExamples); | ||
const metrics = source.getMetricFields(); | ||
expect(metrics.length).toBe(2); | ||
|
||
expect(metrics[0].getRootName()).toEqual(sumFieldName); | ||
expect(metrics[0].getName()).toEqual('sum_of_myFieldGettingSummed'); | ||
expect(await metrics[0].getLabel()).toEqual('my custom label'); | ||
|
||
expect(metrics[1].getName()).toEqual('doc_count'); | ||
expect(await metrics[1].getLabel()).toEqual('count'); | ||
}); | ||
|
||
it('getMetrics should be identical to getFields', async () => { | ||
const source = new TestESAggSource(metricExamples); | ||
const metrics = source.getMetricFields(); | ||
const fields = await source.getFields(); | ||
|
||
const getFieldMeta = async (field: IField) => { | ||
const esAggField = field as IESAggField; // this ensures we can downcast correctly. | ||
return { | ||
name: esAggField.getName(), | ||
label: await esAggField.getLabel(), | ||
esDoc: esAggField.getRootName(), | ||
}; | ||
}; | ||
|
||
const metricsFieldMeta = await Promise.all(metrics.map(getFieldMeta)); | ||
const fieldsFieldMeta = await Promise.all(fields.map(getFieldMeta)); | ||
|
||
expect(_.isEqual(metricsFieldMeta, fieldsFieldMeta)).toEqual(true); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
41 changes: 41 additions & 0 deletions
41
...k/legacy/plugins/maps/public/layers/sources/es_geo_grid_source/es_geo_grid_source.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
/* | ||
* 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. | ||
*/ | ||
jest.mock('../../../kibana_services', () => {}); | ||
jest.mock('ui/new_platform'); | ||
|
||
import { ESGeoGridSource } from './es_geo_grid_source'; | ||
import { ES_GEO_GRID, GRID_RESOLUTION, RENDER_AS } from '../../../../common/constants'; | ||
|
||
describe('ESGeoGridSource', () => { | ||
const geogridSource = new ESGeoGridSource( | ||
{ | ||
id: 'foobar', | ||
indexPatternId: 'fooIp', | ||
geoField: 'bar', | ||
metrics: [], | ||
resolution: GRID_RESOLUTION.COARSE, | ||
type: ES_GEO_GRID, | ||
requestType: RENDER_AS.HEATMAP, | ||
}, | ||
{} | ||
); | ||
|
||
describe('getGridResolution', () => { | ||
it('should echo gridResoltuion', () => { | ||
expect(geogridSource.getGridResolution()).toBe(GRID_RESOLUTION.COARSE); | ||
}); | ||
}); | ||
|
||
describe('getGeoGridPrecision', () => { | ||
it('should clamp geo-grid derived zoom to max geotile level supported by ES', () => { | ||
expect(geogridSource.getGeoGridPrecision(29)).toBe(29); | ||
}); | ||
|
||
it('should use heuristic to derive precision', () => { | ||
expect(geogridSource.getGeoGridPrecision(10)).toBe(12); | ||
}); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.