import { fireEvent, screen } from '@testing-library/react'; import { fromPartial } from '@total-typescript/shoehorn'; import { createMemoryHistory } from 'history'; import { Router } from 'react-router-dom'; import type { ReachableServer, SelectedServer } from '../../src/servers/data'; import { EditServerFactory } from '../../src/servers/EditServer'; import { checkAccessibility } from '../__helpers__/accessibility'; import { renderWithEvents } from '../__helpers__/setUpTest'; describe('', () => { const ServerError = vi.fn(); const editServerMock = vi.fn(); const defaultSelectedServer = fromPartial({ id: 'abc123', name: 'the_name', url: 'the_url', apiKey: 'the_api_key', }); const EditServer = EditServerFactory(fromPartial({ ServerError })); const setUp = (selectedServer: SelectedServer = defaultSelectedServer) => { const history = createMemoryHistory({ initialEntries: ['/foo', '/bar'] }); return { history, ...renderWithEvents( , ), }; }; it('passes a11y checks', () => checkAccessibility(setUp())); it('renders nothing if selected server is not reachable', () => { setUp(fromPartial({})); expect(screen.queryByText('Edit')).not.toBeInTheDocument(); expect(screen.queryByText('Cancel')).not.toBeInTheDocument(); expect(screen.queryByText('Save')).not.toBeInTheDocument(); }); it('renders server title', () => { setUp(); expect(screen.getByText(`Edit "${defaultSelectedServer.name}"`)).toBeInTheDocument(); }); it('display the server info in the form components', () => { setUp(); expect(screen.getByDisplayValue('the_name')).toBeInTheDocument(); expect(screen.getByDisplayValue('the_url')).toBeInTheDocument(); expect(screen.getByDisplayValue('the_api_key')).toBeInTheDocument(); }); it('edits server and redirects to it when form is submitted', async () => { const { user, history } = setUp(); await user.type(screen.getByDisplayValue('the_name'), ' edited'); await user.type(screen.getByDisplayValue('the_url'), ' edited'); // TODO Using fire event because userEvent.click on the Submit button does not submit the form // await user.click(screen.getByRole('button', { name: 'Save' })); fireEvent.submit(screen.getByRole('form')); expect(editServerMock).toHaveBeenCalledWith('abc123', { name: 'the_name edited', url: 'the_url edited', apiKey: 'the_api_key', }); // After saving we go back, to the first route from history's initialEntries expect(history.location.pathname).toEqual('/foo'); }); });