From 2c89e169769ead722394a79ed67fcd08e96863dd Mon Sep 17 00:00:00 2001 From: GitLab Bot Date: Wed, 12 Feb 2020 15:09:37 +0000 Subject: Add latest changes from gitlab-org/gitlab@master --- spec/frontend/ide/ide_router_extension_spec.js | 48 ++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 spec/frontend/ide/ide_router_extension_spec.js (limited to 'spec/frontend/ide') diff --git a/spec/frontend/ide/ide_router_extension_spec.js b/spec/frontend/ide/ide_router_extension_spec.js new file mode 100644 index 00000000000..3e29ecc4a90 --- /dev/null +++ b/spec/frontend/ide/ide_router_extension_spec.js @@ -0,0 +1,48 @@ +import VueRouter from 'vue-router'; +import IdeRouter from '~/ide/ide_router_extension'; + +jest.mock('vue-router'); + +describe('IDE overrides of VueRouter', () => { + const paths = branch => [ + `${branch}`, + `/${branch}`, + `/${branch}/-/`, + `/edit/${branch}`, + `/edit/${branch}/-/`, + `/blob/${branch}`, + `/blob/${branch}/-/`, + `/blob/${branch}/-/src/merge_requests/2`, + `/blob/${branch}/-/src/blob/`, + `/tree/${branch}/-/src/blob/`, + `/tree/${branch}/-/src/tree/`, + ]; + let router; + + beforeEach(() => { + VueRouter.mockClear(); + router = new IdeRouter({ + mode: 'history', + }); + }); + + it.each` + path | expected + ${'#-test'} | ${'%23-test'} + ${'#test'} | ${'%23test'} + ${'test#'} | ${'test%23'} + ${'test-#'} | ${'test-%23'} + ${'test-#-hash'} | ${'test-%23-hash'} + ${'test/hash#123'} | ${'test/hash%23123'} + `('finds project path when route is $path', ({ path, expected }) => { + paths(path).forEach(route => { + const expectedPath = route.replace(path, expected); + + router.push(route); + expect(VueRouter.prototype.push).toHaveBeenCalledWith(expectedPath, undefined, undefined); + + router.resolve(route); + expect(VueRouter.prototype.resolve).toHaveBeenCalledWith(expectedPath, undefined, undefined); + }); + }); +}); -- cgit v1.2.1