2019-10-28 10:09:48 -07:00
|
|
|
import * as React from 'react';
|
|
|
|
import { mount } from 'enzyme';
|
|
|
|
import ExpressionInput from './ExpressionInput';
|
|
|
|
import Downshift from 'downshift';
|
|
|
|
import { Button, InputGroup, InputGroupAddon, Input } from 'reactstrap';
|
|
|
|
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
|
|
|
import { faSearch, faSpinner } from '@fortawesome/free-solid-svg-icons';
|
|
|
|
import SanitizeHTML from './components/SanitizeHTML';
|
|
|
|
|
|
|
|
const getKeyEvent = (key: string): React.KeyboardEvent<HTMLInputElement> =>
|
|
|
|
({
|
|
|
|
key,
|
|
|
|
nativeEvent: {},
|
|
|
|
preventDefault: () => {},
|
|
|
|
} as React.KeyboardEvent<HTMLInputElement>);
|
|
|
|
|
|
|
|
describe('ExpressionInput', () => {
|
|
|
|
const metricNames = ['instance:node_cpu_utilisation:rate1m', 'node_cpu_guest_seconds_total', 'node_cpu_seconds_total'];
|
|
|
|
const expressionInputProps = {
|
|
|
|
value: 'node_cpu',
|
|
|
|
autocompleteSections: {
|
|
|
|
'Query History': [],
|
|
|
|
'Metric Names': metricNames,
|
|
|
|
},
|
|
|
|
executeQuery: (): void => {},
|
|
|
|
loading: false,
|
|
|
|
};
|
|
|
|
const expressionInput = mount(<ExpressionInput {...expressionInputProps} />);
|
|
|
|
|
|
|
|
it('renders a downshift component', () => {
|
|
|
|
const downshift = expressionInput.find(Downshift);
|
|
|
|
expect(downshift.prop('inputValue')).toEqual('node_cpu');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders an InputGroup', () => {
|
|
|
|
const inputGroup = expressionInput.find(InputGroup);
|
|
|
|
expect(inputGroup.prop('className')).toEqual('expression-input');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders a search icon when it is not loading', () => {
|
|
|
|
const addon = expressionInput.find(InputGroupAddon).filterWhere(addon => addon.prop('addonType') === 'prepend');
|
|
|
|
const icon = addon.find(FontAwesomeIcon);
|
|
|
|
expect(icon.prop('icon')).toEqual(faSearch);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders a loading icon when it is loading', () => {
|
|
|
|
const expressionInput = mount(<ExpressionInput {...expressionInputProps} loading={true} />);
|
|
|
|
const addon = expressionInput.find(InputGroupAddon).filterWhere(addon => addon.prop('addonType') === 'prepend');
|
|
|
|
const icon = addon.find(FontAwesomeIcon);
|
|
|
|
expect(icon.prop('icon')).toEqual(faSpinner);
|
|
|
|
expect(icon.prop('spin')).toBe(true);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders an Input', () => {
|
|
|
|
const expressionInput = mount(<ExpressionInput {...expressionInputProps} />);
|
|
|
|
const input = expressionInput.find(Input);
|
|
|
|
expect(input.prop('style')).toEqual({ height: 0 });
|
|
|
|
expect(input.prop('autoFocus')).toEqual(true);
|
|
|
|
expect(input.prop('type')).toEqual('textarea');
|
|
|
|
expect(input.prop('rows')).toEqual('1');
|
|
|
|
expect(input.prop('placeholder')).toEqual('Expression (press Shift+Enter for newlines)');
|
|
|
|
expect(expressionInput.state('value')).toEqual('node_cpu');
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when autosuggest is closed', () => {
|
|
|
|
it('prevents Downshift default on Home, End, Arrows', () => {
|
|
|
|
const downshift = expressionInput.find(Downshift);
|
|
|
|
const input = downshift.find(Input);
|
|
|
|
downshift.setState({ isOpen: false });
|
|
|
|
const onKeyDown = input.prop('onKeyDown');
|
|
|
|
['Home', 'End', 'ArrowUp', 'ArrowDown'].forEach(key => {
|
|
|
|
const event = getKeyEvent(key);
|
|
|
|
input.simulate('keydown', event);
|
|
|
|
const nativeEvent = event.nativeEvent as any;
|
|
|
|
expect(nativeEvent.preventDownshiftDefault).toBe(true);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('does not render an autosuggest', () => {
|
|
|
|
const downshift = expressionInput.find(Downshift);
|
|
|
|
downshift.setState({ isOpen: false });
|
|
|
|
const ul = downshift.find('ul');
|
|
|
|
expect(ul).toHaveLength(0);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when downshift is open', () => {
|
|
|
|
it('closes the menu on "Enter"', () => {
|
|
|
|
const downshift = expressionInput.find(Downshift);
|
|
|
|
const input = downshift.find(Input);
|
|
|
|
downshift.setState({ isOpen: true });
|
|
|
|
const event = getKeyEvent('Enter');
|
|
|
|
input.simulate('keydown', event);
|
|
|
|
expect(downshift.state('isOpen')).toBe(false);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('noops on ArrowUp or ArrowDown', () => {
|
|
|
|
const downshift = expressionInput.find(Downshift);
|
|
|
|
const input = downshift.find(Input);
|
|
|
|
downshift.setState({ isOpen: true });
|
|
|
|
['ArrowUp', 'ArrowDown'].forEach(key => {
|
|
|
|
const event = getKeyEvent(key);
|
|
|
|
input.simulate('keydown', event);
|
|
|
|
const nativeEvent = event.nativeEvent as any;
|
|
|
|
expect(nativeEvent.preventDownshiftDefault).toBeUndefined();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('does not render an autosuggest if there are no matches', () => {
|
|
|
|
const expressionInputProps = {
|
|
|
|
value: 'foo',
|
|
|
|
autocompleteSections: {
|
|
|
|
'Query History': [],
|
|
|
|
'Metric Names': [],
|
|
|
|
},
|
|
|
|
executeQuery: (): void => {},
|
|
|
|
loading: false,
|
|
|
|
};
|
|
|
|
const expressionInput = mount(<ExpressionInput {...expressionInputProps} />);
|
|
|
|
const downshift = expressionInput.find(Downshift);
|
|
|
|
downshift.setState({ isOpen: true });
|
|
|
|
const ul = downshift.find('ul');
|
|
|
|
expect(ul).toHaveLength(0);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders an autosuggest if there are matches', () => {
|
|
|
|
const downshift = expressionInput.find(Downshift);
|
|
|
|
downshift.setState({ isOpen: true });
|
|
|
|
const ul = downshift.find('ul');
|
2019-11-03 03:47:47 -08:00
|
|
|
expect(ul.prop('className')).toEqual('autosuggest-dropdown-list');
|
2019-10-28 10:09:48 -07:00
|
|
|
const items = ul.find(SanitizeHTML);
|
|
|
|
expect(items.map(item => item.text()).join(', ')).toEqual(
|
|
|
|
'node_cpu_guest_seconds_total, node_cpu_seconds_total, instance:node_cpu_utilisation:rate1m'
|
|
|
|
);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders an execute Button', () => {
|
|
|
|
const addon = expressionInput.find(InputGroupAddon).filterWhere(addon => addon.prop('addonType') === 'append');
|
|
|
|
const button = addon.find(Button);
|
|
|
|
expect(button.prop('className')).toEqual('execute-btn');
|
|
|
|
expect(button.prop('color')).toEqual('primary');
|
|
|
|
expect(button.text()).toEqual('Execute');
|
|
|
|
});
|
|
|
|
});
|