shlink-web-client/test/api/ShlinkApiError.test.tsx

32 lines
1.5 KiB
TypeScript
Raw Normal View History

import { render, screen } from '@testing-library/react';
2020-12-22 10:05:32 +01:00
import { Mock } from 'ts-mockery';
2023-02-18 10:40:37 +01:00
import type { ShlinkApiErrorProps } from '../../src/api/ShlinkApiError';
import { ShlinkApiError } from '../../src/api/ShlinkApiError';
import type { InvalidArgumentError, ProblemDetailsError } from '../../src/api/types/errors';
import { ErrorTypeV2, ErrorTypeV3 } from '../../src/api/types/errors';
2020-12-22 10:05:32 +01:00
describe('<ShlinkApiError />', () => {
const setUp = (props: ShlinkApiErrorProps) => render(<ShlinkApiError {...props} />);
2020-12-22 10:05:32 +01:00
it.each([
2022-03-26 12:17:42 +01:00
[undefined, 'the fallback', 'the fallback'],
[Mock.all<ProblemDetailsError>(), 'the fallback', 'the fallback'],
[Mock.of<ProblemDetailsError>({ detail: 'the detail' }), 'the fallback', 'the detail'],
2020-12-22 10:05:32 +01:00
])('renders proper message', (errorData, fallbackMessage, expectedMessage) => {
const { container } = setUp({ errorData, fallbackMessage });
2020-12-22 10:05:32 +01:00
expect(container.firstChild).toHaveTextContent(expectedMessage);
expect(screen.queryByRole('paragraph')).not.toBeInTheDocument();
2020-12-22 10:05:32 +01:00
});
it.each([
2022-03-26 12:17:42 +01:00
[undefined, 0],
[Mock.all<ProblemDetailsError>(), 0],
[Mock.of<InvalidArgumentError>({ type: ErrorTypeV2.INVALID_ARGUMENT, invalidElements: [] }), 1],
[Mock.of<InvalidArgumentError>({ type: ErrorTypeV3.INVALID_ARGUMENT, invalidElements: [] }), 1],
2020-12-22 10:05:32 +01:00
])('renders list of invalid elements when provided error is an InvalidError', (errorData, expectedElementsCount) => {
setUp({ errorData });
expect(screen.queryAllByText(/^Invalid elements/)).toHaveLength(expectedElementsCount);
2020-12-22 10:05:32 +01:00
});
});