-
Notifications
You must be signed in to change notification settings - Fork 8.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[Lens] Fix context formula functions (#172710)
## Summary Fix #170762 https://github.com/elastic/kibana/assets/315764/f5b50ffa-4a03-45ee-bc7a-2f2aca7fa3bd ### Checklist - [x] [Unit or functional tests](https://www.elastic.co/guide/en/kibana/master/development-tests.html) were updated or added to match the most common scenarios --------- Co-authored-by: Kibana Machine <[email protected]>
- Loading branch information
1 parent
d79f191
commit 99763dc
Showing
23 changed files
with
264 additions
and
171 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
1 change: 1 addition & 0 deletions
1
src/plugins/data/common/search/expressions/__snapshots__/kibana.test.ts.snap
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
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
91 changes: 91 additions & 0 deletions
91
x-pack/plugins/lens/common/expressions/formula_context/context_fns.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,91 @@ | ||
/* | ||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one | ||
* or more contributor license agreements. Licensed under the Elastic License | ||
* 2.0; you may not use this file except in compliance with the Elastic License | ||
* 2.0. | ||
*/ | ||
|
||
import { ExecutionContext } from '@kbn/expressions-plugin/common'; | ||
import { Adapters } from '@kbn/inspector-plugin/common'; | ||
import { formulaIntervalFn, formulaNowFn, formulaTimeRangeFn } from './context_fns'; | ||
|
||
describe('interval', () => { | ||
it('should return 0 if no time range available', () => { | ||
// (not sure if this case is actually possible) | ||
const result = formulaIntervalFn.fn(undefined, { targetBars: 100 }, { | ||
getSearchContext: () => ({ | ||
/* no time range */ | ||
}), | ||
} as ExecutionContext<Adapters>); | ||
expect(result).toEqual(0); | ||
}); | ||
|
||
it('should return 0 if no targetBars is passed', () => { | ||
const result = formulaIntervalFn.fn( | ||
undefined, | ||
{ | ||
/* no targetBars */ | ||
}, | ||
{ | ||
getSearchContext: () => ({ | ||
timeRange: { | ||
from: 'now-15m', | ||
to: 'now', | ||
}, | ||
}), | ||
} as ExecutionContext<Adapters> | ||
); | ||
expect(result).toEqual(0); | ||
}); | ||
|
||
it('should return a valid value > 0 if both timeRange and targetBars is passed', () => { | ||
const result = formulaIntervalFn.fn(undefined, { targetBars: 100 }, { | ||
getSearchContext: () => ({ | ||
timeRange: { | ||
from: 'now-15m', | ||
to: 'now', | ||
}, | ||
}), | ||
} as ExecutionContext<Adapters>); | ||
expect(result).toEqual(10000); | ||
}); | ||
}); | ||
|
||
describe('time range', () => { | ||
it('should return 0 if no time range is available', () => { | ||
// (not sure if this case is actually possible) | ||
const result = formulaTimeRangeFn.fn(undefined, {}, { | ||
getSearchContext: () => ({ | ||
/* no time range */ | ||
}), | ||
} as ExecutionContext<Adapters>); | ||
expect(result).toEqual(0); | ||
}); | ||
|
||
it('should return a valid value > 0 if time range is available', () => { | ||
const result = formulaTimeRangeFn.fn(undefined, {}, { | ||
getSearchContext: () => ({ | ||
timeRange: { | ||
from: 'now-15m', | ||
to: 'now', | ||
}, | ||
now: 1000000, // important to provide this to make the result consistent | ||
}), | ||
} as ExecutionContext<Adapters>); | ||
|
||
expect(result).toBe(900000); | ||
}); | ||
}); | ||
|
||
describe('now', () => { | ||
it('should return the now value when passed', () => { | ||
const now = 123456789; | ||
expect( | ||
formulaNowFn.fn(undefined, {}, { | ||
getSearchContext: () => ({ | ||
now, | ||
}), | ||
} as ExecutionContext<Adapters>) | ||
).toEqual(now); | ||
}); | ||
}); |
97 changes: 97 additions & 0 deletions
97
x-pack/plugins/lens/common/expressions/formula_context/context_fns.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,97 @@ | ||
/* | ||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one | ||
* or more contributor license agreements. Licensed under the Elastic License | ||
* 2.0; you may not use this file except in compliance with the Elastic License | ||
* 2.0. | ||
*/ | ||
|
||
import { getAbsoluteTimeRange, calcAutoIntervalNear } from '@kbn/data-plugin/common'; | ||
import type { TimeRange } from '@kbn/es-query'; | ||
import type { ExpressionFunctionDefinition } from '@kbn/expressions-plugin/common'; | ||
import moment from 'moment'; | ||
import { i18n } from '@kbn/i18n'; | ||
|
||
export type ExpressionFunctionFormulaTimeRange = ExpressionFunctionDefinition< | ||
'formula_time_range', | ||
undefined, | ||
object, | ||
number | ||
>; | ||
|
||
const getTimeRangeAsNumber = (timeRange: TimeRange | undefined, now: number | undefined) => { | ||
if (!timeRange) return 0; | ||
const absoluteTimeRange = getAbsoluteTimeRange( | ||
timeRange, | ||
now != null ? { forceNow: new Date(now) } : {} | ||
); | ||
return timeRange ? moment(absoluteTimeRange.to).diff(moment(absoluteTimeRange.from)) : 0; | ||
}; | ||
|
||
export const formulaTimeRangeFn: ExpressionFunctionFormulaTimeRange = { | ||
name: 'formula_time_range', | ||
|
||
help: i18n.translate('xpack.lens.formula.timeRange.help', { | ||
defaultMessage: 'The specified time range, in milliseconds (ms).', | ||
}), | ||
|
||
args: {}, | ||
|
||
fn(_input, _args, { getSearchContext }) { | ||
const { timeRange, now } = getSearchContext(); | ||
return getTimeRangeAsNumber(timeRange, now); | ||
}, | ||
}; | ||
|
||
export type ExpressionFunctionFormulaInterval = ExpressionFunctionDefinition< | ||
'formula_interval', | ||
undefined, | ||
{ | ||
targetBars?: number; | ||
}, | ||
number | ||
>; | ||
|
||
export const formulaIntervalFn: ExpressionFunctionFormulaInterval = { | ||
name: 'formula_interval', | ||
|
||
help: i18n.translate('xpack.lens.formula.interval.help', { | ||
defaultMessage: 'The specified minimum interval for the date histogram, in milliseconds (ms).', | ||
}), | ||
|
||
args: { | ||
targetBars: { | ||
types: ['number'], | ||
help: i18n.translate('xpack.lens.formula.interval.targetBars.help', { | ||
defaultMessage: 'The target number of bars for the date histogram.', | ||
}), | ||
}, | ||
}, | ||
|
||
fn(_input, args, { getSearchContext }) { | ||
const { timeRange, now } = getSearchContext(); | ||
return timeRange && args.targetBars | ||
? calcAutoIntervalNear(args.targetBars, getTimeRangeAsNumber(timeRange, now)).asMilliseconds() | ||
: 0; | ||
}, | ||
}; | ||
|
||
export type ExpressionFunctionFormulaNow = ExpressionFunctionDefinition< | ||
'formula_now', | ||
undefined, | ||
object, | ||
number | ||
>; | ||
|
||
export const formulaNowFn: ExpressionFunctionFormulaNow = { | ||
name: 'formula_now', | ||
|
||
help: i18n.translate('xpack.lens.formula.now.help', { | ||
defaultMessage: 'The current now moment used in Kibana expressed in milliseconds (ms).', | ||
}), | ||
|
||
args: {}, | ||
|
||
fn(_input, _args, { getSearchContext }) { | ||
return getSearchContext().now ?? Date.now(); | ||
}, | ||
}; |
8 changes: 8 additions & 0 deletions
8
x-pack/plugins/lens/common/expressions/formula_context/index.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,8 @@ | ||
/* | ||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one | ||
* or more contributor license agreements. Licensed under the Elastic License | ||
* 2.0; you may not use this file except in compliance with the Elastic License | ||
* 2.0. | ||
*/ | ||
|
||
export * from './context_fns'; |
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.