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('.box'); div.simulate('mouseenter'); expect(onVisibleChange).not.toHaveBeenCalled(); expect(wrapper.ref('tooltip').prop('visible')).toBe(false); div.simulate('mouseleave'); expect(onVisibleChange).not.toHaveBeenCalled(); expect(wrapper.ref('tooltip').prop('visible')).toBe(false); // update `title` value. wrapper.setProps({ title: 'Have a nice day!' }); div.simulate('mouseenter'); expect(onVisibleChange).toHaveBeenLastCalledWith(true); expect(wrapper.ref('tooltip').prop('visible')).toBe(true); div.simulate('mouseleave'); expect(onVisibleChange).toHaveBeenLastCalledWith(false); expect(wrapper.ref('tooltip').prop('visible')).toBe(false); // add `visible` props. wrapper.setProps({ visible: false }); div.simulate('mouseenter'); expect(onVisibleChange).toHaveBeenLastCalledWith(true); const lastCount = onVisibleChange.mock.calls.length; expect(wrapper.ref('tooltip').prop('visible')).toBe(false); // always trigger onVisibleChange div.simulate('mouseleave'); expect(onVisibleChange.mock.calls.length).toBe(lastCount); // no change with lastCount expect(wrapper.ref('tooltip').prop('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.ref('tooltip').prop('visible')).toBe(true); button.simulate('mouseleave'); expect(onVisibleChange).toBeCalledWith(false); expect(wrapper.ref('tooltip').prop('visible')).toBe(false); }); it('should hide when mouse leave antd disabled Button', () => { const onVisibleChange = jest.fn(); const wrapper = mount( ); expect(wrapper).toMatchSnapshot(); const button = wrapper.find('span').at(0); button.simulate('mouseenter'); expect(onVisibleChange).toBeCalledWith(true); expect(wrapper.ref('tooltip').prop('visible')).toBe(true); button.simulate('mouseleave'); expect(onVisibleChange).toBeCalledWith(false); expect(wrapper.ref('tooltip').prop('visible')).toBe(false); }); it('should render disabled Button style properly', () => { const wrapper1 = mount( ); const wrapper2 = mount( ); expect(wrapper1).toMatchSnapshot(); expect(wrapper2).toMatchSnapshot(); }); it('should not wrap span when trigger is not hover', () => { const wrapper = mount( ); expect(wrapper.find('span')).toHaveLength(0); }); it('should works for arrowPointAtCenter', () => { jest.dontMock('rc-trigger', () => { 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); }); }); });