import React from 'react'; import { render, mount } from 'enzyme'; import Icon from '..'; import ReactIcon from '@ant-design/icons-react'; import Tooltip from '../../tooltip'; import { getThemeFromTypeName, withThemeSuffix } from '../utils'; describe('Icon', () => { it('should render to a ...', () => { const wrapper = render( ); expect(wrapper).toMatchSnapshot(); }); it('should support basic usage', () => { const wrapper = render(
); expect(wrapper).toMatchSnapshot(); }); it('should support older usage', () => { const wrapper = render(
); expect(wrapper).toMatchSnapshot(); }); it('should support two-tone icon', () => { const wrapper = render( ); expect(wrapper).toMatchSnapshot(); }); it('should support config global two-tone primary color', () => { const colors = ReactIcon.getTwoToneColors(); Icon.setTwoToneColor('#1890ff'); expect(Icon.getTwoToneColor()).toBe('#1890ff'); const wrapper = render( ); expect(wrapper).toMatchSnapshot(); ReactIcon.setTwoToneColors(colors); }); it('should support pass svg paths as children', () => { const wrapper = render( Cool Home ); expect(wrapper).toMatchSnapshot(); }); it('should give warning and render {null}', () => { const wrapper = render( ); expect(wrapper).toMatchSnapshot(); }); it('should support wrapped by Tooltip', () => { const onVisibleChange = jest.fn(); const wrapper = mount( ); expect(wrapper.find('i')).toHaveLength(1); const icon = wrapper.find('i').at(0); icon.simulate('mouseenter'); expect(onVisibleChange).toBeCalledWith(true); expect(wrapper.instance().tooltip.props.visible).toBe(true); icon.simulate('mouseleave'); expect(onVisibleChange).toBeCalledWith(false); expect(wrapper.instance().tooltip.props.visible).toBe(false); }); describe('`component` prop', () => { it('can access to svg defs if has children', () => { const wrapper = render( ( { React.Children.map( svgProps.children, child => React.cloneElement( child, child.type === 'path' ? { fill: 'scriptUrl(#gradient)' } : {} ) ) } )} > Cool Home ); expect(wrapper).toMatchSnapshot(); }); }); it('should support svg react component', () => { const SvgComponent = props => ( Cool Home ); const wrapper = render( Cool Home ); expect(wrapper).toMatchSnapshot(); }); }); describe('Icon.createFromIconfontCN()', () => { const IconFont = Icon.createFromIconfontCN({ scriptUrl: '//at.alicdn.com/t/font_8d5l8fzk5b87iudi.js', }); it('should support iconfont.cn', () => { const wrapper = render(
); expect(wrapper).toMatchSnapshot(); }); }); describe('utils', () => { it('getThemeFromTypeName() should work', () => { const testCases = ['check-circle', 'check-circle-o', 'check-circle-fill', 'check-circle-twotone']; const result = testCases.map(type => getThemeFromTypeName(type)); expect(result).toEqual( [null, 'outlined', 'filled', 'twoTone'] ); }); it('withThemeSuffix() should work', () => { const testCases = [ { type: 'home', theme: 'filled' }, { type: 'home', theme: 'outlined' }, { type: 'home', theme: 'twoTone' }, { type: 'home', theme: 'This-is-the-secret' }, { type: 'home-o', theme: 'filled' }, { type: 'home-fill', theme: 'outlined' }, { type: 'home-o', theme: 'twoTone' }, { type: 'home-o', theme: 'This-is-the-secret' }, ]; const result = testCases.map(({ type, theme }) => withThemeSuffix(type, theme)); expect(result).toEqual( ['home-fill', 'home-o', 'home-twotone', 'home', 'home-o-fill', 'home-fill-o', 'home-o-twotone', 'home-o'] ); }); });