import { render, screen } from '@testing-library/react'; import { fromPartial } from '@total-typescript/shoehorn'; import type { InvalidArgumentError, ProblemDetailsError } from '../../src/api-contract'; import { ErrorTypeV2, ErrorTypeV3 } from '../../src/api-contract'; import type { ShlinkApiErrorProps } from '../../src/common/ShlinkApiError'; import { ShlinkApiError } from '../../src/common/ShlinkApiError'; describe('', () => { const setUp = (props: ShlinkApiErrorProps) => render(); it.each([ [undefined, 'the fallback', 'the fallback'], [fromPartial({}), 'the fallback', 'the fallback'], [fromPartial({ detail: 'the detail' }), 'the fallback', 'the detail'], ])('renders proper message', (errorData, fallbackMessage, expectedMessage) => { const { container } = setUp({ errorData, fallbackMessage }); expect(container.firstChild).toHaveTextContent(expectedMessage); expect(screen.queryByRole('paragraph')).not.toBeInTheDocument(); }); it.each([ [undefined, 0], [fromPartial({}), 0], [fromPartial({ type: ErrorTypeV2.INVALID_ARGUMENT, invalidElements: [] }), 1], [fromPartial({ type: ErrorTypeV3.INVALID_ARGUMENT, invalidElements: [] }), 1], ])('renders list of invalid elements when provided error is an InvalidError', (errorData, expectedElementsCount) => { setUp({ errorData }); expect(screen.queryAllByText(/^Invalid elements/)).toHaveLength(expectedElementsCount); }); });