aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sonar-plugin-api/src/main/java/org/sonar/api/profiles/XMLProfileParser.java22
-rw-r--r--sonar-plugin-api/src/test/java/org/sonar/api/profiles/XMLProfileParserTest.java16
2 files changed, 36 insertions, 2 deletions
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/profiles/XMLProfileParser.java b/sonar-plugin-api/src/main/java/org/sonar/api/profiles/XMLProfileParser.java
index 84cc6c0ea79..819ee316b15 100644
--- a/sonar-plugin-api/src/main/java/org/sonar/api/profiles/XMLProfileParser.java
+++ b/sonar-plugin-api/src/main/java/org/sonar/api/profiles/XMLProfileParser.java
@@ -45,6 +45,8 @@ import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamException;
/**
+ * TODO should be an interface
+ *
* @since 2.3
*/
public final class XMLProfileParser implements ServerComponent {
@@ -52,6 +54,22 @@ public final class XMLProfileParser implements ServerComponent {
private RuleFinder ruleFinder;
private MetricFinder metricFinder;
+ /**
+ * For backward compatibility.
+ *
+ * @deprecated since 2.5. Plugins shouldn't directly instantiate this class,
+ * because it should be retrieved as an IoC dependency.
+ */
+ @Deprecated
+ public XMLProfileParser(RuleFinder ruleFinder) {
+ this.ruleFinder = ruleFinder;
+ }
+
+ /**
+ * @deprecated since 2.5. Plugins shouldn't directly instantiate this class,
+ * because it should be retrieved as an IoC dependency.
+ */
+ @Deprecated
public XMLProfileParser(RuleFinder ruleFinder, MetricFinder metricFinder) {
this.ruleFinder = ruleFinder;
this.metricFinder = metricFinder;
@@ -183,6 +201,10 @@ public final class XMLProfileParser implements ServerComponent {
}
private void processAlerts(SMInputCursor alertsCursor, RulesProfile profile, ValidationMessages messages) throws XMLStreamException {
+ if (metricFinder == null) {
+ // TODO remove when constructor without MetricFinder would be removed
+ return;
+ }
while (alertsCursor.getNext() != null) {
SMInputCursor alertCursor = alertsCursor.childElementCursor();
diff --git a/sonar-plugin-api/src/test/java/org/sonar/api/profiles/XMLProfileParserTest.java b/sonar-plugin-api/src/test/java/org/sonar/api/profiles/XMLProfileParserTest.java
index 6a6ca1af8da..765c58ae667 100644
--- a/sonar-plugin-api/src/test/java/org/sonar/api/profiles/XMLProfileParserTest.java
+++ b/sonar-plugin-api/src/test/java/org/sonar/api/profiles/XMLProfileParserTest.java
@@ -62,7 +62,6 @@ public class XMLProfileParserTest {
assertThat(validation.getErrors().size(), is(2));
assertThat(validation.getErrors().get(0), containsString(""));
-
}
@Test
@@ -100,9 +99,22 @@ public class XMLProfileParserTest {
assertThat(alert.getValueError(), is("12"));
}
+ @Test
+ public void shouldNotFailWhenNoMetricFinder() {
+ ValidationMessages validation = ValidationMessages.create();
+ RulesProfile profile = new XMLProfileParser(newRuleFinder(), null)
+ .parseResource(getClass().getClassLoader(), getResourcePath("importProfileWithAlerts.xml"), validation);
+
+ assertThat(profile.getAlerts().size(), is(0));
+ }
+
private RulesProfile parse(String resource, ValidationMessages validation) {
return new XMLProfileParser(newRuleFinder(), newMetricFinder())
- .parseResource(getClass().getClassLoader(), "org/sonar/api/profiles/XMLProfileParserTest/" + resource, validation);
+ .parseResource(getClass().getClassLoader(), getResourcePath(resource), validation);
+ }
+
+ private String getResourcePath(String resource) {
+ return "org/sonar/api/profiles/XMLProfileParserTest/" + resource;
}
private MetricFinder newMetricFinder() {