shlink-web-client/test/utils/Result.test.tsx
2023-08-03 09:13:10 +02:00

33 lines
1.3 KiB
TypeScript

import { render, screen } from '@testing-library/react';
import type { ResultProps, ResultType } from '../../shlink-frontend-kit/src/block/Result';
import { Result } from '../../shlink-frontend-kit/src/block/Result';
describe('<Result />', () => {
const setUp = (props: ResultProps) => render(<Result {...props} />);
it.each([
['success' as ResultType, 'bg-main text-white'],
['error' as ResultType, 'bg-danger text-white'],
['warning' as ResultType, 'bg-warning'],
])('renders expected classes based on type', (type, expectedClasses) => {
setUp({ type });
expect(screen.getByRole('document')).toHaveClass(expectedClasses);
});
it.each([
['foo'],
['bar'],
])('renders provided classes in root element', (className) => {
const { container } = setUp({ type: 'success', className });
expect(container.firstChild).toHaveClass(className);
});
it.each([{ small: true }, { small: false }])('renders small results properly', ({ small }) => {
const { container } = setUp({ type: 'success', small });
const bigElement = container.querySelectorAll('.col-md-10');
const smallElement = container.querySelectorAll('.col-12');
expect(bigElement).toHaveLength(small ? 0 : 1);
expect(smallElement).toHaveLength(small ? 1 : 0);
});
});