import React from 'react'; import mountTest from '../../../tests/shared/mountTest'; import { render, waitFakeTimer, fireEvent, act } from '../../../tests/utils'; import ConfigProvider from '../../config-provider'; import Wave from '../wave'; import type { InternalWave } from '../wave'; describe('Wave component', () => { mountTest(Wave); beforeAll(() => { jest.useFakeTimers(); }); afterAll(() => { jest.useRealTimers(); }); beforeEach(() => { document.body.innerHTML = ''; }); afterEach(() => { jest.clearAllTimers(); const styles = document.getElementsByTagName('style'); for (let i = 0; i < styles.length; i += 1) { styles[i].remove(); } }); function filterStyles(styles: any) { return Array.from(styles).filter( (style: HTMLStyleElement) => !style.hasAttribute('data-css-hash'), ); } it('isHidden works', () => { const TEST_NODE_ENV = process.env.NODE_ENV; process.env.NODE_ENV = 'development'; const { container, unmount } = render( , ); expect(container.querySelector('button')?.className).toBe(''); container.querySelector('button')?.click(); expect( container.querySelector('button')?.hasAttribute('ant-click-animating-without-extra-node'), ).toBeFalsy(); unmount(); process.env.NODE_ENV = TEST_NODE_ENV; }); it('isHidden is mocked', () => { const { container, unmount } = render( , ); expect(container.querySelector('button')?.className).toBe(''); container.querySelector('button')?.click(); expect( container.querySelector('button')?.getAttribute('ant-click-animating-without-extra-node'), ).toBe('false'); unmount(); }); it('wave color is grey', async () => { const { container, unmount } = render( , ); container.querySelector('button')?.click(); await waitFakeTimer(); let styles: HTMLCollectionOf | HTMLStyleElement[] = ( container.querySelector('button')?.getRootNode() as HTMLButtonElement ).getElementsByTagName('style'); styles = filterStyles(styles); expect(styles.length).toBe(0); unmount(); }); it('wave color is not grey', async () => { const { container, unmount } = render( , ); container.querySelector('button')?.click(); await waitFakeTimer(); let styles: HTMLCollectionOf | HTMLStyleElement[] = ( container.querySelector('button')?.getRootNode() as HTMLButtonElement ).getElementsByTagName('style'); styles = filterStyles(styles); expect(styles.length).toBe(1); expect(styles[0].innerHTML).toContain('--antd-wave-shadow-color: red;'); unmount(); }); it('read wave color from border-top-color', async () => { const { container, unmount } = render(
button
, ); container.querySelector('div')?.click(); await waitFakeTimer(); let styles: HTMLCollectionOf | HTMLStyleElement[] = ( container.querySelector('div')?.getRootNode() as HTMLDivElement ).getElementsByTagName('style'); styles = filterStyles(styles); expect(styles.length).toBe(1); expect(styles[0].innerHTML).toContain('--antd-wave-shadow-color: blue;'); unmount(); }); it('read wave color from background color', async () => { const { container, unmount } = render(
button
, ); container.querySelector('div')?.click(); await waitFakeTimer(); let styles: HTMLCollectionOf | HTMLStyleElement[] = ( container.querySelector('div')?.getRootNode() as HTMLDivElement ).getElementsByTagName('style'); styles = filterStyles(styles); expect(styles.length).toBe(1); expect(styles[0].innerHTML).toContain('--antd-wave-shadow-color: green;'); unmount(); }); it('read wave color from border firstly', async () => { const { container, unmount } = render(
button
, ); container.querySelector('div')?.click(); await waitFakeTimer(); let styles: HTMLCollectionOf | HTMLStyleElement[] = ( container.querySelector('div')?.getRootNode() as HTMLDivElement ).getElementsByTagName('style'); styles = filterStyles(styles); expect(styles.length).toBe(1); expect(styles[0].innerHTML).toContain('--antd-wave-shadow-color: yellow;'); unmount(); }); it('hidden element with -leave className', async () => { const { container, unmount } = render( , ); container.querySelector('button')?.click(); await waitFakeTimer(); let styles: HTMLCollectionOf | HTMLStyleElement[] = ( container.querySelector('button')?.getRootNode() as HTMLButtonElement ).getElementsByTagName('style'); styles = filterStyles(styles); expect(styles.length).toBe(0); unmount(); }); it('ConfigProvider csp', async () => { const { container, unmount } = render( , ); container.querySelector('button')?.click(); await waitFakeTimer(); let styles: HTMLCollectionOf | HTMLStyleElement[] = ( container.querySelector('button')?.getRootNode() as HTMLButtonElement ).getElementsByTagName('style'); styles = filterStyles(styles); expect(styles[0].getAttribute('nonce')).toBe('YourNonceCode'); unmount(); }); it('bindAnimationEvent should return when node is null', () => { const ref = React.createRef(); render( , ); expect(ref.current?.bindAnimationEvent()).toBe(undefined); }); it('bindAnimationEvent.onClick should return when children is hidden', () => { const ref = React.createRef(); render( , ); expect(ref.current?.bindAnimationEvent()).toBe(undefined); }); it('bindAnimationEvent.onClick should return when children is input', () => { const ref = React.createRef(); render( , ); expect(ref.current?.bindAnimationEvent()).toBe(undefined); }); it('should not throw when click it', () => { expect(() => { const { container } = render(
, ); fireEvent.click(container); }).not.toThrow(); }); it('should not throw when no children', () => { expect(() => render()).not.toThrow(); }); it('wave color should inferred if border is transparent and background is not', async () => { const { container, unmount } = render( , ); fireEvent.click(container.querySelector('button')!); await waitFakeTimer(); let styles = (container.querySelector('button')!.getRootNode() as any).getElementsByTagName( 'style', ); styles = filterStyles(styles); expect(styles.length).toBe(1); expect(styles[0].innerHTML).toContain('--antd-wave-shadow-color: red;'); unmount(); }); it('wave color should inferred if borderTopColor is transparent and borderColor is not', async () => { const { container, unmount } = render( , ); fireEvent.click(container.querySelector('button')!); await waitFakeTimer(); let styles = (container.querySelector('button')!.getRootNode() as any).getElementsByTagName( 'style', ); styles = filterStyles(styles); expect(styles[0].innerHTML).toContain('--antd-wave-shadow-color: red;'); unmount(); }); it('Wave style should append to validate element', () => { jest.useFakeTimers(); const { container } = render(
, ); // Mock shadow container const fakeDoc = document.createElement('div'); fakeDoc.append('text'); fakeDoc.appendChild(document.createElement('span')); expect(fakeDoc.childNodes).toHaveLength(2); const elem = container.querySelector('.bamboo'); if (elem) { elem.getRootNode = () => fakeDoc; // Click should not throw fireEvent.click(elem); act(() => { jest.runAllTimers(); }); expect(fakeDoc.querySelector('style')).toBeTruthy(); } jest.useRealTimers(); }); });