shlink-web-client/test/servers/ManageServersRowDropdown.test.tsx

56 lines
2.3 KiB
TypeScript
Raw Normal View History

import { screen } from '@testing-library/react';
import { fromPartial } from '@total-typescript/shoehorn';
import { MemoryRouter } from 'react-router-dom';
2023-02-18 10:40:37 +01:00
import type { ServerWithId } from '../../src/servers/data';
2021-10-23 10:55:52 +02:00
import { ManageServersRowDropdown as createManageServersRowDropdown } from '../../src/servers/ManageServersRowDropdown';
2022-07-10 19:44:49 +02:00
import { renderWithEvents } from '../__helpers__/setUpTest';
2021-10-23 10:55:52 +02:00
describe('<ManageServersRowDropdown />', () => {
const ManageServersRowDropdown = createManageServersRowDropdown(
({ isOpen }) => <span>DeleteServerModal {isOpen ? '[OPEN]' : '[CLOSED]'}</span>,
);
2023-05-27 11:57:26 +02:00
const setAutoConnect = vi.fn();
const setUp = (autoConnect = false) => {
const server = fromPartial<ServerWithId>({ id: 'abc123', autoConnect });
return renderWithEvents(
<MemoryRouter>
<ManageServersRowDropdown setAutoConnect={setAutoConnect} server={server} />
</MemoryRouter>,
);
2021-10-23 10:55:52 +02:00
};
it('renders expected amount of dropdown items', async () => {
const { user } = setUp();
2021-10-23 10:55:52 +02:00
expect(screen.queryByRole('menu')).not.toBeInTheDocument();
await user.click(screen.getByRole('button'));
expect(screen.getByRole('menu')).toBeInTheDocument();
expect(screen.getAllByRole('menuitem')).toHaveLength(4);
expect(screen.getByRole('menuitem', { name: 'Connect' })).toHaveAttribute('href', '/server/abc123');
expect(screen.getByRole('menuitem', { name: 'Edit server' })).toHaveAttribute('href', '/server/abc123/edit');
2021-10-23 10:55:52 +02:00
});
it('allows toggling auto-connect', async () => {
const { user } = setUp();
2021-10-23 10:55:52 +02:00
expect(setAutoConnect).not.toHaveBeenCalled();
await user.click(screen.getByRole('button'));
await user.click(screen.getByRole('menuitem', { name: 'Auto-connect' }));
2021-10-23 10:55:52 +02:00
expect(setAutoConnect).toHaveBeenCalledWith(expect.objectContaining({ id: 'abc123' }), true);
});
it('renders deletion modal', async () => {
const { user } = setUp();
2021-10-23 10:55:52 +02:00
expect(screen.queryByText('DeleteServerModal [OPEN]')).not.toBeInTheDocument();
expect(screen.getByText('DeleteServerModal [CLOSED]')).toBeInTheDocument();
2021-10-23 10:55:52 +02:00
await user.click(screen.getByRole('button'));
await user.click(screen.getByRole('menuitem', { name: 'Remove server' }));
2021-10-23 10:55:52 +02:00
expect(screen.getByText('DeleteServerModal [OPEN]')).toBeInTheDocument();
expect(screen.queryByText('DeleteServerModal [CLOSED]')).not.toBeInTheDocument();
2021-10-23 10:55:52 +02:00
});
});