dropdownAutoCompleteMenu.spec.jsx 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. import {mountWithTheme} from 'sentry-test/enzyme';
  2. import DropdownAutoCompleteMenu from 'sentry/components/dropdownAutoComplete/menu';
  3. describe('DropdownAutoCompleteMenu', function () {
  4. const items = [
  5. {
  6. value: 'apple',
  7. label: <div>Apple</div>,
  8. },
  9. {
  10. value: 'bacon',
  11. label: <div>Bacon</div>,
  12. },
  13. {
  14. value: 'corn',
  15. label: <div>Corn</div>,
  16. },
  17. ];
  18. it('renders without a group', function () {
  19. const wrapper = mountWithTheme(
  20. <DropdownAutoCompleteMenu isOpen items={items}>
  21. {() => 'Click Me!'}
  22. </DropdownAutoCompleteMenu>
  23. );
  24. expect(wrapper).toSnapshot();
  25. });
  26. it('renders with a group', function () {
  27. const wrapper = mountWithTheme(
  28. <DropdownAutoCompleteMenu
  29. isOpen
  30. items={[
  31. {
  32. id: 'countries',
  33. value: 'countries',
  34. label: 'countries',
  35. items: [
  36. {
  37. value: 'new zealand',
  38. label: <div>New Zealand</div>,
  39. },
  40. {
  41. value: 'australia',
  42. label: <div>Australia</div>,
  43. },
  44. ],
  45. },
  46. ]}
  47. >
  48. {() => 'Click Me!'}
  49. </DropdownAutoCompleteMenu>
  50. );
  51. expect(wrapper).toSnapshot();
  52. });
  53. it('selects', function () {
  54. const mock = jest.fn();
  55. const countries = [
  56. {
  57. value: 'new zealand',
  58. label: <div>New Zealand</div>,
  59. },
  60. {
  61. value: 'australia',
  62. label: <div>Australia</div>,
  63. },
  64. ];
  65. const wrapper = mountWithTheme(
  66. <DropdownAutoCompleteMenu
  67. isOpen
  68. items={[
  69. {
  70. id: 'countries',
  71. value: 'countries',
  72. label: 'countries',
  73. items: countries,
  74. },
  75. ]}
  76. onSelect={mock}
  77. >
  78. {({selectedItem}) => (selectedItem ? selectedItem.label : 'Click me!')}
  79. </DropdownAutoCompleteMenu>
  80. );
  81. wrapper.find('AutoCompleteItem').last().simulate('click');
  82. expect(mock).toHaveBeenCalledTimes(1);
  83. expect(mock).toHaveBeenCalledWith(
  84. {index: 1, ...countries[1]},
  85. {highlightedIndex: 0, inputValue: '', isOpen: true, selectedItem: undefined},
  86. expect.anything()
  87. );
  88. });
  89. it('shows empty message when there are no items', function () {
  90. const wrapper = mountWithTheme(
  91. <DropdownAutoCompleteMenu
  92. items={[]}
  93. emptyMessage="No items!"
  94. emptyHidesInput
  95. isOpen
  96. >
  97. {({selectedItem}) => (selectedItem ? selectedItem.label : 'Click me!')}
  98. </DropdownAutoCompleteMenu>
  99. );
  100. expect(wrapper.find('EmptyMessage')).toHaveLength(1);
  101. expect(wrapper.find('EmptyMessage').text()).toBe('No items!');
  102. // No input because there are no items
  103. expect(wrapper.find('StyledInput')).toHaveLength(0);
  104. });
  105. it('shows default empty results message when there are no items found in search', function () {
  106. const wrapper = mountWithTheme(
  107. <DropdownAutoCompleteMenu isOpen items={items} emptyMessage="No items!">
  108. {({selectedItem}) => (selectedItem ? selectedItem.label : 'Click me!')}
  109. </DropdownAutoCompleteMenu>
  110. );
  111. wrapper.find('StyledInput').simulate('change', {target: {value: 'U-S-A'}});
  112. expect(wrapper.find('EmptyMessage')).toHaveLength(1);
  113. expect(wrapper.find('EmptyMessage').text()).toBe('No items! found');
  114. });
  115. it('overrides default empty results message', function () {
  116. const wrapper = mountWithTheme(
  117. <DropdownAutoCompleteMenu
  118. isOpen
  119. items={items}
  120. emptyMessage="No items!"
  121. noResultsMessage="No search results"
  122. >
  123. {({selectedItem}) => (selectedItem ? selectedItem.label : 'Click me!')}
  124. </DropdownAutoCompleteMenu>
  125. );
  126. wrapper.find('StyledInput').simulate('change', {target: {value: 'U-S-A'}});
  127. expect(wrapper.find('EmptyMessage').text()).toBe('No search results');
  128. });
  129. it('hides filter with `hideInput` prop', function () {
  130. const wrapper = mountWithTheme(
  131. <DropdownAutoCompleteMenu isOpen items={items} hideInput>
  132. {() => 'Click Me!'}
  133. </DropdownAutoCompleteMenu>
  134. );
  135. expect(wrapper.find('StyledInput')).toHaveLength(0);
  136. });
  137. it('filters using a value from prop instead of input', function () {
  138. const wrapper = mountWithTheme(
  139. <DropdownAutoCompleteMenu isOpen items={items} filterValue="Apple">
  140. {() => 'Click Me!'}
  141. </DropdownAutoCompleteMenu>
  142. );
  143. wrapper.find('StyledInput').simulate('change', {target: {value: 'U-S-A'}});
  144. expect(wrapper.find('EmptyMessage')).toHaveLength(0);
  145. expect(wrapper.find('AutoCompleteItem')).toHaveLength(1);
  146. expect(wrapper.find('AutoCompleteItem').text()).toBe('Apple');
  147. });
  148. });