import React from 'react'; import { render, mount } from 'enzyme'; import Slider from '..'; import ConfigProvider from '../../config-provider'; import mountTest from '../../../tests/shared/mountTest'; import rtlTest from '../../../tests/shared/rtlTest'; import focusTest from '../../../tests/shared/focusTest'; import SliderTooltip from '../SliderTooltip'; import { sleep } from '../../../tests/utils'; describe('Slider', () => { mountTest(Slider); rtlTest(Slider); focusTest(Slider, { refFocus: true }); it('should show tooltip when hovering slider handler', () => { const wrapper = mount(); wrapper.find('.ant-slider-handle').at(0).simulate('mouseEnter'); expect(render(wrapper.find('Trigger').instance().getComponent())).toMatchSnapshot(); wrapper.find('.ant-slider-handle').at(0).simulate('mouseLeave'); expect(render(wrapper.find('Trigger').instance().getComponent())).toMatchSnapshot(); }); it('should show correct placement tooltip when set tooltipPlacement', () => { const wrapper = mount(); wrapper.find('.ant-slider-handle').at(0).simulate('mouseEnter'); expect(render(wrapper.find('Trigger').instance().getComponent())).toMatchSnapshot(); wrapper.find('.ant-slider-handle').at(0).simulate('mouseLeave'); expect(render(wrapper.find('Trigger').instance().getComponent())).toMatchSnapshot(); }); it('when tooltipVisible is true, tooltip should show always, or should never show', () => { let wrapper = mount(); expect(wrapper.find('.ant-tooltip-content').at(0).hasClass('ant-tooltip-hidden')).toBe(false); wrapper.find('.ant-slider-handle').at(0).simulate('mouseEnter'); expect(wrapper.find('.ant-tooltip-content').at(0).hasClass('ant-tooltip-hidden')).toBe(false); wrapper.find('.ant-slider-handle').at(0).simulate('click'); expect(wrapper.find('.ant-tooltip-content').at(0).hasClass('ant-tooltip-hidden')).toBe(false); wrapper = mount(); expect(wrapper.find('.ant-tooltip-content').length).toBe(0); }); it('should render in RTL direction', () => { const wrapper = mount( , ); expect(render(wrapper)).toMatchSnapshot(); }); it('should keepAlign by calling forcePopupAlign', async () => { let ref; mount( { ref = node; }} />, ); ref.forcePopupAlign = jest.fn(); await sleep(20); expect(ref.forcePopupAlign).toHaveBeenCalled(); }); it('tipFormatter should not crash with undefined value', () => { [undefined, null].forEach(value => { mount(); }); }); });