2022-05-02 20:34:33 +03:00
|
|
|
import { render, screen } from '@testing-library/react';
|
2023-04-13 22:48:29 +03:00
|
|
|
import { fromPartial } from '@total-typescript/shoehorn';
|
2023-07-29 11:43:15 +03:00
|
|
|
import type { ShlinkApiErrorProps } from '../../shlink-web-component/common/ShlinkApiError';
|
|
|
|
import { ShlinkApiError } from '../../shlink-web-component/common/ShlinkApiError';
|
2023-02-18 12:40:37 +03:00
|
|
|
import type { InvalidArgumentError, ProblemDetailsError } from '../../src/api/types/errors';
|
|
|
|
import { ErrorTypeV2, ErrorTypeV3 } from '../../src/api/types/errors';
|
2020-12-22 12:05:32 +03:00
|
|
|
|
|
|
|
describe('<ShlinkApiError />', () => {
|
2022-05-02 20:34:33 +03:00
|
|
|
const setUp = (props: ShlinkApiErrorProps) => render(<ShlinkApiError {...props} />);
|
2020-12-22 12:05:32 +03:00
|
|
|
|
|
|
|
it.each([
|
2022-03-26 14:17:42 +03:00
|
|
|
[undefined, 'the fallback', 'the fallback'],
|
2023-04-13 22:48:29 +03:00
|
|
|
[fromPartial<ProblemDetailsError>({}), 'the fallback', 'the fallback'],
|
|
|
|
[fromPartial<ProblemDetailsError>({ detail: 'the detail' }), 'the fallback', 'the detail'],
|
2020-12-22 12:05:32 +03:00
|
|
|
])('renders proper message', (errorData, fallbackMessage, expectedMessage) => {
|
2022-05-02 20:34:33 +03:00
|
|
|
const { container } = setUp({ errorData, fallbackMessage });
|
2020-12-22 12:05:32 +03:00
|
|
|
|
2022-05-02 20:34:33 +03:00
|
|
|
expect(container.firstChild).toHaveTextContent(expectedMessage);
|
|
|
|
expect(screen.queryByRole('paragraph')).not.toBeInTheDocument();
|
2020-12-22 12:05:32 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
it.each([
|
2022-03-26 14:17:42 +03:00
|
|
|
[undefined, 0],
|
2023-04-13 22:48:29 +03:00
|
|
|
[fromPartial<ProblemDetailsError>({}), 0],
|
|
|
|
[fromPartial<InvalidArgumentError>({ type: ErrorTypeV2.INVALID_ARGUMENT, invalidElements: [] }), 1],
|
|
|
|
[fromPartial<InvalidArgumentError>({ type: ErrorTypeV3.INVALID_ARGUMENT, invalidElements: [] }), 1],
|
2020-12-22 12:05:32 +03:00
|
|
|
])('renders list of invalid elements when provided error is an InvalidError', (errorData, expectedElementsCount) => {
|
2022-05-02 20:34:33 +03:00
|
|
|
setUp({ errorData });
|
|
|
|
expect(screen.queryAllByText(/^Invalid elements/)).toHaveLength(expectedElementsCount);
|
2020-12-22 12:05:32 +03:00
|
|
|
});
|
|
|
|
});
|