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