2022-11-22 19:39:07 +01:00
|
|
|
import { screen, waitFor } from '@testing-library/react';
|
2023-04-13 21:48:29 +02:00
|
|
|
import { fromPartial } from '@total-typescript/shoehorn';
|
2023-08-07 10:51:08 +02:00
|
|
|
import type { InvalidShortUrlDeletion, ShlinkShortUrl } from '../../../src/api-contract';
|
2023-08-02 09:01:44 +02:00
|
|
|
import { ErrorTypeV2, ErrorTypeV3 } from '../../../src/api-contract';
|
|
|
|
import { DeleteShortUrlModal } from '../../../src/short-urls/helpers/DeleteShortUrlModal';
|
|
|
|
import type { ShortUrlDeletion } from '../../../src/short-urls/reducers/shortUrlDeletion';
|
2022-07-15 22:00:30 +02:00
|
|
|
import { renderWithEvents } from '../../__helpers__/setUpTest';
|
2022-11-22 20:22:03 +01:00
|
|
|
import { TestModalWrapper } from '../../__helpers__/TestModalWrapper';
|
2018-11-01 12:24:16 +01:00
|
|
|
|
|
|
|
describe('<DeleteShortUrlModal />', () => {
|
2023-08-06 21:27:57 +02:00
|
|
|
const shortUrl = fromPartial<ShlinkShortUrl>({
|
2018-11-01 12:24:16 +01:00
|
|
|
tags: [],
|
|
|
|
shortCode: 'abc123',
|
2020-08-26 20:37:36 +02:00
|
|
|
longUrl: 'https://long-domain.com/foo/bar',
|
|
|
|
});
|
2023-05-27 11:57:26 +02:00
|
|
|
const deleteShortUrl = vi.fn().mockResolvedValue(undefined);
|
|
|
|
const shortUrlDeleted = vi.fn();
|
2022-07-15 22:00:30 +02:00
|
|
|
const setUp = (shortUrlDeletion: Partial<ShortUrlDeletion>) => renderWithEvents(
|
2022-11-22 20:22:03 +01:00
|
|
|
<TestModalWrapper
|
|
|
|
renderModal={(args) => (
|
|
|
|
<DeleteShortUrlModal
|
|
|
|
{...args}
|
|
|
|
shortUrl={shortUrl}
|
2023-04-13 21:48:29 +02:00
|
|
|
shortUrlDeletion={fromPartial(shortUrlDeletion)}
|
2022-11-22 20:22:03 +01:00
|
|
|
deleteShortUrl={deleteShortUrl}
|
|
|
|
shortUrlDeleted={shortUrlDeleted}
|
2023-05-27 11:57:26 +02:00
|
|
|
resetDeleteShortUrl={vi.fn()}
|
2022-11-22 20:22:03 +01:00
|
|
|
/>
|
|
|
|
)}
|
2022-07-15 22:00:30 +02:00
|
|
|
/>,
|
|
|
|
);
|
2018-11-01 12:24:16 +01:00
|
|
|
|
|
|
|
it('shows generic error when non-threshold error occurs', () => {
|
2022-07-15 22:00:30 +02:00
|
|
|
setUp({
|
2018-11-01 12:24:16 +01:00
|
|
|
loading: false,
|
|
|
|
error: true,
|
|
|
|
shortCode: 'abc123',
|
2023-04-13 21:48:29 +02:00
|
|
|
errorData: fromPartial({ type: 'OTHER_ERROR' }),
|
2018-11-01 12:24:16 +01:00
|
|
|
});
|
2022-10-12 10:43:30 +02:00
|
|
|
expect(screen.getByText('Something went wrong while deleting the URL :(').parentElement).not.toHaveClass(
|
|
|
|
'bg-warning',
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it.each([
|
2023-04-13 21:48:29 +02:00
|
|
|
[fromPartial<InvalidShortUrlDeletion>({ type: ErrorTypeV3.INVALID_SHORT_URL_DELETION })],
|
|
|
|
[fromPartial<InvalidShortUrlDeletion>({ type: ErrorTypeV2.INVALID_SHORT_URL_DELETION })],
|
2022-10-12 10:43:30 +02:00
|
|
|
])('shows specific error when threshold error occurs', (errorData) => {
|
|
|
|
setUp({ loading: false, error: true, shortCode: 'abc123', errorData });
|
|
|
|
expect(screen.getByText('Something went wrong while deleting the URL :(').parentElement).toHaveClass('bg-warning');
|
2018-11-01 12:24:16 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
it('disables submit button when loading', () => {
|
2022-07-15 22:00:30 +02:00
|
|
|
setUp({
|
2018-11-01 12:24:16 +01:00
|
|
|
loading: true,
|
|
|
|
error: false,
|
|
|
|
shortCode: 'abc123',
|
|
|
|
});
|
2022-07-15 22:00:30 +02:00
|
|
|
expect(screen.getByRole('button', { name: 'Deleting...' })).toHaveAttribute('disabled');
|
2018-11-01 12:24:16 +01:00
|
|
|
});
|
|
|
|
|
2022-07-15 22:00:30 +02:00
|
|
|
it('enables submit button when proper short code is provided', async () => {
|
|
|
|
const { user } = setUp({
|
2018-11-01 12:24:16 +01:00
|
|
|
loading: false,
|
|
|
|
error: false,
|
2022-11-25 19:08:40 +01:00
|
|
|
shortCode: 'abc123',
|
2018-11-01 12:24:16 +01:00
|
|
|
});
|
2022-07-15 22:00:30 +02:00
|
|
|
const getDeleteBtn = () => screen.getByRole('button', { name: 'Delete' });
|
2018-11-01 12:24:16 +01:00
|
|
|
|
2022-07-15 22:00:30 +02:00
|
|
|
expect(getDeleteBtn()).toHaveAttribute('disabled');
|
2022-11-25 19:08:40 +01:00
|
|
|
await user.type(screen.getByPlaceholderText('Insert delete'), 'delete');
|
2022-07-15 22:00:30 +02:00
|
|
|
expect(getDeleteBtn()).not.toHaveAttribute('disabled');
|
2018-11-01 12:24:16 +01:00
|
|
|
});
|
|
|
|
|
2022-07-15 22:00:30 +02:00
|
|
|
it('tries to delete short URL when form is submit', async () => {
|
|
|
|
const { user } = setUp({
|
2018-11-01 12:24:16 +01:00
|
|
|
loading: false,
|
|
|
|
error: false,
|
2022-11-22 20:22:03 +01:00
|
|
|
deleted: true,
|
2022-11-25 19:08:40 +01:00
|
|
|
shortCode: 'abc123',
|
2018-11-01 12:24:16 +01:00
|
|
|
});
|
|
|
|
|
2021-10-31 12:33:17 +01:00
|
|
|
expect(deleteShortUrl).not.toHaveBeenCalled();
|
2022-11-25 19:08:40 +01:00
|
|
|
await user.type(screen.getByPlaceholderText('Insert delete'), 'delete');
|
2022-07-15 22:00:30 +02:00
|
|
|
await user.click(screen.getByRole('button', { name: 'Delete' }));
|
2021-10-31 12:33:17 +01:00
|
|
|
expect(deleteShortUrl).toHaveBeenCalledTimes(1);
|
2022-11-22 20:22:03 +01:00
|
|
|
await waitFor(() => expect(shortUrlDeleted).toHaveBeenCalledTimes(1));
|
2018-11-01 12:24:16 +01:00
|
|
|
});
|
|
|
|
});
|