mirror of
https://github.com/grafana/grafana.git
synced 2025-02-12 16:45:43 -06:00
* Fixes several usability issues with QueryField component - Can now indent with tab and `mod+[`, `mod+]` - Copy/Cut preserves new lines, and paste correctly splits blocks now - Adds support for selection hotkeys
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, 'handleEnterKey');
|
|
instance.onKeyDown({ key: 'Enter', preventDefault: () => {} } as KeyboardEvent, {});
|
|
expect(handleEnterAndTabKeySpy).toBeCalled();
|
|
expect(instance.executeOnChangeAndRunQueries).toBeCalled();
|
|
});
|
|
});
|