import React from 'react'; import DropdownButton from '../dropdown-button'; import mountTest from '../../../tests/shared/mountTest'; import rtlTest from '../../../tests/shared/rtlTest'; import Menu from '../../menu'; import type { DropdownProps } from '../dropdown'; import { render } from '../../../tests/utils'; let dropdownProps: DropdownProps; jest.mock('../dropdown', () => { const ActualDropdown = jest.requireActual('../dropdown'); const ActualDropdownComponent = ActualDropdown.default; const h: typeof React = jest.requireActual('react'); const mockedDropdown = (props: DropdownProps) => { dropdownProps = props; const { children, ...restProps } = props; return h.createElement(ActualDropdownComponent, { ...restProps }, children); }; mockedDropdown.defaultProps = ActualDropdownComponent.defaultProps; mockedDropdown.Button = ActualDropdownComponent.Button; return { ...ActualDropdown, __esModule: true, default: mockedDropdown, }; }); describe('DropdownButton', () => { mountTest(DropdownButton); rtlTest(DropdownButton); it('pass appropriate props to Dropdown', () => { const props: DropdownProps = { align: { offset: [10, 20], }, overlay: ( foo ), disabled: false, trigger: ['hover'], open: true, onOpenChange: () => {}, }; const { rerender } = render(); Object.keys(props).forEach((key: keyof DropdownProps) => { expect(dropdownProps[key]).toBe(props[key]); }); rerender(123} visible />); expect(dropdownProps.open).toBe(true); }); it("don't pass open to Dropdown if it's not exits", () => { const menu = ( foo ); render(); expect('open' in dropdownProps).toBe(false); }); it('should support href like Button', () => { const menu = ( foo ); const { asFragment } = render(); expect(asFragment().firstChild).toMatchSnapshot(); }); it('have static property for type detecting', () => { expect(DropdownButton.__ANT_BUTTON).toBe(true); }); it('should pass mouseEnterDelay and mouseLeaveDelay to Dropdown', () => { const menu = ( foo ); render(); expect(dropdownProps.mouseEnterDelay).toBe(1); expect(dropdownProps.mouseLeaveDelay).toBe(2); }); it('should support overlayClassName and overlayStyle', () => { const menu = ( foo ); const { container } = render( , ); expect(container.querySelector('.ant-dropdown')?.classList).toContain('className'); expect((container.querySelector('.ant-dropdown') as HTMLElement).style.color).toContain('red'); }); it('should support loading', () => { const { container } = render(} loading />); expect(container.querySelector('.ant-dropdown-button .ant-btn-loading')?.classList).toContain( 'ant-btn', ); }); });