summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/permission/GroupWithPermissionQueryResult.java42
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/permission/PermissionFinder.java59
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/permission/UserWithPermissionQueryResult.java43
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/permission/ws/GroupsAction.java29
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/permission/ws/UsersAction.java40
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/permission/PermissionFinderTest.java295
-rw-r--r--sonar-db/src/main/java/org/sonar/core/permission/GroupWithPermission.java93
-rw-r--r--sonar-db/src/main/java/org/sonar/core/permission/UserWithPermission.java89
-rw-r--r--sonar-db/src/main/java/org/sonar/db/permission/GroupWithPermissionDto.java9
-rw-r--r--sonar-db/src/main/java/org/sonar/db/permission/UserWithPermissionDto.java9
-rw-r--r--sonar-db/src/test/java/org/sonar/db/permission/GroupWithPermissionDtoTest.java54
-rw-r--r--sonar-db/src/test/java/org/sonar/db/permission/GroupWithPermissionTest.java56
-rw-r--r--sonar-db/src/test/java/org/sonar/db/permission/UserWithPermissionDtoTest.java55
-rw-r--r--sonar-db/src/test/java/org/sonar/db/permission/UserWithPermissionTest.java59
14 files changed, 42 insertions, 890 deletions
diff --git a/server/sonar-server/src/main/java/org/sonar/server/permission/GroupWithPermissionQueryResult.java b/server/sonar-server/src/main/java/org/sonar/server/permission/GroupWithPermissionQueryResult.java
deleted file mode 100644
index e5c9b5d97d5..00000000000
--- a/server/sonar-server/src/main/java/org/sonar/server/permission/GroupWithPermissionQueryResult.java
+++ /dev/null
@@ -1,42 +0,0 @@
-/*
- * SonarQube, open source software quality management tool.
- * Copyright (C) 2008-2014 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * SonarQube is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * SonarQube is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.server.permission;
-
-import java.util.List;
-import org.sonar.core.permission.GroupWithPermission;
-
-public class GroupWithPermissionQueryResult {
-
- private final List<GroupWithPermission> groups;
- private final int total;
-
- public GroupWithPermissionQueryResult(List<GroupWithPermission> groups, int total) {
- this.groups = groups;
- this.total = total;
- }
-
- public List<GroupWithPermission> groups() {
- return groups;
- }
-
- public int total() {
- return total;
- }
-}
diff --git a/server/sonar-server/src/main/java/org/sonar/server/permission/PermissionFinder.java b/server/sonar-server/src/main/java/org/sonar/server/permission/PermissionFinder.java
index fc13eee3374..b7d885d99e2 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/permission/PermissionFinder.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/permission/PermissionFinder.java
@@ -29,8 +29,6 @@ import org.sonar.api.security.DefaultGroups;
import org.sonar.api.server.ServerSide;
import org.sonar.api.utils.Paging;
import org.sonar.core.permission.GlobalPermissions;
-import org.sonar.core.permission.GroupWithPermission;
-import org.sonar.core.permission.UserWithPermission;
import org.sonar.db.DbClient;
import org.sonar.db.DbSession;
import org.sonar.db.component.ResourceDao;
@@ -39,8 +37,6 @@ import org.sonar.db.component.ResourceQuery;
import org.sonar.db.permission.GroupWithPermissionDto;
import org.sonar.db.permission.PermissionDao;
import org.sonar.db.permission.PermissionQuery;
-import org.sonar.db.permission.PermissionTemplateDao;
-import org.sonar.db.permission.PermissionTemplateDto;
import org.sonar.db.permission.UserWithPermissionDto;
import org.sonar.server.exceptions.NotFoundException;
@@ -53,56 +49,26 @@ public class PermissionFinder {
private final PermissionDao permissionDao;
private final ResourceDao resourceDao;
- private final PermissionTemplateDao permissionTemplateDao;
public PermissionFinder(DbClient dbClient) {
this.resourceDao = dbClient.resourceDao();
this.permissionDao = dbClient.permissionDao();
- this.permissionTemplateDao = dbClient.permissionTemplateDao();
}
- public UserWithPermissionQueryResult findUsersWithPermission(DbSession dbSession, PermissionQuery query) {
+ public List<UserWithPermissionDto> findUsersWithPermission(DbSession dbSession, PermissionQuery query) {
Long componentId = componentId(query.component());
int limit = query.pageSize();
- int total = permissionDao.countUsers(dbSession, query, componentId);
- return toUserQueryResult(permissionDao.selectUsers(dbSession, query, componentId, offset(query), limit), total);
- }
-
- public UserWithPermissionQueryResult findUsersWithPermissionTemplate(DbSession dbSession, PermissionQuery query) {
- Long permissionTemplateId = templateId(query.template());
- int limit = query.pageSize();
- int total = permissionTemplateDao.countUsers(dbSession, query, permissionTemplateId);
- return toUserQueryResult(permissionTemplateDao.selectUsers(dbSession, query, permissionTemplateId, offset(query), limit), total);
+ return permissionDao.selectUsers(dbSession, query, componentId, offset(query), limit);
}
/**
* Paging for groups search is done in Java in order to correctly handle the 'Anyone' group
*/
- public GroupWithPermissionQueryResult findGroupsWithPermission(DbSession dbSession, PermissionQuery query) {
+ public List<GroupWithPermissionDto> findGroupsWithPermission(DbSession dbSession, PermissionQuery query) {
Long componentId = componentId(query.component());
return toGroupQueryResult(permissionDao.selectGroups(dbSession, query, componentId), query);
}
- /**
- * Paging for groups search is done in Java in order to correctly handle the 'Anyone' group
- */
- public GroupWithPermissionQueryResult findGroupsWithPermissionTemplate(DbSession dbSession, PermissionQuery query) {
- Long permissionTemplateId = templateId(query.template());
- return toGroupQueryResult(permissionTemplateDao.selectGroups(dbSession, query, permissionTemplateId), query);
- }
-
- private static UserWithPermissionQueryResult toUserQueryResult(List<UserWithPermissionDto> dtos, int total) {
- return new UserWithPermissionQueryResult(toUserWithPermissionList(dtos), total);
- }
-
- private static List<UserWithPermission> toUserWithPermissionList(List<UserWithPermissionDto> dtos) {
- List<UserWithPermission> users = newArrayList();
- for (UserWithPermissionDto dto : dtos) {
- users.add(dto.toUserWithPermission());
- }
- return users;
- }
-
@Nullable
private Long componentId(@Nullable String componentKey) {
if (componentKey == null) {
@@ -116,7 +82,7 @@ public class PermissionFinder {
}
}
- private GroupWithPermissionQueryResult toGroupQueryResult(List<GroupWithPermissionDto> dtos, PermissionQuery query) {
+ private List<GroupWithPermissionDto> toGroupQueryResult(List<GroupWithPermissionDto> dtos, PermissionQuery query) {
addAnyoneGroup(dtos, query);
List<GroupWithPermissionDto> filteredDtos = filterMembership(dtos, query);
@@ -124,16 +90,7 @@ public class PermissionFinder {
.withPageSize(query.pageSize())
.andTotal(filteredDtos.size());
- List<GroupWithPermission> pagedGroups = pagedGroups(filteredDtos, paging);
- return new GroupWithPermissionQueryResult(pagedGroups, filteredDtos.size());
- }
-
- private Long templateId(String templateKey) {
- PermissionTemplateDto dto = permissionTemplateDao.selectByUuid(templateKey);
- if (dto == null) {
- throw new NotFoundException(String.format("Template '%s' does not exist", templateKey));
- }
- return dto.getId();
+ return pagedGroups(filteredDtos, paging);
}
private static int offset(PermissionQuery query) {
@@ -159,12 +116,12 @@ public class PermissionFinder {
}
}
- private static List<GroupWithPermission> pagedGroups(Collection<GroupWithPermissionDto> dtos, Paging paging) {
- List<GroupWithPermission> groups = newArrayList();
+ private static List<GroupWithPermissionDto> pagedGroups(Collection<GroupWithPermissionDto> dtos, Paging paging) {
+ List<GroupWithPermissionDto> groups = newArrayList();
int index = 0;
for (GroupWithPermissionDto dto : dtos) {
if (index >= paging.offset() && groups.size() < paging.pageSize()) {
- groups.add(dto.toGroupWithPermission());
+ groups.add(dto);
} else if (groups.size() >= paging.pageSize()) {
break;
}
diff --git a/server/sonar-server/src/main/java/org/sonar/server/permission/UserWithPermissionQueryResult.java b/server/sonar-server/src/main/java/org/sonar/server/permission/UserWithPermissionQueryResult.java
deleted file mode 100644
index 7b06087aa1b..00000000000
--- a/server/sonar-server/src/main/java/org/sonar/server/permission/UserWithPermissionQueryResult.java
+++ /dev/null
@@ -1,43 +0,0 @@
-/*
- * SonarQube, open source software quality management tool.
- * Copyright (C) 2008-2014 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * SonarQube is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * SonarQube is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-
-package org.sonar.server.permission;
-
-import java.util.List;
-import org.sonar.core.permission.UserWithPermission;
-
-public class UserWithPermissionQueryResult {
-
- private final List<UserWithPermission> users;
- private final int total;
-
- public UserWithPermissionQueryResult(List<UserWithPermission> users, int total) {
- this.users = users;
- this.total = total;
- }
-
- public List<UserWithPermission> users() {
- return users;
- }
-
- public int total() {
- return total;
- }
-}
diff --git a/server/sonar-server/src/main/java/org/sonar/server/permission/ws/GroupsAction.java b/server/sonar-server/src/main/java/org/sonar/server/permission/ws/GroupsAction.java
index 7cddc442a8e..66b8defa643 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/permission/ws/GroupsAction.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/permission/ws/GroupsAction.java
@@ -28,12 +28,11 @@ import org.sonar.api.server.ws.Response;
import org.sonar.api.server.ws.WebService;
import org.sonar.api.server.ws.WebService.Param;
import org.sonar.api.server.ws.WebService.SelectionMode;
-import org.sonar.core.permission.GroupWithPermission;
import org.sonar.db.DbClient;
import org.sonar.db.DbSession;
import org.sonar.db.component.ComponentDto;
+import org.sonar.db.permission.GroupWithPermissionDto;
import org.sonar.db.permission.PermissionQuery;
-import org.sonar.server.permission.GroupWithPermissionQueryResult;
import org.sonar.server.permission.PermissionFinder;
import org.sonar.server.permission.ws.PermissionRequest.Builder;
import org.sonar.server.user.UserSession;
@@ -89,8 +88,10 @@ public class GroupsAction implements PermissionsWsAction {
checkProjectAdminUserByComponentDto(userSession, project);
PermissionQuery permissionQuery = buildPermissionQuery(request, project);
- GroupWithPermissionQueryResult groupsResult = permissionFinder.findGroupsWithPermission(dbSession, permissionQuery);
- WsGroupsResponse groupsResponse = buildResponse(groupsResult, request);
+ Long projectIdIfPresent = project.isPresent() ? project.get().getId() : null;
+ int total = dbClient.permissionDao().countGroups(dbSession, permissionQuery.permission(), projectIdIfPresent);
+ List<GroupWithPermissionDto> groupsWithPermission = permissionFinder.findGroupsWithPermission(dbSession, permissionQuery);
+ WsGroupsResponse groupsResponse = buildResponse(groupsWithPermission, request, total);
writeProtobuf(groupsResponse, wsRequest, wsResponse);
} finally {
@@ -98,24 +99,22 @@ public class GroupsAction implements PermissionsWsAction {
}
}
- private WsGroupsResponse buildResponse(GroupWithPermissionQueryResult groupsResult, PermissionRequest permissionRequest) {
- List<GroupWithPermission> groupsWithPermission = groupsResult.groups();
-
+ private WsGroupsResponse buildResponse(List<GroupWithPermissionDto> groupsWithPermission, PermissionRequest permissionRequest, int total) {
WsGroupsResponse.Builder groupsResponse = WsGroupsResponse.newBuilder();
WsGroupsResponse.Group.Builder group = WsGroupsResponse.Group.newBuilder();
Common.Paging.Builder paging = Common.Paging.newBuilder();
- for (GroupWithPermission groupWithPermission : groupsWithPermission) {
+ for (GroupWithPermissionDto groupWithPermission : groupsWithPermission) {
group
.clear()
- .setName(groupWithPermission.name())
- .setSelected(groupWithPermission.hasPermission());
+ .setName(groupWithPermission.getName())
+ .setSelected(groupWithPermission.getPermission() != null);
// anyone group return with id = 0
- if (groupWithPermission.id() != 0) {
- group.setId(String.valueOf(groupWithPermission.id()));
+ if (groupWithPermission.getId() != 0) {
+ group.setId(String.valueOf(groupWithPermission.getId()));
}
- if (groupWithPermission.description() != null) {
- group.setDescription(groupWithPermission.description());
+ if (groupWithPermission.getDescription() != null) {
+ group.setDescription(groupWithPermission.getDescription());
}
groupsResponse.addGroups(group);
@@ -125,7 +124,7 @@ public class GroupsAction implements PermissionsWsAction {
paging
.setPageIndex(permissionRequest.page())
.setPageSize(permissionRequest.pageSize())
- .setTotal(groupsResult.total())
+ .setTotal(total)
);
return groupsResponse.build();
diff --git a/server/sonar-server/src/main/java/org/sonar/server/permission/ws/UsersAction.java b/server/sonar-server/src/main/java/org/sonar/server/permission/ws/UsersAction.java
index c359deacfa6..d1093b05e73 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/permission/ws/UsersAction.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/permission/ws/UsersAction.java
@@ -27,20 +27,20 @@ import org.sonar.api.server.ws.Response;
import org.sonar.api.server.ws.WebService;
import org.sonar.api.server.ws.WebService.Param;
import org.sonar.api.server.ws.WebService.SelectionMode;
-import org.sonar.core.permission.UserWithPermission;
+import org.sonar.api.utils.Paging;
import org.sonar.db.DbClient;
import org.sonar.db.DbSession;
import org.sonar.db.component.ComponentDto;
import org.sonar.db.permission.PermissionQuery;
+import org.sonar.db.permission.UserWithPermissionDto;
import org.sonar.server.permission.PermissionFinder;
-import org.sonar.server.permission.UserWithPermissionQueryResult;
import org.sonar.server.permission.ws.PermissionRequest.Builder;
import org.sonar.server.user.UserSession;
-import org.sonarqube.ws.Common.Paging;
import org.sonarqube.ws.WsPermissions.WsUsersResponse;
import static com.google.common.base.Objects.firstNonNull;
import static com.google.common.base.Strings.nullToEmpty;
+import static org.sonar.api.utils.Paging.forPageIndex;
import static org.sonar.server.permission.PermissionPrivilegeChecker.checkProjectAdminUserByComponentDto;
import static org.sonar.server.permission.ws.PermissionQueryParser.fromSelectionModeToMembership;
import static org.sonar.server.permission.ws.WsPermissionParameters.createPermissionParameter;
@@ -89,8 +89,10 @@ public class UsersAction implements PermissionsWsAction {
Optional<ComponentDto> project = dependenciesFinder.searchProject(dbSession, request);
checkProjectAdminUserByComponentDto(userSession, project);
PermissionQuery permissionQuery = buildPermissionQuery(request, project);
- UserWithPermissionQueryResult usersResult = permissionFinder.findUsersWithPermission(dbSession, permissionQuery);
- WsUsersResponse wsUsersResponse = buildResponse(usersResult, request.page(), request.pageSize());
+ Long projectIdIfPresent = project.isPresent() ? project.get().getId() : null;
+ int total = dbClient.permissionDao().countUsers(dbSession, permissionQuery, projectIdIfPresent);
+ List<UserWithPermissionDto> usersWithPermission = permissionFinder.findUsersWithPermission(dbSession, permissionQuery);
+ WsUsersResponse wsUsersResponse = buildResponse(usersWithPermission, forPageIndex(request.page()).withPageSize(request.pageSize()).andTotal(total));
writeProtobuf(wsUsersResponse, wsRequest, wsResponse);
} finally {
@@ -98,27 +100,25 @@ public class UsersAction implements PermissionsWsAction {
}
}
- private WsUsersResponse buildResponse(UserWithPermissionQueryResult usersResult, int page, int pageSize) {
- List<UserWithPermission> usersWithPermission = usersResult.users();
-
+ private WsUsersResponse buildResponse(List<UserWithPermissionDto> usersWithPermission, Paging paging) {
WsUsersResponse.Builder userResponse = WsUsersResponse.newBuilder();
WsUsersResponse.User.Builder user = WsUsersResponse.User.newBuilder();
- for (UserWithPermission userWithPermission : usersWithPermission) {
+ for (UserWithPermissionDto userWithPermission : usersWithPermission) {
userResponse.addUsers(
user
.clear()
- .setLogin(userWithPermission.login())
- .setName(nullToEmpty(userWithPermission.name()))
- .setEmail(nullToEmpty(userWithPermission.email()))
- .setSelected(userWithPermission.hasPermission()));
+ .setLogin(userWithPermission.getLogin())
+ .setName(nullToEmpty(userWithPermission.getName()))
+ .setEmail(nullToEmpty(userWithPermission.getEmail()))
+ .setSelected(userWithPermission.getPermission() != null));
}
- userResponse.setPaging(
- Paging.newBuilder()
- .clear()
- .setPageIndex(page)
- .setPageSize(pageSize)
- .setTotal(usersResult.total())
- );
+
+ userResponse.getPagingBuilder()
+ .clear()
+ .setPageIndex(paging.pageIndex())
+ .setPageSize(paging.pageSize())
+ .setTotal(paging.total())
+ .build();
return userResponse.build();
}
diff --git a/server/sonar-server/src/test/java/org/sonar/server/permission/PermissionFinderTest.java b/server/sonar-server/src/test/java/org/sonar/server/permission/PermissionFinderTest.java
deleted file mode 100644
index 5c350e0a857..00000000000
--- a/server/sonar-server/src/test/java/org/sonar/server/permission/PermissionFinderTest.java
+++ /dev/null
@@ -1,295 +0,0 @@
-/*
- * SonarQube, open source software quality management tool.
- * Copyright (C) 2008-2014 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * SonarQube is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * SonarQube is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.server.permission;
-
-import java.util.List;
-import org.junit.Before;
-import org.junit.Test;
-import org.mockito.ArgumentCaptor;
-import org.sonar.core.permission.GroupWithPermission;
-import org.sonar.db.DbClient;
-import org.sonar.db.DbSession;
-import org.sonar.db.component.ResourceDao;
-import org.sonar.db.component.ResourceDto;
-import org.sonar.db.component.ResourceQuery;
-import org.sonar.db.permission.GroupWithPermissionDto;
-import org.sonar.db.permission.PermissionDao;
-import org.sonar.db.permission.PermissionQuery;
-import org.sonar.db.permission.PermissionTemplateDao;
-import org.sonar.db.permission.PermissionTemplateDto;
-import org.sonar.db.permission.UserWithPermissionDto;
-import org.sonar.server.exceptions.NotFoundException;
-
-import static com.google.common.collect.Lists.newArrayList;
-import static org.assertj.core.api.Assertions.assertThat;
-import static org.junit.Assert.fail;
-import static org.mockito.Matchers.any;
-import static org.mockito.Matchers.anyInt;
-import static org.mockito.Matchers.anyLong;
-import static org.mockito.Matchers.anyString;
-import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.verify;
-import static org.mockito.Mockito.when;
-
-public class PermissionFinderTest {
-
- PermissionDao permissionDao = mock(PermissionDao.class);
- ResourceDao resourceDao = mock(ResourceDao.class);
- PermissionTemplateDao permissionTemplateDao = mock(PermissionTemplateDao.class);
- DbSession dbSession = mock(DbSession.class);
-
- PermissionFinder underTest;
-
- @Before
- public void setUp() {
- DbClient dbClient = mock(DbClient.class);
- when(dbClient.resourceDao()).thenReturn(resourceDao);
- when(dbClient.permissionDao()).thenReturn(permissionDao);
- when(dbClient.permissionTemplateDao()).thenReturn(permissionTemplateDao);
- when(resourceDao.selectResource(any(ResourceQuery.class))).thenReturn(new ResourceDto().setId(100L).setName("org.sample.Sample"));
- underTest = new PermissionFinder(dbClient);
- }
-
- @Test
- public void find_users() {
- when(permissionDao.selectUsers(any(DbSession.class), any(PermissionQuery.class), anyLong(), anyInt(), anyInt())).thenReturn(
- newArrayList(new UserWithPermissionDto().setName("user1").setPermission("user"))
- );
- when(permissionDao.countUsers(any(DbSession.class), any(PermissionQuery.class), anyLong())).thenReturn(1);
-
- UserWithPermissionQueryResult result = underTest.findUsersWithPermission(dbSession, PermissionQuery.builder().permission("user").build());
- assertThat(result.users()).hasSize(1);
- assertThat(result.total()).isEqualTo(1);
- }
-
- @Test
- public void fail_to_find_users_when_component_not_found() {
- when(resourceDao.selectResource(any(ResourceQuery.class))).thenReturn(null);
-
- try {
- underTest.findUsersWithPermission(dbSession, PermissionQuery.builder().permission("user").component("Unknown").build());
- fail();
- } catch (Exception e) {
- assertThat(e).isInstanceOf(NotFoundException.class).hasMessage("Project 'Unknown' does not exist");
- }
- }
-
- @Test
- public void find_users_with_paging() {
- underTest.findUsersWithPermission(dbSession, PermissionQuery.builder().permission("user").pageIndex(3).pageSize(10).build());
-
- ArgumentCaptor<Integer> argumentOffset = ArgumentCaptor.forClass(Integer.class);
- ArgumentCaptor<Integer> argumentLimit = ArgumentCaptor.forClass(Integer.class);
- verify(permissionDao).selectUsers(any(DbSession.class), any(PermissionQuery.class), anyLong(), argumentOffset.capture(), argumentLimit.capture());
-
- assertThat(argumentOffset.getValue()).isEqualTo(20);
- assertThat(argumentLimit.getValue()).isEqualTo(10);
- }
-
- @Test
- public void find_users_with_paging_having_more_results() {
- when(permissionDao.selectUsers(any(DbSession.class), any(PermissionQuery.class), anyLong(), anyInt(), anyInt())).thenReturn(newArrayList(
- new UserWithPermissionDto().setName("user1").setPermission("user"),
- new UserWithPermissionDto().setName("user2").setPermission("user"),
- new UserWithPermissionDto().setName("user3").setPermission("user"))
- );
- when(permissionDao.countUsers(any(DbSession.class), any(PermissionQuery.class), anyLong())).thenReturn(3);
- UserWithPermissionQueryResult result = underTest.findUsersWithPermission(dbSession, PermissionQuery.builder().permission("user").pageIndex(1).pageSize(2).build());
-
- ArgumentCaptor<Integer> argumentOffset = ArgumentCaptor.forClass(Integer.class);
- ArgumentCaptor<Integer> argumentLimit = ArgumentCaptor.forClass(Integer.class);
- verify(permissionDao).selectUsers(any(DbSession.class), any(PermissionQuery.class), anyLong(), argumentOffset.capture(), argumentLimit.capture());
-
- assertThat(argumentOffset.getValue()).isEqualTo(0);
- assertThat(argumentLimit.getValue()).isEqualTo(2);
- assertThat(result.total()).isEqualTo(3);
- }
-
- @Test
- public void find_users_with_paging_having_no_more_results() {
- when(permissionDao.selectUsers(any(DbSession.class), any(PermissionQuery.class), anyLong(), anyInt(), anyInt())).thenReturn(newArrayList(
- new UserWithPermissionDto().setName("user1").setPermission("user"),
- new UserWithPermissionDto().setName("user2").setPermission("user"),
- new UserWithPermissionDto().setName("user4").setPermission("user"),
- new UserWithPermissionDto().setName("user3").setPermission("user"))
- );
- when(permissionDao.countUsers(any(DbSession.class), any(PermissionQuery.class), anyLong())).thenReturn(4);
-
- UserWithPermissionQueryResult result = underTest.findUsersWithPermission(dbSession, PermissionQuery.builder().permission("user").pageIndex(1).pageSize(10).build());
-
- ArgumentCaptor<Integer> argumentOffset = ArgumentCaptor.forClass(Integer.class);
- ArgumentCaptor<Integer> argumentLimit = ArgumentCaptor.forClass(Integer.class);
- verify(permissionDao).selectUsers(any(DbSession.class), any(PermissionQuery.class), anyLong(), argumentOffset.capture(), argumentLimit.capture());
-
- assertThat(argumentOffset.getValue()).isEqualTo(0);
- assertThat(argumentLimit.getValue()).isEqualTo(10);
- assertThat(result.total()).isEqualTo(4);
- }
-
- @Test
- public void find_groups() {
- when(permissionDao.selectGroups(any(DbSession.class), any(PermissionQuery.class), anyLong())).thenReturn(
- newArrayList(new GroupWithPermissionDto().setName("users").setPermission("user"))
- );
-
- GroupWithPermissionQueryResult result = underTest.findGroupsWithPermission(dbSession, PermissionQuery.builder().permission("user").membership(PermissionQuery.IN).build());
-
- assertThat(result.groups()).hasSize(1);
- }
-
- @Test
- public void find_groups_should_be_paginated() {
- when(permissionDao.selectGroups(any(DbSession.class), any(PermissionQuery.class), anyLong())).thenReturn(newArrayList(
- new GroupWithPermissionDto().setName("Anyone").setPermission("user"),
- new GroupWithPermissionDto().setName("Admin").setPermission("user"),
- new GroupWithPermissionDto().setName("Users").setPermission(null),
- new GroupWithPermissionDto().setName("Reviewers").setPermission(null),
- new GroupWithPermissionDto().setName("Other").setPermission(null)
- ));
-
- GroupWithPermissionQueryResult result = underTest.findGroupsWithPermission(dbSession,
- PermissionQuery.builder()
- .permission("user")
- .pageSize(2)
- .pageIndex(2)
- .build());
-
- List<GroupWithPermission> groups = result.groups();
- assertThat(groups).hasSize(2);
- assertThat(groups.get(0).name()).isEqualTo("Users");
- assertThat(groups.get(1).name()).isEqualTo("Reviewers");
- }
-
- @Test
- public void find_groups_should_filter_membership() {
- when(permissionDao.selectGroups(any(DbSession.class), any(PermissionQuery.class), anyLong())).thenReturn(newArrayList(
- new GroupWithPermissionDto().setName("Anyone").setPermission("user"),
- new GroupWithPermissionDto().setName("Admin").setPermission("user"),
- new GroupWithPermissionDto().setName("Users").setPermission(null),
- new GroupWithPermissionDto().setName("Reviewers").setPermission(null),
- new GroupWithPermissionDto().setName("Other").setPermission(null)
- ));
-
- assertThat(underTest.findGroupsWithPermission(dbSession, PermissionQuery.builder().permission("user").membership(PermissionQuery.IN).build()).groups()).hasSize(2);
- assertThat(underTest.findGroupsWithPermission(dbSession, PermissionQuery.builder().permission("user").membership(PermissionQuery.OUT).build()).groups()).hasSize(3);
- assertThat(underTest.findGroupsWithPermission(dbSession, PermissionQuery.builder().permission("user").membership(PermissionQuery.ANY).build()).groups()).hasSize(5);
- }
-
- @Test
- public void find_groups_with_added_anyone_group() {
- when(permissionDao.selectGroups(any(DbSession.class), any(PermissionQuery.class), anyLong())).thenReturn(
- newArrayList(new GroupWithPermissionDto().setName("users").setPermission("user"))
- );
-
- GroupWithPermissionQueryResult result = underTest.findGroupsWithPermission(dbSession, PermissionQuery.builder().permission("user").pageIndex(1).membership(PermissionQuery.ANY)
- .build());
- assertThat(result.groups()).hasSize(2);
- GroupWithPermission first = result.groups().get(0);
- assertThat(first.name()).isEqualTo("Anyone");
- assertThat(first.hasPermission()).isFalse();
- }
-
- @Test
- public void find_groups_without_adding_anyone_group_when_search_text_do_not_matched() {
- when(permissionDao.selectGroups(any(DbSession.class), any(PermissionQuery.class), anyLong())).thenReturn(
- newArrayList(new GroupWithPermissionDto().setName("users").setPermission("user"))
- );
-
- GroupWithPermissionQueryResult result = underTest.findGroupsWithPermission(dbSession, PermissionQuery.builder().permission("user").search("other")
- .pageIndex(1).membership(PermissionQuery.ANY).build());
- // Anyone group should not be added
- assertThat(result.groups()).hasSize(1);
- }
-
- @Test
- public void find_groups_with_added_anyone_group_when_search_text_matched() {
- when(permissionDao.selectGroups(any(DbSession.class), any(PermissionQuery.class), anyLong())).thenReturn(
- newArrayList(new GroupWithPermissionDto().setName("MyAnyGroup").setPermission("user"))
- );
-
- GroupWithPermissionQueryResult result = underTest.findGroupsWithPermission(dbSession, PermissionQuery.builder().permission("user").search("any")
- .pageIndex(1).membership(PermissionQuery.ANY).build());
- assertThat(result.groups()).hasSize(2);
- }
-
- @Test
- public void find_groups_without_adding_anyone_group_when_out_membership_selected() {
- when(permissionDao.selectGroups(any(DbSession.class), any(PermissionQuery.class), anyLong())).thenReturn(
- newArrayList(new GroupWithPermissionDto().setName("users").setPermission("user"))
- );
-
- GroupWithPermissionQueryResult result = underTest.findGroupsWithPermission(dbSession, PermissionQuery.builder().permission("user")
- .pageIndex(1).membership(PermissionQuery.OUT).build());
- // Anyone group should not be added
- assertThat(result.groups()).hasSize(1);
- }
-
- @Test
- public void find_users_from_permission_template() {
- when(permissionTemplateDao.selectByUuid(anyString())).thenReturn(new PermissionTemplateDto().setId(1L).setUuid("my_template"));
-
- when(permissionTemplateDao.selectUsers(any(DbSession.class), any(PermissionQuery.class), anyLong(), anyInt(), anyInt())).thenReturn(
- newArrayList(new UserWithPermissionDto().setName("user1").setPermission("user"))
- );
-
- when(permissionTemplateDao.countUsers(any(DbSession.class), any(PermissionQuery.class), anyLong())).thenReturn(1);
-
- UserWithPermissionQueryResult result = underTest.findUsersWithPermissionTemplate(dbSession, PermissionQuery.builder().permission("user").template("my_template").build());
- assertThat(result.users()).hasSize(1);
- assertThat(result.total()).isEqualTo(1);
- }
-
- @Test
- public void fail_to_find_users_from_permission_template_when_template_not_found() {
- when(permissionTemplateDao.selectByUuid(anyString())).thenReturn(null);
-
- try {
- underTest.findUsersWithPermissionTemplate(dbSession, PermissionQuery.builder().permission("user").template("Unknown").build());
- fail();
- } catch (Exception e) {
- assertThat(e).isInstanceOf(NotFoundException.class).hasMessage("Template 'Unknown' does not exist");
- }
- }
-
- @Test
- public void find_groups_from_permission_template() {
- when(permissionTemplateDao.selectByUuid(anyString())).thenReturn(new PermissionTemplateDto().setId(1L).setUuid("my_template"));
-
- when(permissionTemplateDao.selectGroups(any(DbSession.class), any(PermissionQuery.class), anyLong())).thenReturn(
- newArrayList(new GroupWithPermissionDto().setName("users").setPermission("user"))
- );
-
- GroupWithPermissionQueryResult result = underTest.findGroupsWithPermissionTemplate(dbSession,
- PermissionQuery.builder().permission("user").template("my_template").membership(PermissionQuery.OUT).build());
- assertThat(result.groups()).hasSize(1);
- }
-
- @Test
- public void fail_to_find_groups_from_permission_template_when_template_not_found() {
- when(permissionTemplateDao.selectByUuid(anyString())).thenReturn(null);
-
- try {
- underTest.findGroupsWithPermissionTemplate(dbSession, PermissionQuery.builder().permission("user").template("Unknown").build());
- fail();
- } catch (Exception e) {
- assertThat(e).isInstanceOf(NotFoundException.class).hasMessage("Template 'Unknown' does not exist");
- }
- }
-}
diff --git a/sonar-db/src/main/java/org/sonar/core/permission/GroupWithPermission.java b/sonar-db/src/main/java/org/sonar/core/permission/GroupWithPermission.java
deleted file mode 100644
index 29f3a296c2b..00000000000
--- a/sonar-db/src/main/java/org/sonar/core/permission/GroupWithPermission.java
+++ /dev/null
@@ -1,93 +0,0 @@
-/*
- * SonarQube, open source software quality management tool.
- * Copyright (C) 2008-2014 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * SonarQube is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * SonarQube is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-
-package org.sonar.core.permission;
-
-import javax.annotation.CheckForNull;
-import javax.annotation.Nullable;
-import org.apache.commons.lang.builder.ToStringBuilder;
-import org.apache.commons.lang.builder.ToStringStyle;
-
-public class GroupWithPermission {
-
- private long id;
- private String name;
- private String description;
- private boolean hasPermission;
-
- public long id() {
- return id;
- }
-
- public GroupWithPermission setId(Long id) {
- this.id = id;
- return this;
- }
-
- public String name() {
- return name;
- }
-
- public GroupWithPermission setName(String name) {
- this.name = name;
- return this;
- }
-
- @CheckForNull
- public String description() {
- return description;
- }
-
- public GroupWithPermission setDescription(@Nullable String description) {
- this.description = description;
- return this;
- }
-
- public boolean hasPermission() {
- return hasPermission;
- }
-
- public GroupWithPermission hasPermission(boolean hasPermission) {
- this.hasPermission = hasPermission;
- return this;
- }
-
- @Override
- public String toString() {
- return ToStringBuilder.reflectionToString(this, ToStringStyle.SHORT_PREFIX_STYLE);
- }
-
- @Override
- public boolean equals(Object o) {
- if (this == o) {
- return true;
- }
- if (o == null || getClass() != o.getClass()) {
- return false;
- }
- GroupWithPermission that = (GroupWithPermission) o;
- return name.equals(that.name);
- }
-
- @Override
- public int hashCode() {
- return name.hashCode();
- }
-}
diff --git a/sonar-db/src/main/java/org/sonar/core/permission/UserWithPermission.java b/sonar-db/src/main/java/org/sonar/core/permission/UserWithPermission.java
deleted file mode 100644
index 7e8080d4ccb..00000000000
--- a/sonar-db/src/main/java/org/sonar/core/permission/UserWithPermission.java
+++ /dev/null
@@ -1,89 +0,0 @@
-/*
- * SonarQube, open source software quality management tool.
- * Copyright (C) 2008-2014 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * SonarQube is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * SonarQube is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.core.permission;
-
-import org.apache.commons.lang.builder.ToStringBuilder;
-import org.apache.commons.lang.builder.ToStringStyle;
-
-public class UserWithPermission {
-
- private String login;
- private String name;
- private String email;
- private boolean hasPermission;
-
- public String login() {
- return login;
- }
-
- public UserWithPermission setLogin(String login) {
- this.login = login;
- return this;
- }
-
- public String name() {
- return name;
- }
-
- public UserWithPermission setName(String name) {
- this.name = name;
- return this;
- }
-
- public String email() {
- return email;
- }
-
- public UserWithPermission setEmail(String email) {
- this.email = email;
- return this;
- }
-
- public boolean hasPermission() {
- return hasPermission;
- }
-
- public UserWithPermission hasPermission(boolean hasPermission) {
- this.hasPermission = hasPermission;
- return this;
- }
-
- @Override
- public String toString() {
- return ToStringBuilder.reflectionToString(this, ToStringStyle.SHORT_PREFIX_STYLE);
- }
-
- @Override
- public boolean equals(Object o) {
- if (this == o) {
- return true;
- }
- if (o == null || getClass() != o.getClass()) {
- return false;
- }
- UserWithPermission that = (UserWithPermission) o;
- return login.equals(that.login);
- }
-
- @Override
- public int hashCode() {
- return login.hashCode();
- }
-}
diff --git a/sonar-db/src/main/java/org/sonar/db/permission/GroupWithPermissionDto.java b/sonar-db/src/main/java/org/sonar/db/permission/GroupWithPermissionDto.java
index 3df694d5814..521a87439d8 100644
--- a/sonar-db/src/main/java/org/sonar/db/permission/GroupWithPermissionDto.java
+++ b/sonar-db/src/main/java/org/sonar/db/permission/GroupWithPermissionDto.java
@@ -22,7 +22,6 @@ package org.sonar.db.permission;
import javax.annotation.CheckForNull;
import javax.annotation.Nullable;
-import org.sonar.core.permission.GroupWithPermission;
public class GroupWithPermissionDto {
@@ -67,12 +66,4 @@ public class GroupWithPermissionDto {
this.description = description;
return this;
}
-
- public GroupWithPermission toGroupWithPermission() {
- return new GroupWithPermission()
- .setId(id)
- .setName(name)
- .setDescription(description)
- .hasPermission(permission != null);
- }
}
diff --git a/sonar-db/src/main/java/org/sonar/db/permission/UserWithPermissionDto.java b/sonar-db/src/main/java/org/sonar/db/permission/UserWithPermissionDto.java
index efa0d17c07c..15ed345eb11 100644
--- a/sonar-db/src/main/java/org/sonar/db/permission/UserWithPermissionDto.java
+++ b/sonar-db/src/main/java/org/sonar/db/permission/UserWithPermissionDto.java
@@ -22,7 +22,6 @@ package org.sonar.db.permission;
import javax.annotation.CheckForNull;
import javax.annotation.Nullable;
-import org.sonar.core.permission.UserWithPermission;
public class UserWithPermissionDto {
@@ -67,12 +66,4 @@ public class UserWithPermissionDto {
this.permission = permission;
return this;
}
-
- public UserWithPermission toUserWithPermission() {
- return new UserWithPermission()
- .setLogin(login)
- .setName(name)
- .setEmail(email)
- .hasPermission(permission != null);
- }
}
diff --git a/sonar-db/src/test/java/org/sonar/db/permission/GroupWithPermissionDtoTest.java b/sonar-db/src/test/java/org/sonar/db/permission/GroupWithPermissionDtoTest.java
deleted file mode 100644
index 04101abeb04..00000000000
--- a/sonar-db/src/test/java/org/sonar/db/permission/GroupWithPermissionDtoTest.java
+++ /dev/null
@@ -1,54 +0,0 @@
-/*
- * SonarQube, open source software quality management tool.
- * Copyright (C) 2008-2014 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * SonarQube is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * SonarQube is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-
-package org.sonar.db.permission;
-
-import org.junit.Test;
-import org.sonar.core.permission.GroupWithPermission;
-
-import static org.assertj.core.api.Assertions.assertThat;
-
-public class GroupWithPermissionDtoTest {
-
- @Test
- public void to_group_with_permission_having_permission() {
- GroupWithPermission group = new GroupWithPermissionDto()
- .setName("users")
- .setDescription("desc")
- .setPermission("user")
- .toGroupWithPermission();
-
- assertThat(group.name()).isEqualTo("users");
- assertThat(group.description()).isEqualTo("desc");
- assertThat(group.hasPermission()).isTrue();
- }
-
- @Test
- public void to_group_with_permission_not_having_permission() {
- GroupWithPermission group = new GroupWithPermissionDto()
- .setName("users")
- .setPermission(null)
- .toGroupWithPermission();
-
- assertThat(group.name()).isEqualTo("users");
- assertThat(group.description()).isNull();
- assertThat(group.hasPermission()).isFalse();
- }
-}
diff --git a/sonar-db/src/test/java/org/sonar/db/permission/GroupWithPermissionTest.java b/sonar-db/src/test/java/org/sonar/db/permission/GroupWithPermissionTest.java
deleted file mode 100644
index 7ddc78d1308..00000000000
--- a/sonar-db/src/test/java/org/sonar/db/permission/GroupWithPermissionTest.java
+++ /dev/null
@@ -1,56 +0,0 @@
-/*
- * SonarQube, open source software quality management tool.
- * Copyright (C) 2008-2014 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * SonarQube is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * SonarQube is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.db.permission;
-
-import org.junit.Test;
-import org.sonar.core.permission.GroupWithPermission;
-
-import static org.assertj.core.api.Assertions.assertThat;
-
-public class GroupWithPermissionTest {
-
- @Test
- public void test_setters_and_getters() throws Exception {
- GroupWithPermission user = new GroupWithPermission()
- .setName("users")
- .hasPermission(true);
-
- assertThat(user.name()).isEqualTo("users");
- assertThat(user.hasPermission()).isTrue();
- }
-
- @Test
- public void test_equals() throws Exception {
- assertThat(new GroupWithPermission().setName("users")).isEqualTo(new GroupWithPermission().setName("users"));
- assertThat(new GroupWithPermission().setName("users")).isNotEqualTo(new GroupWithPermission().setName("reviewers"));
-
- GroupWithPermission group = new GroupWithPermission()
- .setName("users")
- .hasPermission(true);
- assertThat(group).isEqualTo(group);
- }
-
- @Test
- public void test_hashcode() throws Exception {
- assertThat(new GroupWithPermission().setName("users").hashCode()).isEqualTo(new GroupWithPermission().setName("users").hashCode());
- assertThat(new GroupWithPermission().setName("users").hashCode()).isNotEqualTo(new GroupWithPermission().setName("reviewers").hashCode());
- }
-
-}
diff --git a/sonar-db/src/test/java/org/sonar/db/permission/UserWithPermissionDtoTest.java b/sonar-db/src/test/java/org/sonar/db/permission/UserWithPermissionDtoTest.java
deleted file mode 100644
index 56d951ebb2d..00000000000
--- a/sonar-db/src/test/java/org/sonar/db/permission/UserWithPermissionDtoTest.java
+++ /dev/null
@@ -1,55 +0,0 @@
-/*
- * SonarQube, open source software quality management tool.
- * Copyright (C) 2008-2014 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * SonarQube is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * SonarQube is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-
-package org.sonar.db.permission;
-
-import org.junit.Test;
-import org.sonar.core.permission.UserWithPermission;
-
-import static org.assertj.core.api.Assertions.assertThat;
-
-public class UserWithPermissionDtoTest {
-
- @Test
- public void to_user_with_permission_having_permission() {
- UserWithPermission user = new UserWithPermissionDto()
- .setName("Arthur")
- .setLogin("arthur")
- .setPermission("user")
- .toUserWithPermission();
-
- assertThat(user.name()).isEqualTo("Arthur");
- assertThat(user.login()).isEqualTo("arthur");
- assertThat(user.hasPermission()).isTrue();
- }
-
- @Test
- public void to_user_with_permission_not_having_permission() {
- UserWithPermission user = new UserWithPermissionDto()
- .setName("Arthur")
- .setLogin("arthur")
- .setPermission(null)
- .toUserWithPermission();
-
- assertThat(user.name()).isEqualTo("Arthur");
- assertThat(user.login()).isEqualTo("arthur");
- assertThat(user.hasPermission()).isFalse();
- }
-}
diff --git a/sonar-db/src/test/java/org/sonar/db/permission/UserWithPermissionTest.java b/sonar-db/src/test/java/org/sonar/db/permission/UserWithPermissionTest.java
deleted file mode 100644
index baada745f8c..00000000000
--- a/sonar-db/src/test/java/org/sonar/db/permission/UserWithPermissionTest.java
+++ /dev/null
@@ -1,59 +0,0 @@
-/*
- * SonarQube, open source software quality management tool.
- * Copyright (C) 2008-2014 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * SonarQube is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * SonarQube is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.db.permission;
-
-import org.junit.Test;
-import org.sonar.core.permission.UserWithPermission;
-
-import static org.assertj.core.api.Assertions.assertThat;
-
-public class UserWithPermissionTest {
-
- @Test
- public void test_setters_and_getters() throws Exception {
- UserWithPermission user = new UserWithPermission()
- .setName("Arthur")
- .setLogin("arthur")
- .hasPermission(true);
-
- assertThat(user.name()).isEqualTo("Arthur");
- assertThat(user.login()).isEqualTo("arthur");
- assertThat(user.hasPermission()).isTrue();
- }
-
- @Test
- public void test_equals() throws Exception {
- assertThat(new UserWithPermission().setLogin("arthur")).isEqualTo(new UserWithPermission().setLogin("arthur"));
- assertThat(new UserWithPermission().setLogin("arthur")).isNotEqualTo(new UserWithPermission().setLogin("john"));
-
- UserWithPermission user = new UserWithPermission()
- .setName("Arthur")
- .setLogin("arthur")
- .hasPermission(true);
- assertThat(user).isEqualTo(user);
- }
-
- @Test
- public void test_hashcode() throws Exception {
- assertThat(new UserWithPermission().setLogin("arthur").hashCode()).isEqualTo(new UserWithPermission().setLogin("arthur").hashCode());
- assertThat(new UserWithPermission().setLogin("arthur").hashCode()).isNotEqualTo(new UserWithPermission().setLogin("john").hashCode());
- }
-
-}