2023-05-30 07:01:07 +00:00
|
|
|
import { render, screen } from '@testing-library/react'
|
2023-05-31 08:34:26 +00:00
|
|
|
|
|
|
|
import Card from 'components/Card'
|
2023-06-05 06:47:42 +00:00
|
|
|
|
|
|
|
jest.mock('components/Text', () => {
|
|
|
|
return {
|
|
|
|
__esModule: true,
|
|
|
|
default: (props: any) =>
|
|
|
|
require('utils/testing').createMockComponent('mock-text-component', props),
|
|
|
|
}
|
|
|
|
})
|
2023-05-30 07:01:07 +00:00
|
|
|
|
|
|
|
describe('<Card />', () => {
|
|
|
|
const defaultProps = {
|
|
|
|
children: <></>,
|
|
|
|
}
|
|
|
|
|
2023-06-05 06:47:42 +00:00
|
|
|
afterAll(() => {
|
|
|
|
jest.unmock('components/Text')
|
|
|
|
})
|
|
|
|
|
2023-05-30 07:01:07 +00:00
|
|
|
it('should render', () => {
|
|
|
|
const { container } = render(<Card {...defaultProps} />)
|
|
|
|
expect(container).toBeInTheDocument()
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should handle `className` prop correctly', () => {
|
|
|
|
const testClass = 'test-class'
|
|
|
|
const { container } = render(<Card {...defaultProps} className={testClass} />)
|
|
|
|
expect(container.querySelector('section')).toHaveClass(testClass)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should handle `contentClassName` prop correctly', () => {
|
|
|
|
const testClass = 'test-class'
|
|
|
|
const { container } = render(<Card {...defaultProps} contentClassName={testClass} />)
|
|
|
|
|
|
|
|
expect(container.querySelector('div')).toHaveClass(testClass)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should handle `title` prop as string correctly', () => {
|
2023-06-05 06:47:42 +00:00
|
|
|
const testTitle = 'this-is-the-test-title'
|
|
|
|
const { queryByText } = render(<Card {...defaultProps} title={testTitle} />)
|
2023-05-30 07:01:07 +00:00
|
|
|
|
2023-06-05 06:47:42 +00:00
|
|
|
expect(queryByText(testTitle)).toBeInTheDocument()
|
2023-05-30 07:01:07 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
it('should handle `title` prop as element correctly', () => {
|
2023-06-05 06:47:42 +00:00
|
|
|
const testTitle = <p data-testid='test-title'>Test title</p>
|
|
|
|
const { queryByTestId } = render(<Card {...defaultProps} title={testTitle} />)
|
|
|
|
|
|
|
|
expect(queryByTestId('test-title')).toBeInTheDocument()
|
|
|
|
expect(queryByTestId('mock-text-component')).not.toBeInTheDocument()
|
2023-05-30 07:01:07 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
it('should handle `id` prop as element correctly', () => {
|
|
|
|
const testId = 'test-id'
|
2023-06-05 06:47:42 +00:00
|
|
|
const { container } = render(<Card {...defaultProps} id={testId} />)
|
|
|
|
expect(container.querySelector(`section#${testId}`)).toBeInTheDocument()
|
2023-05-30 07:01:07 +00:00
|
|
|
})
|
|
|
|
})
|