diff options
author | Duarte Meneses <duarte.meneses@sonarsource.com> | 2018-08-21 17:45:17 +0200 |
---|---|---|
committer | sonartech <sonartech@sonarsource.com> | 2018-09-19 10:51:40 +0200 |
commit | 47571cbb5b56357f4f7be610f2a04b6688e7d8ba (patch) | |
tree | e833d32361d9db4eb5e180492021681381eb840a | |
parent | 790d026a6731ca53cf9580f9cb1ce48b44d40d2b (diff) | |
download | sonarqube-47571cbb5b56357f4f7be610f2a04b6688e7d8ba.tar.gz sonarqube-47571cbb5b56357f4f7be610f2a04b6688e7d8ba.zip |
SONAR-11139 Store changed lines information received in scanner report
2 files changed, 10 insertions, 7 deletions
diff --git a/sonar-scanner-engine/src/main/java/org/sonar/scanner/report/ChangedLinesPublisher.java b/sonar-scanner-engine/src/main/java/org/sonar/scanner/report/ChangedLinesPublisher.java index d15fa2d0961..1413a7a6bfa 100644 --- a/sonar-scanner-engine/src/main/java/org/sonar/scanner/report/ChangedLinesPublisher.java +++ b/sonar-scanner-engine/src/main/java/org/sonar/scanner/report/ChangedLinesPublisher.java @@ -20,6 +20,7 @@ package org.sonar.scanner.report; import java.nio.file.Path; +import java.util.Collections; import java.util.Map; import java.util.Set; import java.util.stream.Collectors; @@ -78,17 +79,19 @@ public class ChangedLinesPublisher implements ReportPublisherStep { int count = 0; if (pathSetMap == null) { + // no information returned by the SCM, we write nothing in the report and + // the compute engine will use SCM dates to estimate which lines are new return count; } for (Map.Entry<Path, DefaultInputFile> e : allPublishedFiles.entrySet()) { - Set<Integer> changedLines = pathSetMap.get(e.getKey()); - // if the file got no information returned by the SCM, we write nothing in the report and - // the compute engine will use SCM dates to estimate which lines are new - if (changedLines != null && !changedLines.isEmpty()) { - count++; - writeChangedLines(writer, e.getValue().batchId(), changedLines); + Set<Integer> changedLines = pathSetMap.getOrDefault(e.getKey(), Collections.emptySet()); + + if (changedLines.isEmpty()) { + LOG.warn("File '{}' was detected as changed but without having changed lines", e.getKey().toAbsolutePath()); } + count++; + writeChangedLines(writer, e.getValue().batchId(), changedLines); } return count; } diff --git a/sonar-scanner-engine/src/test/java/org/sonar/scanner/report/ChangedLinesPublisherTest.java b/sonar-scanner-engine/src/test/java/org/sonar/scanner/report/ChangedLinesPublisherTest.java index 78413d95a07..4f73d5894cf 100644 --- a/sonar-scanner-engine/src/test/java/org/sonar/scanner/report/ChangedLinesPublisherTest.java +++ b/sonar-scanner-engine/src/test/java/org/sonar/scanner/report/ChangedLinesPublisherTest.java @@ -124,7 +124,7 @@ public class ChangedLinesPublisherTest { publisher.publish(writer); assertPublished(fileWithChangedLines, lines); - assertNotPublished(fileWithoutChangedLines); + assertPublished(fileWithoutChangedLines, Collections.emptySet()); } private DefaultInputFile createInputFile(String path) { |