mirror of
https://github.com/grafana/grafana.git
synced 2025-02-12 16:45:43 -06:00
* Explore/Prometheus: More consistently allows for multi-line queries Allows a user to hit shift+enter to create a new line in the query field, even when the autocomplete suggestions are displayed. Also fixes an issue where a new line was inserted when selecting a suggestion Closes #18341 * Fixes behavior where query wasn't running on pressing Enter Also adds test to verify this behavior
32 lines
1.2 KiB
TypeScript
32 lines
1.2 KiB
TypeScript
import React from 'react';
|
|
import { shallow } from 'enzyme';
|
|
|
|
import { QueryField } from './QueryField';
|
|
|
|
describe('<QueryField />', () => {
|
|
it('should render with null initial value', () => {
|
|
const wrapper = shallow(<QueryField initialQuery={null} />);
|
|
expect(wrapper.find('div').exists()).toBeTruthy();
|
|
});
|
|
|
|
it('should render with empty initial value', () => {
|
|
const wrapper = shallow(<QueryField initialQuery="" />);
|
|
expect(wrapper.find('div').exists()).toBeTruthy();
|
|
});
|
|
|
|
it('should render with initial value', () => {
|
|
const wrapper = shallow(<QueryField initialQuery="my query" />);
|
|
expect(wrapper.find('div').exists()).toBeTruthy();
|
|
});
|
|
|
|
it('should execute query when enter is pressed and there are no suggestions visible', () => {
|
|
const wrapper = shallow(<QueryField initialQuery="my query" />);
|
|
const instance = wrapper.instance() as QueryField;
|
|
instance.executeOnChangeAndRunQueries = jest.fn();
|
|
const handleEnterAndTabKeySpy = jest.spyOn(instance, 'handleEnterAndTabKey');
|
|
instance.onKeyDown({ key: 'Enter', preventDefault: () => {} } as KeyboardEvent, {});
|
|
expect(handleEnterAndTabKeySpy).toBeCalled();
|
|
expect(instance.executeOnChangeAndRunQueries).toBeCalled();
|
|
});
|
|
});
|