2022-06-04 09:46:49 +02:00
|
|
|
import { render, screen } from '@testing-library/react';
|
2023-09-05 09:08:42 +02:00
|
|
|
import { fromPartial } from '@total-typescript/shoehorn';
|
2022-06-04 09:46:49 +02:00
|
|
|
import { MemoryRouter } from 'react-router-dom';
|
2023-02-18 10:40:37 +01:00
|
|
|
import type { ServerWithId } from '../../src/servers/data';
|
2023-09-05 09:08:42 +02:00
|
|
|
import { ManageServersRowFactory } from '../../src/servers/ManageServersRow';
|
2021-10-23 10:34:20 +02:00
|
|
|
|
|
|
|
describe('<ManageServersRow />', () => {
|
2023-09-05 09:08:42 +02:00
|
|
|
const ManageServersRow = ManageServersRowFactory(fromPartial({
|
|
|
|
ManageServersRowDropdown: () => <span>ManageServersRowDropdown</span>,
|
|
|
|
}));
|
2021-10-23 10:34:20 +02:00
|
|
|
const server: ServerWithId = {
|
|
|
|
name: 'My server',
|
|
|
|
url: 'https://example.com',
|
|
|
|
apiKey: '123',
|
|
|
|
id: 'abc',
|
|
|
|
};
|
2022-06-04 09:46:49 +02:00
|
|
|
const setUp = (hasAutoConnect = false, autoConnect = false) => render(
|
|
|
|
<MemoryRouter>
|
|
|
|
<table>
|
|
|
|
<tbody>
|
|
|
|
<ManageServersRow server={{ ...server, autoConnect }} hasAutoConnect={hasAutoConnect} />
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
</MemoryRouter>,
|
|
|
|
);
|
2021-10-23 10:34:20 +02:00
|
|
|
|
|
|
|
it.each([
|
2022-03-26 12:17:42 +01:00
|
|
|
[true, 4],
|
|
|
|
[false, 3],
|
2021-10-23 10:34:20 +02:00
|
|
|
])('renders expected amount of columns', (hasAutoConnect, expectedCols) => {
|
2022-06-04 09:46:49 +02:00
|
|
|
setUp(hasAutoConnect);
|
|
|
|
|
|
|
|
const td = screen.getAllByRole('cell');
|
|
|
|
const th = screen.getAllByRole('columnheader');
|
2021-10-23 10:34:20 +02:00
|
|
|
|
|
|
|
expect(td.length + th.length).toEqual(expectedCols);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders a dropdown', () => {
|
2022-06-04 09:46:49 +02:00
|
|
|
setUp();
|
|
|
|
expect(screen.getByText('ManageServersRowDropdown')).toBeInTheDocument();
|
2021-10-23 10:34:20 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
it.each([
|
2022-06-04 09:46:49 +02:00
|
|
|
[true],
|
|
|
|
[false],
|
|
|
|
])('renders auto-connect icon only if server is autoConnect', (autoConnect) => {
|
|
|
|
const { container } = setUp(true, autoConnect);
|
|
|
|
expect(container).toMatchSnapshot();
|
2021-10-23 10:34:20 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
it('renders server props where appropriate', () => {
|
2022-06-04 09:46:49 +02:00
|
|
|
setUp();
|
|
|
|
|
|
|
|
const link = screen.getByRole('link');
|
2021-10-23 10:34:20 +02:00
|
|
|
|
2022-06-04 09:46:49 +02:00
|
|
|
expect(link).toHaveAttribute('href', `/server/${server.id}`);
|
|
|
|
expect(link).toHaveTextContent(server.name);
|
|
|
|
expect(screen.getByText(server.url)).toBeInTheDocument();
|
2021-10-23 10:34:20 +02:00
|
|
|
});
|
|
|
|
});
|