123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- import {mountWithTheme} from 'sentry-test/enzyme';
- import DropdownAutoComplete from 'sentry/components/dropdownAutoComplete';
- describe('DropdownAutoComplete', function () {
- const items = [
- {
- value: 'apple',
- label: <div>Apple</div>,
- },
- {
- value: 'bacon',
- label: <div>Bacon</div>,
- },
- {
- value: 'corn',
- label: <div>Corn</div>,
- },
- ];
- it('has actor wrapper', function () {
- const wrapper = mountWithTheme(
- <DropdownAutoComplete items={items}>{() => 'Click Me!'}</DropdownAutoComplete>
- );
- expect(wrapper.find('div[role="button"]')).toHaveLength(1);
- expect(wrapper.find('div[role="button"]').text()).toBe('Click Me!');
- });
- it('opens dropdown menu when actor is clicked', function () {
- const wrapper = mountWithTheme(
- <DropdownAutoComplete items={items}>{() => 'Click Me!'}</DropdownAutoComplete>
- );
- wrapper.find('Actor[role="button"]').simulate('click');
- expect(wrapper.find('StyledDropdownBubble')).toHaveLength(1);
- wrapper.find('Actor[role="button"]').simulate('click');
- expect(wrapper.find('StyledDropdownBubble')).toHaveLength(1);
- });
- it('toggles dropdown menu when actor is clicked', function () {
- const wrapper = mountWithTheme(
- <DropdownAutoComplete allowActorToggle items={items}>
- {() => 'Click Me!'}
- </DropdownAutoComplete>
- );
- wrapper.find('Actor[role="button"]').simulate('click');
- expect(wrapper.find('StyledDropdownBubble')).toHaveLength(1);
- wrapper.find('Actor[role="button"]').simulate('click');
- expect(wrapper.find('StyledDropdownBubble')).toHaveLength(0);
- });
- });
|