From 50eddd3eb0ef9c677183698a9aa565d2ae9289ab Mon Sep 17 00:00:00 2001 From: Léo Geoffroy Date: Tue, 7 Nov 2023 16:31:27 +0100 Subject: SONAR-20877 Support null values for status --- .../src/main/java/org/sonar/core/issue/DefaultIssue.java | 1 - .../main/java/org/sonar/core/issue/status/IssueStatus.java | 11 ++++++++++- .../src/test/java/org/sonar/core/issue/DefaultIssueTest.java | 9 --------- .../java/org/sonar/core/issue/status/IssueStatusTest.java | 10 ++++++++-- 4 files changed, 18 insertions(+), 13 deletions(-) (limited to 'sonar-core/src') 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 f919ade4c22..3f00898de4b 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 @@ -346,7 +346,6 @@ public class DefaultIssue implements Issue, Trackable, org.sonar.api.ce.measure. @Nullable public IssueStatus getIssueStatus() { - Preconditions.checkArgument(!Strings.isNullOrEmpty(status), "Status must be set"); return IssueStatus.of(status, resolution); } diff --git a/sonar-core/src/main/java/org/sonar/core/issue/status/IssueStatus.java b/sonar-core/src/main/java/org/sonar/core/issue/status/IssueStatus.java index fc615cd266b..8967460de51 100644 --- a/sonar-core/src/main/java/org/sonar/core/issue/status/IssueStatus.java +++ b/sonar-core/src/main/java/org/sonar/core/issue/status/IssueStatus.java @@ -42,7 +42,14 @@ public enum IssueStatus { private static final Logger LOGGER = LoggerFactory.getLogger(IssueStatus.class); @CheckForNull - public static IssueStatus of(String status, @Nullable String resolution) { + public static IssueStatus of(@Nullable String status, @Nullable String resolution) { + + //null status is not supposed to happen, but since it is nullable in database, we want the mapping to be resilient. + if (status == null) { + LOGGER.warn("Missing status, falling back to {}", IssueStatus.OPEN); + return IssueStatus.OPEN; + } + switch (status) { case Issue.STATUS_OPEN: case Issue.STATUS_REOPENED: @@ -68,6 +75,8 @@ public enum IssueStatus { default: } } + + LOGGER.warn("Can't find mapped issue status for status '{}' and resolution '{}'", status, resolution); return null; } 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 baae9a88dd6..76e016639b9 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 @@ -312,15 +312,6 @@ public class DefaultIssueTest { assertThat(issue.getIssueStatus()).isEqualTo(IssueStatus.FIXED); } - @Test - public void getIssueStatus_shouldThrowException_whenStatusNotSet() { - issue.setResolution(Issue.RESOLUTION_FIXED); - - assertThatThrownBy(issue::getIssueStatus) - .hasMessage("Status must be set") - .isInstanceOf(IllegalArgumentException.class); - } - @Test public void replaceImpacts_shouldReplaceExistingImpacts() { issue.addImpact(SoftwareQuality.MAINTAINABILITY, Severity.HIGH); diff --git a/sonar-core/src/test/java/org/sonar/core/issue/status/IssueStatusTest.java b/sonar-core/src/test/java/org/sonar/core/issue/status/IssueStatusTest.java index c3c8eef6513..606babaae9a 100644 --- a/sonar-core/src/test/java/org/sonar/core/issue/status/IssueStatusTest.java +++ b/sonar-core/src/test/java/org/sonar/core/issue/status/IssueStatusTest.java @@ -54,7 +54,7 @@ public class IssueStatusTest { } @Test - public void of_shouldReturnNull_WhenStatusBelongsToHotspot() { + public void of_shouldReturnNull_whenStatusBelongsToHotspot() { assertThat(IssueStatus.of(Issue.STATUS_TO_REVIEW, null)) .isNull(); @@ -66,7 +66,7 @@ public class IssueStatusTest { } @Test - public void of_shouldThrowExceptionWhenUnknownMapping() { + public void of_shouldLogWarning_whenUnknownMapping() { assertThat(IssueStatus.of(Issue.STATUS_RESOLVED, null)).isNull(); assertThat(logTester.getLogs()).extracting(LogAndArguments::getFormattedMsg).contains("Can't find mapped issue status for status 'RESOLVED' and resolution 'null'"); @@ -74,4 +74,10 @@ public class IssueStatusTest { assertThat(logTester.getLogs()).extracting(LogAndArguments::getFormattedMsg).contains("Can't find mapped issue status for status 'RESOLVED' and resolution 'SAFE'"); } + @Test + public void of_shouldLogWarning_whenStatusIsNull() { + assertThat(IssueStatus.of(null, null)).isEqualTo(IssueStatus.OPEN); + assertThat(logTester.getLogs()).extracting(LogAndArguments::getFormattedMsg).contains("Missing status, falling back to OPEN"); + } + } -- cgit v1.2.3