diff options
author | Jean-Baptiste Vilain <jean-baptiste.vilain@sonarsource.com> | 2013-07-04 13:38:22 +0200 |
---|---|---|
committer | Jean-Baptiste Vilain <jean-baptiste.vilain@sonarsource.com> | 2013-07-04 13:38:22 +0200 |
commit | 67506dbb60457e0634e4aca3d8ca74f2afd8d50e (patch) | |
tree | 90116b4dfbc4e7f113789fdac194b1a6899febce | |
parent | da1e8934e2fe8942867299679fe3e6cf9a148f3e (diff) | |
download | sonarqube-67506dbb60457e0634e4aca3d8ca74f2afd8d50e.tar.gz sonarqube-67506dbb60457e0634e4aca3d8ca74f2afd8d50e.zip |
SONAR-4463 Updated the permission tables and the permission template select query
21 files changed, 213 insertions, 42 deletions
diff --git a/sonar-core/src/main/java/org/sonar/core/user/PermissionDao.java b/sonar-core/src/main/java/org/sonar/core/user/PermissionDao.java index f834ec1d2c7..2e70595ec14 100644 --- a/sonar-core/src/main/java/org/sonar/core/user/PermissionDao.java +++ b/sonar-core/src/main/java/org/sonar/core/user/PermissionDao.java @@ -27,6 +27,7 @@ import org.sonar.core.persistence.MyBatis; import javax.annotation.Nullable; import java.util.Date; +import java.util.List; public class PermissionDao implements TaskExtension, ServerExtension { @@ -41,7 +42,9 @@ public class PermissionDao implements TaskExtension, ServerExtension { SqlSession session = myBatis.openSession(); try { PermissionTemplateMapper mapper = session.getMapper(PermissionTemplateMapper.class); - permissionTemplate = mapper.selectByName(templateName); + permissionTemplate = mapper.selectTemplateUsersPermissions(templateName); + PermissionTemplateDto templateWithGroupsPermissions = mapper.selectTemplateGroupsPermissions(templateName); + permissionTemplate.setGroupsByPermission(templateWithGroupsPermissions.getGroupsPermissions()); session.commit(); } finally { MyBatis.closeQuietly(session); @@ -49,6 +52,15 @@ public class PermissionDao implements TaskExtension, ServerExtension { return permissionTemplate; } + public List<PermissionTemplateDto> selectAllPermissionTemplates() { + SqlSession session = myBatis.openSession(); + try { + return session.selectList("selectAllPermissionTemplates"); + } finally { + MyBatis.closeQuietly(session); + } + } + public PermissionTemplateDto createPermissionTemplate(String templateName, @Nullable String description) { PermissionTemplateDto permissionTemplate = new PermissionTemplateDto() .setName(templateName) @@ -66,10 +78,11 @@ public class PermissionDao implements TaskExtension, ServerExtension { return permissionTemplate; } - public void addUserPermission(Long templateId, Long userId) { + public void addUserPermission(Long templateId, Long userId, String permission) { PermissionTemplateUserDto permissionTemplateUser = new PermissionTemplateUserDto() .setTemplateId(templateId) .setUserId(userId) + .setPermission(permission) .setCreatedAt(now()) .setUpdatedAt(now()); SqlSession session = myBatis.openSession(); @@ -82,9 +95,10 @@ public class PermissionDao implements TaskExtension, ServerExtension { } } - public void removeUserPermission(Long templateId, Long userId) { + public void removeUserPermission(Long templateId, Long userId, String permission) { PermissionTemplateUserDto permissionTemplateUser = new PermissionTemplateUserDto() .setTemplateId(templateId) + .setPermission(permission) .setUserId(userId); SqlSession session = myBatis.openSession(); try { @@ -96,9 +110,10 @@ public class PermissionDao implements TaskExtension, ServerExtension { } } - public void addGroupPermission(Long templateId, @Nullable Long groupId) { + public void addGroupPermission(Long templateId, @Nullable Long groupId, String permission) { PermissionTemplateGroupDto permissionTemplateGroup = new PermissionTemplateGroupDto() .setTemplateId(templateId) + .setPermission(permission) .setGroupId(groupId) .setCreatedAt(now()) .setUpdatedAt(now()); @@ -112,9 +127,10 @@ public class PermissionDao implements TaskExtension, ServerExtension { } } - public void removeGroupPermission(Long templateId, @Nullable Long groupId) { + public void removeGroupPermission(Long templateId, @Nullable Long groupId, String permission) { PermissionTemplateGroupDto permissionTemplateGroup = new PermissionTemplateGroupDto() .setTemplateId(templateId) + .setPermission(permission) .setGroupId(groupId); SqlSession session = myBatis.openSession(); try { diff --git a/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateDto.java b/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateDto.java index 58fca22abe0..fb235c99e8b 100644 --- a/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateDto.java +++ b/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateDto.java @@ -22,12 +22,15 @@ package org.sonar.core.user; import javax.annotation.Nullable; import java.util.Date; +import java.util.List; public class PermissionTemplateDto { private Long id; private String name; private String description; + private List<PermissionTemplateUserDto> usersPermissions; + private List<PermissionTemplateGroupDto> groupsPermissions; private Date createdAt; private Date updatedAt; @@ -58,6 +61,24 @@ public class PermissionTemplateDto { return this; } + public List<PermissionTemplateUserDto> getUsersPermissions() { + return usersPermissions; + } + + public PermissionTemplateDto setUsersPermissions(List<PermissionTemplateUserDto> usersPermissions) { + this.usersPermissions = usersPermissions; + return this; + } + + public List<PermissionTemplateGroupDto> getGroupsPermissions() { + return groupsPermissions; + } + + public PermissionTemplateDto setGroupsByPermission(List<PermissionTemplateGroupDto> groupsPermissions) { + this.groupsPermissions = groupsPermissions; + return this; + } + public Date getCreatedAt() { return createdAt; } diff --git a/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateGroupDto.java b/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateGroupDto.java index 5000ee760f9..157c6f78582 100644 --- a/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateGroupDto.java +++ b/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateGroupDto.java @@ -28,6 +28,8 @@ public class PermissionTemplateGroupDto { private Long id; private Long templateId; private Long groupId; + private String permission; + private String groupName; private Date createdAt; private Date updatedAt; @@ -58,6 +60,24 @@ public class PermissionTemplateGroupDto { return this; } + public String getPermission() { + return permission; + } + + public PermissionTemplateGroupDto setPermission(String permission) { + this.permission = permission; + return this; + } + + public String getGroupName() { + return groupName; + } + + public PermissionTemplateGroupDto setGroupName(String groupName) { + this.groupName = groupName; + return this; + } + public Date getCreatedAt() { return createdAt; } diff --git a/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateMapper.java b/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateMapper.java index 772b6e7ef9e..cc0f392e5d2 100644 --- a/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateMapper.java +++ b/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateMapper.java @@ -27,7 +27,9 @@ public interface PermissionTemplateMapper { void insert(PermissionTemplateDto permissionTemplate); - PermissionTemplateDto selectByName(String name); + PermissionTemplateDto selectTemplateUsersPermissions(String templateName); + + PermissionTemplateDto selectTemplateGroupsPermissions(String templateName); void insertUserPermission(PermissionTemplateUserDto permissionTemplateUser); diff --git a/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateUserDto.java b/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateUserDto.java index 7ebdc2cd0b1..bb441bcea98 100644 --- a/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateUserDto.java +++ b/sonar-core/src/main/java/org/sonar/core/user/PermissionTemplateUserDto.java @@ -27,6 +27,8 @@ public class PermissionTemplateUserDto { private Long id; private Long templateId; private Long userId; + private String permission; + private String userName; private Date createdAt; private Date updatedAt; @@ -57,6 +59,25 @@ public class PermissionTemplateUserDto { return this; } + public String getUserName() { + return userName; + } + + public PermissionTemplateUserDto setUserName(String userName) { + this.userName = userName; + return this; + } + + public String getPermission() { + return permission; + } + + + public PermissionTemplateUserDto setPermission(String permission) { + this.permission = permission; + return this; + } + public Date getCreatedAt() { return createdAt; } diff --git a/sonar-core/src/main/resources/org/sonar/core/persistence/schema-h2.ddl b/sonar-core/src/main/resources/org/sonar/core/persistence/schema-h2.ddl index 9924b3780d4..6bf00be3dbb 100644 --- a/sonar-core/src/main/resources/org/sonar/core/persistence/schema-h2.ddl +++ b/sonar-core/src/main/resources/org/sonar/core/persistence/schema-h2.ddl @@ -544,6 +544,7 @@ CREATE TABLE "PERM_TEMPLATES_USERS" ( "ID" INTEGER NOT NULL GENERATED BY DEFAULT AS IDENTITY (START WITH 1, INCREMENT BY 1), "USER_ID" INTEGER NOT NULL, "TEMPLATE_ID" INTEGER NOT NULL, + "PERMISSION" VARCHAR(64) NOT NULL, "CREATED_AT" TIMESTAMP, "UPDATED_AT" TIMESTAMP ); @@ -552,6 +553,7 @@ CREATE TABLE "PERM_TEMPLATES_GROUPS" ( "ID" INTEGER NOT NULL GENERATED BY DEFAULT AS IDENTITY (START WITH 1, INCREMENT BY 1), "GROUP_ID" INTEGER, "TEMPLATE_ID" INTEGER NOT NULL, + "PERMISSION" VARCHAR(64) NOT NULL, "CREATED_AT" TIMESTAMP, "UPDATED_AT" TIMESTAMP ); diff --git a/sonar-core/src/main/resources/org/sonar/core/user/PermissionTemplateMapper.xml b/sonar-core/src/main/resources/org/sonar/core/user/PermissionTemplateMapper.xml index 5876cda0f7e..ee260ea609b 100644 --- a/sonar-core/src/main/resources/org/sonar/core/user/PermissionTemplateMapper.xml +++ b/sonar-core/src/main/resources/org/sonar/core/user/PermissionTemplateMapper.xml @@ -9,8 +9,8 @@ </insert> <insert id="insertUserPermission" parameterType="PermissionTemplateUser"> - INSERT INTO perm_templates_users (template_id, user_id, created_at, updated_at) - VALUES (#{templateId}, #{userId}, #{createdAt}, #{updatedAt}) + INSERT INTO perm_templates_users (template_id, user_id, permission, created_at, updated_at) + VALUES (#{templateId}, #{userId}, #{permission}, #{createdAt}, #{updatedAt}) </insert> <delete id="deleteUserPermission" parameterType="PermissionTemplateUser"> @@ -20,8 +20,8 @@ </delete> <insert id="insertGroupPermission" parameterType="PermissionTemplateGroup"> - INSERT INTO perm_templates_groups (template_id, group_id, created_at, updated_at) - VALUES (#{templateId}, #{groupId}, #{createdAt}, #{updatedAt}) + INSERT INTO perm_templates_groups (template_id, group_id, permission, created_at, updated_at) + VALUES (#{templateId}, #{groupId}, #{permission}, #{createdAt}, #{updatedAt}) </insert> <delete id="deleteGroupPermission" parameterType="PermissionTemplateGroup"> @@ -38,9 +38,57 @@ </choose> </delete> - <select id="selectByName" parameterType="string" resultType="PermissionTemplate"> + <select id="selectAllPermissionTemplates" resultType="PermissionTemplate"> SELECT id, name, description, created_at AS createdAt, updated_at AS updatedAt - FROM permission_templates WHERE name=#{name} + FROM permission_templates </select> + <select id="selectTemplateUsersPermissions" parameterType="String" resultMap="fullPermissionsTemplateResult"> + SELECT pt.id AS template_id, + pt.name AS template_name, + pt.description AS template_description, + pt.created_at AS template_created_at, + pt.updated_at AS template_updated_at, + ptu.id AS permission_template_user_id, + ptu.permission AS user_permission, + u.name AS user_name + FROM permission_templates AS pt + INNER JOIN perm_templates_users AS ptu ON ptu.template_id = pt.id + INNER JOIN users AS u ON u.id = ptu.user_id + WHERE pt.name = #{templateName} + </select> + + <select id="selectTemplateGroupsPermissions" parameterType="String" resultMap="fullPermissionsTemplateResult"> + SELECT pt.id AS template_id, + pt.name AS template_name, + pt.description AS template_description, + pt.created_at AS template_created_at, + pt.updated_at AS template_updated_at, + ptg.id AS permission_template_group_id, + ptg.permission AS group_permission, + g.name AS group_name + FROM permission_templates AS pt + INNER JOIN perm_templates_groups AS ptg ON ptg.template_id = pt.id + LEFT OUTER JOIN groups AS g ON g.id = ptg.group_id + WHERE pt.name = #{templateName} + </select> + + <resultMap id="fullPermissionsTemplateResult" type="PermissionTemplate"> + <id property="id" column="template_id" /> + <result property="name" column="template_name"/> + <result property="description" column="template_description"/> + <result property="createdAt" column="template_created_at"/> + <result property="updatedAt" column="template_updated_at"/> + <collection property="usersPermissions" ofType="PermissionTemplateUser"> + <id property="id" column="permission_template_user_id"/> + <result property="permission" column="user_permission"/> + <result property="userName" column="user_name"/> + </collection> + <collection property="groupsPermissions" ofType="PermissionTemplateGroup"> + <id property="id" column="permission_template_group_id"/> + <result property="permission" column="group_permission"/> + <result property="groupName" column="group_name"/> + </collection> + </resultMap> + </mapper> diff --git a/sonar-core/src/test/java/org/sonar/core/user/PermissionDaoTest.java b/sonar-core/src/test/java/org/sonar/core/user/PermissionDaoTest.java index 6a81efda50b..205c9365cfb 100644 --- a/sonar-core/src/test/java/org/sonar/core/user/PermissionDaoTest.java +++ b/sonar-core/src/test/java/org/sonar/core/user/PermissionDaoTest.java @@ -24,6 +24,8 @@ import org.junit.Before; import org.junit.Test; import org.sonar.core.persistence.AbstractDaoTestCase; +import java.util.List; + import static org.fest.assertions.Assertions.assertThat; public class PermissionDaoTest extends AbstractDaoTestCase { @@ -52,65 +54,83 @@ public class PermissionDaoTest extends AbstractDaoTestCase { assertThat(permissionTemplate).isNotNull(); assertThat(permissionTemplate.getName()).isEqualTo("my template"); assertThat(permissionTemplate.getDescription()).isEqualTo("my description"); + assertThat(permissionTemplate.getUsersPermissions()).hasSize(3); + assertThat(permissionTemplate.getUsersPermissions()).onProperty("userName").containsOnly("user1", "user2", "user2"); + assertThat(permissionTemplate.getUsersPermissions()).onProperty("permission").containsOnly("user_permission1", "user_permission1", "user_permission2"); + assertThat(permissionTemplate.getGroupsPermissions()).hasSize(3); + assertThat(permissionTemplate.getGroupsPermissions()).onProperty("groupName").containsOnly("group1", "group2", null); + assertThat(permissionTemplate.getGroupsPermissions()).onProperty("permission").containsOnly("group_permission1", "group_permission1", "group_permission2"); + } + + @Test + public void should_select_all_permission_templates() throws Exception { + setupData("selectAllPermissionTemplates"); + + List<PermissionTemplateDto> permissionTemplates = permissionDao.selectAllPermissionTemplates(); + + assertThat(permissionTemplates).hasSize(3); + assertThat(permissionTemplates).onProperty("id").containsOnly(1L, 2L, 3L); + assertThat(permissionTemplates).onProperty("name").containsOnly("template1", "template2", "template3"); + assertThat(permissionTemplates).onProperty("description").containsOnly("description1", "description2", "description3"); } @Test public void should_add_user_permission_to_template() throws Exception { setupData("addUserPermissionToTemplate"); - permissionDao.addUserPermission(1L, 1L); + permissionDao.addUserPermission(1L, 1L, "new_permission"); checkTable("addUserPermissionToTemplate", "permission_templates", "id", "name", "description"); - checkTable("addUserPermissionToTemplate", "perm_templates_users", "id", "template_id", "user_id"); - checkTable("addUserPermissionToTemplate", "perm_templates_groups", "id", "template_id", "group_id"); + checkTable("addUserPermissionToTemplate", "perm_templates_users", "id", "template_id", "user_id", "permission"); + checkTable("addUserPermissionToTemplate", "perm_templates_groups", "id", "template_id", "group_id", "permission"); } @Test public void should_remove_user_permission_from_template() throws Exception { setupData("removeUserPermissionFromTemplate"); - permissionDao.removeUserPermission(1L, 2L); + permissionDao.removeUserPermission(1L, 2L, "existing_permission"); checkTable("removeUserPermissionFromTemplate", "permission_templates", "id", "name", "description"); - checkTable("removeUserPermissionFromTemplate", "perm_templates_users", "id", "template_id", "user_id"); - checkTable("removeUserPermissionFromTemplate", "perm_templates_groups", "id", "template_id", "group_id"); + checkTable("removeUserPermissionFromTemplate", "perm_templates_users", "id", "template_id", "user_id", "permission"); + checkTable("removeUserPermissionFromTemplate", "perm_templates_groups", "id", "template_id", "group_id", "permission"); } @Test public void should_add_group_permission_to_template() throws Exception { setupData("addGroupPermissionToTemplate"); - permissionDao.addGroupPermission(1L, 1L); + permissionDao.addGroupPermission(1L, 1L, "new_permission"); checkTable("addGroupPermissionToTemplate", "permission_templates", "id", "name", "description"); - checkTable("addGroupPermissionToTemplate", "perm_templates_users", "id", "template_id", "user_id"); - checkTable("addGroupPermissionToTemplate", "perm_templates_groups", "id", "template_id", "group_id"); + checkTable("addGroupPermissionToTemplate", "perm_templates_users", "id", "template_id", "user_id", "permission"); + checkTable("addGroupPermissionToTemplate", "perm_templates_groups", "id", "template_id", "group_id", "permission"); } @Test public void should_remove_group_permission_from_template() throws Exception { setupData("removeGroupPermissionFromTemplate"); - permissionDao.removeGroupPermission(1L, 2L); + permissionDao.removeGroupPermission(1L, 2L, "existing_permission"); checkTable("removeGroupPermissionFromTemplate", "permission_templates", "id", "name", "description"); - checkTable("removeGroupPermissionFromTemplate", "perm_templates_users", "id", "template_id", "user_id"); - checkTable("removeGroupPermissionFromTemplate", "perm_templates_groups", "id", "template_id", "group_id"); + checkTable("removeGroupPermissionFromTemplate", "perm_templates_users", "id", "template_id", "user_id", "permission"); + checkTable("removeGroupPermissionFromTemplate", "perm_templates_groups", "id", "template_id", "group_id", "permission"); } @Test public void should_add_group_permission_with_null_name() throws Exception { setupData("addNullGroupPermissionToTemplate"); - permissionDao.addGroupPermission(1L, null); + permissionDao.addGroupPermission(1L, null, "new_permission"); checkTable("addNullGroupPermissionToTemplate", "permission_templates", "id", "name", "description"); - checkTable("addNullGroupPermissionToTemplate", "perm_templates_users", "id", "template_id", "user_id"); - checkTable("addNullGroupPermissionToTemplate", "perm_templates_groups", "id", "template_id", "group_id"); + checkTable("addNullGroupPermissionToTemplate", "perm_templates_users", "id", "template_id", "user_id", "permission"); + checkTable("addNullGroupPermissionToTemplate", "perm_templates_groups", "id", "template_id", "group_id", "permission"); } @Test public void should_remove_group_permission_with_null_name() throws Exception { setupData("removeNullGroupPermissionFromTemplate"); - permissionDao.removeGroupPermission(1L, null); + permissionDao.removeGroupPermission(1L, null, "existing_permission"); checkTable("removeNullGroupPermissionFromTemplate", "permission_templates", "id", "name", "description"); - checkTable("removeNullGroupPermissionFromTemplate", "perm_templates_users", "id", "template_id", "user_id"); - checkTable("removeNullGroupPermissionFromTemplate", "perm_templates_groups", "id", "template_id", "group_id"); + checkTable("removeNullGroupPermissionFromTemplate", "perm_templates_users", "id", "template_id", "user_id", "permission"); + checkTable("removeNullGroupPermissionFromTemplate", "perm_templates_groups", "id", "template_id", "group_id", "permission"); } } diff --git a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/addGroupPermissionToTemplate-result.xml b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/addGroupPermissionToTemplate-result.xml index 55f6631b4bd..b7b0225d345 100644 --- a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/addGroupPermissionToTemplate-result.xml +++ b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/addGroupPermissionToTemplate-result.xml @@ -1,5 +1,5 @@ <dataset> <permission_templates id="1" name="my template" description="my description"/> <perm_templates_users/> - <perm_templates_groups id="1" template_id="1" group_id="1"/> + <perm_templates_groups id="1" template_id="1" group_id="1" permission="new_permission"/> </dataset>
\ No newline at end of file diff --git a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/addNullGroupPermissionToTemplate-result.xml b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/addNullGroupPermissionToTemplate-result.xml index 28a40c594b9..fda5cefa69b 100644 --- a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/addNullGroupPermissionToTemplate-result.xml +++ b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/addNullGroupPermissionToTemplate-result.xml @@ -1,5 +1,5 @@ <dataset> <permission_templates id="1" name="my template" description="my description"/> <perm_templates_users/> - <perm_templates_groups id="1" template_id="1" group_id="[null]"/> + <perm_templates_groups id="1" template_id="1" group_id="[null]" permission="new_permission"/> </dataset>
\ No newline at end of file diff --git a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/addUserPermissionToTemplate-result.xml b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/addUserPermissionToTemplate-result.xml index c691de7ca4b..3f243536113 100644 --- a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/addUserPermissionToTemplate-result.xml +++ b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/addUserPermissionToTemplate-result.xml @@ -1,5 +1,5 @@ <dataset> <permission_templates id="1" name="my template" description="my description"/> - <perm_templates_users id="1" template_id="1" user_id="1"/> + <perm_templates_users id="1" template_id="1" user_id="1" permission="new_permission"/> <perm_templates_groups/> </dataset>
\ No newline at end of file diff --git a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeGroupPermissionFromTemplate-result.xml b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeGroupPermissionFromTemplate-result.xml index 55f6631b4bd..1d43ca22fea 100644 --- a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeGroupPermissionFromTemplate-result.xml +++ b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeGroupPermissionFromTemplate-result.xml @@ -1,5 +1,5 @@ <dataset> <permission_templates id="1" name="my template" description="my description"/> <perm_templates_users/> - <perm_templates_groups id="1" template_id="1" group_id="1"/> + <perm_templates_groups id="1" template_id="1" group_id="1" permission="remaining_permission"/> </dataset>
\ No newline at end of file diff --git a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeGroupPermissionFromTemplate.xml b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeGroupPermissionFromTemplate.xml index af9c26e2a75..06e5322a5d3 100644 --- a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeGroupPermissionFromTemplate.xml +++ b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeGroupPermissionFromTemplate.xml @@ -1,6 +1,6 @@ <dataset> <permission_templates id="1" name="my template" description="my description"/> <perm_templates_users/> - <perm_templates_groups id="1" template_id="1" group_id="1"/> - <perm_templates_groups id="2" template_id="1" group_id="2"/> + <perm_templates_groups id="1" template_id="1" group_id="1" permission="remaining_permission"/> + <perm_templates_groups id="2" template_id="1" group_id="2" permission="existing_permission"/> </dataset>
\ No newline at end of file diff --git a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeNullGroupPermissionFromTemplate-result.xml b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeNullGroupPermissionFromTemplate-result.xml index 55f6631b4bd..1d43ca22fea 100644 --- a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeNullGroupPermissionFromTemplate-result.xml +++ b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeNullGroupPermissionFromTemplate-result.xml @@ -1,5 +1,5 @@ <dataset> <permission_templates id="1" name="my template" description="my description"/> <perm_templates_users/> - <perm_templates_groups id="1" template_id="1" group_id="1"/> + <perm_templates_groups id="1" template_id="1" group_id="1" permission="remaining_permission"/> </dataset>
\ No newline at end of file diff --git a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeNullGroupPermissionFromTemplate.xml b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeNullGroupPermissionFromTemplate.xml index c438548850b..095449a77b6 100644 --- a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeNullGroupPermissionFromTemplate.xml +++ b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeNullGroupPermissionFromTemplate.xml @@ -1,6 +1,6 @@ <dataset> <permission_templates id="1" name="my template" description="my description"/> <perm_templates_users/> - <perm_templates_groups id="1" template_id="1" group_id="1"/> - <perm_templates_groups id="2" template_id="1" group_id="[null]"/> + <perm_templates_groups id="1" template_id="1" group_id="1" permission="remaining_permission"/> + <perm_templates_groups id="2" template_id="1" group_id="[null]" permission="existing_permission"/> </dataset>
\ No newline at end of file diff --git a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeUserPermissionFromTemplate-result.xml b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeUserPermissionFromTemplate-result.xml index 11cf1aeeafc..68bf04077f4 100644 --- a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeUserPermissionFromTemplate-result.xml +++ b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeUserPermissionFromTemplate-result.xml @@ -1,7 +1,7 @@ <dataset> <permission_templates id="1" name="my template" description="my description"/> - <perm_templates_users id="1" template_id="1" user_id="1"/> + <perm_templates_users id="1" template_id="1" user_id="1" permission="remaining_permission"/> <perm_templates_groups/> </dataset>
\ No newline at end of file diff --git a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeUserPermissionFromTemplate.xml b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeUserPermissionFromTemplate.xml index e48d90f3df6..69427d2d3bf 100644 --- a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeUserPermissionFromTemplate.xml +++ b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/removeUserPermissionFromTemplate.xml @@ -1,8 +1,8 @@ <dataset> <permission_templates id="1" name="my template" description="my description"/> - <perm_templates_users id="1" template_id="1" user_id="1"/> - <perm_templates_users id="2" template_id="1" user_id="2"/> + <perm_templates_users id="1" template_id="1" user_id="1" permission="remaining_permission"/> + <perm_templates_users id="2" template_id="1" user_id="2" permission="existing_permission"/> <perm_templates_groups/> </dataset>
\ No newline at end of file diff --git a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/selectAllPermissionTemplates.xml b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/selectAllPermissionTemplates.xml new file mode 100644 index 00000000000..fc6e8c15234 --- /dev/null +++ b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/selectAllPermissionTemplates.xml @@ -0,0 +1,5 @@ +<dataset> + <permission_templates id="1" name="template1" description="description1" created_at="[null]" updated_at="[null]"/> + <permission_templates id="2" name="template2" description="description2" created_at="[null]" updated_at="[null]"/> + <permission_templates id="3" name="template3" description="description3" created_at="[null]" updated_at="[null]"/> +</dataset>
\ No newline at end of file diff --git a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/selectPermissionTemplate.xml b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/selectPermissionTemplate.xml index ff512b88358..0de01c53486 100644 --- a/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/selectPermissionTemplate.xml +++ b/sonar-core/src/test/resources/org/sonar/core/user/PermissionDaoTest/selectPermissionTemplate.xml @@ -1,3 +1,17 @@ <dataset> <permission_templates id="1" name="my template" description="my description" created_at="[null]" updated_at="[null]"/> + + <perm_templates_users id="1" template_id="1" user_id="1" permission="user_permission1"/> + <perm_templates_users id="2" template_id="1" user_id="2" permission="user_permission1"/> + <perm_templates_users id="3" template_id="1" user_id="2" permission="user_permission2"/> + + <users id="1" login="user1" name="user1" /> + <users id="2" login="user2" name="user2" /> + + <perm_templates_groups id="1" template_id="1" group_id="1" permission="group_permission1"/> + <perm_templates_groups id="2" template_id="1" group_id="2" permission="group_permission1"/> + <perm_templates_groups id="3" template_id="1" group_id="[null]" permission="group_permission2"/> + + <groups id="1" name="group1"/> + <groups id="2" name="group2"/> </dataset>
\ No newline at end of file diff --git a/sonar-server/src/main/webapp/WEB-INF/db/migrate/416_create_permission_templates_users.rb b/sonar-server/src/main/webapp/WEB-INF/db/migrate/416_create_permission_templates_users.rb index 1c5094ddefe..13581fad766 100644 --- a/sonar-server/src/main/webapp/WEB-INF/db/migrate/416_create_permission_templates_users.rb +++ b/sonar-server/src/main/webapp/WEB-INF/db/migrate/416_create_permission_templates_users.rb @@ -27,6 +27,7 @@ class CreatePermissionTemplatesUsers < ActiveRecord::Migration create_table :perm_templates_users do |t| t.column :user_id, :integer, :null => false t.column :template_id, :integer, :null => false + t.column :permission, :string, :null => false, :limit => 64 t.column :created_at, :datetime, :null => true t.column :updated_at, :datetime, :null => true end diff --git a/sonar-server/src/main/webapp/WEB-INF/db/migrate/417_create_permission_templates_groups.rb b/sonar-server/src/main/webapp/WEB-INF/db/migrate/417_create_permission_templates_groups.rb index d63b8ec1dac..b88ceabfc62 100644 --- a/sonar-server/src/main/webapp/WEB-INF/db/migrate/417_create_permission_templates_groups.rb +++ b/sonar-server/src/main/webapp/WEB-INF/db/migrate/417_create_permission_templates_groups.rb @@ -27,6 +27,7 @@ class CreatePermissionTemplatesGroups < ActiveRecord::Migration create_table :perm_templates_groups do |t| t.column :group_id, :integer, :null => true t.column :template_id, :integer, :null => false + t.column :permission, :string, :null => false, :limit => 64 t.column :created_at, :datetime, :null => true t.column :updated_at, :datetime, :null => true end |