2023-04-19 19:36:01 +02:00
|
|
|
/* eslint-disable jest/require-top-level-describe */
|
|
|
|
import { render, fireEvent } from '@testing-library/react';
|
|
|
|
import React from 'react';
|
|
|
|
import { PopoverHeader } from './popover-header';
|
|
|
|
|
|
|
|
describe('PopoverHeader', () => {
|
|
|
|
it('should render PopoverHeader correctly', () => {
|
|
|
|
const { getByTestId, container } = render(
|
2023-04-25 23:27:54 +02:00
|
|
|
<PopoverHeader data-testid="popover-header">PopoverHeader</PopoverHeader>,
|
2023-04-19 19:36:01 +02:00
|
|
|
);
|
|
|
|
expect(getByTestId('popover-header')).toHaveClass('mm-popover-header');
|
|
|
|
expect(container).toMatchSnapshot();
|
|
|
|
});
|
|
|
|
|
2023-04-25 23:27:54 +02:00
|
|
|
it('should render popover header children as a string', () => {
|
2023-04-19 19:36:01 +02:00
|
|
|
const { getByText } = render(
|
|
|
|
<PopoverHeader data-testid="popover-header">
|
2023-04-25 23:27:54 +02:00
|
|
|
PopoverHeader test
|
|
|
|
</PopoverHeader>,
|
|
|
|
);
|
|
|
|
expect(getByText('PopoverHeader test')).toBeDefined();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should render popover header children as a node', () => {
|
|
|
|
const { getByText, getByTestId } = render(
|
|
|
|
<PopoverHeader data-testid="popover-header">
|
|
|
|
<div data-testid="div">PopoverHeader test</div>
|
2023-04-19 19:36:01 +02:00
|
|
|
</PopoverHeader>,
|
|
|
|
);
|
2023-04-25 23:27:54 +02:00
|
|
|
expect(getByText('PopoverHeader test')).toBeDefined();
|
|
|
|
expect(getByTestId('div')).toBeDefined();
|
2023-04-19 19:36:01 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should render popover header back button', () => {
|
|
|
|
const onBackTest = jest.fn();
|
|
|
|
const { getByTestId } = render(
|
|
|
|
<PopoverHeader
|
|
|
|
onBack={onBackTest}
|
|
|
|
backButtonProps={{ 'data-testid': 'back' }}
|
|
|
|
>
|
2023-04-25 23:27:54 +02:00
|
|
|
PopoverHeader
|
2023-04-19 19:36:01 +02:00
|
|
|
</PopoverHeader>,
|
|
|
|
);
|
|
|
|
|
|
|
|
const backButton = getByTestId('back');
|
|
|
|
fireEvent.click(backButton);
|
|
|
|
|
|
|
|
expect(onBackTest).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should render popover header close button', () => {
|
|
|
|
const onCloseTest = jest.fn();
|
|
|
|
const { getByTestId } = render(
|
|
|
|
<PopoverHeader
|
|
|
|
onClose={onCloseTest}
|
|
|
|
closeButtonProps={{ 'data-testid': 'close' }}
|
|
|
|
>
|
2023-04-25 23:27:54 +02:00
|
|
|
PopoverHeader
|
2023-04-19 19:36:01 +02:00
|
|
|
</PopoverHeader>,
|
|
|
|
);
|
|
|
|
|
|
|
|
const closeButton = getByTestId('close');
|
|
|
|
fireEvent.click(closeButton);
|
|
|
|
|
|
|
|
expect(onCloseTest).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
});
|