mirror of
https://github.com/grafana/grafana.git
synced 2025-02-12 16:45:43 -06:00
* Normalize alert state name for UI descriptor retrieval * Bring back alert state and metric values to annotation tooltip * Make sure alert state is only shown when present * Update test * Handle Error alerting satte
160 lines
4.2 KiB
TypeScript
160 lines
4.2 KiB
TypeScript
import { FieldType, toDataFrame } from '@grafana/data';
|
|
import { getAnnotationsFromData } from './standardAnnotationSupport';
|
|
|
|
describe('DataFrame to annotations', () => {
|
|
test('simple conversion', async () => {
|
|
const frame = toDataFrame({
|
|
fields: [
|
|
{ type: FieldType.time, values: [1, 2, 3, 4, 5] },
|
|
{ name: 'first string field', values: ['t1', 't2', 't3', null, undefined] },
|
|
{ name: 'tags', values: ['aaa,bbb', 'bbb,ccc', 'zyz', null, undefined] },
|
|
],
|
|
});
|
|
|
|
await expect(getAnnotationsFromData([frame])).toEmitValues([
|
|
[
|
|
{
|
|
color: 'red',
|
|
tags: ['aaa', 'bbb'],
|
|
text: 't1',
|
|
time: 1,
|
|
type: 'default',
|
|
},
|
|
{
|
|
color: 'red',
|
|
tags: ['bbb', 'ccc'],
|
|
text: 't2',
|
|
time: 2,
|
|
type: 'default',
|
|
},
|
|
{
|
|
color: 'red',
|
|
tags: ['zyz'],
|
|
text: 't3',
|
|
time: 3,
|
|
type: 'default',
|
|
},
|
|
{
|
|
color: 'red',
|
|
time: 4,
|
|
type: 'default',
|
|
},
|
|
{
|
|
color: 'red',
|
|
time: 5,
|
|
type: 'default',
|
|
},
|
|
],
|
|
]);
|
|
});
|
|
|
|
test('explicit mappins', async () => {
|
|
const frame = toDataFrame({
|
|
fields: [
|
|
{ name: 'time1', values: [111, 222, 333] },
|
|
{ name: 'time2', values: [100, 200, 300] },
|
|
{ name: 'aaaaa', values: ['a1', 'a2', 'a3'] },
|
|
{ name: 'bbbbb', values: ['b1', 'b2', 'b3'] },
|
|
],
|
|
});
|
|
|
|
const observable = getAnnotationsFromData([frame], {
|
|
text: { value: 'bbbbb' },
|
|
time: { value: 'time2' },
|
|
timeEnd: { value: 'time1' },
|
|
title: { value: 'aaaaa' },
|
|
});
|
|
|
|
await expect(observable).toEmitValues([
|
|
[
|
|
{
|
|
color: 'red',
|
|
text: 'b1',
|
|
time: 100,
|
|
timeEnd: 111,
|
|
title: 'a1',
|
|
type: 'default',
|
|
},
|
|
{
|
|
color: 'red',
|
|
text: 'b2',
|
|
time: 200,
|
|
timeEnd: 222,
|
|
title: 'a2',
|
|
type: 'default',
|
|
},
|
|
{
|
|
color: 'red',
|
|
text: 'b3',
|
|
time: 300,
|
|
timeEnd: 333,
|
|
title: 'a3',
|
|
type: 'default',
|
|
},
|
|
],
|
|
]);
|
|
});
|
|
|
|
it('all valid key names should be included in the output result', async () => {
|
|
const frame = toDataFrame({
|
|
fields: [
|
|
{ name: 'time', values: [100] },
|
|
{ name: 'timeEnd', values: [200] },
|
|
{ name: 'title', values: ['title'] },
|
|
{ name: 'text', values: ['text'] },
|
|
{ name: 'tags', values: ['t1,t2,t3'] },
|
|
{ name: 'id', values: [1] },
|
|
{ name: 'userId', values: ['Admin'] },
|
|
{ name: 'login', values: ['admin'] },
|
|
{ name: 'email', values: ['admin@unknown.us'] },
|
|
{ name: 'prevState', values: ['normal'] },
|
|
{ name: 'newState', values: ['alerting'] },
|
|
{ name: 'data', values: [{ text: 'a', value: 'A' }] },
|
|
{ name: 'panelId', values: [4] },
|
|
{ name: 'alertId', values: [0] },
|
|
],
|
|
});
|
|
|
|
const observable = getAnnotationsFromData([frame]);
|
|
|
|
await expect(observable).toEmitValues([
|
|
[
|
|
{
|
|
color: 'red',
|
|
data: { text: 'a', value: 'A' },
|
|
email: 'admin@unknown.us',
|
|
id: 1,
|
|
login: 'admin',
|
|
newState: 'alerting',
|
|
panelId: 4,
|
|
prevState: 'normal',
|
|
tags: ['t1', 't2', 't3'],
|
|
text: 'text',
|
|
time: 100,
|
|
timeEnd: 200,
|
|
title: 'title',
|
|
type: 'default',
|
|
userId: 'Admin',
|
|
alertId: 0,
|
|
},
|
|
],
|
|
]);
|
|
});
|
|
|
|
it('key names that are not valid should be excluded in the output result', async () => {
|
|
const frame = toDataFrame({
|
|
fields: [
|
|
{ name: 'time', values: [100] },
|
|
{ name: 'text', values: ['text'] },
|
|
{ name: 'someData', values: [{ value: 'bar' }] },
|
|
{ name: 'panelSource', values: ['100'] },
|
|
{ name: 'timeStart', values: [100] },
|
|
],
|
|
});
|
|
|
|
const observable = getAnnotationsFromData([frame]);
|
|
|
|
await expect(observable).toEmitValues([[{ color: 'red', text: 'text', time: 100, type: 'default' }]]);
|
|
});
|
|
});
|