import React from 'react'; import { mount } from 'enzyme'; import Tooltip from '..'; import Button from '../../button'; describe('Tooltip', () => { it('check `onVisibleChange` arguments', () => { const onVisibleChange = jest.fn(); const wrapper = mount(
Hello world!
); // `title` is empty. const div = wrapper.find('div').at(0); div.simulate('mouseenter'); expect(onVisibleChange).not.toHaveBeenCalled(); expect(wrapper.instance().tooltip.props.visible).toBe(false); div.simulate('mouseleave'); expect(onVisibleChange).not.toHaveBeenCalled(); expect(wrapper.instance().tooltip.props.visible).toBe(false); // update `title` value. wrapper.setProps({ title: 'Have a nice day!' }); wrapper.simulate('mouseenter'); expect(onVisibleChange).toHaveBeenLastCalledWith(true); expect(wrapper.instance().tooltip.props.visible).toBe(true); wrapper.simulate('mouseleave'); expect(onVisibleChange).toHaveBeenLastCalledWith(false); expect(wrapper.instance().tooltip.props.visible).toBe(false); // add `visible` props. wrapper.setProps({ visible: false }); wrapper.simulate('mouseenter'); expect(onVisibleChange).toHaveBeenLastCalledWith(true); const lastCount = onVisibleChange.mock.calls.length; expect(wrapper.instance().tooltip.props.visible).toBe(false); // always trigger onVisibleChange wrapper.simulate('mouseleave'); expect(onVisibleChange.mock.calls.length).toBe(lastCount); // no change with lastCount expect(wrapper.instance().tooltip.props.visible).toBe(false); }); it('should hide when mouse leave native disabled button', () => { const onVisibleChange = jest.fn(); const wrapper = mount( ); expect(wrapper.find('span')).toHaveLength(1); const button = wrapper.find('span').at(0); button.simulate('mouseenter'); expect(onVisibleChange).toBeCalledWith(true); expect(wrapper.instance().tooltip.props.visible).toBe(true); button.simulate('mouseleave'); expect(onVisibleChange).toBeCalledWith(false); expect(wrapper.instance().tooltip.props.visible).toBe(false); }); it('should hide when mouse leave antd disabled Button', () => { const onVisibleChange = jest.fn(); const wrapper = mount( ); expect(wrapper.getDOMNode().tagName).toBe('SPAN'); const button = wrapper.find('span').at(0); button.simulate('mouseenter'); expect(onVisibleChange).toBeCalledWith(true); expect(wrapper.instance().tooltip.props.visible).toBe(true); button.simulate('mouseleave'); expect(onVisibleChange).toBeCalledWith(false); expect(wrapper.instance().tooltip.props.visible).toBe(false); }); it('should render disabled Button style properly', () => { const wrapper1 = mount( ); const wrapper2 = mount( ); expect(wrapper1.getDOMNode().style.display).toBe('inline-block'); expect(wrapper2.getDOMNode().style.display).toBe('block'); }); it('should not wrap span when trigger is not hover', () => { const wrapper = mount( ); expect(wrapper.find('span')).toHaveLength(0); }); it('should works for arrowPointAtCenter', () => { const arrowWidth = 5; const horizontalArrowShift = 16; const triggerWidth = 200; const wrapper = mount( ); wrapper.find('button').at(0).simulate('click'); const popupLeftDefault = parseInt(wrapper.node.getPopupDomNode().style.left, 10); const wrapper2 = mount( ); wrapper2.find('button').at(0).simulate('click'); const popupLeftArrowPointAtCenter = parseInt(wrapper2.node.getPopupDomNode().style.left, 10); expect(popupLeftArrowPointAtCenter - popupLeftDefault).toBe((triggerWidth / 2) - horizontalArrowShift - arrowWidth); }); });