Skip to content
Snippets Groups Projects
Commit d66e51ab authored by zonia3000's avatar zonia3000
Browse files

Added is_leaf property on GroupNode

parent 96361f84
No related branches found
No related tags found
No related merge requests found
...@@ -6,6 +6,7 @@ public class GroupNode { ...@@ -6,6 +6,7 @@ public class GroupNode {
private String groupName; private String groupName;
private Permission permission; private Permission permission;
private boolean hasChildren; private boolean hasChildren;
private boolean leaf;
public String getGroupId() { public String getGroupId() {
return groupId; return groupId;
...@@ -38,4 +39,12 @@ public class GroupNode { ...@@ -38,4 +39,12 @@ public class GroupNode {
public void setHasChildren(boolean hasChildren) { public void setHasChildren(boolean hasChildren) {
this.hasChildren = hasChildren; this.hasChildren = hasChildren;
} }
public boolean isLeaf() {
return leaf;
}
public void setLeaf(boolean leaf) {
this.leaf = leaf;
}
} }
...@@ -9,6 +9,8 @@ public class AddGroupRequest extends PaginatedModelRequest implements SearchFilt ...@@ -9,6 +9,8 @@ public class AddGroupRequest extends PaginatedModelRequest implements SearchFilt
@NotEmpty @NotEmpty
private String newGroupName; private String newGroupName;
private boolean leaf;
private String searchFilter; private String searchFilter;
public String getNewGroupName() { public String getNewGroupName() {
...@@ -27,6 +29,14 @@ public class AddGroupRequest extends PaginatedModelRequest implements SearchFilt ...@@ -27,6 +29,14 @@ public class AddGroupRequest extends PaginatedModelRequest implements SearchFilt
this.parentGroupId = parentGroupId; this.parentGroupId = parentGroupId;
} }
public boolean isLeaf() {
return leaf;
}
public void setLeaf(boolean leaf) {
this.leaf = leaf;
}
@Override @Override
public String getSearchFilter() { public String getSearchFilter() {
return searchFilter; return searchFilter;
......
...@@ -59,6 +59,7 @@ public class GroupsTreeBuilder { ...@@ -59,6 +59,7 @@ public class GroupsTreeBuilder {
GroupNode node = new GroupNode(); GroupNode node = new GroupNode();
node.setGroupId(group.getId()); node.setGroupId(group.getId());
node.setGroupName(group.getName()); node.setGroupName(group.getName());
node.setLeaf(group.isLeaf());
node.setPermission(permission); node.setPermission(permission);
nodes.add(node); nodes.add(node);
}); });
......
package it.inaf.ia2.gms.controller; package it.inaf.ia2.gms.controller;
import com.fasterxml.jackson.databind.ObjectMapper;
import it.inaf.ia2.gms.authn.SessionData;
import it.inaf.ia2.gms.model.GroupNode;
import it.inaf.ia2.gms.model.Permission; import it.inaf.ia2.gms.model.Permission;
import it.inaf.ia2.gms.model.request.AddGroupRequest;
import it.inaf.ia2.gms.model.response.GroupsTabResponse; import it.inaf.ia2.gms.model.response.GroupsTabResponse;
import it.inaf.ia2.gms.model.response.PaginatedData; import it.inaf.ia2.gms.model.response.PaginatedData;
import it.inaf.ia2.gms.persistence.model.GroupEntity;
import it.inaf.ia2.gms.service.GroupsService;
import it.inaf.ia2.gms.service.GroupsTreeBuilder;
import it.inaf.ia2.gms.service.PermissionsService;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List;
import static org.hamcrest.CoreMatchers.is; import static org.hamcrest.CoreMatchers.is;
import static org.hamcrest.CoreMatchers.notNullValue; import static org.hamcrest.CoreMatchers.notNullValue;
import org.junit.Before; import org.junit.Before;
...@@ -14,10 +23,13 @@ import org.mockito.InjectMocks; ...@@ -14,10 +23,13 @@ import org.mockito.InjectMocks;
import org.mockito.Mock; import org.mockito.Mock;
import static org.mockito.Mockito.when; import static org.mockito.Mockito.when;
import org.mockito.junit.MockitoJUnitRunner; import org.mockito.junit.MockitoJUnitRunner;
import org.springframework.http.MediaType;
import org.springframework.test.web.servlet.MockMvc; import org.springframework.test.web.servlet.MockMvc;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status; import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get; import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.post;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.jsonPath; import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.jsonPath;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
import org.springframework.test.web.servlet.setup.MockMvcBuilders; import org.springframework.test.web.servlet.setup.MockMvcBuilders;
@RunWith(MockitoJUnitRunner.class) @RunWith(MockitoJUnitRunner.class)
...@@ -26,9 +38,23 @@ public class GroupsControllerTest { ...@@ -26,9 +38,23 @@ public class GroupsControllerTest {
@Mock @Mock
private GroupsTabResponseBuilder groupsTabResponseBuilder; private GroupsTabResponseBuilder groupsTabResponseBuilder;
@Mock
private GroupsService groupsService;
@Mock
private SessionData session;
@Mock
private PermissionsService permissionsService;
@Mock
private GroupsTreeBuilder groupsTreeBuilder;
@InjectMocks @InjectMocks
private GroupsController controller; private GroupsController controller;
private final ObjectMapper mapper = new ObjectMapper();
private MockMvc mockMvc; private MockMvc mockMvc;
@Before @Before
...@@ -52,4 +78,31 @@ public class GroupsControllerTest { ...@@ -52,4 +78,31 @@ public class GroupsControllerTest {
.andExpect(jsonPath("$.groupsPanel", notNullValue())) .andExpect(jsonPath("$.groupsPanel", notNullValue()))
.andExpect(jsonPath("$.permission", is("ADMIN"))); .andExpect(jsonPath("$.permission", is("ADMIN")));
} }
@Test
public void testAddGroups() throws Exception {
AddGroupRequest request = new AddGroupRequest();
request.setNewGroupName("New Group");
request.setParentGroupId("abcd");
request.setLeaf(true);
request.setPaginatorPage(1);
request.setPaginatorPageSize(10);
GroupEntity parent = new GroupEntity();
when(groupsService.getGroupById(any())).thenReturn(parent);
when(permissionsService.getUserPermissionForGroup(any(), any())).thenReturn(Permission.ADMIN);
List<GroupNode> nodes = new ArrayList<>();
PaginatedData<GroupNode> paginatedData = new PaginatedData<>(nodes, 1, 10);
when(groupsTreeBuilder.listSubGroups(any(), any(), any())).thenReturn(paginatedData);
when(session.getUserId()).thenReturn("admin_id");
mockMvc.perform(post("/group")
.content(mapper.writeValueAsString(request))
.contentType(MediaType.APPLICATION_JSON_UTF8))
.andExpect(status().isCreated());
}
} }
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment