Commit 4b83d88f authored by Eulyeon Ko's avatar Eulyeon Ko

Make startup.js to account for the param orders

When startup.js checks whether a API call has been prefetched or not,
it uses a path string (e.g., /path?a=1&c=2) but this check can fail
when the params listed in the path string in a different order.

This MR uses options.sort for mergeUrlParams
to sort the params in the requested path string to fix the above issue.
parent 60e36e72
...@@ -7,7 +7,7 @@ const removeGitLabUrl = url => url.replace(gon.gitlab_url, ''); ...@@ -7,7 +7,7 @@ const removeGitLabUrl = url => url.replace(gon.gitlab_url, '');
const getFullUrl = req => { const getFullUrl = req => {
const url = removeGitLabUrl(req.url); const url = removeGitLabUrl(req.url);
return mergeUrlParams(req.params || {}, url); return mergeUrlParams(req.params || {}, url, { sort: true });
}; };
const handleStartupCall = async ({ fetchCall }, req) => { const handleStartupCall = async ({ fetchCall }, req) => {
......
...@@ -111,21 +111,44 @@ describe('setupAxiosStartupCalls', () => { ...@@ -111,21 +111,44 @@ describe('setupAxiosStartupCalls', () => {
}); });
}); });
it('removes GitLab Base URL from startup call', async () => { describe('startup call', () => {
const oldGon = window.gon; let oldGon;
window.gon = { gitlab_url: 'https://example.org/gitlab' };
beforeEach(() => {
window.gl.startup_calls = { oldGon = window.gon;
'/startup': { window.gon = { gitlab_url: 'https://example.org/gitlab' };
fetchCall: mockFetchCall(200), });
},
}; afterEach(() => {
setupAxiosStartupCalls(axios); window.gon = oldGon;
});
const { data } = await axios.get('https://example.org/gitlab/startup'); it('removes GitLab Base URL from startup call', async () => {
window.gl.startup_calls = {
'/startup': {
fetchCall: mockFetchCall(200),
},
};
setupAxiosStartupCalls(axios);
expect(data).toEqual(STARTUP_JS_RESPONSE); const { data } = await axios.get('https://example.org/gitlab/startup');
window.gon = oldGon; expect(data).toEqual(STARTUP_JS_RESPONSE);
});
it('sorts the params in the requested API url', async () => {
window.gl.startup_calls = {
'/startup?alpha=true&bravo=true': {
fetchCall: mockFetchCall(200),
},
};
setupAxiosStartupCalls(axios);
// Use a full url instead of passing options = { params: { ... } } to axios.get
// to ensure the params are listed in the specified order.
const { data } = await axios.get('https://example.org/gitlab/startup?bravo=true&alpha=true');
expect(data).toEqual(STARTUP_JS_RESPONSE);
});
}); });
}); });
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment