diff options
author | Duarte Meneses <duarte.meneses@sonarsource.com> | 2016-07-07 15:28:47 +0200 |
---|---|---|
committer | Duarte Meneses <duarte.meneses@sonarsource.com> | 2016-07-08 11:13:27 +0200 |
commit | ce748e217f599da5efb043bb847738b4f6aa9f23 (patch) | |
tree | 107b4c5287977574cc1c2af58974f046e00c1fbf /plugins/sonar-xoo-plugin/src | |
parent | 169b22e13d1bd50cf582eeb00d3231d3b8392d28 (diff) | |
download | sonarqube-ce748e217f599da5efb043bb847738b4f6aa9f23.tar.gz sonarqube-ce748e217f599da5efb043bb847738b4f6aa9f23.zip |
SONAR-7783 Ensure Sensors don't save same data twice
Diffstat (limited to 'plugins/sonar-xoo-plugin/src')
3 files changed, 65 insertions, 2 deletions
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/XooPlugin.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/XooPlugin.java index 38127ef52a3..870992596e7 100644 --- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/XooPlugin.java +++ b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/XooPlugin.java @@ -47,6 +47,7 @@ import org.sonar.xoo.rule.OneIssuePerLineSensor; import org.sonar.xoo.rule.OneIssuePerModuleSensor; import org.sonar.xoo.rule.OneVulnerabilityIssuePerModuleSensor; import org.sonar.xoo.rule.RandomAccessSensor; +import org.sonar.xoo.rule.SaveDataTwiceSensor; import org.sonar.xoo.rule.Xoo2BasicProfile; import org.sonar.xoo.rule.XooBasicProfile; import org.sonar.xoo.rule.XooEmptyProfile; @@ -97,6 +98,7 @@ public class XooPlugin implements Plugin { ChecksSensor.class, RandomAccessSensor.class, DeprecatedResourceApiSensor.class, + SaveDataTwiceSensor.class, OneBlockerIssuePerFileSensor.class, OneIssuePerLineSensor.class, diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/SaveDataTwiceSensor.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/SaveDataTwiceSensor.java new file mode 100644 index 00000000000..4233bb72463 --- /dev/null +++ b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/SaveDataTwiceSensor.java @@ -0,0 +1,61 @@ +/* + * SonarQube + * Copyright (C) 2009-2016 SonarSource SA + * mailto:contact AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.xoo.rule; + +import java.util.Iterator; + +import org.sonar.api.batch.fs.InputFile; +import org.sonar.api.batch.sensor.Sensor; +import org.sonar.api.batch.sensor.SensorContext; +import org.sonar.api.batch.sensor.SensorDescriptor; +import org.sonar.api.batch.sensor.highlighting.TypeOfText; + +/** + * This sensor will create and save highlighting twice on the first file that it finds in the index. + * It requires the property sonar.it.savedatatwice + */ +public class SaveDataTwiceSensor implements Sensor { + + @Override + public void describe(SensorDescriptor descriptor) { + descriptor.name("SaveDataTwice IT Sensor ") + .requireProperty("sonar.it.savedatatwice"); + } + + @Override + public void execute(SensorContext context) { + Iterator<InputFile> inputFiles = context.fileSystem().inputFiles(context.fileSystem().predicates().all()).iterator(); + + if (!inputFiles.hasNext()) { + throw new IllegalStateException("No files indexed"); + } + + InputFile file = inputFiles.next(); + context.newHighlighting() + .onFile(file) + .highlight(file.selectLine(1), TypeOfText.CONSTANT) + .save(); + + context.newHighlighting() + .onFile(file) + .highlight(file.selectLine(file.lines()), TypeOfText.COMMENT) + .save(); + } +} diff --git a/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/XooPluginTest.java b/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/XooPluginTest.java index 6257dea6f92..b9255f056d8 100644 --- a/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/XooPluginTest.java +++ b/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/XooPluginTest.java @@ -35,10 +35,10 @@ public class XooPluginTest { public void provide_extensions_for_5_5() { Plugin.Context context = new Plugin.Context(new SonarRuntime(Version.parse("5.5"), SonarProduct.SONARQUBE, SonarQubeSide.SCANNER)); new XooPlugin().define(context); - assertThat(context.getExtensions()).hasSize(40).contains(CpdTokenizerSensor.class); + assertThat(context.getExtensions()).hasSize(41).contains(CpdTokenizerSensor.class); context = new Plugin.Context(new SonarRuntime(Version.parse("5.4"), SonarProduct.SONARLINT, null)); new XooPlugin().define(context); - assertThat(context.getExtensions()).hasSize(39).doesNotContain(CpdTokenizerSensor.class); + assertThat(context.getExtensions()).hasSize(40).doesNotContain(CpdTokenizerSensor.class); } } |