import React from 'react';
import { mount } from 'enzyme';
import { render } from '../../../tests/utils';
import Popover from '..';
import mountTest from '../../../tests/shared/mountTest';
import ConfigProvider from '../../config-provider';
describe('Popover', () => {
mountTest(Popover);
it('should show overlay when trigger is clicked', () => {
const ref = React.createRef();
const popover = mount(
show me your code
,
);
expect(ref.current.getPopupDomNode()).toBe(null);
popover.find('span').simulate('click');
expect(popover.find('Trigger PopupInner').props().visible).toBeTruthy();
});
it('shows content for render functions', () => {
const renderTitle = () => 'some-title';
const renderContent = () => 'some-content';
const ref = React.createRef();
const popover = mount(
show me your code
,
);
popover.find('span').simulate('click');
const popup = ref.current.getPopupDomNode();
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 ref = React.createRef();
const popover = mount(
show me your code
,
);
popover.find('span').simulate('click');
const popup = ref.current.getPopupDomNode();
expect(popup).toBe(null);
});
it('should not render popover when the title & content props is empty', () => {
const ref = React.createRef();
const popover = mount(
show me your code
,
);
popover.find('span').simulate('click');
const popup = ref.current.getPopupDomNode();
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 wrapper = mount(
show me your Rtl demo
,
);
expect(wrapper.render()).toMatchSnapshot();
});
});