Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

SetSeverityActionIT.java 5.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. /*
  2. * SonarQube
  3. * Copyright (C) 2009-2023 SonarSource SA
  4. * mailto:info AT sonarsource DOT com
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 3 of the License, or (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public License
  17. * along with this program; if not, write to the Free Software Foundation,
  18. * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  19. */
  20. package org.sonar.server.issue;
  21. import com.google.common.collect.ImmutableMap;
  22. import com.google.common.collect.Lists;
  23. import java.util.Date;
  24. import java.util.Map;
  25. import org.junit.Rule;
  26. import org.junit.Test;
  27. import org.sonar.api.issue.Issue;
  28. import org.sonar.api.rules.RuleType;
  29. import org.sonar.core.issue.DefaultIssue;
  30. import org.sonar.core.issue.FieldDiffs;
  31. import org.sonar.db.DbTester;
  32. import org.sonar.db.component.BranchDto;
  33. import org.sonar.db.component.ComponentDto;
  34. import org.sonar.db.issue.IssueDto;
  35. import org.sonar.db.issue.IssueTesting;
  36. import org.sonar.db.project.ProjectDto;
  37. import org.sonar.db.rule.RuleDto;
  38. import org.sonar.server.tester.AnonymousMockUserSession;
  39. import org.sonar.server.tester.UserSessionRule;
  40. import static org.assertj.core.api.Assertions.assertThat;
  41. import static org.assertj.core.api.Assertions.assertThatThrownBy;
  42. import static org.sonar.api.rule.Severity.MAJOR;
  43. import static org.sonar.api.rule.Severity.MINOR;
  44. import static org.sonar.api.web.UserRole.ISSUE_ADMIN;
  45. import static org.sonar.api.web.UserRole.USER;
  46. import static org.sonar.core.issue.IssueChangeContext.issueChangeContextByUserBuilder;
  47. import static org.sonar.db.component.ComponentTesting.newFileDto;
  48. import static org.sonar.db.rule.RuleTesting.newRule;
  49. public class SetSeverityActionIT {
  50. private static final Date NOW = new Date(10_000_000_000L);
  51. private static final String USER_LOGIN = "john";
  52. @Rule
  53. public UserSessionRule userSession = UserSessionRule.standalone();
  54. @Rule
  55. public DbTester db = DbTester.create();
  56. private IssueFieldsSetter issueUpdater = new IssueFieldsSetter();
  57. private SetSeverityAction action = new SetSeverityAction(issueUpdater, userSession);
  58. @Test
  59. public void set_severity() {
  60. IssueDto issueDto = newIssue().setSeverity(MAJOR);
  61. DefaultIssue issue = issueDto.toDefaultIssue();
  62. setUserWithBrowseAndAdministerIssuePermission(issueDto);
  63. Action.Context context = new ActionContext(issue, issueChangeContextByUserBuilder(NOW, userSession.getUuid()).build(), null);
  64. action.execute(ImmutableMap.of("severity", MINOR), context);
  65. assertThat(issue.severity()).isEqualTo(MINOR);
  66. assertThat(issue.isChanged()).isTrue();
  67. assertThat(issue.manualSeverity()).isTrue();
  68. assertThat(issue.updateDate()).isEqualTo(NOW);
  69. assertThat(issue.mustSendNotifications()).isTrue();
  70. Map<String, FieldDiffs.Diff> change = issue.currentChange().diffs();
  71. assertThat(change.get("severity").newValue()).isEqualTo(MINOR);
  72. assertThat(change.get("severity").oldValue()).isEqualTo(MAJOR);
  73. }
  74. @Test
  75. public void fail_if_parameter_not_found() {
  76. assertThatThrownBy(() -> action.verify(ImmutableMap.of("unknwown", MINOR), Lists.newArrayList(), new AnonymousMockUserSession()))
  77. .isInstanceOf(IllegalArgumentException.class)
  78. .hasMessage("Missing parameter : 'severity'");
  79. }
  80. @Test
  81. public void support_only_unresolved_issues() {
  82. IssueDto issueDto = newIssue().setSeverity(MAJOR).setChecksum(null);
  83. DefaultIssue issue = issueDto.toDefaultIssue();
  84. setUserWithBrowseAndAdministerIssuePermission(issueDto);
  85. assertThat(action.supports(issue.setResolution(null))).isTrue();
  86. assertThat(action.supports(issue.setResolution(Issue.RESOLUTION_FIXED))).isFalse();
  87. }
  88. @Test
  89. public void doesnt_support_security_hotspots() {
  90. IssueDto issueDto = newIssue().setSeverity(MAJOR);
  91. DefaultIssue issue = issueDto.toDefaultIssue();
  92. setUserWithBrowseAndAdministerIssuePermission(issueDto);
  93. assertThat(action.supports(issue.setType(RuleType.CODE_SMELL))).isTrue();
  94. assertThat(action.supports(issue.setType(RuleType.SECURITY_HOTSPOT))).isFalse();
  95. }
  96. @Test
  97. public void support_only_issues_with_issue_admin_permission() {
  98. IssueDto authorizedIssue = newIssue().setSeverity(MAJOR);
  99. setUserWithBrowseAndAdministerIssuePermission(authorizedIssue);
  100. IssueDto unauthorizedIssue = newIssue().setSeverity(MAJOR);
  101. assertThat(action.supports(authorizedIssue.toDefaultIssue().setResolution(null))).isTrue();
  102. assertThat(action.supports(unauthorizedIssue.toDefaultIssue().setResolution(null))).isFalse();
  103. }
  104. private void setUserWithBrowseAndAdministerIssuePermission(IssueDto issue) {
  105. BranchDto branchDto = db.getDbClient().branchDao().selectByUuid(db.getSession(), issue.getProjectUuid())
  106. .orElseThrow(() -> new IllegalStateException("Couldn't find branch :" + issue.getProjectUuid()));
  107. ProjectDto project = db.getDbClient().projectDao().selectByUuid(db.getSession(), branchDto.getProjectUuid()).get();
  108. userSession.logIn(USER_LOGIN)
  109. .addProjectPermission(ISSUE_ADMIN, project)
  110. .addProjectPermission(USER, project)
  111. .registerBranches(branchDto);
  112. }
  113. private IssueDto newIssue() {
  114. RuleDto rule = db.rules().insert(newRule());
  115. ComponentDto project = db.components().insertPrivateProject().getMainBranchComponent();
  116. ComponentDto file = db.components().insertComponent(newFileDto(project));
  117. return IssueTesting.newIssue(rule, project, file);
  118. }
  119. }