2022-05-03 17:36:34 +02:00
|
|
|
import { render, screen } from '@testing-library/react';
|
2023-04-13 21:48:29 +02:00
|
|
|
import { fromPartial } from '@total-typescript/shoehorn';
|
2022-05-03 17:36:34 +02:00
|
|
|
import { createMemoryHistory } from 'history';
|
2023-02-18 11:11:01 +01:00
|
|
|
import { Router } 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
|
|
|
);
|
2022-05-03 17:36:34 +02:00
|
|
|
const setUp = (activeRoute = '/') => {
|
|
|
|
const history = createMemoryHistory();
|
|
|
|
history.push(activeRoute);
|
2018-08-26 19:48:21 +02:00
|
|
|
|
2022-05-03 17:36:34 +02:00
|
|
|
return render(
|
|
|
|
<Router location={history.location} navigator={history}>
|
|
|
|
<App
|
|
|
|
fetchServers={() => {}}
|
|
|
|
servers={{}}
|
2023-04-13 21:48:29 +02:00
|
|
|
settings={fromPartial({})}
|
2022-05-03 17:36:34 +02:00
|
|
|
appUpdated
|
|
|
|
resetAppUpdate={() => {}}
|
|
|
|
/>
|
|
|
|
</Router>,
|
|
|
|
);
|
2021-11-13 23:04:59 +01:00
|
|
|
};
|
2018-08-26 19:48:21 +02:00
|
|
|
|
2023-09-30 10:20:28 +02:00
|
|
|
it('passes a11y checks', () => checkAccessibility(setUp()));
|
|
|
|
|
2021-11-13 23:04:59 +01:00
|
|
|
it('renders children components', () => {
|
2022-05-03 17:36:34 +02:00
|
|
|
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();
|
|
|
|
expect(screen.getByText('This app has just been updated!')).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) => {
|
|
|
|
setUp(activeRoute);
|
|
|
|
expect(await screen.findByText(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'],
|
|
|
|
['/', 'shlink-wrapper d-flex d-md-block align-items-center'],
|
2021-11-13 23:04:59 +01:00
|
|
|
])('renders expected classes on shlink-wrapper based on current pathname', (pathname, expectedClasses) => {
|
2022-05-03 17:36:34 +02:00
|
|
|
const { container } = setUp(pathname);
|
|
|
|
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
|
|
|
});
|