2020-08-17 17:09:56 -04:00
|
|
|
import waitForPromises from 'helpers/wait_for_promises';
|
2020-06-04 20:08:38 -04:00
|
|
|
import { createRouter } from '~/ide/ide_router';
|
|
|
|
import { createStore } from '~/ide/stores';
|
2018-07-19 09:20:26 -04:00
|
|
|
|
|
|
|
describe('IDE router', () => {
|
|
|
|
const PROJECT_NAMESPACE = 'my-group/sub-group';
|
|
|
|
const PROJECT_NAME = 'my-project';
|
2020-06-04 20:08:38 -04:00
|
|
|
const TEST_PATH = `/project/${PROJECT_NAMESPACE}/${PROJECT_NAME}/merge_requests/2`;
|
2018-07-19 09:20:26 -04:00
|
|
|
|
2020-06-04 20:08:38 -04:00
|
|
|
let store;
|
|
|
|
let router;
|
2018-07-19 09:20:26 -04:00
|
|
|
|
2020-06-04 20:08:38 -04:00
|
|
|
beforeEach(() => {
|
2018-07-19 09:20:26 -04:00
|
|
|
window.history.replaceState({}, '', '/');
|
2020-06-04 20:08:38 -04:00
|
|
|
store = createStore();
|
|
|
|
router = createRouter(store);
|
|
|
|
jest.spyOn(store, 'dispatch').mockReturnValue(new Promise(() => {}));
|
2018-07-19 09:20:26 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
[
|
|
|
|
`/project/${PROJECT_NAMESPACE}/${PROJECT_NAME}/tree/master/-/src/blob/`,
|
|
|
|
`/project/${PROJECT_NAMESPACE}/${PROJECT_NAME}/tree/master/-/src/blob`,
|
|
|
|
`/project/${PROJECT_NAMESPACE}/${PROJECT_NAME}/tree/blob/-/src/blob`,
|
|
|
|
`/project/${PROJECT_NAMESPACE}/${PROJECT_NAME}/tree/master/-/src/tree/`,
|
|
|
|
`/project/${PROJECT_NAMESPACE}/${PROJECT_NAME}/tree/weird:branch/name-123/-/src/tree/`,
|
|
|
|
`/project/${PROJECT_NAMESPACE}/${PROJECT_NAME}/blob/master/-/src/blob`,
|
|
|
|
`/project/${PROJECT_NAMESPACE}/${PROJECT_NAME}/blob/master/-/src/edit`,
|
|
|
|
`/project/${PROJECT_NAMESPACE}/${PROJECT_NAME}/blob/master/-/src/merge_requests/2`,
|
|
|
|
`/project/${PROJECT_NAMESPACE}/${PROJECT_NAME}/blob/blob/-/src/blob`,
|
|
|
|
`/project/${PROJECT_NAMESPACE}/${PROJECT_NAME}/edit/blob/-/src/blob`,
|
|
|
|
`/project/${PROJECT_NAMESPACE}/${PROJECT_NAME}/merge_requests/2`,
|
|
|
|
`/project/${PROJECT_NAMESPACE}/${PROJECT_NAME}/tree/blob`,
|
|
|
|
`/project/${PROJECT_NAMESPACE}/${PROJECT_NAME}/edit`,
|
|
|
|
`/project/${PROJECT_NAMESPACE}/${PROJECT_NAME}`,
|
|
|
|
].forEach(route => {
|
|
|
|
it(`finds project path when route is "${route}"`, () => {
|
|
|
|
router.push(route);
|
|
|
|
|
|
|
|
expect(store.dispatch).toHaveBeenCalledWith('getProjectData', {
|
|
|
|
namespace: PROJECT_NAMESPACE,
|
|
|
|
projectId: PROJECT_NAME,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2020-06-04 20:08:38 -04:00
|
|
|
|
|
|
|
it('keeps router in sync when store changes', async () => {
|
|
|
|
expect(router.currentRoute.fullPath).toBe('/');
|
|
|
|
|
|
|
|
store.state.router.fullPath = TEST_PATH;
|
|
|
|
|
|
|
|
await waitForPromises();
|
|
|
|
|
|
|
|
expect(router.currentRoute.fullPath).toBe(TEST_PATH);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('keeps store in sync when router changes', () => {
|
|
|
|
expect(store.dispatch).not.toHaveBeenCalled();
|
|
|
|
|
|
|
|
router.push(TEST_PATH);
|
|
|
|
|
|
|
|
expect(store.dispatch).toHaveBeenCalledWith('router/push', TEST_PATH, { root: true });
|
|
|
|
});
|
2018-07-19 09:20:26 -04:00
|
|
|
});
|