diff options
author | Evgeny Mandrikov <mandrikov@gmail.com> | 2012-03-26 12:18:44 +0600 |
---|---|---|
committer | Evgeny Mandrikov <mandrikov@gmail.com> | 2012-03-26 12:54:14 +0600 |
commit | 0d41c77bf1d0d84b0ad908b9b0e675de5562d072 (patch) | |
tree | fe93638e84f153730c7224b74ff4eae81503e5d9 | |
parent | 594da410d3152a76ca4dc92aecb4d05e599284c9 (diff) | |
download | sonarqube-0d41c77bf1d0d84b0ad908b9b0e675de5562d072.tar.gz sonarqube-0d41c77bf1d0d84b0ad908b9b0e675de5562d072.zip |
SONAR-3347 Limit time of analysis of single file for bridge between PMD and Sonar CPD
-rw-r--r-- | plugins/sonar-cpd-plugin/src/main/java/org/sonar/plugins/cpd/SonarBridgeEngine.java | 47 | ||||
-rw-r--r-- | plugins/sonar-cpd-plugin/src/main/java/org/sonar/plugins/cpd/SonarEngine.java | 2 |
2 files changed, 38 insertions, 11 deletions
diff --git a/plugins/sonar-cpd-plugin/src/main/java/org/sonar/plugins/cpd/SonarBridgeEngine.java b/plugins/sonar-cpd-plugin/src/main/java/org/sonar/plugins/cpd/SonarBridgeEngine.java index 7aee8b8ed4a..026893d031c 100644 --- a/plugins/sonar-cpd-plugin/src/main/java/org/sonar/plugins/cpd/SonarBridgeEngine.java +++ b/plugins/sonar-cpd-plugin/src/main/java/org/sonar/plugins/cpd/SonarBridgeEngine.java @@ -22,12 +22,14 @@ package org.sonar.plugins.cpd; import com.google.common.annotations.VisibleForTesting; import com.google.common.base.Predicate; import com.google.common.collect.Iterables; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; import org.sonar.api.batch.CpdMapping; import org.sonar.api.batch.SensorContext; import org.sonar.api.resources.*; +import org.sonar.api.utils.SonarException; import org.sonar.duplications.DuplicationPredicates; import org.sonar.duplications.block.Block; -import org.sonar.duplications.detector.suffixtree.SuffixTreeCloneDetectionAlgorithm; import org.sonar.duplications.index.CloneGroup; import org.sonar.duplications.internal.pmd.TokenizerBridge; import org.sonar.plugins.cpd.index.IndexFactory; @@ -35,9 +37,17 @@ import org.sonar.plugins.cpd.index.SonarDuplicationsIndex; import java.util.Collection; import java.util.List; +import java.util.concurrent.*; public class SonarBridgeEngine extends CpdEngine { + private static final Logger LOG = LoggerFactory.getLogger(SonarBridgeEngine.class); + + /** + * Limit of time to analyse one file (in seconds). + */ + private static final int TIMEOUT = 5 * 60; + private final IndexFactory indexFactory; private final CpdMapping[] mappings; @@ -71,6 +81,7 @@ public class SonarBridgeEngine extends CpdEngine { TokenizerBridge bridge = new TokenizerBridge(mapping.getTokenizer(), fileSystem.getSourceCharset().name(), getBlockSize(project)); for (InputFile inputFile : inputFiles) { + LOG.debug("Populating index from {}", inputFile.getFile()); Resource resource = mapping.createResource(inputFile.getFile(), fileSystem.getSourceDirs()); String resourceId = SonarEngine.getFullKey(project, resource); List<Block> blocks = bridge.chunk(resourceId, inputFile.getFile()); @@ -80,16 +91,32 @@ public class SonarBridgeEngine extends CpdEngine { // Detect Predicate<CloneGroup> minimumTokensPredicate = DuplicationPredicates.numberOfUnitsNotLessThan(PmdEngine.getMinimumTokens(project)); - for (InputFile inputFile : inputFiles) { - Resource resource = mapping.createResource(inputFile.getFile(), fileSystem.getSourceDirs()); - String resourceKey = SonarEngine.getFullKey(project, resource); - - Collection<Block> fileBlocks = index.getByResource(resource, resourceKey); - List<CloneGroup> duplications = SuffixTreeCloneDetectionAlgorithm.detect(index, fileBlocks); - - Iterable<CloneGroup> filtered = Iterables.filter(duplications, minimumTokensPredicate); + ExecutorService executorService = Executors.newSingleThreadExecutor(); + try { + for (InputFile inputFile : inputFiles) { + LOG.debug("Detection of duplications for {}", inputFile.getFile()); + Resource resource = mapping.createResource(inputFile.getFile(), fileSystem.getSourceDirs()); + String resourceKey = SonarEngine.getFullKey(project, resource); + + Collection<Block> fileBlocks = index.getByResource(resource, resourceKey); + + Iterable<CloneGroup> filtered; + try { + List<CloneGroup> duplications = executorService.submit(new SonarEngine.Task(index, fileBlocks)).get(TIMEOUT, TimeUnit.SECONDS); + filtered = Iterables.filter(duplications, minimumTokensPredicate); + } catch (TimeoutException e) { + filtered = null; + LOG.warn("Timeout during detection of duplications for " + inputFile.getFile(), e); + } catch (InterruptedException e) { + throw new SonarException(e); + } catch (ExecutionException e) { + throw new SonarException(e); + } - SonarEngine.save(context, resource, filtered); + SonarEngine.save(context, resource, filtered); + } + } finally { + executorService.shutdown(); } } diff --git a/plugins/sonar-cpd-plugin/src/main/java/org/sonar/plugins/cpd/SonarEngine.java b/plugins/sonar-cpd-plugin/src/main/java/org/sonar/plugins/cpd/SonarEngine.java index 460fdd10fa0..88c2c90656a 100644 --- a/plugins/sonar-cpd-plugin/src/main/java/org/sonar/plugins/cpd/SonarEngine.java +++ b/plugins/sonar-cpd-plugin/src/main/java/org/sonar/plugins/cpd/SonarEngine.java @@ -156,7 +156,7 @@ public class SonarEngine extends CpdEngine { } } - private static class Task implements Callable<List<CloneGroup>> { + static class Task implements Callable<List<CloneGroup>> { private final CloneIndex index; private final Collection<Block> fileBlocks; |