aboutsummaryrefslogtreecommitdiffstats
path: root/plugins/sonar-xoo-plugin
diff options
context:
space:
mode:
authorDuarte Meneses <duarte.meneses@sonarsource.com>2021-06-09 16:26:56 -0500
committersonartech <sonartech@sonarsource.com>2021-06-17 20:03:08 +0000
commit2754feca4e5fa8fdd804c827783250f48676296c (patch)
tree1ed9522bbc9eff9444fae6bf0a951d976da2b859 /plugins/sonar-xoo-plugin
parent97f2c01fdd4ae863134d4aa1bf32b7dcd512b10c (diff)
downloadsonarqube-2754feca4e5fa8fdd804c827783250f48676296c.tar.gz
sonarqube-2754feca4e5fa8fdd804c827783250f48676296c.zip
SONAR-14925 Remove code deprecated before 7.0 in the Plugin API
Diffstat (limited to 'plugins/sonar-xoo-plugin')
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/XooPlugin.java6
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/AbstractCoverageSensor.java6
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/ItCoverageSensor.java7
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/OverallCoverageSensor.java7
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/UtCoverageSensor.java7
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/extensions/XooPostJob.java5
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/lang/SymbolReferencesSensor.java45
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/lang/SyntaxHighlightingSensor.java8
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/Xoo2BasicProfile.java22
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/Xoo2SonarWayProfile.java21
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/XooBasicProfile.java21
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/XooEmptyProfile.java12
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/XooSonarWayProfile.java26
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/test/CoveragePerTestSensor.java121
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/test/TestExecutionSensor.java119
-rw-r--r--plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/test/package-info.java23
-rw-r--r--plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/extensions/XooPostJobTest.java8
-rw-r--r--plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/lang/SymbolReferencesSensorTest.java6
-rw-r--r--plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/lang/SyntaxHighlightingSensorTest.java2
-rw-r--r--plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/rule/OneIssuePerLineSensorTest.java11
20 files changed, 66 insertions, 417 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 ba4ffd9c554..e493d286402 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
@@ -78,8 +78,6 @@ import org.sonar.xoo.rule.XooSonarWayProfile;
import org.sonar.xoo.scm.XooBlameCommand;
import org.sonar.xoo.scm.XooIgnoreCommand;
import org.sonar.xoo.scm.XooScmProvider;
-import org.sonar.xoo.test.CoveragePerTestSensor;
-import org.sonar.xoo.test.TestExecutionSensor;
/**
* Plugin entry-point, as declared in pom.xml.
@@ -172,10 +170,6 @@ public class XooPlugin implements Plugin {
// Analysis errors
AnalysisErrorSensor.class,
- // Tests
- TestExecutionSensor.class,
- CoveragePerTestSensor.class,
-
// Other
XooProjectBuilder.class,
XooPostJob.class,
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/AbstractCoverageSensor.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/AbstractCoverageSensor.java
index d01c96b1bf7..3e49638de9b 100644
--- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/AbstractCoverageSensor.java
+++ b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/AbstractCoverageSensor.java
@@ -30,7 +30,6 @@ 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.coverage.CoverageType;
import org.sonar.api.batch.sensor.coverage.NewCoverage;
import org.sonar.api.utils.log.Logger;
import org.sonar.api.utils.log.Loggers;
@@ -46,8 +45,7 @@ public abstract class AbstractCoverageSensor implements Sensor {
try {
List<String> lines = FileUtils.readLines(coverageFile, context.fileSystem().encoding().name());
NewCoverage coverageBuilder = context.newCoverage()
- .onFile(inputFile)
- .ofType(getCoverageType());
+ .onFile(inputFile);
int lineNumber = 0;
for (String line : lines) {
lineNumber++;
@@ -80,8 +78,6 @@ public abstract class AbstractCoverageSensor implements Sensor {
protected abstract String getCoverageExtension();
- protected abstract CoverageType getCoverageType();
-
@Override
public void describe(SensorDescriptor descriptor) {
descriptor
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/ItCoverageSensor.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/ItCoverageSensor.java
index 45ba3770a73..046e7d13071 100644
--- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/ItCoverageSensor.java
+++ b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/ItCoverageSensor.java
@@ -19,8 +19,6 @@
*/
package org.sonar.xoo.coverage;
-import org.sonar.api.batch.sensor.coverage.CoverageType;
-
/**
* Parse files *.xoo.itcoverage
*/
@@ -32,11 +30,6 @@ public class ItCoverageSensor extends AbstractCoverageSensor {
}
@Override
- protected CoverageType getCoverageType() {
- return CoverageType.IT;
- }
-
- @Override
protected String getSensorName() {
return "Xoo IT Coverage Sensor";
}
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/OverallCoverageSensor.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/OverallCoverageSensor.java
index f654826a464..419b86fe606 100644
--- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/OverallCoverageSensor.java
+++ b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/OverallCoverageSensor.java
@@ -19,8 +19,6 @@
*/
package org.sonar.xoo.coverage;
-import org.sonar.api.batch.sensor.coverage.CoverageType;
-
/**
* Parse files *.xoo.overallcoverage
*/
@@ -32,11 +30,6 @@ public class OverallCoverageSensor extends AbstractCoverageSensor {
}
@Override
- protected CoverageType getCoverageType() {
- return CoverageType.OVERALL;
- }
-
- @Override
protected String getSensorName() {
return "Xoo Overall Coverage Sensor";
}
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/UtCoverageSensor.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/UtCoverageSensor.java
index cba44d76f76..3ff71222e2d 100644
--- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/UtCoverageSensor.java
+++ b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/coverage/UtCoverageSensor.java
@@ -19,8 +19,6 @@
*/
package org.sonar.xoo.coverage;
-import org.sonar.api.batch.sensor.coverage.CoverageType;
-
/**
* Parse files *.xoo.coverage
*/
@@ -32,11 +30,6 @@ public class UtCoverageSensor extends AbstractCoverageSensor {
}
@Override
- protected CoverageType getCoverageType() {
- return CoverageType.UNIT;
- }
-
- @Override
protected String getSensorName() {
return "Xoo UT Coverage Sensor";
}
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/extensions/XooPostJob.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/extensions/XooPostJob.java
index 717402dd1c7..6b4dc103fd1 100644
--- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/extensions/XooPostJob.java
+++ b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/extensions/XooPostJob.java
@@ -19,7 +19,6 @@
*/
package org.sonar.xoo.extensions;
-import com.google.common.collect.Iterables;
import org.sonar.api.batch.postjob.PostJob;
import org.sonar.api.batch.postjob.PostJobContext;
import org.sonar.api.batch.postjob.PostJobDescriptor;
@@ -34,13 +33,11 @@ public class XooPostJob implements PostJob {
public void describe(PostJobDescriptor descriptor) {
descriptor.name("Xoo Post Job")
.requireProperty("sonar.xoo.enablePostJob");
-
}
@Override
public void execute(PostJobContext context) {
- LOG.info("Resolved issues: " + Iterables.size(context.resolvedIssues()));
- LOG.info("Open issues: " + Iterables.size(context.issues()));
+ LOG.info("Running Xoo PostJob");
}
}
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/lang/SymbolReferencesSensor.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/lang/SymbolReferencesSensor.java
index 63778317a1b..9bd845064ce 100644
--- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/lang/SymbolReferencesSensor.java
+++ b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/lang/SymbolReferencesSensor.java
@@ -24,7 +24,6 @@ import java.io.File;
import java.io.IOException;
import java.util.Iterator;
import java.util.List;
-import javax.annotation.Nullable;
import org.apache.commons.io.FileUtils;
import org.apache.commons.lang.StringUtils;
import org.sonar.api.batch.fs.InputFile;
@@ -77,54 +76,38 @@ public class SymbolReferencesSensor implements Sensor {
Iterator<String> split = Splitter.on(",").split(line).iterator();
String[] symbolOffsets = split.next().split(":");
- if (symbolOffsets.length == 2) {
- int startOffset = parseInt(symbolOffsets[0]);
- int endOffset = parseInt(symbolOffsets[1]);
- NewSymbol s = symbolTable.newSymbol(startOffset, endOffset);
- parseReferences(s, split, endOffset - startOffset);
- } else if (symbolOffsets.length == 4) {
+ if (symbolOffsets.length == 4) {
int startLine = parseInt(symbolOffsets[0]);
int startLineOffset = parseInt(symbolOffsets[1]);
int endLine = parseInt(symbolOffsets[2]);
int endLineOffset = parseInt(symbolOffsets[3]);
NewSymbol s = symbolTable.newSymbol(startLine, startLineOffset, endLine, endLineOffset);
- parseReferences(s, split, null);
+ parseReferences(s, split);
} else {
throw new IllegalStateException("Illegal number of elements separated by ':'. " +
- "Must either be startOffset:endOffset (offset in whole file) or startLine:startLineOffset:endLine:endLineOffset");
+ "Must be startLine:startLineOffset:endLine:endLineOffset");
}
} catch (Exception e) {
throw new IllegalStateException("Error processing line " + lineNumber + " of file " + symbolFile.getAbsolutePath(), e);
}
}
- private static void parseReferences(NewSymbol s, Iterator<String> split, @Nullable Integer defaultLen) {
+ private static void parseReferences(NewSymbol s, Iterator<String> split) {
while (split.hasNext()) {
- addReference(s, split.next(), defaultLen);
+ addReference(s, split.next());
}
}
- private static void addReference(NewSymbol s, String str, @Nullable Integer defaultLen) {
- if (str.contains(":")) {
- String[] split = str.split(":");
- if (split.length == 2) {
- int startOffset = parseInt(split[0]);
- int endOffset = parseInt(split[1]);
- s.newReference(startOffset, endOffset);
- } else if (split.length == 4) {
- int startLine = parseInt(split[0]);
- int startLineOffset = parseInt(split[1]);
- int endLine = parseInt(split[2]);
- int endLineOffset = parseInt(split[3]);
- s.newReference(startLine, startLineOffset, endLine, endLineOffset);
- } else {
- throw new IllegalStateException("Illegal number of elements separated by ':'");
- }
- } else if (defaultLen == null) {
- throw new IllegalStateException("Mix of new and old format. Use startLine:startLineOffset:endLine:endLineOffset for references too");
+ private static void addReference(NewSymbol s, String str) {
+ String[] split = str.split(":");
+ if (split.length == 4) {
+ int startLine = parseInt(split[0]);
+ int startLineOffset = parseInt(split[1]);
+ int endLine = parseInt(split[2]);
+ int endLineOffset = parseInt(split[3]);
+ s.newReference(startLine, startLineOffset, endLine, endLineOffset);
} else {
- int startOffset = parseInt(str);
- s.newReference(startOffset, startOffset + defaultLen);
+ throw new IllegalStateException("Illegal number of elements separated by ':'");
}
}
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/lang/SyntaxHighlightingSensor.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/lang/SyntaxHighlightingSensor.java
index ec943a34432..628259e4e43 100644
--- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/lang/SyntaxHighlightingSensor.java
+++ b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/lang/SyntaxHighlightingSensor.java
@@ -71,11 +71,7 @@ public class SyntaxHighlightingSensor implements Sensor {
private static void processLine(File highlightingFile, int lineNumber, NewHighlighting highlighting, String line) {
try {
String[] split = line.split(":");
- if (split.length == 3) {
- int startOffset = parseInt(split[0]);
- int endOffset = parseInt(split[1]);
- highlighting.highlight(startOffset, endOffset, TypeOfText.forCssClass(split[2]));
- } else if (split.length == 5) {
+ if (split.length == 5) {
int startLine = parseInt(split[0]);
int startLineOffset = parseInt(split[1]);
int endLine = parseInt(split[2]);
@@ -83,7 +79,7 @@ public class SyntaxHighlightingSensor implements Sensor {
highlighting.highlight(startLine, startLineOffset, endLine, endLineOffset, TypeOfText.forCssClass(split[4]));
} else {
throw new IllegalStateException("Illegal number of elements separated by ':'. " +
- "Must either be startOffset:endOffset:class (offset in whole file) or startLine:startLineOffset:endLine:endLineOffset:class");
+ "Must be startLine:startLineOffset:endLine:endLineOffset:class");
}
} catch (Exception e) {
throw new IllegalStateException("Error processing line " + lineNumber + " of file " + highlightingFile.getAbsolutePath(), e);
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/Xoo2BasicProfile.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/Xoo2BasicProfile.java
index 2283c517f2a..6b2de61586d 100644
--- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/Xoo2BasicProfile.java
+++ b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/Xoo2BasicProfile.java
@@ -19,23 +19,15 @@
*/
package org.sonar.xoo.rule;
-import org.sonar.api.profiles.ProfileDefinition;
-import org.sonar.api.profiles.RulesProfile;
-import org.sonar.api.rules.Rule;
-import org.sonar.api.rules.RulePriority;
-import org.sonar.api.utils.ValidationMessages;
+import org.sonar.api.server.profile.BuiltInQualityProfilesDefinition;
import org.sonar.xoo.Xoo2;
-public class Xoo2BasicProfile extends ProfileDefinition {
-
+public class Xoo2BasicProfile implements BuiltInQualityProfilesDefinition {
@Override
- public RulesProfile createProfile(ValidationMessages messages) {
- RulesProfile profile = RulesProfile.create("Basic", Xoo2.KEY);
- profile.setDefaultProfile(true);
-
- // so UGLY
- profile.activateRule(Rule.create(XooRulesDefinition.XOO2_REPOSITORY, HasTagSensor.RULE_KEY), RulePriority.MAJOR);
-
- return profile;
+ public void define(Context context) {
+ NewBuiltInQualityProfile qProfile = context.createBuiltInQualityProfile("Basic", Xoo2.KEY);
+ qProfile.setDefault(true);
+ qProfile.activateRule(XooRulesDefinition.XOO2_REPOSITORY, HasTagSensor.RULE_KEY);
+ qProfile.done();
}
}
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/Xoo2SonarWayProfile.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/Xoo2SonarWayProfile.java
index e611408aa6c..cf938351c5f 100644
--- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/Xoo2SonarWayProfile.java
+++ b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/Xoo2SonarWayProfile.java
@@ -19,22 +19,15 @@
*/
package org.sonar.xoo.rule;
-import org.sonar.api.profiles.ProfileDefinition;
-import org.sonar.api.profiles.RulesProfile;
-import org.sonar.api.rules.Rule;
-import org.sonar.api.rules.RulePriority;
-import org.sonar.api.utils.ValidationMessages;
+import org.sonar.api.server.profile.BuiltInQualityProfilesDefinition;
import org.sonar.xoo.Xoo2;
-public class Xoo2SonarWayProfile extends ProfileDefinition {
-
+public class Xoo2SonarWayProfile implements BuiltInQualityProfilesDefinition {
@Override
- public RulesProfile createProfile(ValidationMessages messages) {
- RulesProfile profile = RulesProfile.create("Sonar way", Xoo2.KEY);
-
- profile.activateRule(Rule.create(XooRulesDefinition.XOO2_REPOSITORY, HasTagSensor.RULE_KEY), RulePriority.MAJOR);
- profile.activateRule(Rule.create(XooRulesDefinition.XOO2_REPOSITORY, OneIssuePerLineSensor.RULE_KEY), RulePriority.MINOR);
-
- return profile;
+ public void define(Context context) {
+ NewBuiltInQualityProfile qProfile = context.createBuiltInQualityProfile("Sonar way", Xoo2.KEY);
+ qProfile.activateRule(XooRulesDefinition.XOO2_REPOSITORY, HasTagSensor.RULE_KEY);
+ qProfile.activateRule(XooRulesDefinition.XOO2_REPOSITORY, OneIssuePerLineSensor.RULE_KEY);
+ qProfile.done();
}
}
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/XooBasicProfile.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/XooBasicProfile.java
index 3b4b5f25e32..c68efdfc0ee 100644
--- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/XooBasicProfile.java
+++ b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/XooBasicProfile.java
@@ -19,22 +19,15 @@
*/
package org.sonar.xoo.rule;
-import org.sonar.api.profiles.ProfileDefinition;
-import org.sonar.api.profiles.RulesProfile;
-import org.sonar.api.rules.Rule;
-import org.sonar.api.rules.RulePriority;
-import org.sonar.api.utils.ValidationMessages;
+import org.sonar.api.server.profile.BuiltInQualityProfilesDefinition;
import org.sonar.xoo.Xoo;
-public class XooBasicProfile extends ProfileDefinition {
-
+public class XooBasicProfile implements BuiltInQualityProfilesDefinition {
@Override
- public RulesProfile createProfile(ValidationMessages validation) {
- final RulesProfile profile = RulesProfile.create("Basic", Xoo.KEY);
- profile.setDefaultProfile(true);
-
- profile.activateRule(Rule.create(XooRulesDefinition.XOO_REPOSITORY, HasTagSensor.RULE_KEY), RulePriority.MAJOR);
-
- return profile;
+ public void define(Context context) {
+ NewBuiltInQualityProfile qProfile = context.createBuiltInQualityProfile("Basic", Xoo.KEY);
+ qProfile.setDefault(true);
+ qProfile.activateRule(XooRulesDefinition.XOO_REPOSITORY, HasTagSensor.RULE_KEY);
+ qProfile.done();
}
}
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/XooEmptyProfile.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/XooEmptyProfile.java
index 1f51a24e526..049735c0d8c 100644
--- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/XooEmptyProfile.java
+++ b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/XooEmptyProfile.java
@@ -19,15 +19,13 @@
*/
package org.sonar.xoo.rule;
-import org.sonar.api.profiles.ProfileDefinition;
-import org.sonar.api.profiles.RulesProfile;
-import org.sonar.api.utils.ValidationMessages;
+import org.sonar.api.server.profile.BuiltInQualityProfilesDefinition;
import org.sonar.xoo.Xoo;
-public class XooEmptyProfile extends ProfileDefinition {
-
+public class XooEmptyProfile implements BuiltInQualityProfilesDefinition {
@Override
- public RulesProfile createProfile(ValidationMessages validation) {
- return RulesProfile.create("empty", Xoo.KEY);
+ public void define(Context context) {
+ context.createBuiltInQualityProfile("empty", Xoo.KEY)
+ .done();
}
}
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/XooSonarWayProfile.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/XooSonarWayProfile.java
index 0c92f9b67aa..f35fd64ae99 100644
--- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/XooSonarWayProfile.java
+++ b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/rule/XooSonarWayProfile.java
@@ -19,24 +19,18 @@
*/
package org.sonar.xoo.rule;
-import org.sonar.api.profiles.ProfileDefinition;
-import org.sonar.api.profiles.RulesProfile;
-import org.sonar.api.rules.Rule;
-import org.sonar.api.rules.RulePriority;
-import org.sonar.api.utils.ValidationMessages;
+import org.sonar.api.rule.Severity;
+import org.sonar.api.server.profile.BuiltInQualityProfilesDefinition;
import org.sonar.xoo.Xoo;
-public class XooSonarWayProfile extends ProfileDefinition {
-
+public class XooSonarWayProfile implements BuiltInQualityProfilesDefinition {
@Override
- public RulesProfile createProfile(ValidationMessages validation) {
- final RulesProfile profile = RulesProfile.create("Sonar way", Xoo.KEY);
-
- profile.activateRule(Rule.create(XooRulesDefinition.XOO_REPOSITORY, HasTagSensor.RULE_KEY), RulePriority.MAJOR);
- profile.activateRule(Rule.create(XooRulesDefinition.XOO_REPOSITORY, OneIssuePerLineSensor.RULE_KEY), RulePriority.INFO);
- profile.activateRule(Rule.create(XooRulesDefinition.XOO_REPOSITORY, OneIssuePerFileSensor.RULE_KEY), RulePriority.CRITICAL);
- profile.activateRule(Rule.create(XooRulesDefinition.XOO_REPOSITORY, HotspotSensor.RULE_KEY), RulePriority.CRITICAL);
-
- return profile;
+ public void define(Context context) {
+ NewBuiltInQualityProfile qProfile = context.createBuiltInQualityProfile("Sonar way", Xoo.KEY);
+ qProfile.activateRule(XooRulesDefinition.XOO_REPOSITORY, HasTagSensor.RULE_KEY).overrideSeverity(Severity.MAJOR);
+ qProfile.activateRule(XooRulesDefinition.XOO_REPOSITORY, OneIssuePerLineSensor.RULE_KEY).overrideSeverity(Severity.INFO);
+ qProfile.activateRule(XooRulesDefinition.XOO_REPOSITORY, OneIssuePerFileSensor.RULE_KEY).overrideSeverity(Severity.CRITICAL);
+ qProfile.activateRule(XooRulesDefinition.XOO_REPOSITORY, HotspotSensor.RULE_KEY).overrideSeverity(Severity.CRITICAL);
+ qProfile.done();
}
}
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/test/CoveragePerTestSensor.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/test/CoveragePerTestSensor.java
deleted file mode 100644
index 0c0c199ed38..00000000000
--- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/test/CoveragePerTestSensor.java
+++ /dev/null
@@ -1,121 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2021 SonarSource SA
- * mailto:info 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.test;
-
-import com.google.common.base.Splitter;
-import java.io.File;
-import java.io.IOException;
-import java.util.ArrayList;
-import java.util.Iterator;
-import java.util.List;
-import org.apache.commons.io.FileUtils;
-import org.apache.commons.lang.StringUtils;
-import org.sonar.api.batch.DependsUpon;
-import org.sonar.api.batch.fs.FilePredicates;
-import org.sonar.api.batch.fs.FileSystem;
-import org.sonar.api.batch.fs.InputFile;
-import org.sonar.api.batch.fs.InputFile.Type;
-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.component.ResourcePerspectives;
-import org.sonar.api.test.MutableTestCase;
-import org.sonar.api.test.MutableTestPlan;
-import org.sonar.api.test.MutableTestable;
-import org.sonar.api.utils.log.Logger;
-import org.sonar.api.utils.log.Loggers;
-import org.sonar.xoo.Xoo;
-
-/**
- * Parse files *.xoo.testcoverage
- */
-@DependsUpon("test-exec")
-public class CoveragePerTestSensor implements Sensor {
- private static final Logger LOG = Loggers.get(CoveragePerTestSensor.class);
-
- private static final String TEST_EXTENSION = ".testcoverage";
-
- private final FileSystem fs;
- private final ResourcePerspectives perspectives;
-
- public CoveragePerTestSensor(FileSystem fileSystem, ResourcePerspectives perspectives) {
- this.fs = fileSystem;
- this.perspectives = perspectives;
- }
-
- private void processTestFile(InputFile inputFile, SensorContext context) {
- File testExecutionFile = new File(inputFile.file().getParentFile(), inputFile.file().getName() + TEST_EXTENSION);
- if (testExecutionFile.exists()) {
- LOG.debug("Processing " + testExecutionFile.getAbsolutePath());
- try {
- List<String> lines = FileUtils.readLines(testExecutionFile, fs.encoding().name());
- int lineNumber = 0;
- MutableTestPlan testPlan = perspectives.as(MutableTestPlan.class, inputFile);
- for (String line : lines) {
- lineNumber++;
- if (StringUtils.isBlank(line)) {
- continue;
- }
- if (line.startsWith("#")) {
- continue;
- }
- try {
- Iterator<String> split = Splitter.on(";").split(line).iterator();
- String name = split.next();
- while (split.hasNext()) {
- String coveredBlockStr = split.next();
- Iterator<String> splitCoveredBlock = Splitter.on(",").split(coveredBlockStr).iterator();
- String componentPath = splitCoveredBlock.next();
- InputFile coveredFile = context.fileSystem().inputFile(context.fileSystem().predicates().hasPath(componentPath));
- MutableTestable testable = perspectives.as(MutableTestable.class, coveredFile);
- List<Integer> coveredLines = new ArrayList<>();
- while (splitCoveredBlock.hasNext()) {
- coveredLines.add(Integer.parseInt(splitCoveredBlock.next()));
- }
- for (MutableTestCase testCase : testPlan.testCasesByName(name)) {
- testCase.setCoverageBlock(testable, coveredLines);
- }
- }
- } catch (Exception e) {
- throw new IllegalStateException("Error processing line " + lineNumber + " of file " + testExecutionFile.getAbsolutePath(), e);
- }
- }
- } catch (IOException e) {
- throw new RuntimeException(e);
- }
- }
- }
-
- @Override
- public void describe(SensorDescriptor descriptor) {
- descriptor
- .name("Xoo Coverage Per Test Sensor")
- .onlyOnLanguages(Xoo.KEY);
- }
-
- @Override
- public void execute(SensorContext context) {
- FilePredicates p = context.fileSystem().predicates();
- for (InputFile file : context.fileSystem().inputFiles(p.and(p.hasLanguages(Xoo.KEY), p.hasType(Type.TEST)))) {
- processTestFile(file, context);
- }
- }
-
-}
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/test/TestExecutionSensor.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/test/TestExecutionSensor.java
deleted file mode 100644
index b39b2cbb18f..00000000000
--- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/test/TestExecutionSensor.java
+++ /dev/null
@@ -1,119 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2021 SonarSource SA
- * mailto:info 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.test;
-
-import com.google.common.base.Splitter;
-import java.io.File;
-import java.io.IOException;
-import java.util.Iterator;
-import java.util.List;
-import org.apache.commons.io.FileUtils;
-import org.apache.commons.lang.StringUtils;
-import org.sonar.api.batch.DependedUpon;
-import org.sonar.api.batch.fs.FilePredicates;
-import org.sonar.api.batch.fs.FileSystem;
-import org.sonar.api.batch.fs.InputFile;
-import org.sonar.api.batch.fs.InputFile.Type;
-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.component.ResourcePerspectives;
-import org.sonar.api.test.MutableTestCase;
-import org.sonar.api.test.MutableTestPlan;
-import org.sonar.api.test.TestCase;
-import org.sonar.api.utils.log.Logger;
-import org.sonar.api.utils.log.Loggers;
-import org.sonar.xoo.Xoo;
-
-/**
- * Parse files *.xoo.test
- */
-@DependedUpon("test-exec")
-public class TestExecutionSensor implements Sensor {
- private static final Logger LOG = Loggers.get(TestExecutionSensor.class);
-
- private static final String TEST_EXTENSION = ".test";
-
- private final FileSystem fs;
- private final ResourcePerspectives perspectives;
-
- public TestExecutionSensor(FileSystem fileSystem, ResourcePerspectives perspectives) {
- this.fs = fileSystem;
- this.perspectives = perspectives;
- }
-
- private void processTestFile(InputFile inputFile, SensorContext context) {
- File testExecutionFile = new File(inputFile.file().getParentFile(), inputFile.file().getName() + TEST_EXTENSION);
- if (testExecutionFile.exists()) {
- LOG.debug("Processing " + testExecutionFile.getAbsolutePath());
- try {
- List<String> lines = FileUtils.readLines(testExecutionFile, fs.encoding().name());
- int lineNumber = 0;
- MutableTestPlan testPlan = perspectives.as(MutableTestPlan.class, inputFile);
- for (String line : lines) {
- lineNumber++;
- if (StringUtils.isBlank(line)) {
- continue;
- }
- if (line.startsWith("#")) {
- continue;
- }
- try {
- Iterator<String> split = Splitter.on(":").split(line).iterator();
- String name = split.next();
- String durationStr = split.next();
- Long duration = StringUtils.isNotBlank(durationStr) ? Long.parseLong(durationStr) : null;
- String msg = split.next();
- String stack = split.next();
- String status = split.next();
- String type = split.next();
- MutableTestCase testCase = testPlan.addTestCase(name);
- testCase.setDurationInMs(duration);
- testCase.setMessage(msg);
- testCase.setStackTrace(stack);
- testCase.setStatus(TestCase.Status.valueOf(status));
- testCase.setType(type);
- } catch (Exception e) {
- throw new IllegalStateException("Error processing line " + lineNumber + " of file " + testExecutionFile.getAbsolutePath(), e);
- }
- }
- } catch (IOException e) {
- throw new RuntimeException(e);
- }
- }
- }
-
- @Override
- public void describe(SensorDescriptor descriptor) {
- descriptor
- .name("Xoo Test Execution Sensor")
- .onlyOnLanguages(Xoo.KEY);
- }
-
- @Override
- public void execute(SensorContext context) {
- FilePredicates p = context.fileSystem().predicates();
- for (InputFile file : context.fileSystem().inputFiles(p.and(p.hasLanguages(Xoo.KEY), p.hasType(Type.TEST)))) {
- processTestFile(file, context);
- }
- }
-
-
-}
diff --git a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/test/package-info.java b/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/test/package-info.java
deleted file mode 100644
index 8586ad8b37e..00000000000
--- a/plugins/sonar-xoo-plugin/src/main/java/org/sonar/xoo/test/package-info.java
+++ /dev/null
@@ -1,23 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2021 SonarSource SA
- * mailto:info 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.
- */
-@ParametersAreNonnullByDefault
-package org.sonar.xoo.test;
-
-import javax.annotation.ParametersAreNonnullByDefault;
diff --git a/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/extensions/XooPostJobTest.java b/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/extensions/XooPostJobTest.java
index 7ee02b46c47..7ada6d09d07 100644
--- a/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/extensions/XooPostJobTest.java
+++ b/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/extensions/XooPostJobTest.java
@@ -19,16 +19,14 @@
*/
package org.sonar.xoo.extensions;
-import java.util.Arrays;
import org.junit.Rule;
import org.junit.Test;
import org.sonar.api.batch.postjob.PostJobContext;
-import org.sonar.api.utils.log.LogTester;
import org.sonar.api.batch.postjob.internal.DefaultPostJobDescriptor;
+import org.sonar.api.utils.log.LogTester;
import static org.assertj.core.api.Assertions.assertThat;
import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.when;
public class XooPostJobTest {
@@ -39,9 +37,7 @@ public class XooPostJobTest {
public void increaseCoverage() {
new XooPostJob().describe(new DefaultPostJobDescriptor());
PostJobContext context = mock(PostJobContext.class);
- when(context.issues()).thenReturn(Arrays.asList());
- when(context.resolvedIssues()).thenReturn(Arrays.asList());
new XooPostJob().execute(context);
- assertThat(logTester.logs()).contains("Resolved issues: 0", "Open issues: 0");
+ assertThat(logTester.logs()).contains("Running Xoo PostJob");
}
}
diff --git a/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/lang/SymbolReferencesSensorTest.java b/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/lang/SymbolReferencesSensorTest.java
index f525c39f4d9..6c681ba53fb 100644
--- a/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/lang/SymbolReferencesSensorTest.java
+++ b/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/lang/SymbolReferencesSensorTest.java
@@ -66,7 +66,7 @@ public class SymbolReferencesSensorTest {
@Test
public void testExecution() throws IOException {
File symbol = new File(baseDir, "src/foo.xoo.symbol");
- FileUtils.write(symbol, "1:4,7\n12:15,23:33\n\n#comment");
+ FileUtils.write(symbol, "1:1:1:4,1:7:1:10\n1:11:1:13,1:14:1:33\n\n#comment");
InputFile inputFile = new TestInputFileBuilder("foo", "src/foo.xoo")
.initMetadata("xoo file with some source code and length over 33")
.setLanguage(Xoo.KEY)
@@ -78,8 +78,8 @@ public class SymbolReferencesSensorTest {
assertThat(context.referencesForSymbolAt("foo:src/foo.xoo", 1, 2))
.containsOnly(new DefaultTextRange(new DefaultTextPointer(1, 7), new DefaultTextPointer(1, 10)));
- assertThat(context.referencesForSymbolAt("foo:src/foo.xoo", 1, 13))
- .containsOnly(new DefaultTextRange(new DefaultTextPointer(1, 23), new DefaultTextPointer(1, 33)));
+ assertThat(context.referencesForSymbolAt("foo:src/foo.xoo", 1, 12))
+ .containsOnly(new DefaultTextRange(new DefaultTextPointer(1, 14), new DefaultTextPointer(1, 33)));
}
}
diff --git a/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/lang/SyntaxHighlightingSensorTest.java b/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/lang/SyntaxHighlightingSensorTest.java
index c00ddb270e6..3f4cd46a781 100644
--- a/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/lang/SyntaxHighlightingSensorTest.java
+++ b/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/lang/SyntaxHighlightingSensorTest.java
@@ -68,7 +68,7 @@ public class SyntaxHighlightingSensorTest {
@Test
public void testExecution() throws IOException {
File symbol = new File(baseDir, "src/foo.xoo.highlighting");
- FileUtils.write(symbol, "1:4:k\n12:15:cd\n\n#comment");
+ FileUtils.write(symbol, "1:1:1:4:k\n2:7:2:10:cd\n\n#comment");
DefaultInputFile inputFile = new TestInputFileBuilder("foo", "src/foo.xoo")
.setLanguage("xoo")
.setModuleBaseDir(baseDir.toPath())
diff --git a/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/rule/OneIssuePerLineSensorTest.java b/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/rule/OneIssuePerLineSensorTest.java
index 8214b783d40..fabca7a0567 100644
--- a/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/rule/OneIssuePerLineSensorTest.java
+++ b/plugins/sonar-xoo-plugin/src/test/java/org/sonar/xoo/rule/OneIssuePerLineSensorTest.java
@@ -25,12 +25,13 @@ import org.junit.Test;
import org.junit.rules.TemporaryFolder;
import org.sonar.api.SonarEdition;
import org.sonar.api.SonarQubeSide;
-import org.sonar.api.batch.rule.Severity;
-import org.sonar.api.batch.sensor.issue.Issue;
import org.sonar.api.batch.fs.internal.DefaultInputFile;
import org.sonar.api.batch.fs.internal.TestInputFileBuilder;
+import org.sonar.api.batch.rule.Severity;
import org.sonar.api.batch.sensor.internal.DefaultSensorDescriptor;
import org.sonar.api.batch.sensor.internal.SensorContextTester;
+import org.sonar.api.batch.sensor.issue.Issue;
+import org.sonar.api.config.internal.MapSettings;
import org.sonar.api.internal.SonarRuntimeImpl;
import org.sonar.api.utils.Version;
import org.sonar.xoo.Xoo;
@@ -77,7 +78,7 @@ public class OneIssuePerLineSensorTest {
SensorContextTester context = SensorContextTester.create(temp.newFolder());
context.fileSystem().add(inputFile);
- context.settings().setProperty(OneIssuePerLineSensor.FORCE_SEVERITY_PROPERTY, "MINOR");
+ context.setSettings(new MapSettings().setProperty(OneIssuePerLineSensor.FORCE_SEVERITY_PROPERTY, "MINOR"));
sensor.execute(context);
@@ -96,7 +97,7 @@ public class OneIssuePerLineSensorTest {
SensorContextTester context = SensorContextTester.create(temp.newFolder());
context.fileSystem().add(inputFile);
- context.settings().setProperty(OneIssuePerLineSensor.EFFORT_TO_FIX_PROPERTY, "1.2");
+ context.setSettings(new MapSettings().setProperty(OneIssuePerLineSensor.EFFORT_TO_FIX_PROPERTY, "1.2"));
sensor.execute(context);
@@ -115,7 +116,7 @@ public class OneIssuePerLineSensorTest {
SensorContextTester context = SensorContextTester.create(temp.newFolder());
context.fileSystem().add(inputFile);
- context.settings().setProperty(OneIssuePerLineSensor.EFFORT_TO_FIX_PROPERTY, "1.2");
+ context.setSettings(new MapSettings().setProperty(OneIssuePerLineSensor.EFFORT_TO_FIX_PROPERTY, "1.2"));
context.setRuntime(SonarRuntimeImpl.forSonarQube(Version.parse("5.4"), SonarQubeSide.SCANNER, SonarEdition.COMMUNITY));
sensor.execute(context);