Commit 1389fd5a authored by Kushal Pandya's avatar Kushal Pandya

Merge branch '9247-security-dashboard-project-filter-limited-to-20-entries' into 'master'

Security Dashboard: Recursively retrieve all projects

Closes #9247

See merge request gitlab-org/gitlab-ee!9205
parents 7ff3e144 5faaa558
import axios from '~/lib/utils/axios_utils'; import axios from '~/lib/utils/axios_utils';
import * as types from './mutation_types'; import * as types from './mutation_types';
const getAllProjects = (url, page = '1', projects = []) =>
axios({
method: 'GET',
url,
params: {
per_page: 100,
page,
include_subgroups: true,
order_by: 'path',
sort: 'asc',
},
}).then(({ headers, data }) => {
const result = projects.concat(data);
const nextPage = headers && headers['x-next-page'];
if (nextPage) {
return getAllProjects(url, nextPage, result);
}
return result;
});
export const setProjectsEndpoint = ({ commit }, endpoint) => { export const setProjectsEndpoint = ({ commit }, endpoint) => {
commit(types.SET_PROJECTS_ENDPOINT, endpoint); commit(types.SET_PROJECTS_ENDPOINT, endpoint);
}; };
...@@ -8,12 +28,9 @@ export const setProjectsEndpoint = ({ commit }, endpoint) => { ...@@ -8,12 +28,9 @@ export const setProjectsEndpoint = ({ commit }, endpoint) => {
export const fetchProjects = ({ state, dispatch }) => { export const fetchProjects = ({ state, dispatch }) => {
dispatch('requestProjects'); dispatch('requestProjects');
axios({ getAllProjects(state.projectsEndpoint)
method: 'GET', .then(projects => {
url: state.projectsEndpoint, dispatch('receiveProjectsSuccess', { projects });
})
.then(({ data }) => {
dispatch('receiveProjectsSuccess', { projects: data });
}) })
.catch(() => { .catch(() => {
dispatch('receiveProjectsError'); dispatch('receiveProjectsError');
......
---
title: Recursively get all of a groups projects
merge_request: 9205
author:
type: fixed
...@@ -49,6 +49,33 @@ describe('projects actions', () => { ...@@ -49,6 +49,33 @@ describe('projects actions', () => {
}); });
}); });
describe('calls the API multiple times if there is a next page', () => {
beforeEach(() => {
mock
.onGet(state.projectsEndpoint, { page: '1' })
.replyOnce(200, [1], { 'x-next-page': '2' });
mock.onGet(state.projectsEndpoint, { page: '2' }).replyOnce(200, [2]);
});
it('should dispatch the request and success actions', done => {
testAction(
actions.fetchProjects,
{},
state,
[],
[
{ type: 'requestProjects' },
{
type: 'receiveProjectsSuccess',
payload: { projects: [1, 2] },
},
],
done,
);
});
});
describe('on error', () => { describe('on error', () => {
beforeEach(() => { beforeEach(() => {
mock.onGet(state.projectsEndpoint).replyOnce(404, {}); mock.onGet(state.projectsEndpoint).replyOnce(404, {});
......
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