1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00
metamask-extension/ui/components/component-library/modal/modal.test.tsx

83 lines
2.2 KiB
TypeScript
Raw Permalink Normal View History

/* eslint-disable jest/require-top-level-describe */
import { render, fireEvent } from '@testing-library/react';
import React from 'react';
import { Modal } from './modal';
describe('Modal', () => {
const onClose = jest.fn();
beforeEach(() => {
onClose.mockClear();
});
it('should render the Modal without crashing', () => {
const { getByText, getByTestId } = render(
<Modal onClose={onClose} isOpen data-testid="modal">
<div>modal content</div>
</Modal>,
);
expect(getByText('modal content')).toBeDefined();
expect(getByTestId('modal')).toHaveClass('mm-modal');
});
it('should match snapshot', () => {
const { getByTestId } = render(
<Modal onClose={onClose} isOpen={true} data-testid="test">
<div>modal content</div>
</Modal>,
);
expect(getByTestId('test')).toMatchSnapshot();
});
it('should render with and additional className', () => {
const { getByTestId } = render(
<Modal
onClose={onClose}
isOpen
className="test-class"
data-testid="modal"
>
<div>modal content</div>
</Modal>,
);
expect(getByTestId('modal')).toHaveClass('mm-modal test-class');
});
it('should render the modal when isOpen is true', () => {
const { getByText } = render(
<Modal isOpen={true} onClose={onClose}>
<div>modal content</div>
</Modal>,
);
const modalContent = getByText('modal content');
expect(modalContent).toBeInTheDocument();
});
it('should not render the modal when isOpen is false', () => {
const { queryByText } = render(
<Modal isOpen={false} onClose={onClose}>
<div>modal content</div>
</Modal>,
);
const modalContent = queryByText('modal content');
expect(modalContent).not.toBeInTheDocument();
});
it('should call the onClose callback when clicking the close button', () => {
const { getByText } = render(
<Modal isOpen={true} onClose={onClose}>
<div>modal content</div>
<button onClick={() => onClose()}>Close</button>
</Modal>,
);
const closeButton = getByText('Close');
fireEvent.click(closeButton);
expect(onClose).toHaveBeenCalledTimes(1);
});
});