import React from 'react'; import Popover from '..'; import mountTest from '../../../tests/shared/mountTest'; import { fireEvent, render } from '../../../tests/utils'; import ConfigProvider from '../../config-provider'; import type { TooltipRef } from '../../tooltip'; const { _InternalPanelDoNotUseOrYouWillBeFired: InternalPanelDoNotUseOrYouWillBeFired } = Popover; describe('Popover', () => { mountTest(Popover); const eventObject = expect.objectContaining({ target: expect.anything(), preventDefault: expect.any(Function), }); it('should show overlay when trigger is clicked', () => { const ref = React.createRef(); const { container } = render( show me your code , ); expect(container.querySelector('.ant-popover-inner-content')).toBeFalsy(); fireEvent.click(container.querySelector('span')!); expect(container.querySelector('.ant-popover-inner-content')).toBeTruthy(); }); it('should support defaultOpen', () => { const { container } = render( show me your code , ); expect(container.querySelector('.ant-popover')).toBeTruthy(); }); it('shows content for render functions', () => { const renderTitle = () => 'some-title'; const renderContent = () => 'some-content'; const ref = React.createRef(); const { container } = render( show me your code , ); fireEvent.click(container.querySelector('span')!); const popup = document.querySelector('.ant-popover')!; expect(popup).not.toBe(null); expect(popup.innerHTML).toContain('some-title'); expect(popup.innerHTML).toContain('some-content'); expect(popup.innerHTML).toMatchSnapshot(); }); it('handles empty title/content props safely', () => { const { container } = render( show me your code , ); fireEvent.click(container.querySelector('span')!); const popup = document.querySelector('.ant-popover'); expect(popup).toBe(null); }); it('should not render popover when the title & content props is empty', () => { const { container } = render( show me your code , ); fireEvent.click(container.querySelector('span')!); const popup = document.querySelector('.ant-popover'); expect(popup).toBe(null); }); it('props#overlay do not warn anymore', () => { const errorSpy = jest.spyOn(console, 'error').mockImplementation(() => {}); const overlay = jest.fn(); render( show me your code , ); expect(errorSpy).not.toHaveBeenCalled(); expect(overlay).not.toHaveBeenCalled(); }); it(`should be rendered correctly in RTL direction`, () => { const { container } = render( show me your Rtl demo , ); expect(Array.from(container.children)).toMatchSnapshot(); }); it('should right work when content is null & title is null', () => { expect(() => { render(); }).not.toThrow(); }); it('should be closed by pressing ESC', () => { const onOpenChange = jest.fn((_, e) => { e?.persist?.(); }); const wrapper = render( Delete , ); const triggerNode = wrapper.container.querySelectorAll('span')[0]; fireEvent.click(triggerNode); expect(onOpenChange).toHaveBeenLastCalledWith(true, undefined); fireEvent.keyDown(triggerNode, { key: 'Escape', keyCode: 27 }); expect(onOpenChange).toHaveBeenLastCalledWith(false, eventObject); }); it('should not display overlay when the content is null/undefined', () => { [null, undefined].forEach((item) => { const { container } = render( item} content={() => item} trigger="click"> show me your code , ); fireEvent.click(container.querySelector('span')!); const popup = document.querySelector('.ant-popover'); expect(popup).toBe(null); }); }); });