2022-06-05 11:06:26 +02:00
|
|
|
import { fireEvent, render, screen, waitFor } from '@testing-library/react';
|
|
|
|
import userEvent from '@testing-library/user-event';
|
2020-08-22 11:20:27 +02:00
|
|
|
import { Mock } from 'ts-mockery';
|
2022-05-28 10:47:39 +02:00
|
|
|
import {
|
|
|
|
ImportServersBtn as createImportServersBtn,
|
|
|
|
ImportServersBtnProps,
|
|
|
|
} from '../../../src/servers/helpers/ImportServersBtn';
|
2022-01-01 12:20:09 +01:00
|
|
|
import { ServersImporter } from '../../../src/servers/services/ServersImporter';
|
2022-06-05 11:06:26 +02:00
|
|
|
import { ServersMap, ServerWithId } from '../../../src/servers/data';
|
2018-08-23 16:26:42 +02:00
|
|
|
|
|
|
|
describe('<ImportServersBtn />', () => {
|
2019-04-19 10:29:49 +02:00
|
|
|
const onImportMock = jest.fn();
|
|
|
|
const createServersMock = jest.fn();
|
2021-10-31 12:07:38 +01:00
|
|
|
const importServersFromFile = jest.fn().mockResolvedValue([]);
|
|
|
|
const serversImporterMock = Mock.of<ServersImporter>({ importServersFromFile });
|
2022-05-28 10:47:39 +02:00
|
|
|
const ImportServersBtn = createImportServersBtn(serversImporterMock);
|
2022-06-05 11:06:26 +02:00
|
|
|
const setUp = (props: Partial<ImportServersBtnProps> = {}, servers: ServersMap = {}) => ({
|
|
|
|
user: userEvent.setup(),
|
|
|
|
...render(
|
2021-10-22 18:53:00 +02:00
|
|
|
<ImportServersBtn
|
2022-06-05 11:06:26 +02:00
|
|
|
servers={servers}
|
2022-01-01 12:20:09 +01:00
|
|
|
{...props}
|
|
|
|
createServers={createServersMock}
|
2021-10-22 18:53:00 +02:00
|
|
|
onImport={onImportMock}
|
|
|
|
/>,
|
2022-06-05 11:06:26 +02:00
|
|
|
),
|
|
|
|
});
|
2021-10-22 18:53:00 +02:00
|
|
|
|
|
|
|
afterEach(jest.clearAllMocks);
|
2018-08-23 16:26:42 +02:00
|
|
|
|
2022-06-05 11:06:26 +02:00
|
|
|
it('shows tooltip on button hover', async () => {
|
|
|
|
const { user } = setUp();
|
2021-10-22 18:53:00 +02:00
|
|
|
|
2022-06-05 11:06:26 +02:00
|
|
|
expect(screen.queryByText(/^You can create servers by importing a CSV file/)).not.toBeInTheDocument();
|
|
|
|
await user.hover(screen.getByRole('button'));
|
|
|
|
await waitFor(
|
|
|
|
() => expect(screen.getByText(/^You can create servers by importing a CSV file/)).toBeInTheDocument(),
|
|
|
|
);
|
2018-08-23 16:26:42 +02:00
|
|
|
});
|
|
|
|
|
2021-10-22 18:53:00 +02:00
|
|
|
it.each([
|
2022-03-26 12:17:42 +01:00
|
|
|
[undefined, ''],
|
|
|
|
['foo', 'foo'],
|
|
|
|
['bar', 'bar'],
|
2021-10-22 18:53:00 +02:00
|
|
|
])('allows a class name to be provided', (providedClassName, expectedClassName) => {
|
2022-06-05 11:06:26 +02:00
|
|
|
setUp({ className: providedClassName });
|
|
|
|
expect(screen.getByRole('button')).toHaveAttribute('class', expect.stringContaining(expectedClassName));
|
2021-10-22 18:53:00 +02:00
|
|
|
});
|
|
|
|
|
2021-10-22 19:03:12 +02:00
|
|
|
it.each([
|
2022-06-05 11:06:26 +02:00
|
|
|
[undefined, 'Import from file'],
|
|
|
|
['foo', 'foo'],
|
|
|
|
['bar', 'bar'],
|
|
|
|
])('has expected text', (children, expectedText) => {
|
|
|
|
setUp({ children });
|
|
|
|
expect(screen.getByRole('button')).toHaveTextContent(expectedText);
|
2018-08-23 16:26:42 +02:00
|
|
|
});
|
|
|
|
|
2021-10-31 12:07:38 +01:00
|
|
|
it('imports servers when file input changes', async () => {
|
2022-06-05 11:06:26 +02:00
|
|
|
const { container } = setUp();
|
|
|
|
const input = container.querySelector('[type=file]');
|
2018-08-23 16:26:42 +02:00
|
|
|
|
2022-06-05 11:06:26 +02:00
|
|
|
input && fireEvent.change(input, { target: { files: [''] } });
|
2021-10-31 12:07:38 +01:00
|
|
|
expect(importServersFromFile).toHaveBeenCalledTimes(1);
|
2022-01-01 12:20:09 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
it.each([
|
2022-06-05 11:06:26 +02:00
|
|
|
['Save anyway', true],
|
|
|
|
['Discard', false],
|
|
|
|
])('creates expected servers depending on selected option in modal', async (btnName, savesDuplicatedServers) => {
|
|
|
|
const existingServer = Mock.of<ServerWithId>({ id: 'abc', url: 'existingUrl', apiKey: 'existingApiKey' });
|
|
|
|
const newServer = Mock.of<ServerWithId>({ url: 'newUrl', apiKey: 'newApiKey' });
|
|
|
|
const { container, user } = setUp({}, { abc: existingServer });
|
|
|
|
const input = container.querySelector('[type=file]');
|
|
|
|
importServersFromFile.mockResolvedValue([existingServer, newServer]);
|
|
|
|
|
|
|
|
expect(screen.queryByRole('dialog')).not.toBeInTheDocument();
|
|
|
|
input && fireEvent.change(input, { target: { files: [''] } });
|
|
|
|
await waitFor(() => expect(screen.getByRole('dialog')).toBeInTheDocument());
|
|
|
|
await user.click(screen.getByRole('button', { name: btnName }));
|
|
|
|
|
|
|
|
expect(createServersMock).toHaveBeenCalledWith(savesDuplicatedServers ? [existingServer, newServer] : [newServer]);
|
2021-10-31 12:07:38 +01:00
|
|
|
expect(onImportMock).toHaveBeenCalledTimes(1);
|
2018-08-23 16:26:42 +02:00
|
|
|
});
|
|
|
|
});
|