aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-core
diff options
context:
space:
mode:
Diffstat (limited to 'sonar-core')
-rw-r--r--sonar-core/src/main/java/org/sonar/core/issue/DefaultIssue.java13
-rw-r--r--sonar-core/src/test/java/org/sonar/core/issue/DefaultIssueTest.java66
2 files changed, 49 insertions, 30 deletions
diff --git a/sonar-core/src/main/java/org/sonar/core/issue/DefaultIssue.java b/sonar-core/src/main/java/org/sonar/core/issue/DefaultIssue.java
index 7afc0784a49..83427a1a193 100644
--- a/sonar-core/src/main/java/org/sonar/core/issue/DefaultIssue.java
+++ b/sonar-core/src/main/java/org/sonar/core/issue/DefaultIssue.java
@@ -81,6 +81,7 @@ public class DefaultIssue implements Issue, Trackable, org.sonar.api.ce.measure.
private List<DefaultIssueComment> comments = null;
private Set<String> tags = null;
private Set<String> codeVariants = null;
+ private boolean prioritizedRule = false;
// temporarily an Object as long as DefaultIssue is used by sonar-batch
private Object locations = null;
@@ -536,7 +537,8 @@ public class DefaultIssue implements Issue, Trackable, org.sonar.api.ce.measure.
return this;
}
- public DefaultIssue setFieldChange(IssueChangeContext context, String field, @Nullable Serializable oldValue, @Nullable Serializable newValue) {
+ public DefaultIssue setFieldChange(IssueChangeContext context, String field, @Nullable Serializable oldValue,
+ @Nullable Serializable newValue) {
if (!Objects.equals(oldValue, newValue)) {
if (currentChange == null) {
currentChange = new FieldDiffs();
@@ -726,6 +728,15 @@ public class DefaultIssue implements Issue, Trackable, org.sonar.api.ce.measure.
return this;
}
+ public boolean isPrioritizedRule() {
+ return prioritizedRule;
+ }
+
+ public DefaultIssue setPrioritizedRule(boolean isBlockerRule) {
+ this.prioritizedRule = isBlockerRule;
+ return this;
+ }
+
@Nullable
public CleanCodeAttribute getCleanCodeAttribute() {
return cleanCodeAttribute;
diff --git a/sonar-core/src/test/java/org/sonar/core/issue/DefaultIssueTest.java b/sonar-core/src/test/java/org/sonar/core/issue/DefaultIssueTest.java
index a550be9ca87..a50efdc2ef4 100644
--- a/sonar-core/src/test/java/org/sonar/core/issue/DefaultIssueTest.java
+++ b/sonar-core/src/test/java/org/sonar/core/issue/DefaultIssueTest.java
@@ -22,7 +22,7 @@ package org.sonar.core.issue;
import java.util.List;
import java.util.Map;
import org.apache.commons.lang3.StringUtils;
-import org.junit.Test;
+import org.junit.jupiter.api.Test;
import org.sonar.api.issue.Issue;
import org.sonar.api.issue.IssueStatus;
import org.sonar.api.issue.impact.Severity;
@@ -35,12 +35,12 @@ import static org.junit.Assert.fail;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
-public class DefaultIssueTest {
+class DefaultIssueTest {
private final DefaultIssue issue = new DefaultIssue();
@Test
- public void set_empty_dates() {
+ void set_empty_dates() {
issue
.setCreationDate(null)
.setUpdateDate(null)
@@ -54,7 +54,7 @@ public class DefaultIssueTest {
}
@Test
- public void fail_on_empty_status() {
+ void fail_on_empty_status() {
try {
issue.setStatus("");
fail();
@@ -64,7 +64,7 @@ public class DefaultIssueTest {
}
@Test
- public void fail_on_bad_severity() {
+ void fail_on_bad_severity() {
try {
issue.setSeverity("FOO");
fail();
@@ -74,19 +74,19 @@ public class DefaultIssueTest {
}
@Test
- public void message_should_be_abbreviated_if_too_long() {
+ void message_should_be_abbreviated_if_too_long() {
issue.setMessage(StringUtils.repeat("a", 5_000));
assertThat(issue.message()).hasSize(1_333);
}
@Test
- public void message_could_be_null() {
+ void message_could_be_null() {
issue.setMessage(null);
assertThat(issue.message()).isNull();
}
@Test
- public void test_nullable_fields() {
+ void test_nullable_fields() {
issue.setGap(null).setSeverity(null).setLine(null);
assertThat(issue.gap()).isNull();
assertThat(issue.severity()).isNull();
@@ -94,7 +94,7 @@ public class DefaultIssueTest {
}
@Test
- public void test_equals_and_hashCode() {
+ void test_equals_and_hashCode() {
DefaultIssue a1 = new DefaultIssue().setKey("AAA");
DefaultIssue a2 = new DefaultIssue().setKey("AAA");
DefaultIssue b = new DefaultIssue().setKey("BBB");
@@ -106,7 +106,7 @@ public class DefaultIssueTest {
}
@Test
- public void comments_should_not_be_modifiable() {
+ void comments_should_not_be_modifiable() {
DefaultIssue issue = new DefaultIssue().setKey("AAA");
List<DefaultIssueComment> comments = issue.defaultIssueComments();
@@ -123,7 +123,7 @@ public class DefaultIssueTest {
}
@Test
- public void all_changes_contain_current_change() {
+ void all_changes_contain_current_change() {
IssueChangeContext issueChangeContext = mock(IssueChangeContext.class);
when(issueChangeContext.getExternalUser()).thenReturn("toto");
when(issueChangeContext.getWebhookSource()).thenReturn("github");
@@ -139,7 +139,7 @@ public class DefaultIssueTest {
}
@Test
- public void setFieldChange_whenAddingChange_shouldUpdateCurrentChange() {
+ void setFieldChange_whenAddingChange_shouldUpdateCurrentChange() {
IssueChangeContext issueChangeContext = mock(IssueChangeContext.class);
DefaultIssue issue = new DefaultIssue().setKey("AAA");
@@ -158,7 +158,7 @@ public class DefaultIssueTest {
}
@Test
- public void adding_null_change_has_no_effect() {
+ void adding_null_change_has_no_effect() {
DefaultIssue issue = new DefaultIssue();
issue.addChange(null);
@@ -167,7 +167,7 @@ public class DefaultIssueTest {
}
@Test
- public void test_isToBeMigratedAsNewCodeReferenceIssue_is_correctly_calculated() {
+ void test_isToBeMigratedAsNewCodeReferenceIssue_is_correctly_calculated() {
issue.setKey("ABCD")
.setIsOnChangedLine(true)
.setIsNewCodeReferenceIssue(false)
@@ -219,7 +219,7 @@ public class DefaultIssueTest {
}
@Test
- public void isQuickFixAvailable_givenQuickFixAvailable_returnTrue() {
+ void isQuickFixAvailable_givenQuickFixAvailable_returnTrue() {
DefaultIssue defaultIssue = new DefaultIssue();
defaultIssue.setQuickFixAvailable(true);
@@ -232,7 +232,7 @@ public class DefaultIssueTest {
}
@Test
- public void setLine_whenLineIsNegative_shouldThrowException() {
+ void setLine_whenLineIsNegative_shouldThrowException() {
int anyNegativeValue = Integer.MIN_VALUE;
assertThatThrownBy(() -> issue.setLine(anyNegativeValue))
.isInstanceOf(IllegalArgumentException.class)
@@ -240,14 +240,14 @@ public class DefaultIssueTest {
}
@Test
- public void setLine_whenLineIsZero_shouldThrowException() {
+ void setLine_whenLineIsZero_shouldThrowException() {
assertThatThrownBy(() -> issue.setLine(0))
.isInstanceOf(IllegalArgumentException.class)
.hasMessage("Line must be null or greater than zero (got 0)");
}
@Test
- public void setGap_whenGapIsNegative_shouldThrowException() {
+ void setGap_whenGapIsNegative_shouldThrowException() {
Double anyNegativeValue = -1.0;
assertThatThrownBy(() -> issue.setGap(anyNegativeValue))
.isInstanceOf(IllegalArgumentException.class)
@@ -255,41 +255,41 @@ public class DefaultIssueTest {
}
@Test
- public void setGap_whenGapIsZero_shouldWork() {
+ void setGap_whenGapIsZero_shouldWork() {
issue.setGap(0.0);
assertThat(issue.gap()).isEqualTo(0.0);
}
@Test
- public void effortInMinutes_shouldConvertEffortToMinutes() {
+ void effortInMinutes_shouldConvertEffortToMinutes() {
issue.setEffort(Duration.create(60));
assertThat(issue.effortInMinutes()).isEqualTo(60L);
}
@Test
- public void effortInMinutes_whenNull_shouldReturnNull() {
+ void effortInMinutes_whenNull_shouldReturnNull() {
issue.setEffort(null);
assertThat(issue.effortInMinutes()).isNull();
}
@Test
- public void tags_whenNull_shouldReturnEmptySet() {
+ void tags_whenNull_shouldReturnEmptySet() {
assertThat(issue.tags()).isEmpty();
}
@Test
- public void codeVariants_whenNull_shouldReturnEmptySet() {
+ void codeVariants_whenNull_shouldReturnEmptySet() {
assertThat(issue.codeVariants()).isEmpty();
}
@Test
- public void issueByDefault_shouldNotHaveAppliedAnticipatedTransitions() {
+ void issueByDefault_shouldNotHaveAppliedAnticipatedTransitions() {
DefaultIssue defaultIssue = new DefaultIssue();
assertThat(defaultIssue.getAnticipatedTransitionUuid()).isNotPresent();
}
@Test
- public void anticipatedTransitions_WhenSetTrue_shouldReturnTrue() {
+ void anticipatedTransitions_WhenSetTrue_shouldReturnTrue() {
DefaultIssue defaultIssue = new DefaultIssue();
defaultIssue.setAnticipatedTransitionUuid("uuid");
assertThat(defaultIssue.getAnticipatedTransitionUuid()).isPresent();
@@ -297,15 +297,16 @@ public class DefaultIssueTest {
}
@Test
- public void getImpacts_whenAddingNewImpacts_shouldReturnListOfImpacts() {
+ void getImpacts_whenAddingNewImpacts_shouldReturnListOfImpacts() {
issue.addImpact(SoftwareQuality.MAINTAINABILITY, Severity.HIGH);
issue.addImpact(SoftwareQuality.RELIABILITY, Severity.LOW);
- assertThat(issue.impacts()).containsExactlyInAnyOrderEntriesOf(Map.of(SoftwareQuality.MAINTAINABILITY, Severity.HIGH, SoftwareQuality.RELIABILITY, Severity.LOW));
+ assertThat(issue.impacts()).containsExactlyInAnyOrderEntriesOf(Map.of(SoftwareQuality.MAINTAINABILITY, Severity.HIGH,
+ SoftwareQuality.RELIABILITY, Severity.LOW));
}
@Test
- public void getIssueStatus_shouldReturnExpectedStatus() {
+ void getIssueStatus_shouldReturnExpectedStatus() {
issue.setStatus(Issue.STATUS_RESOLVED);
issue.setResolution(Issue.RESOLUTION_FIXED);
@@ -313,7 +314,7 @@ public class DefaultIssueTest {
}
@Test
- public void replaceImpacts_shouldReplaceExistingImpacts() {
+ void replaceImpacts_shouldReplaceExistingImpacts() {
issue.addImpact(SoftwareQuality.MAINTAINABILITY, Severity.HIGH);
issue.addImpact(SoftwareQuality.RELIABILITY, Severity.LOW);
@@ -321,4 +322,11 @@ public class DefaultIssueTest {
assertThat(issue.impacts()).containsExactlyEntriesOf(Map.of(SoftwareQuality.SECURITY, Severity.LOW));
}
+
+ @Test
+ void prioritizedRule_shouldHaveCorrectDefaultValue() {
+ assertThat(issue.isPrioritizedRule()).isFalse();
+ issue.setPrioritizedRule(true);
+ assertThat(issue.isPrioritizedRule()).isTrue();
+ }
}