import React from 'react'; import { mount } from 'enzyme'; import { render } from '@testing-library/react'; import { act } from 'react-dom/test-utils'; import ConfigProvider from '..'; import zhCN from '../../locale/zh_CN'; import Form from '../../form'; describe('ConfigProvider.Form', () => { beforeAll(() => { jest.useFakeTimers(); }); afterAll(() => { jest.useRealTimers(); }); describe('form validateMessages', () => { const renderComponent = ({ validateMessages }) => { const formRef = React.createRef(); const { container } = render(
, ); return [container, formRef]; }; it('set locale zhCN', async () => { const [container, formRef] = renderComponent({}); await act(async () => { try { await formRef.current.validateFields(); } catch (e) { // Do nothing } }); await act(async () => { jest.runAllTimers(); await Promise.resolve(); }); expect(container.querySelector('.ant-form-item-explain')).toHaveTextContent('请输入姓名'); }); it('set locale zhCN and set form validateMessages one item, other use default message', async () => { const [container, formRef] = renderComponent({ validateMessages: { required: '必须' } }); await act(async () => { try { await formRef.current.validateFields(); } catch (e) { // Do nothing } }); await act(async () => { jest.runAllTimers(); await Promise.resolve(); }); const explains = Array.from(container.querySelectorAll('.ant-form-item-explain')); expect(explains[0]).toHaveTextContent('必须'); expect(explains[explains.length - 1]).toHaveTextContent('年龄必须等于17'); }); }); describe('form requiredMark', () => { it('set requiredMark optional', async () => { const wrapper = mount(
, ); expect(wrapper.render()).toMatchSnapshot(); }); }); describe('form colon', () => { it('set colon false', async () => { const wrapper = mount(
, ); expect(wrapper.exists('.ant-form-item-no-colon')).toBeTruthy(); }); it('set colon default', async () => { const wrapper = mount(
, ); expect(wrapper.exists('.ant-form-item-no-colon')).toBeFalsy(); }); }); });