import { createCache, StyleProvider } from '@ant-design/cssinjs'; import { SmileOutlined } from '@ant-design/icons'; import IconContext from '@ant-design/icons/lib/components/Context'; import React from 'react'; import ConfigProvider from '..'; import { render } from '../../../tests/utils'; import Button from '../../button'; describe('ConfigProvider.Icon', () => { beforeEach(() => { // eslint-disable-next-line jest/no-standalone-expect expect(document.querySelectorAll('style')).toHaveLength(0); }); afterEach(() => { document.querySelectorAll('style').forEach((style) => { style.parentNode?.removeChild(style); }); }); describe('csp', () => { it('raw', () => { render( , ); const styleNode = document.querySelector('style'); expect(styleNode?.nonce).toEqual('little'); }); it('mix with iconPrefixCls', () => { const { container } = render( , ); const styleNode = document.querySelector('style'); expect(container.querySelector('.bamboo-smile')).toBeTruthy(); expect(styleNode?.nonce).toEqual('light'); }); }); it('nest', () => { const Checker = () => { const { csp } = React.useContext(IconContext); return
{csp?.nonce}
; }; const { container } = render( , ); const styleNode = document.querySelector('style'); expect(container.querySelector('.bamboo-smile')).toBeTruthy(); expect(styleNode?.nonce).toEqual('light'); expect(container.querySelector('#csp')?.innerHTML).toEqual('light'); }); it('cssinjs should support nonce', () => { render(