Commit a15a6f06 authored by Enrique Alcántara's avatar Enrique Alcántara

Merge branch 'approvers-use-new-project-api-fe' into 'master'

Update approvers dropdown to use new endpoint

See merge request gitlab-org/gitlab!53781
parents 46cd76e1 50c7675e
...@@ -31,6 +31,7 @@ const Api = { ...@@ -31,6 +31,7 @@ const Api = {
projectLabelsPath: '/:namespace_path/:project_path/-/labels', projectLabelsPath: '/:namespace_path/:project_path/-/labels',
projectFileSchemaPath: '/:namespace_path/:project_path/-/schema/:ref/:filename', projectFileSchemaPath: '/:namespace_path/:project_path/-/schema/:ref/:filename',
projectUsersPath: '/api/:version/projects/:id/users', projectUsersPath: '/api/:version/projects/:id/users',
projectGroupsPath: '/api/:version/projects/:id/groups.json',
projectInvitationsPath: '/api/:version/projects/:id/invitations', projectInvitationsPath: '/api/:version/projects/:id/invitations',
projectMembersPath: '/api/:version/projects/:id/members', projectMembersPath: '/api/:version/projects/:id/members',
projectMergeRequestsPath: '/api/:version/projects/:id/merge_requests', projectMergeRequestsPath: '/api/:version/projects/:id/merge_requests',
...@@ -241,6 +242,20 @@ const Api = { ...@@ -241,6 +242,20 @@ const Api = {
.then(({ data }) => data); .then(({ data }) => data);
}, },
projectGroups(id, options) {
const url = Api.buildUrl(this.projectGroupsPath).replace(':id', encodeURIComponent(id));
return axios
.get(url, {
params: {
...options,
},
})
.then(({ data }) => {
return data;
});
},
addProjectMembersByUserId(id, data) { addProjectMembersByUserId(id, data) {
const url = Api.buildUrl(this.projectMembersPath).replace(':id', encodeURIComponent(id)); const url = Api.buildUrl(this.projectMembersPath).replace(':id', encodeURIComponent(id));
......
...@@ -135,13 +135,11 @@ export default { ...@@ -135,13 +135,11 @@ export default {
.then((results) => ({ results })); .then((results) => ({ results }));
}, },
fetchGroups(term) { fetchGroups(term) {
// Don't includeAll when search is empty. Otherwise, the user could get a lot of garbage choices. const hasTerm = term.trim().length > 0;
// https://gitlab.com/gitlab-org/gitlab/issues/11566
const includeAll = term.trim().length > 0;
return Api.groups(term, { return Api.projectGroups(this.projectId, {
skip_groups: this.skipGroupIds, skip_groups: this.skipGroupIds,
all_available: includeAll, ...(hasTerm ? { search: term } : {}),
}); });
}, },
fetchUsers(term) { fetchUsers(term) {
......
...@@ -73,11 +73,7 @@ RSpec.describe 'Merge request > User edits MR with approval rules', :js do ...@@ -73,11 +73,7 @@ RSpec.describe 'Merge request > User edits MR with approval rules', :js do
end end
context "with public group" do context "with public group" do
let_it_be(:group) { create(:group, :public) }
before do before do
group.add_developer create(:user)
click_button 'Approval rules' click_button 'Approval rules'
click_button "Add approval rule" click_button "Add approval rule"
end end
......
...@@ -87,10 +87,12 @@ RSpec.describe 'Merge request > User sets approvers', :js do ...@@ -87,10 +87,12 @@ RSpec.describe 'Merge request > User sets approvers', :js do
it 'allows setting groups as approvers' do it 'allows setting groups as approvers' do
group = create :group group = create :group
group.add_developer(other_user) group_project = create :project, :repository, group: group
visit project_new_merge_request_path(project, merge_request: { target_branch: 'master', source_branch: 'feature' }) group.add_developer(user)
group.add_developer(other_user)
visit project_new_merge_request_path(group_project, merge_request: { target_branch: 'master', source_branch: 'feature' })
open_modal(text: 'Add approval rule') open_modal(text: 'Add approval rule')
open_approver_select open_approver_select
...@@ -156,9 +158,13 @@ RSpec.describe 'Merge request > User sets approvers', :js do ...@@ -156,9 +158,13 @@ RSpec.describe 'Merge request > User sets approvers', :js do
it 'allows setting groups as approvers' do it 'allows setting groups as approvers' do
group = create :group group = create :group
group_project = create :project, :repository, group: group
group_project_merge_request = create :merge_request, source_project: group_project
group.add_developer(user)
group.add_developer(other_user) group.add_developer(other_user)
visit edit_project_merge_request_path(project, merge_request) visit edit_project_merge_request_path(group_project, group_project_merge_request)
open_modal(text: 'Add approval rule') open_modal(text: 'Add approval rule')
open_approver_select open_approver_select
......
...@@ -6,8 +6,8 @@ RSpec.describe 'Project settings > [EE] Merge Requests', :js do ...@@ -6,8 +6,8 @@ RSpec.describe 'Project settings > [EE] Merge Requests', :js do
include FeatureApprovalHelper include FeatureApprovalHelper
let(:user) { create(:user) } let(:user) { create(:user) }
let(:project) { create(:project) }
let(:group) { create(:group) } let(:group) { create(:group) }
let(:project) { create(:project, group: group) }
let(:group_member) { create(:user) } let(:group_member) { create(:user) }
let(:non_member) { create(:user) } let(:non_member) { create(:user) }
let!(:config_selector) { '.js-approval-rules' } let!(:config_selector) { '.js-approval-rules' }
......
...@@ -76,7 +76,7 @@ describe('Approvals ApproversSelect', () => { ...@@ -76,7 +76,7 @@ describe('Approvals ApproversSelect', () => {
}; };
beforeEach(() => { beforeEach(() => {
jest.spyOn(Api, 'groups').mockResolvedValue(TEST_GROUPS); jest.spyOn(Api, 'projectGroups').mockResolvedValue(TEST_GROUPS);
jest.spyOn(Api, 'projectUsers').mockReturnValue(Promise.resolve(TEST_USERS)); jest.spyOn(Api, 'projectUsers').mockReturnValue(Promise.resolve(TEST_USERS));
}); });
...@@ -126,7 +126,10 @@ describe('Approvals ApproversSelect', () => { ...@@ -126,7 +126,10 @@ describe('Approvals ApproversSelect', () => {
}); });
it('fetches all available groups', () => { it('fetches all available groups', () => {
expect(Api.groups).toHaveBeenCalledWith(term, { skip_groups: [], all_available: true }); expect(Api.projectGroups).toHaveBeenCalledWith(TEST_PROJECT_ID, {
skip_groups: [],
search: term,
});
}); });
it('fetches users', () => { it('fetches users', () => {
...@@ -157,9 +160,8 @@ describe('Approvals ApproversSelect', () => { ...@@ -157,9 +160,8 @@ describe('Approvals ApproversSelect', () => {
}); });
it('skips groups and does not fetch all available', () => { it('skips groups and does not fetch all available', () => {
expect(Api.groups).toHaveBeenCalledWith('', { expect(Api.projectGroups).toHaveBeenCalledWith(TEST_PROJECT_ID, {
skip_groups: skipGroupIds, skip_groups: skipGroupIds,
all_available: false,
}); });
}); });
......
...@@ -3,7 +3,8 @@ ...@@ -3,7 +3,8 @@
RSpec.shared_context 'with project with approval rules' do RSpec.shared_context 'with project with approval rules' do
let_it_be(:approver) { create(:user) } let_it_be(:approver) { create(:user) }
let_it_be(:author) { create(:user) } let_it_be(:author) { create(:user) }
let_it_be(:project) { create(:project, :public, :repository) } let_it_be(:group) { create(:group) }
let_it_be(:project) { create(:project, :public, :repository, group: group) }
before do before do
stub_licensed_features(multiple_approval_rules: true) stub_licensed_features(multiple_approval_rules: true)
......
...@@ -352,6 +352,20 @@ describe('Api', () => { ...@@ -352,6 +352,20 @@ describe('Api', () => {
}); });
}); });
describe('projectGroups', () => {
it('fetches a project group', async () => {
const options = { unused: 'option' };
const projectId = 1;
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/groups.json`;
mock.onGet(expectedUrl, { params: options }).reply(httpStatus.OK, {
name: 'test',
});
const { name } = await Api.projectGroups(projectId, options);
expect(name).toBe('test');
});
});
describe('projectUsers', () => { describe('projectUsers', () => {
it('fetches all users of a particular project', (done) => { it('fetches all users of a particular project', (done) => {
const query = 'dummy query'; const query = 'dummy query';
......
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