shlink-web-client/test/domains/ManageDomains.test.tsx

70 lines
2.9 KiB
TypeScript
Raw Normal View History

import { screen, waitFor } from '@testing-library/react';
import { fromPartial } from '@total-typescript/shoehorn';
2023-02-18 10:40:37 +01:00
import type { ShlinkDomain } from '../../src/api/types';
2023-02-18 11:11:01 +01:00
import type { ProblemDetailsError } from '../../src/api/types/errors';
import { ManageDomains } from '../../src/shlink-web-component/domains/ManageDomains';
import type { DomainsList } from '../../src/shlink-web-component/domains/reducers/domainsList';
2022-07-10 19:44:49 +02:00
import { renderWithEvents } from '../__helpers__/setUpTest';
2021-08-24 20:13:54 +02:00
describe('<ManageDomains />', () => {
2023-05-27 11:57:26 +02:00
const listDomains = vi.fn();
const filterDomains = vi.fn();
const setUp = (domainsList: DomainsList) => renderWithEvents(
<ManageDomains
listDomains={listDomains}
filterDomains={filterDomains}
2023-05-27 11:57:26 +02:00
editDomainRedirects={vi.fn()}
checkDomainHealth={vi.fn()}
domainsList={domainsList}
selectedServer={fromPartial({})}
/>,
);
2021-08-24 20:13:54 +02:00
it('shows loading message while domains are loading', () => {
setUp(fromPartial({ loading: true, filteredDomains: [] }));
2021-08-24 20:13:54 +02:00
expect(screen.getByText('Loading...')).toBeInTheDocument();
expect(screen.queryByText('Error loading domains :(')).not.toBeInTheDocument();
2021-08-24 20:13:54 +02:00
});
it.each([
[undefined, 'Error loading domains :('],
[fromPartial<ProblemDetailsError>({}), 'Error loading domains :('],
[fromPartial<ProblemDetailsError>({ detail: 'Foo error!!' }), 'Foo error!!'],
])('shows error result when domains loading fails', (errorData, expectedErrorMessage) => {
setUp(fromPartial({ loading: false, error: true, errorData, filteredDomains: [] }));
2021-08-24 20:13:54 +02:00
expect(screen.queryByText('Loading...')).not.toBeInTheDocument();
expect(screen.getByText(expectedErrorMessage)).toBeInTheDocument();
2021-08-24 20:13:54 +02:00
});
it('filters domains when SearchField changes', async () => {
const { user } = setUp(fromPartial({ loading: false, error: false, filteredDomains: [] }));
2021-08-24 20:13:54 +02:00
expect(filterDomains).not.toHaveBeenCalled();
await user.type(screen.getByPlaceholderText('Search...'), 'Foo');
await waitFor(() => expect(filterDomains).toHaveBeenCalledWith('Foo'));
2021-08-24 20:13:54 +02:00
});
it('shows expected headers and one row when list of domains is empty', () => {
setUp(fromPartial({ loading: false, error: false, filteredDomains: [] }));
2021-08-24 20:13:54 +02:00
expect(screen.getAllByRole('columnheader')).toHaveLength(7);
expect(screen.getByText('No results found')).toBeInTheDocument();
2021-08-24 20:13:54 +02:00
});
it('has many rows if multiple domains are provided', () => {
const filteredDomains: ShlinkDomain[] = [
fromPartial({ domain: 'foo' }),
fromPartial({ domain: 'bar' }),
fromPartial({ domain: 'baz' }),
2021-08-24 20:13:54 +02:00
];
setUp(fromPartial({ loading: false, error: false, filteredDomains }));
2021-08-24 20:13:54 +02:00
expect(screen.getAllByRole('row')).toHaveLength(filteredDomains.length + 1);
expect(screen.getByText('foo')).toBeInTheDocument();
expect(screen.getByText('bar')).toBeInTheDocument();
expect(screen.getByText('baz')).toBeInTheDocument();
2021-08-24 20:13:54 +02:00
});
});