2023-12-31 20:16:06 +01:00
|
|
|
import { act, render, screen } from '@testing-library/react';
|
2023-04-13 21:48:29 +02:00
|
|
|
import { fromPartial } from '@total-typescript/shoehorn';
|
2023-12-18 23:05:17 +01:00
|
|
|
import { MemoryRouter } from 'react-router-dom';
|
2023-09-03 11:06:35 +02:00
|
|
|
import { AppFactory } from '../../src/app/App';
|
2023-09-30 10:20:28 +02:00
|
|
|
import { checkAccessibility } from '../__helpers__/accessibility';
|
2022-02-07 22:17:57 +01:00
|
|
|
|
2018-08-26 19:48:21 +02:00
|
|
|
describe('<App />', () => {
|
2023-09-03 11:06:35 +02:00
|
|
|
const App = AppFactory(
|
|
|
|
fromPartial({
|
|
|
|
MainHeader: () => <>MainHeader</>,
|
|
|
|
Home: () => <>Home</>,
|
|
|
|
ShlinkWebComponentContainer: () => <>ShlinkWebComponentContainer</>,
|
|
|
|
CreateServer: () => <>CreateServer</>,
|
|
|
|
EditServer: () => <>EditServer</>,
|
|
|
|
Settings: () => <>SettingsComp</>,
|
|
|
|
ManageServers: () => <>ManageServers</>,
|
|
|
|
ShlinkVersionsContainer: () => <>ShlinkVersions</>,
|
|
|
|
}),
|
2021-11-13 23:04:59 +01:00
|
|
|
);
|
2023-12-31 19:59:56 +01:00
|
|
|
const setUp = async (activeRoute = '/') => act(() => render(
|
2023-12-18 23:05:17 +01:00
|
|
|
<MemoryRouter initialEntries={[{ pathname: activeRoute }]}>
|
|
|
|
<App
|
|
|
|
fetchServers={() => {}}
|
|
|
|
servers={{}}
|
|
|
|
settings={fromPartial({})}
|
2023-12-31 20:16:06 +01:00
|
|
|
appUpdated={false}
|
2023-12-18 23:05:17 +01:00
|
|
|
resetAppUpdate={() => {}}
|
|
|
|
/>
|
|
|
|
</MemoryRouter>,
|
2023-12-31 19:59:56 +01:00
|
|
|
));
|
2018-08-26 19:48:21 +02:00
|
|
|
|
2023-09-30 10:20:28 +02:00
|
|
|
it('passes a11y checks', () => checkAccessibility(setUp()));
|
|
|
|
|
2023-12-31 19:59:56 +01:00
|
|
|
it('renders children components', async () => {
|
|
|
|
await setUp();
|
2021-11-13 23:04:59 +01:00
|
|
|
|
2022-05-03 17:36:34 +02:00
|
|
|
expect(screen.getByText('MainHeader')).toBeInTheDocument();
|
|
|
|
expect(screen.getByText('ShlinkVersions')).toBeInTheDocument();
|
2021-11-13 23:04:59 +01:00
|
|
|
});
|
2021-06-06 18:54:55 +02:00
|
|
|
|
2022-05-03 17:36:34 +02:00
|
|
|
it.each([
|
|
|
|
['/settings/foo', 'SettingsComp'],
|
|
|
|
['/settings/bar', 'SettingsComp'],
|
|
|
|
['/manage-servers', 'ManageServers'],
|
|
|
|
['/server/create', 'CreateServer'],
|
|
|
|
['/server/abc123/edit', 'EditServer'],
|
|
|
|
['/server/def456/edit', 'EditServer'],
|
2023-08-04 08:56:06 +02:00
|
|
|
['/server/abc123/foo', 'ShlinkWebComponentContainer'],
|
|
|
|
['/server/def456/bar', 'ShlinkWebComponentContainer'],
|
2022-05-03 17:36:34 +02:00
|
|
|
['/other', 'Oops! We could not find requested route.'],
|
|
|
|
])('renders expected route', async (activeRoute, expectedComponent) => {
|
2023-12-31 19:59:56 +01:00
|
|
|
await setUp(activeRoute);
|
|
|
|
expect(screen.getByText(expectedComponent)).toBeInTheDocument();
|
2018-08-26 19:48:21 +02:00
|
|
|
});
|
2021-11-13 23:04:59 +01:00
|
|
|
|
|
|
|
it.each([
|
2022-03-26 12:17:42 +01:00
|
|
|
['/foo', 'shlink-wrapper'],
|
|
|
|
['/bar', 'shlink-wrapper'],
|
2024-10-19 14:14:31 +02:00
|
|
|
['/', 'shlink-wrapper d-flex align-items-center pt-3'],
|
2023-12-31 19:59:56 +01:00
|
|
|
])('renders expected classes on shlink-wrapper based on current pathname', async (pathname, expectedClasses) => {
|
|
|
|
const { container } = await setUp(pathname);
|
2022-05-03 17:36:34 +02:00
|
|
|
const shlinkWrapper = container.querySelector('.shlink-wrapper');
|
2021-11-13 23:04:59 +01:00
|
|
|
|
2022-05-03 17:36:34 +02:00
|
|
|
expect(shlinkWrapper).toHaveAttribute('class', expectedClasses);
|
2021-11-13 23:04:59 +01:00
|
|
|
});
|
2018-08-26 19:48:21 +02:00
|
|
|
});
|