shlink-web-client/test/app/App.test.tsx

84 lines
2.4 KiB
TypeScript
Raw Normal View History

import { shallow, ShallowWrapper } from 'enzyme';
import { Route, useLocation } from 'react-router-dom';
import { Mock } from 'ts-mockery';
2021-09-19 10:31:53 +02:00
import { Settings } from '../../src/settings/reducers/settings';
import appFactory from '../../src/app/App';
import { AppUpdateBanner } from '../../src/common/AppUpdateBanner';
2018-08-26 19:48:21 +02:00
jest.mock('react-router-dom', () => ({
...jest.requireActual('react-router-dom'),
useLocation: jest.fn().mockReturnValue({}),
}));
2018-08-26 19:48:21 +02:00
describe('<App />', () => {
let wrapper: ShallowWrapper;
const MainHeader = () => null;
2021-06-06 18:54:55 +02:00
const ShlinkVersions = () => null;
const App = appFactory(
MainHeader,
() => null,
() => null,
() => null,
() => null,
() => null,
() => null,
ShlinkVersions,
);
const createWrapper = () => {
2021-06-06 18:54:55 +02:00
wrapper = shallow(
<App
fetchServers={() => {}}
servers={{}}
settings={Mock.all<Settings>()}
appUpdated={false}
resetAppUpdate={() => {}}
/>,
);
2018-08-26 19:48:21 +02:00
return wrapper;
};
2018-08-26 19:48:21 +02:00
afterEach(jest.clearAllMocks);
afterEach(() => wrapper?.unmount());
2021-06-06 18:54:55 +02:00
it('renders children components', () => {
const wrapper = createWrapper();
expect(wrapper.find(MainHeader)).toHaveLength(1);
expect(wrapper.find(ShlinkVersions)).toHaveLength(1);
expect(wrapper.find(AppUpdateBanner)).toHaveLength(1);
});
2021-06-06 18:54:55 +02:00
2018-08-26 19:48:21 +02:00
it('renders app main routes', () => {
const wrapper = createWrapper();
2018-08-26 19:48:21 +02:00
const routes = wrapper.find(Route);
2019-03-03 11:02:29 +01:00
const expectedPaths = [
undefined,
2022-02-14 20:04:38 +01:00
'/settings/*',
2021-10-17 19:13:06 +02:00
'/manage-servers',
2020-03-15 09:56:16 +01:00
'/server/create',
'/server/:serverId/edit',
'/server/:serverId/*',
2019-03-03 11:02:29 +01:00
];
2018-08-26 19:48:21 +02:00
2019-03-03 11:02:29 +01:00
expect.assertions(expectedPaths.length + 1);
2020-03-15 09:56:16 +01:00
expect(routes).toHaveLength(expectedPaths.length + 1);
2019-03-03 11:02:29 +01:00
expectedPaths.forEach((path, index) => {
expect(routes.at(index).prop('path')).toEqual(path);
});
2018-08-26 19:48:21 +02:00
});
it.each([
[ '/foo', 'shlink-wrapper' ],
[ '/bar', 'shlink-wrapper' ],
[ '/', 'shlink-wrapper d-flex d-md-block align-items-center' ],
])('renders expected classes on shlink-wrapper based on current pathname', (pathname, expectedClasses) => {
(useLocation as any).mockReturnValue({ pathname }); // eslint-disable-line @typescript-eslint/no-unsafe-call
const wrapper = createWrapper();
const shlinkWrapper = wrapper.find('.shlink-wrapper');
expect(shlinkWrapper.prop('className')).toEqual(expectedClasses);
});
2018-08-26 19:48:21 +02:00
});