grafana/public/app/plugins/datasource/loki/queryHints.test.ts
Sven Grossmann d790cb1c09
Loki: Add unpack query builder hint (#65608)
* add unpack hint

* use `hasOwnProperty`

* add unpack completion to monaco

* adjust test name

* fix tests

* fix tests
2023-03-30 15:18:02 +02:00

241 lines
7.5 KiB
TypeScript

import { ArrayVector, DataFrame, FieldType } from '@grafana/data';
import { getQueryHints } from './queryHints';
describe('getQueryHints', () => {
describe('when series with json logs', () => {
const jsonSeries: DataFrame = {
name: 'logs',
length: 2,
fields: [
{
name: 'Line',
type: FieldType.string,
config: {},
values: new ArrayVector(['{"foo": "bar", "bar": "baz"}', '{"foo": "bar", "bar": "baz"}']),
},
],
};
it('suggest json parser when no parser in query', () => {
expect(getQueryHints('{job="grafana"', [jsonSeries])).toEqual(
expect.arrayContaining([expect.objectContaining({ type: 'ADD_JSON_PARSER' })])
);
});
it('does not suggest parser when parser in query', () => {
expect(getQueryHints('{job="grafana" | json', [jsonSeries])).not.toEqual(
expect.arrayContaining([expect.objectContaining({ type: 'ADD_JSON_PARSER' })])
);
});
});
describe('when series with logfmt logs', () => {
const logfmtSeries: DataFrame = {
name: 'logs',
length: 2,
fields: [
{
name: 'Line',
type: FieldType.string,
config: {},
values: new ArrayVector(['foo="bar" bar="baz"', 'foo="bar" bar="baz"']),
},
],
};
it('suggest logfmt parser when no parser in query', () => {
expect(getQueryHints('{job="grafana"', [logfmtSeries])).toEqual(
expect.arrayContaining([expect.objectContaining({ type: 'ADD_LOGFMT_PARSER' })])
);
});
it('does not suggest parser when parser in query', () => {
expect(getQueryHints('{job="grafana" | logfmt', [logfmtSeries])).not.toEqual(
expect.arrayContaining([expect.objectContaining({ type: 'ADD_LOGFMT_PARSER' })])
);
});
});
describe('when series with json and logfmt logs', () => {
const jsonAndLogfmtSeries: DataFrame = {
name: 'logs',
length: 2,
fields: [
{
name: 'Line',
type: FieldType.string,
config: {},
values: new ArrayVector(['{"foo": "bar", "bar": "baz"}', 'foo="bar" bar="baz"']),
},
],
};
it('suggest logfmt and json parser when no parser in query', () => {
expect(getQueryHints('{job="grafana"', [jsonAndLogfmtSeries])).toEqual(
expect.arrayContaining([
expect.objectContaining({ type: 'ADD_JSON_PARSER' }),
expect.objectContaining({ type: 'ADD_LOGFMT_PARSER' }),
])
);
});
it('does not suggest parser when parser in query', () => {
expect(getQueryHints('{job="grafana"} | json', [jsonAndLogfmtSeries])).not.toEqual(
expect.arrayContaining([
expect.objectContaining({ type: 'ADD_JSON_PARSER' }),
expect.objectContaining({ type: 'ADD_LOGFMT_PARSER' }),
])
);
});
});
describe('when series with json and packed logs', () => {
const jsonAndPackSeries: DataFrame = {
name: 'logs',
length: 2,
fields: [
{
name: 'Line',
type: FieldType.string,
config: {},
values: new ArrayVector(['{"_entry": "bar", "bar": "baz"}']),
},
],
};
it('suggest unpack parser when no parser in query', () => {
expect(getQueryHints('{job="grafana"', [jsonAndPackSeries])).toEqual(
expect.arrayContaining([expect.objectContaining({ type: 'ADD_UNPACK_PARSER' })])
);
});
it('does not suggest json parser', () => {
expect(getQueryHints('{job="grafana"', [jsonAndPackSeries])).not.toEqual(
expect.arrayContaining([expect.objectContaining({ type: 'ADD_JSON_PARSER' })])
);
});
it('does not suggest unpack parser when unpack in query', () => {
expect(getQueryHints('{job="grafana"} | unpack', [jsonAndPackSeries])).not.toEqual(
expect.arrayContaining([expect.objectContaining({ type: 'ADD_UNPACK_PARSER' })])
);
});
});
describe('when series with level-like label', () => {
const createSeriesWithLabel = (labelName?: string): DataFrame => {
const labelVariable: { [key: string]: string } = { job: 'a' };
if (labelName) {
labelVariable[labelName] = 'error';
}
return {
name: 'logs',
length: 2,
fields: [
{
name: 'Line',
type: FieldType.string,
config: {},
values: new ArrayVector(['{"foo": "bar", "bar": "baz"}', 'foo="bar" bar="baz"']),
},
{
name: 'labels',
type: FieldType.other,
config: {},
values: new ArrayVector([labelVariable, { job: 'baz', foo: 'bar' }]),
},
],
};
};
it('suggest level renaming when no level label', () => {
expect(getQueryHints('{job="grafana"', [createSeriesWithLabel('lvl')])).toEqual(
expect.arrayContaining([expect.objectContaining({ type: 'ADD_LEVEL_LABEL_FORMAT' })])
);
});
it('does not suggest level renaming if level label', () => {
expect(getQueryHints('{job="grafana"', [createSeriesWithLabel('level')])).not.toEqual(
expect.arrayContaining([expect.objectContaining({ type: 'ADD_LEVEL_LABEL_FORMAT' })])
);
});
});
describe('when series with line filter', () => {
const jsonAndLogfmtSeries: DataFrame = {
name: 'logs',
length: 2,
fields: [
{
name: 'Line',
type: FieldType.string,
config: {},
values: new ArrayVector(['{"foo": "bar", "bar": "baz"}', 'foo="bar" bar="baz"']),
},
],
};
it('suggest line filter when no line filter in query', () => {
expect(getQueryHints('{job="grafana"', [jsonAndLogfmtSeries])).toEqual(
expect.arrayContaining([expect.objectContaining({ type: 'ADD_LINE_FILTER' })])
);
});
it('does not suggest line filter when line filter in query', () => {
expect(getQueryHints('{job="grafana" |= `bar`', [jsonAndLogfmtSeries])).not.toEqual(
expect.arrayContaining([expect.objectContaining({ type: 'ADD_LINE_FILTER' })])
);
});
});
describe('when series with label filter', () => {
const jsonAndLogfmtSeries: DataFrame = {
name: 'logs',
length: 2,
fields: [
{
name: 'Line',
type: FieldType.string,
config: {},
values: new ArrayVector(['{"foo": "bar", "bar": "baz"}', 'foo="bar" bar="baz"']),
},
],
};
it('suggest label filter when no label filter in query', () => {
expect(getQueryHints('{job="grafana" | logfmt', [jsonAndLogfmtSeries])).toEqual(
expect.arrayContaining([expect.objectContaining({ type: 'ADD_LABEL_FILTER' })])
);
});
it('does not suggest label filter when label filter in query', () => {
expect(getQueryHints('{job="grafana" | logfmt | foo = `bar`', [jsonAndLogfmtSeries])).not.toEqual(
expect.arrayContaining([expect.objectContaining({ type: 'ADD_LABEL_FILTER' })])
);
});
});
describe('suggest remove pipeline error', () => {
const logfmtSeries: DataFrame = {
name: 'logs',
length: 1,
fields: [
{
name: 'labels',
type: FieldType.other,
config: {},
values: new ArrayVector([{ __error__: 'some error', job: 'a' }]),
},
],
};
it('suggest remove pipeline error', () => {
expect(getQueryHints('{job="grafana" | json', [logfmtSeries])).toEqual(
expect.arrayContaining([expect.objectContaining({ type: 'ADD_NO_PIPELINE_ERROR' })])
);
});
});
});