2019-10-28 10:09:48 -07:00
|
|
|
import * as React from 'react';
|
|
|
|
import { mount, shallow } from 'enzyme';
|
|
|
|
import Panel, { PanelOptions, PanelType } from './Panel';
|
|
|
|
import ExpressionInput from './ExpressionInput';
|
|
|
|
import GraphControls from './GraphControls';
|
|
|
|
import Graph from './Graph';
|
|
|
|
import { NavLink, TabPane } from 'reactstrap';
|
|
|
|
import TimeInput from './TimeInput';
|
|
|
|
import DataTable from './DataTable';
|
|
|
|
|
|
|
|
describe('Panel', () => {
|
|
|
|
const props = {
|
|
|
|
options: {
|
|
|
|
expr: 'prometheus_engine',
|
|
|
|
type: PanelType.Table,
|
|
|
|
range: 10,
|
|
|
|
endTime: 1572100217898,
|
|
|
|
resolution: 28,
|
|
|
|
stacked: false,
|
|
|
|
},
|
|
|
|
onOptionsChanged: (): void => {},
|
|
|
|
pastQueries: [],
|
|
|
|
metricNames: [
|
|
|
|
'prometheus_engine_queries',
|
|
|
|
'prometheus_engine_queries_concurrent_max',
|
|
|
|
'prometheus_engine_query_duration_seconds',
|
|
|
|
],
|
|
|
|
removePanel: (): void => {},
|
|
|
|
onExecuteQuery: (): void => {},
|
|
|
|
};
|
|
|
|
const panel = shallow(<Panel {...props} />);
|
|
|
|
|
|
|
|
it('renders an ExpressionInput', () => {
|
|
|
|
const input = panel.find(ExpressionInput);
|
|
|
|
expect(input.prop('value')).toEqual('prometheus_engine');
|
|
|
|
expect(input.prop('autocompleteSections')).toEqual({
|
|
|
|
'Metric Names': [
|
|
|
|
'prometheus_engine_queries',
|
|
|
|
'prometheus_engine_queries_concurrent_max',
|
|
|
|
'prometheus_engine_query_duration_seconds',
|
|
|
|
],
|
|
|
|
'Query History': [],
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders NavLinks', () => {
|
|
|
|
const results: PanelOptions[] = [];
|
|
|
|
const onOptionsChanged = (opts: PanelOptions): void => {
|
|
|
|
results.push(opts);
|
|
|
|
};
|
|
|
|
const panel = shallow(<Panel {...props} onOptionsChanged={onOptionsChanged} />);
|
|
|
|
const links = panel.find(NavLink);
|
|
|
|
[{ panelType: 'Table', active: true }, { panelType: 'Graph', active: false }].forEach(
|
|
|
|
(tc: { panelType: string; active: boolean }, i: number) => {
|
|
|
|
const link = links.at(i);
|
|
|
|
const className = tc.active ? 'active' : '';
|
|
|
|
expect(link.prop('className')).toEqual(className);
|
|
|
|
link.simulate('click');
|
|
|
|
expect(results).toHaveLength(1);
|
|
|
|
expect(results[0].type).toEqual(tc.panelType.toLowerCase());
|
|
|
|
results.pop();
|
|
|
|
}
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders a TabPane with a TimeInput and a DataTable when in table mode', () => {
|
|
|
|
const tab = panel.find(TabPane).filterWhere(tab => tab.prop('tabId') === 'table');
|
|
|
|
const timeInput = tab.find(TimeInput);
|
|
|
|
expect(timeInput.prop('time')).toEqual(props.options.endTime);
|
|
|
|
expect(timeInput.prop('range')).toEqual(props.options.range);
|
|
|
|
expect(timeInput.prop('placeholder')).toEqual('Evaluation time');
|
|
|
|
expect(tab.find(DataTable)).toHaveLength(1);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders a TabPane with a Graph and GraphControls when in graph mode', () => {
|
|
|
|
const options = {
|
|
|
|
expr: 'prometheus_engine',
|
|
|
|
type: PanelType.Graph,
|
|
|
|
range: 10,
|
|
|
|
endTime: 1572100217898,
|
|
|
|
resolution: 28,
|
|
|
|
stacked: false,
|
|
|
|
};
|
|
|
|
const graphPanel = mount(<Panel {...props} options={options} />);
|
|
|
|
const controls = graphPanel.find(GraphControls);
|
2019-11-24 04:14:57 -08:00
|
|
|
graphPanel.setState({ data: [] });
|
2019-10-28 10:09:48 -07:00
|
|
|
const graph = graphPanel.find(Graph);
|
2019-11-24 04:14:57 -08:00
|
|
|
expect(controls.prop('endTime')).toEqual(options.endTime);
|
|
|
|
expect(controls.prop('range')).toEqual(options.range);
|
|
|
|
expect(controls.prop('resolution')).toEqual(options.resolution);
|
|
|
|
expect(controls.prop('stacked')).toEqual(options.stacked);
|
|
|
|
expect(graph.prop('stacked')).toEqual(options.stacked);
|
2019-10-28 10:09:48 -07:00
|
|
|
});
|
|
|
|
});
|