2020-08-22 09:15:05 +02:00
|
|
|
import { shallow, ShallowWrapper } from 'enzyme';
|
2022-02-07 22:17:57 +01:00
|
|
|
import { Route, useLocation } from 'react-router-dom';
|
2021-02-16 19:25:23 +01:00
|
|
|
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
|
|
|
|
2022-02-07 22:17:57 +01: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 />', () => {
|
2020-08-22 09:15:05 +02:00
|
|
|
let wrapper: ShallowWrapper;
|
|
|
|
const MainHeader = () => null;
|
2021-06-06 18:54:55 +02:00
|
|
|
const ShlinkVersions = () => null;
|
2021-11-13 23:04:59 +01:00
|
|
|
const App = appFactory(
|
|
|
|
MainHeader,
|
|
|
|
() => null,
|
|
|
|
() => null,
|
|
|
|
() => null,
|
|
|
|
() => null,
|
|
|
|
() => null,
|
|
|
|
() => null,
|
|
|
|
ShlinkVersions,
|
|
|
|
);
|
2022-02-07 22:17:57 +01:00
|
|
|
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
|
|
|
|
2021-11-13 23:04:59 +01:00
|
|
|
return wrapper;
|
|
|
|
};
|
2018-08-26 19:48:21 +02:00
|
|
|
|
2022-02-07 22:17:57 +01:00
|
|
|
afterEach(jest.clearAllMocks);
|
|
|
|
afterEach(() => wrapper?.unmount());
|
2021-06-06 18:54:55 +02:00
|
|
|
|
2021-11-13 23:04:59 +01: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', () => {
|
2021-11-13 23:04:59 +01:00
|
|
|
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 = [
|
2022-02-07 22:17:57 +01:00
|
|
|
undefined,
|
2020-04-25 09:49:54 +02: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',
|
2022-02-07 22:17:57 +01:00
|
|
|
'/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
|
|
|
});
|
2021-11-13 23:04:59 +01: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) => {
|
2022-02-07 22:17:57 +01:00
|
|
|
(useLocation as any).mockReturnValue({ pathname }); // eslint-disable-line @typescript-eslint/no-unsafe-call
|
|
|
|
|
|
|
|
const wrapper = createWrapper();
|
2021-11-13 23:04:59 +01:00
|
|
|
const shlinkWrapper = wrapper.find('.shlink-wrapper');
|
|
|
|
|
|
|
|
expect(shlinkWrapper.prop('className')).toEqual(expectedClasses);
|
|
|
|
});
|
2018-08-26 19:48:21 +02:00
|
|
|
});
|