mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
* add prom query var editor with tests and migrations * fix migration, now query not expr * fix label_values migration * remove comments * fix label_values() variables order * update UI and use more clear language * fix tests * use null coalescing operators * allow users to query label values with label and metric if they have not set there flavor and version * use enums instead of numbers for readability * fix label&metrics switch * update type in qv editor * reuse datasource function to get all label names, getLabelNames(), prev named getTagKeys() * use getLabelNames in the query var editor * make label_values() variables label and metric more readable in the migration * fix tooltip for label_values to remove API reference * clean up tooltips and allow newlines in query_result function * change function wording and exprType to query type/qryType for readability * update prometheus query variable docs * Update public/app/plugins/datasource/prometheus/components/VariableQueryEditor.tsx Co-authored-by: Galen Kistler <109082771+gtk-grafana@users.noreply.github.com> --------- Co-authored-by: Galen Kistler <109082771+gtk-grafana@users.noreply.github.com>
143 lines
4.2 KiB
TypeScript
143 lines
4.2 KiB
TypeScript
import { render, screen, waitFor } from '@testing-library/react';
|
|
import userEvent from '@testing-library/user-event';
|
|
import React from 'react';
|
|
import { selectOptionInTest } from 'test/helpers/selectOptionInTest';
|
|
|
|
import { PrometheusDatasource } from '../datasource';
|
|
|
|
import { PromVariableQueryEditor, Props } from './VariableQueryEditor';
|
|
|
|
const refId = 'PrometheusVariableQueryEditor-VariableQuery';
|
|
|
|
describe('PromVariableQueryEditor', () => {
|
|
let props: Props;
|
|
|
|
beforeEach(() => {
|
|
props = {
|
|
datasource: {
|
|
hasLabelsMatchAPISupport: () => 1,
|
|
languageProvider: {
|
|
start: () => Promise.resolve([]),
|
|
syntax: () => {},
|
|
getLabelKeys: () => [],
|
|
metrics: [],
|
|
},
|
|
getInitHints: () => [],
|
|
} as unknown as PrometheusDatasource,
|
|
query: {
|
|
refId: 'test',
|
|
query: 'label_names()',
|
|
},
|
|
onRunQuery: () => {},
|
|
onChange: () => {},
|
|
history: [],
|
|
};
|
|
});
|
|
|
|
test('Displays a group of function options', async () => {
|
|
render(<PromVariableQueryEditor {...props} />);
|
|
|
|
const select = screen.getByLabelText('Query type').parentElement!;
|
|
await userEvent.click(select);
|
|
|
|
await waitFor(() => expect(screen.getAllByText('Label names')).toHaveLength(2));
|
|
await waitFor(() => expect(screen.getByText('Label values')).toBeInTheDocument());
|
|
await waitFor(() => expect(screen.getByText('Metrics')).toBeInTheDocument());
|
|
await waitFor(() => expect(screen.getByText('Query result')).toBeInTheDocument());
|
|
await waitFor(() => expect(screen.getByText('Series query')).toBeInTheDocument());
|
|
});
|
|
|
|
test('Calls onChange for label_names() query', async () => {
|
|
const onChange = jest.fn();
|
|
|
|
props.query = {
|
|
refId: 'test',
|
|
query: '',
|
|
};
|
|
|
|
render(<PromVariableQueryEditor {...props} onChange={onChange} />);
|
|
|
|
await selectOptionInTest(screen.getByLabelText('Query type'), 'Label names');
|
|
|
|
expect(onChange).toHaveBeenCalledWith({
|
|
query: 'label_names()',
|
|
refId,
|
|
});
|
|
});
|
|
|
|
test('Does not call onChange for other queries', async () => {
|
|
const onChange = jest.fn();
|
|
|
|
render(<PromVariableQueryEditor {...props} onChange={onChange} />);
|
|
|
|
await selectOptionInTest(screen.getByLabelText('Query type'), 'Metrics');
|
|
await selectOptionInTest(screen.getByLabelText('Query type'), 'Query result');
|
|
await selectOptionInTest(screen.getByLabelText('Query type'), 'Series query');
|
|
|
|
expect(onChange).not.toHaveBeenCalled();
|
|
});
|
|
|
|
test('Calls onChange for metrics() with argument onBlur', async () => {
|
|
const onChange = jest.fn();
|
|
|
|
props.query = {
|
|
refId: 'test',
|
|
query: 'metrics(a)',
|
|
};
|
|
|
|
render(<PromVariableQueryEditor {...props} onChange={onChange} />);
|
|
|
|
const labelSelect = screen.getByLabelText('Metric selector');
|
|
await userEvent.click(labelSelect);
|
|
const functionSelect = screen.getByLabelText('Query type').parentElement!;
|
|
await userEvent.click(functionSelect);
|
|
|
|
expect(onChange).toHaveBeenCalledWith({
|
|
query: 'metrics(a)',
|
|
refId,
|
|
});
|
|
});
|
|
|
|
test('Calls onChange for query_result() with argument onBlur', async () => {
|
|
const onChange = jest.fn();
|
|
|
|
props.query = {
|
|
refId: 'test',
|
|
query: 'query_result(a)',
|
|
};
|
|
|
|
render(<PromVariableQueryEditor {...props} onChange={onChange} />);
|
|
|
|
const labelSelect = screen.getByLabelText('Prometheus Query');
|
|
await userEvent.click(labelSelect);
|
|
const functionSelect = screen.getByLabelText('Query type').parentElement!;
|
|
await userEvent.click(functionSelect);
|
|
|
|
expect(onChange).toHaveBeenCalledWith({
|
|
query: 'query_result(a)',
|
|
refId,
|
|
});
|
|
});
|
|
|
|
test('Calls onChange for Match[] series with argument onBlur', async () => {
|
|
const onChange = jest.fn();
|
|
|
|
props.query = {
|
|
refId: 'test',
|
|
query: '{a: "example"}',
|
|
};
|
|
|
|
render(<PromVariableQueryEditor {...props} onChange={onChange} />);
|
|
|
|
const labelSelect = screen.getByLabelText('Series Query');
|
|
await userEvent.click(labelSelect);
|
|
const functionSelect = screen.getByLabelText('Query type').parentElement!;
|
|
await userEvent.click(functionSelect);
|
|
|
|
expect(onChange).toHaveBeenCalledWith({
|
|
query: '{a: "example"}',
|
|
refId,
|
|
});
|
|
});
|
|
});
|