import React from 'react'; import Layout from '..'; import { render } from '../../../tests/utils'; const { Sider, Footer, Header } = Layout; describe('Layout.Warning', () => { (['Layout', 'Header', 'Footer', 'Sider'] as const).forEach((tag) => { const ComponentMap = { Layout, Header, Footer, Sider }; // Since react will not throw warning for same message. // We create a new test suite here it(`not warning of non-element attr on ${tag}`, () => { /** * Should not call: * Warning: React does not recognize the `suffixCls` prop on a DOM element. * If you intentionally want it to appear in the DOM as a custom attribute, * spell it as lowercase `suffixcls` instead. * If you accidentally passed it from a parent component, * remove it from the DOM element. */ const errorSpy = jest.spyOn(console, 'error').mockImplementation(() => {}); const Component = ComponentMap[tag]; render(<Component>{tag}</Component>); expect(errorSpy).not.toHaveBeenCalled(); errorSpy.mockRestore(); }); }); });