import React from 'react'; import { mount } from 'enzyme'; import Select from '..'; import Icon from '../../icon'; import focusTest from '../../../tests/shared/focusTest'; const { Option } = Select; describe('Select', () => { focusTest(Select); beforeEach(() => { jest.useFakeTimers(); }); afterEach(() => { jest.useRealTimers(); }); it('should have default notFoundContent', () => { const wrapper = mount(); wrapper.find('.ant-select').simulate('click'); jest.runAllTimers(); const dropdownWrapper = mount( wrapper .find('Trigger') .instance() .getComponent(), ); expect(dropdownWrapper.find('MenuItem').length).toBe(0); }); it('should not have default notFoundContent when mode is combobox', () => { const wrapper = mount(, ); wrapper.find('.ant-select').simulate('click'); jest.runAllTimers(); const dropdownWrapper = mount( wrapper .find('Trigger') .instance() .getComponent(), ); expect(dropdownWrapper.find('MenuItem').length).toBe(1); expect( dropdownWrapper .find('MenuItem') .at(0) .text(), ).toBe('not at all'); }); it('should be controlled by open prop', () => { const onDropdownVisibleChange = jest.fn(); const wrapper = mount( , ); let dropdownWrapper = mount( wrapper .find('Trigger') .instance() .getComponent(), ); expect(dropdownWrapper.props().visible).toBe(true); wrapper.find('.ant-select').simulate('click'); expect(onDropdownVisibleChange).toHaveBeenLastCalledWith(false); expect(dropdownWrapper.props().visible).toBe(true); wrapper.setProps({ open: false }); dropdownWrapper = mount( wrapper .find('Trigger') .instance() .getComponent(), ); expect(dropdownWrapper.props().visible).toBe(false); wrapper.find('.ant-select').simulate('click'); expect(onDropdownVisibleChange).toHaveBeenLastCalledWith(true); expect(dropdownWrapper.props().visible).toBe(false); }); describe('Select Custom Icons', () => { it('should support customized icons', () => { const wrapper = mount( , ); wrapper.setProps({ count: 10 }); jest.runAllTimers(); expect(wrapper.render()).toMatchSnapshot(); }); }); });