import React from 'react'; import { mount } from 'enzyme'; import Carousel from '..'; describe('Carousel', () => { beforeEach(() => { jest.useFakeTimers(); }); afterEach(() => { jest.useRealTimers(); }); it('should has innerSlider', () => { const wrapper = mount(
, ); const { innerSlider } = wrapper.instance(); const innerSliderFromRefs = wrapper.instance().slick.innerSlider; expect(innerSlider).toBe(innerSliderFromRefs); expect(typeof innerSlider.slickNext).toBe('function'); }); it('should has prev, next and go function', () => { const wrapper = mount(
1
2
3
, ); const { prev, next, goTo } = wrapper.instance(); expect(typeof prev).toBe('function'); expect(typeof next).toBe('function'); expect(typeof goTo).toBe('function'); expect(wrapper.instance().slick.innerSlider.state.currentSlide).toBe(0); wrapper.instance().goTo(2); jest.runAllTimers(); expect(wrapper.instance().slick.innerSlider.state.currentSlide).toBe(2); wrapper.instance().prev(); jest.runAllTimers(); expect(wrapper.instance().slick.innerSlider.state.currentSlide).toBe(1); wrapper.instance().next(); jest.runAllTimers(); expect(wrapper.instance().slick.innerSlider.state.currentSlide).toBe(2); }); it('should trigger autoPlay after window resize', async () => { jest.useRealTimers(); const wrapper = mount(
1
2
3
, ); const spy = jest.spyOn(wrapper.instance().slick.innerSlider, 'autoPlay'); window.resizeTo(1000); expect(spy).not.toHaveBeenCalled(); await new Promise(resolve => setTimeout(resolve, 500)); expect(spy).toHaveBeenCalled(); }); it('cancel resize listener when unmount', async () => { const wrapper = mount(
1
2
3
, ); const { onWindowResized } = wrapper.instance(); const spy = jest.spyOn(wrapper.instance().onWindowResized, 'cancel'); const spy2 = jest.spyOn(window, 'removeEventListener'); wrapper.unmount(); expect(spy).toHaveBeenCalled(); expect(spy2).toHaveBeenCalledWith('resize', onWindowResized); }); describe('should works for dotPosition', () => { ['left', 'right', 'top', 'bottom'].forEach(dotPosition => { it(dotPosition, () => { const wrapper = mount(
, ); expect(wrapper.render()).toMatchSnapshot(); }); }); }); it('warning', () => { const warnSpy = jest.spyOn(console, 'error').mockImplementation(() => {}); mount(
, ); expect(warnSpy).toHaveBeenCalledWith( 'Warning: [antd: Carousel] `vertical` is deprecated, please use `dotPosition` instead.', ); warnSpy.mockRestore(); }); describe('should active when children change', () => { it('should active', () => { const wrapper = mount(); wrapper.setProps({ children:
, }); wrapper.update(); expect(wrapper.find('.slick-active').length).toBeTruthy(); }); it('should keep initialSlide', () => { const wrapper = mount(); wrapper.setProps({ children: [
,
,
], }); wrapper.update(); expect( wrapper .find('.slick-dots li') .at(1) .hasClass('slick-active'), ).toBeTruthy(); }); }); });