import React from 'react'; import { act } from 'react-dom/test-utils'; import ConfigProvider from '..'; import { render } from '../../../tests/utils'; import type { FormInstance } from '../../form'; import Form from '../../form'; import zhCN from '../../locale/zh_CN'; describe('ConfigProvider.Form', () => { beforeAll(() => { jest.useFakeTimers(); }); afterAll(() => { jest.useRealTimers(); }); describe('form validateMessages', () => { const renderComponent = ({ validateMessages }: { validateMessages?: any }) => { const formRef = React.createRef(); const { container } = render(
, ); return [container, formRef] as const; }; 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(); }); act(() => { jest.runAllTimers(); }); 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(); }); act(() => { jest.runAllTimers(); }); 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', () => { const { container } = render(
, ); expect(container.firstChild).toMatchSnapshot(); }); }); describe('form colon', () => { it('set colon false', () => { const { container } = render(
, ); expect(container.querySelector('.ant-form-item-no-colon')).toBeTruthy(); }); it('set colon default', () => { const { container } = render(
, ); expect(container.querySelector('.ant-form-item-no-colon')).toBeFalsy(); }); }); });