aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEvgeny Mandrikov <mandrikov@gmail.com>2012-03-16 17:09:22 +0400
committerEvgeny Mandrikov <mandrikov@gmail.com>2012-03-16 17:10:33 +0400
commit1f14e3bcda82079f1ebd577aaca7869f732e4467 (patch)
tree0fb7cdefa3d2dc29555a84e9c6d90a2cf708da1b
parent0a6fa1963cb0463cc4edb3da74fcebd1916d4f32 (diff)
downloadsonarqube-1f14e3bcda82079f1ebd577aaca7869f732e4467.tar.gz
sonarqube-1f14e3bcda82079f1ebd577aaca7869f732e4467.zip
SONAR-3072 Restore behaviour of tracking of violations when importSources=false
-rw-r--r--plugins/sonar-core-plugin/src/main/java/org/sonar/plugins/core/timemachine/ViolationTrackingDecorator.java32
1 files changed, 19 insertions, 13 deletions
diff --git a/plugins/sonar-core-plugin/src/main/java/org/sonar/plugins/core/timemachine/ViolationTrackingDecorator.java b/plugins/sonar-core-plugin/src/main/java/org/sonar/plugins/core/timemachine/ViolationTrackingDecorator.java
index 705069235c9..ad06764637d 100644
--- a/plugins/sonar-core-plugin/src/main/java/org/sonar/plugins/core/timemachine/ViolationTrackingDecorator.java
+++ b/plugins/sonar-core-plugin/src/main/java/org/sonar/plugins/core/timemachine/ViolationTrackingDecorator.java
@@ -55,25 +55,31 @@ public class ViolationTrackingDecorator implements Decorator {
ViolationQuery violationQuery = ViolationQuery.create().forResource(resource).setSwitchMode(ViolationQuery.SwitchMode.BOTH);
if (!context.getViolations(violationQuery).isEmpty()) {
- // Load new violations
- List<Violation> newViolations = prepareNewViolations(context);
+ return;
+ }
+
+ String source = index.getSource(resource);
+ String referenceSource = referenceAnalysis.getSource(resource);
- // Load reference violations
- List<RuleFailureModel> referenceViolations = referenceAnalysis.getViolations(resource);
+ // Load new violations
+ List<Violation> newViolations = prepareNewViolations(context, source);
- // SONAR-3072 Construct blocks recognizer based on reference source
- String referenceSource = referenceAnalysis.getSource(resource);
- String source = index.getSource(context.getResource());
- ViolationTrackingBlocksRecognizer rec = new ViolationTrackingBlocksRecognizer(referenceSource, source);
+ // Load reference violations
+ List<RuleFailureModel> referenceViolations = referenceAnalysis.getViolations(resource);
- // Map new violations with old ones
- mapViolations(newViolations, referenceViolations, rec);
+ // SONAR-3072 Construct blocks recognizer based on reference source
+ ViolationTrackingBlocksRecognizer rec = null;
+ if (source != null && referenceSource != null) {
+ rec = new ViolationTrackingBlocksRecognizer(referenceSource, source);
}
+
+ // Map new violations with old ones
+ mapViolations(newViolations, referenceViolations, rec);
}
- private List<Violation> prepareNewViolations(DecoratorContext context) {
+ private List<Violation> prepareNewViolations(DecoratorContext context, String source) {
List<Violation> result = Lists.newArrayList();
- List<String> checksums = SourceChecksum.lineChecksumsOfFile(index.getSource(context.getResource()));
+ List<String> checksums = SourceChecksum.lineChecksumsOfFile(source);
for (Violation violation : context.getViolations()) {
violation.setChecksum(SourceChecksum.getChecksumForLine(checksums, violation.getLineId()));
result.add(violation);
@@ -236,7 +242,7 @@ public class ViolationTrackingDecorator implements Decorator {
}
private void mapViolation(Violation newViolation, RuleFailureModel pastViolation,
- Multimap<Integer, RuleFailureModel> pastViolationsByRule, Map<Violation, RuleFailureModel> violationMap) {
+ Multimap<Integer, RuleFailureModel> pastViolationsByRule, Map<Violation, RuleFailureModel> violationMap) {
if (pastViolation != null) {
newViolation.setCreatedAt(pastViolation.getCreatedAt());
newViolation.setPermanentId(pastViolation.getPermanentId());