2020-05-25 16:27:02 +08:00
|
|
|
import React from 'react';
|
|
|
|
import { mount } from 'enzyme';
|
|
|
|
import Dropdown from '..';
|
|
|
|
import Menu from '../../menu';
|
|
|
|
import mountTest from '../../../tests/shared/mountTest';
|
|
|
|
import rtlTest from '../../../tests/shared/rtlTest';
|
2021-02-17 17:09:13 +08:00
|
|
|
import { sleep } from '../../../tests/utils';
|
2020-05-25 16:27:02 +08:00
|
|
|
|
|
|
|
describe('Dropdown', () => {
|
|
|
|
mountTest(() => (
|
|
|
|
<Dropdown menu={<Menu />}>
|
|
|
|
<span />
|
|
|
|
</Dropdown>
|
|
|
|
));
|
|
|
|
|
|
|
|
rtlTest(() => (
|
|
|
|
<Dropdown menu={<Menu />}>
|
|
|
|
<span />
|
|
|
|
</Dropdown>
|
|
|
|
));
|
|
|
|
|
|
|
|
it('overlay is function and has custom transitionName', () => {
|
|
|
|
const wrapper = mount(
|
|
|
|
<Dropdown overlay={() => <div>menu</div>} transitionName="move-up" visible>
|
|
|
|
<button type="button">button</button>
|
|
|
|
</Dropdown>,
|
|
|
|
);
|
|
|
|
expect(wrapper).toMatchRenderedSnapshot();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('overlay is string', () => {
|
|
|
|
const wrapper = mount(
|
|
|
|
<Dropdown overlay="string" visible>
|
|
|
|
<button type="button">button</button>
|
|
|
|
</Dropdown>,
|
|
|
|
);
|
|
|
|
expect(wrapper).toMatchRenderedSnapshot();
|
|
|
|
});
|
2021-02-17 17:09:13 +08:00
|
|
|
|
|
|
|
it('support Menu expandIcon', async () => {
|
|
|
|
const props = {
|
|
|
|
overlay: (
|
|
|
|
<Menu expandIcon={<span id="customExpandIcon" />}>
|
2021-06-29 17:55:02 +08:00
|
|
|
<Menu.Item key="1">foo</Menu.Item>
|
2021-02-17 17:09:13 +08:00
|
|
|
<Menu.SubMenu title="SubMenu">
|
2021-06-29 17:55:02 +08:00
|
|
|
<Menu.Item key="1">foo</Menu.Item>
|
2021-02-17 17:09:13 +08:00
|
|
|
</Menu.SubMenu>
|
|
|
|
</Menu>
|
|
|
|
),
|
|
|
|
visible: true,
|
|
|
|
getPopupContainer: node => node,
|
|
|
|
};
|
|
|
|
|
|
|
|
const wrapper = mount(
|
|
|
|
<Dropdown {...props}>
|
|
|
|
<button type="button">button</button>
|
|
|
|
</Dropdown>,
|
|
|
|
);
|
|
|
|
await sleep(500);
|
|
|
|
expect(wrapper.find(Dropdown).find('#customExpandIcon').length).toBe(1);
|
|
|
|
});
|
2020-05-25 16:27:02 +08:00
|
|
|
});
|