mirror of
https://github.com/grafana/grafana.git
synced 2025-02-16 18:34:52 -06:00
* Explore: facetting for label completion - unified metric and non-metric label completion - label keys and values are now fetched fresh for each valid selector - complete selector means only values are suggested that are supported by the selector - properly implemented metric lookup for selectors (until the first metric was used which breaks when multiple metrics are present) - typeahead tests now need a valid selection to demark the cursor * Fix facetting queries for empty selector
180 lines
7.0 KiB
TypeScript
180 lines
7.0 KiB
TypeScript
import React from 'react';
|
|
import Enzyme, { shallow } from 'enzyme';
|
|
import Adapter from 'enzyme-adapter-react-16';
|
|
import Plain from 'slate-plain-serializer';
|
|
|
|
import PromQueryField from './PromQueryField';
|
|
|
|
Enzyme.configure({ adapter: new Adapter() });
|
|
|
|
describe('PromQueryField typeahead handling', () => {
|
|
const defaultProps = {
|
|
request: () => ({ data: { data: [] } }),
|
|
};
|
|
|
|
it('returns default suggestions on emtpty context', () => {
|
|
const instance = shallow(<PromQueryField {...defaultProps} />).instance() as PromQueryField;
|
|
const result = instance.getTypeahead({ text: '', prefix: '', wrapperClasses: [] });
|
|
expect(result.context).toBeUndefined();
|
|
expect(result.refresher).toBeUndefined();
|
|
expect(result.suggestions.length).toEqual(2);
|
|
});
|
|
|
|
describe('range suggestions', () => {
|
|
it('returns range suggestions in range context', () => {
|
|
const instance = shallow(<PromQueryField {...defaultProps} />).instance() as PromQueryField;
|
|
const result = instance.getTypeahead({ text: '1', prefix: '1', wrapperClasses: ['context-range'] });
|
|
expect(result.context).toBe('context-range');
|
|
expect(result.refresher).toBeUndefined();
|
|
expect(result.suggestions).toEqual([
|
|
{
|
|
items: [{ label: '1m' }, { label: '5m' }, { label: '10m' }, { label: '30m' }, { label: '1h' }],
|
|
label: 'Range vector',
|
|
},
|
|
]);
|
|
});
|
|
});
|
|
|
|
describe('metric suggestions', () => {
|
|
it('returns metrics suggestions by default', () => {
|
|
const instance = shallow(
|
|
<PromQueryField {...defaultProps} metrics={['foo', 'bar']} />
|
|
).instance() as PromQueryField;
|
|
const result = instance.getTypeahead({ text: 'a', prefix: 'a', wrapperClasses: [] });
|
|
expect(result.context).toBeUndefined();
|
|
expect(result.refresher).toBeUndefined();
|
|
expect(result.suggestions.length).toEqual(2);
|
|
});
|
|
|
|
it('returns default suggestions after a binary operator', () => {
|
|
const instance = shallow(
|
|
<PromQueryField {...defaultProps} metrics={['foo', 'bar']} />
|
|
).instance() as PromQueryField;
|
|
const result = instance.getTypeahead({ text: '*', prefix: '', wrapperClasses: [] });
|
|
expect(result.context).toBeUndefined();
|
|
expect(result.refresher).toBeUndefined();
|
|
expect(result.suggestions.length).toEqual(2);
|
|
});
|
|
});
|
|
|
|
describe('label suggestions', () => {
|
|
it('returns default label suggestions on label context and no metric', () => {
|
|
const instance = shallow(<PromQueryField {...defaultProps} />).instance() as PromQueryField;
|
|
const value = Plain.deserialize('{}');
|
|
const range = value.selection.merge({
|
|
anchorOffset: 1,
|
|
});
|
|
const valueWithSelection = value.change().select(range).value;
|
|
const result = instance.getTypeahead({
|
|
text: '',
|
|
prefix: '',
|
|
wrapperClasses: ['context-labels'],
|
|
value: valueWithSelection,
|
|
});
|
|
expect(result.context).toBe('context-labels');
|
|
expect(result.suggestions).toEqual([{ items: [{ label: 'job' }, { label: 'instance' }], label: 'Labels' }]);
|
|
});
|
|
|
|
it('returns label suggestions on label context and metric', () => {
|
|
const instance = shallow(
|
|
<PromQueryField {...defaultProps} labelKeys={{ '{__name__="metric"}': ['bar'] }} />
|
|
).instance() as PromQueryField;
|
|
const value = Plain.deserialize('metric{}');
|
|
const range = value.selection.merge({
|
|
anchorOffset: 7,
|
|
});
|
|
const valueWithSelection = value.change().select(range).value;
|
|
const result = instance.getTypeahead({
|
|
text: '',
|
|
prefix: '',
|
|
wrapperClasses: ['context-labels'],
|
|
value: valueWithSelection,
|
|
});
|
|
expect(result.context).toBe('context-labels');
|
|
expect(result.suggestions).toEqual([{ items: [{ label: 'bar' }], label: 'Labels' }]);
|
|
});
|
|
|
|
it('returns a refresher on label context and unavailable metric', () => {
|
|
const instance = shallow(
|
|
<PromQueryField {...defaultProps} labelKeys={{ '{__name__="foo"}': ['bar'] }} />
|
|
).instance() as PromQueryField;
|
|
const value = Plain.deserialize('metric{}');
|
|
const range = value.selection.merge({
|
|
anchorOffset: 7,
|
|
});
|
|
const valueWithSelection = value.change().select(range).value;
|
|
const result = instance.getTypeahead({
|
|
text: '',
|
|
prefix: '',
|
|
wrapperClasses: ['context-labels'],
|
|
value: valueWithSelection,
|
|
});
|
|
expect(result.context).toBeUndefined();
|
|
expect(result.refresher).toBeInstanceOf(Promise);
|
|
expect(result.suggestions).toEqual([]);
|
|
});
|
|
|
|
it('returns label values on label context when given a metric and a label key', () => {
|
|
const instance = shallow(
|
|
<PromQueryField
|
|
{...defaultProps}
|
|
labelKeys={{ '{__name__="metric"}': ['bar'] }}
|
|
labelValues={{ '{__name__="metric"}': { bar: ['baz'] } }}
|
|
/>
|
|
).instance() as PromQueryField;
|
|
const value = Plain.deserialize('metric{bar=ba}');
|
|
const range = value.selection.merge({
|
|
anchorOffset: 13,
|
|
});
|
|
const valueWithSelection = value.change().select(range).value;
|
|
const result = instance.getTypeahead({
|
|
text: '=ba',
|
|
prefix: 'ba',
|
|
wrapperClasses: ['context-labels'],
|
|
labelKey: 'bar',
|
|
value: valueWithSelection,
|
|
});
|
|
expect(result.context).toBe('context-label-values');
|
|
expect(result.suggestions).toEqual([{ items: [{ label: 'baz' }], label: 'Label values for "bar"' }]);
|
|
});
|
|
|
|
it('returns label suggestions on aggregation context and metric w/ selector', () => {
|
|
const instance = shallow(
|
|
<PromQueryField {...defaultProps} labelKeys={{ '{__name__="metric",foo="xx"}': ['bar'] }} />
|
|
).instance() as PromQueryField;
|
|
const value = Plain.deserialize('sum(metric{foo="xx"}) by ()');
|
|
const range = value.selection.merge({
|
|
anchorOffset: 26,
|
|
});
|
|
const valueWithSelection = value.change().select(range).value;
|
|
const result = instance.getTypeahead({
|
|
text: '',
|
|
prefix: '',
|
|
wrapperClasses: ['context-aggregation'],
|
|
value: valueWithSelection,
|
|
});
|
|
expect(result.context).toBe('context-aggregation');
|
|
expect(result.suggestions).toEqual([{ items: [{ label: 'bar' }], label: 'Labels' }]);
|
|
});
|
|
|
|
it('returns label suggestions on aggregation context and metric w/o selector', () => {
|
|
const instance = shallow(
|
|
<PromQueryField {...defaultProps} labelKeys={{ '{__name__="metric"}': ['bar'] }} />
|
|
).instance() as PromQueryField;
|
|
const value = Plain.deserialize('sum(metric) by ()');
|
|
const range = value.selection.merge({
|
|
anchorOffset: 16,
|
|
});
|
|
const valueWithSelection = value.change().select(range).value;
|
|
const result = instance.getTypeahead({
|
|
text: '',
|
|
prefix: '',
|
|
wrapperClasses: ['context-aggregation'],
|
|
value: valueWithSelection,
|
|
});
|
|
expect(result.context).toBe('context-aggregation');
|
|
expect(result.suggestions).toEqual([{ items: [{ label: 'bar' }], label: 'Labels' }]);
|
|
});
|
|
});
|
|
});
|