2021-10-23 12:33:32 +03:00
|
|
|
import { Mock } from 'ts-mockery';
|
2022-07-10 00:03:21 +03:00
|
|
|
import { screen, waitFor } from '@testing-library/react';
|
2022-06-04 10:34:46 +03:00
|
|
|
import { MemoryRouter } from 'react-router-dom';
|
2023-02-18 12:40:37 +03:00
|
|
|
import type ServersExporter from '../../src/servers/services/ServersExporter';
|
2021-10-23 12:33:32 +03:00
|
|
|
import { ManageServers as createManageServers } from '../../src/servers/ManageServers';
|
2023-02-18 12:40:37 +03:00
|
|
|
import type { ServersMap, ServerWithId } from '../../src/servers/data';
|
2022-07-10 20:44:49 +03:00
|
|
|
import { renderWithEvents } from '../__helpers__/setUpTest';
|
2021-10-23 12:33:32 +03:00
|
|
|
|
|
|
|
describe('<ManageServers />', () => {
|
|
|
|
const exportServers = jest.fn();
|
|
|
|
const serversExporter = Mock.of<ServersExporter>({ exportServers });
|
2022-05-29 13:18:21 +03:00
|
|
|
const useTimeoutToggle = jest.fn().mockReturnValue([false, jest.fn()]);
|
2022-06-04 10:34:46 +03:00
|
|
|
const ManageServers = createManageServers(
|
|
|
|
serversExporter,
|
|
|
|
() => <span>ImportServersBtn</span>,
|
|
|
|
useTimeoutToggle,
|
2022-08-03 18:29:07 +03:00
|
|
|
({ hasAutoConnect }) => <tr><td>ManageServersRow {hasAutoConnect ? '[YES]' : '[NO]'}</td></tr>,
|
2022-06-04 10:34:46 +03:00
|
|
|
);
|
2021-10-23 12:33:32 +03:00
|
|
|
const createServerMock = (value: string, autoConnect = false) => Mock.of<ServerWithId>(
|
|
|
|
{ id: value, name: value, url: value, autoConnect },
|
|
|
|
);
|
2022-07-10 00:03:21 +03:00
|
|
|
const setUp = (servers: ServersMap = {}) => renderWithEvents(
|
|
|
|
<MemoryRouter><ManageServers servers={servers} /></MemoryRouter>,
|
|
|
|
);
|
2021-10-23 12:33:32 +03:00
|
|
|
|
|
|
|
afterEach(jest.clearAllMocks);
|
|
|
|
|
2022-06-04 10:34:46 +03:00
|
|
|
it('shows search field which allows searching servers, affecting te amount of rendered rows', async () => {
|
|
|
|
const { user } = setUp({
|
2021-10-23 12:33:32 +03:00
|
|
|
foo: createServerMock('foo'),
|
|
|
|
bar: createServerMock('bar'),
|
|
|
|
baz: createServerMock('baz'),
|
|
|
|
});
|
2022-06-04 10:34:46 +03:00
|
|
|
const search = async (searchTerm: string) => {
|
|
|
|
await user.clear(screen.getByPlaceholderText('Search...'));
|
|
|
|
await user.type(screen.getByPlaceholderText('Search...'), searchTerm);
|
|
|
|
};
|
2021-10-23 12:33:32 +03:00
|
|
|
|
2022-06-04 10:34:46 +03:00
|
|
|
expect(screen.getAllByText(/^ManageServersRow/)).toHaveLength(3);
|
|
|
|
expect(screen.queryByText('No servers found.')).not.toBeInTheDocument();
|
2021-10-23 12:33:32 +03:00
|
|
|
|
2022-06-04 10:34:46 +03:00
|
|
|
await search('foo');
|
|
|
|
await waitFor(() => expect(screen.getAllByText(/^ManageServersRow/)).toHaveLength(1));
|
|
|
|
expect(screen.queryByText('No servers found.')).not.toBeInTheDocument();
|
2021-10-23 12:33:32 +03:00
|
|
|
|
2022-08-07 14:26:26 +03:00
|
|
|
await search('Ba');
|
2022-06-04 10:34:46 +03:00
|
|
|
await waitFor(() => expect(screen.getAllByText(/^ManageServersRow/)).toHaveLength(2));
|
|
|
|
expect(screen.queryByText('No servers found.')).not.toBeInTheDocument();
|
2021-10-23 12:33:32 +03:00
|
|
|
|
2022-06-04 10:34:46 +03:00
|
|
|
await search('invalid');
|
|
|
|
await waitFor(() => expect(screen.queryByText(/^ManageServersRow/)).not.toBeInTheDocument());
|
|
|
|
expect(screen.getByText('No servers found.')).toBeInTheDocument();
|
2021-10-23 12:33:32 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
it.each([
|
2022-03-26 14:17:42 +03:00
|
|
|
[createServerMock('foo'), 3],
|
|
|
|
[createServerMock('foo', true), 4],
|
2021-10-23 12:33:32 +03:00
|
|
|
])('shows different amount of columns if there are at least one auto-connect server', (server, expectedCols) => {
|
2022-06-04 10:34:46 +03:00
|
|
|
setUp({ server });
|
|
|
|
|
|
|
|
expect(screen.getAllByRole('columnheader')).toHaveLength(expectedCols);
|
|
|
|
if (server.autoConnect) {
|
|
|
|
expect(screen.getByText(/\[YES\]/)).toBeInTheDocument();
|
|
|
|
expect(screen.queryByText(/\[NO\]/)).not.toBeInTheDocument();
|
|
|
|
} else {
|
|
|
|
expect(screen.queryByText(/\[YES\]/)).not.toBeInTheDocument();
|
|
|
|
expect(screen.getByText(/\[NO\]/)).toBeInTheDocument();
|
|
|
|
}
|
2021-10-23 12:33:32 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
it.each([
|
2022-06-04 10:34:46 +03:00
|
|
|
[{}, 0],
|
|
|
|
[{ foo: createServerMock('foo') }, 1],
|
2021-10-23 12:33:32 +03:00
|
|
|
])('shows export button if the list of servers is not empty', (servers, expectedButtons) => {
|
2022-06-04 10:34:46 +03:00
|
|
|
setUp(servers);
|
|
|
|
expect(screen.queryAllByRole('button', { name: 'Export servers' })).toHaveLength(expectedButtons);
|
2021-10-23 12:33:32 +03:00
|
|
|
});
|
|
|
|
|
2022-06-04 10:34:46 +03:00
|
|
|
it('allows exporting servers when clicking on button', async () => {
|
|
|
|
const { user } = setUp({ foo: createServerMock('foo') });
|
2021-10-23 12:33:32 +03:00
|
|
|
|
|
|
|
expect(exportServers).not.toHaveBeenCalled();
|
2022-06-04 10:34:46 +03:00
|
|
|
await user.click(screen.getByRole('button', { name: 'Export servers' }));
|
2021-10-23 12:33:32 +03:00
|
|
|
expect(exportServers).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
2022-06-04 10:34:46 +03:00
|
|
|
it.each([[true], [false]])('shows an error message if an error occurs while importing servers', (hasError) => {
|
|
|
|
useTimeoutToggle.mockReturnValue([hasError, jest.fn()]);
|
2021-10-23 12:33:32 +03:00
|
|
|
|
2022-06-04 10:34:46 +03:00
|
|
|
setUp({ foo: createServerMock('foo') });
|
2021-10-23 12:33:32 +03:00
|
|
|
|
2022-06-04 10:34:46 +03:00
|
|
|
if (hasError) {
|
|
|
|
expect(
|
|
|
|
screen.getByText('The servers could not be imported. Make sure the format is correct.'),
|
|
|
|
).toBeInTheDocument();
|
|
|
|
} else {
|
|
|
|
expect(
|
|
|
|
screen.queryByText('The servers could not be imported. Make sure the format is correct.'),
|
|
|
|
).not.toBeInTheDocument();
|
|
|
|
}
|
2021-10-23 12:33:32 +03:00
|
|
|
});
|
|
|
|
});
|