aboutsummaryrefslogtreecommitdiffstats
path: root/plugins
diff options
context:
space:
mode:
authorGodin <mandrikov@gmail.com>2010-10-17 00:23:11 +0000
committerGodin <mandrikov@gmail.com>2010-10-17 00:23:11 +0000
commit9153b187d5e1a2c9f5b5f082d6d0a04aa209ae98 (patch)
tree03f572a11320cad44412837c94ab712bcf97923a /plugins
parent3b3ecef9310c109ad17685f864062230c321f1a7 (diff)
downloadsonarqube-9153b187d5e1a2c9f5b5f082d6d0a04aa209ae98.tar.gz
sonarqube-9153b187d5e1a2c9f5b5f082d6d0a04aa209ae98.zip
SONAR-1784: Extract AbstractSurefireParser from SurefireSensor.
Diffstat (limited to 'plugins')
-rw-r--r--plugins/sonar-surefire-plugin/src/main/java/org/sonar/plugins/surefire/AbstractSurefireParser.java121
-rw-r--r--plugins/sonar-surefire-plugin/src/main/java/org/sonar/plugins/surefire/SurefireSensor.java110
2 files changed, 126 insertions, 105 deletions
diff --git a/plugins/sonar-surefire-plugin/src/main/java/org/sonar/plugins/surefire/AbstractSurefireParser.java b/plugins/sonar-surefire-plugin/src/main/java/org/sonar/plugins/surefire/AbstractSurefireParser.java
new file mode 100644
index 00000000000..56adade806a
--- /dev/null
+++ b/plugins/sonar-surefire-plugin/src/main/java/org/sonar/plugins/surefire/AbstractSurefireParser.java
@@ -0,0 +1,121 @@
+package org.sonar.plugins.surefire;
+
+import org.apache.commons.lang.StringEscapeUtils;
+import org.apache.commons.lang.StringUtils;
+import org.sonar.api.batch.SensorContext;
+import org.sonar.api.measures.CoreMetrics;
+import org.sonar.api.measures.Measure;
+import org.sonar.api.measures.Metric;
+import org.sonar.api.resources.Project;
+import org.sonar.api.resources.Resource;
+import org.sonar.api.utils.ParsingUtils;
+import org.sonar.api.utils.StaxParser;
+import org.sonar.api.utils.XmlParserException;
+
+import java.io.File;
+import java.io.FilenameFilter;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+
+import javax.xml.transform.TransformerException;
+
+/**
+ * @since 2.4
+ */
+public abstract class AbstractSurefireParser {
+
+ protected void collect(Project project, SensorContext context, File reportsDir) {
+ File[] xmlFiles = getReports(reportsDir);
+
+ if (xmlFiles.length == 0) {
+ insertZeroWhenNoReports(project, context);
+ } else {
+ parseFiles(context, xmlFiles);
+ }
+ }
+
+ private File[] getReports(File dir) {
+ if (dir == null || !dir.isDirectory() || !dir.exists()) {
+ return new File[0];
+ }
+ return dir.listFiles(new FilenameFilter() {
+ public boolean accept(File dir, String name) {
+ return name.startsWith("TEST") && name.endsWith(".xml");
+ }
+ });
+ }
+
+ private void insertZeroWhenNoReports(Project pom, SensorContext context) {
+ if ( !StringUtils.equalsIgnoreCase("pom", pom.getPackaging())) {
+ context.saveMeasure(CoreMetrics.TESTS, 0.0);
+ }
+ }
+
+ private void parseFiles(SensorContext context, File[] reports) {
+ Set<TestSuiteReport> analyzedReports = new HashSet<TestSuiteReport>();
+ try {
+ for (File report : reports) {
+ TestSuiteParser parserHandler = new TestSuiteParser();
+ StaxParser parser = new StaxParser(parserHandler, false);
+ parser.parse(report);
+
+ for (TestSuiteReport fileReport : parserHandler.getParsedReports()) {
+ if ( !fileReport.isValid() || analyzedReports.contains(fileReport)) {
+ continue;
+ }
+ if (fileReport.getTests() > 0) {
+ double testsCount = fileReport.getTests() - fileReport.getSkipped();
+ saveClassMeasure(context, fileReport, CoreMetrics.SKIPPED_TESTS, fileReport.getSkipped());
+ saveClassMeasure(context, fileReport, CoreMetrics.TESTS, testsCount);
+ saveClassMeasure(context, fileReport, CoreMetrics.TEST_ERRORS, fileReport.getErrors());
+ saveClassMeasure(context, fileReport, CoreMetrics.TEST_FAILURES, fileReport.getFailures());
+ saveClassMeasure(context, fileReport, CoreMetrics.TEST_EXECUTION_TIME, fileReport.getTimeMS());
+ double passedTests = testsCount - fileReport.getErrors() - fileReport.getFailures();
+ if (testsCount > 0) {
+ double percentage = passedTests * 100d / testsCount;
+ saveClassMeasure(context, fileReport, CoreMetrics.TEST_SUCCESS_DENSITY, ParsingUtils.scaleValue(percentage));
+ }
+ saveTestsDetails(context, fileReport);
+ analyzedReports.add(fileReport);
+ }
+ }
+ }
+
+ } catch (Exception e) {
+ throw new XmlParserException("Can not parse surefire reports", e);
+ }
+ }
+
+ private void saveTestsDetails(SensorContext context, TestSuiteReport fileReport) throws TransformerException {
+ StringBuilder testCaseDetails = new StringBuilder(256);
+ testCaseDetails.append("<tests-details>");
+ List<TestCaseDetails> details = fileReport.getDetails();
+ for (TestCaseDetails detail : details) {
+ testCaseDetails.append("<testcase status=\"").append(detail.getStatus())
+ .append("\" time=\"").append(detail.getTimeMS())
+ .append("\" name=\"").append(detail.getName()).append("\"");
+ boolean isError = detail.getStatus().equals(TestCaseDetails.STATUS_ERROR);
+ if (isError || detail.getStatus().equals(TestCaseDetails.STATUS_FAILURE)) {
+ testCaseDetails.append(">")
+ .append(isError ? "<error message=\"" : "<failure message=\"")
+ .append(StringEscapeUtils.escapeXml(detail.getErrorMessage())).append("\">")
+ .append("<![CDATA[").append(StringEscapeUtils.escapeXml(detail.getStackTrace())).append("]]>")
+ .append(isError ? "</error>" : "</failure>").append("</testcase>");
+ } else {
+ testCaseDetails.append("/>");
+ }
+ }
+ testCaseDetails.append("</tests-details>");
+ context.saveMeasure(getUnitTestResource(fileReport), new Measure(CoreMetrics.TEST_DATA, testCaseDetails.toString()));
+ }
+
+ private void saveClassMeasure(SensorContext context, TestSuiteReport fileReport, Metric metric, double value) {
+ if ( !Double.isNaN(value)) {
+ context.saveMeasure(getUnitTestResource(fileReport), metric, value);
+ }
+ }
+
+ protected abstract Resource<?> getUnitTestResource(TestSuiteReport fileReport);
+
+}
diff --git a/plugins/sonar-surefire-plugin/src/main/java/org/sonar/plugins/surefire/SurefireSensor.java b/plugins/sonar-surefire-plugin/src/main/java/org/sonar/plugins/surefire/SurefireSensor.java
index 47b692c8f97..a4d4335d1d7 100644
--- a/plugins/sonar-surefire-plugin/src/main/java/org/sonar/plugins/surefire/SurefireSensor.java
+++ b/plugins/sonar-surefire-plugin/src/main/java/org/sonar/plugins/surefire/SurefireSensor.java
@@ -19,8 +19,6 @@
*/
package org.sonar.plugins.surefire;
-import org.apache.commons.lang.StringEscapeUtils;
-import org.apache.commons.lang.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.sonar.api.CoreProperties;
@@ -30,23 +28,12 @@ import org.sonar.api.batch.Sensor;
import org.sonar.api.batch.SensorContext;
import org.sonar.api.batch.maven.MavenPlugin;
import org.sonar.api.batch.maven.MavenSurefireUtils;
-import org.sonar.api.measures.CoreMetrics;
-import org.sonar.api.measures.Measure;
-import org.sonar.api.measures.Metric;
import org.sonar.api.resources.Java;
import org.sonar.api.resources.JavaFile;
import org.sonar.api.resources.Project;
import org.sonar.api.resources.Resource;
-import org.sonar.api.utils.ParsingUtils;
-import org.sonar.api.utils.StaxParser;
-import org.sonar.api.utils.XmlParserException;
import java.io.File;
-import java.io.FilenameFilter;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-import javax.xml.transform.TransformerException;
public class SurefireSensor implements Sensor {
@@ -100,101 +87,14 @@ public class SurefireSensor implements Sensor {
return new File(project.getFileSystem().getBuildDir(), "surefire-reports");
}
- private File[] getReports(File dir) {
- if (dir == null || !dir.isDirectory() || !dir.exists()) {
- return new File[0];
- }
- return dir.listFiles(new FilenameFilter() {
- public boolean accept(File dir, String name) {
- return name.startsWith("TEST") && name.endsWith(".xml");
- }
- });
- }
-
-
protected void collect(Project project, SensorContext context, File reportsDir) {
logger.info("parsing {}", reportsDir);
- File[] xmlFiles = getReports(reportsDir);
-
- if (xmlFiles.length == 0) {
- insertZeroWhenNoReports(project, context);
- } else {
- parseFiles(context, xmlFiles);
- }
- }
-
- private void insertZeroWhenNoReports(Project pom, SensorContext context) {
- if (!StringUtils.equalsIgnoreCase("pom", pom.getPackaging())) {
- context.saveMeasure(CoreMetrics.TESTS, 0.0);
- }
- }
-
- private void parseFiles(SensorContext context, File[] reports) {
- Set<TestSuiteReport> analyzedReports = new HashSet<TestSuiteReport>();
- try {
- for (File report : reports) {
- TestSuiteParser parserHandler = new TestSuiteParser();
- StaxParser parser = new StaxParser(parserHandler, false);
- parser.parse(report);
-
- for (TestSuiteReport fileReport : parserHandler.getParsedReports()) {
- if (!fileReport.isValid() || analyzedReports.contains(fileReport)) {
- continue;
- }
- if (fileReport.getTests() > 0) {
- double testsCount = fileReport.getTests() - fileReport.getSkipped();
- saveClassMeasure(context, fileReport, CoreMetrics.SKIPPED_TESTS, fileReport.getSkipped());
- saveClassMeasure(context, fileReport, CoreMetrics.TESTS, testsCount);
- saveClassMeasure(context, fileReport, CoreMetrics.TEST_ERRORS, fileReport.getErrors());
- saveClassMeasure(context, fileReport, CoreMetrics.TEST_FAILURES, fileReport.getFailures());
- saveClassMeasure(context, fileReport, CoreMetrics.TEST_EXECUTION_TIME, fileReport.getTimeMS());
- double passedTests = testsCount - fileReport.getErrors() - fileReport.getFailures();
- if (testsCount > 0) {
- double percentage = passedTests * 100d / testsCount;
- saveClassMeasure(context, fileReport, CoreMetrics.TEST_SUCCESS_DENSITY, ParsingUtils.scaleValue(percentage));
- }
- saveTestsDetails(context, fileReport);
- analyzedReports.add(fileReport);
- }
- }
+ new AbstractSurefireParser() {
+ @Override
+ protected Resource<?> getUnitTestResource(TestSuiteReport fileReport) {
+ return new JavaFile(fileReport.getClassKey(), true);
}
-
- } catch (Exception e) {
- throw new XmlParserException("Can not parse surefire reports", e);
- }
- }
-
- private void saveTestsDetails(SensorContext context, TestSuiteReport fileReport) throws TransformerException {
- StringBuilder testCaseDetails = new StringBuilder(256);
- testCaseDetails.append("<tests-details>");
- List<TestCaseDetails> details = fileReport.getDetails();
- for (TestCaseDetails detail : details) {
- testCaseDetails.append("<testcase status=\"").append(detail.getStatus())
- .append("\" time=\"").append(detail.getTimeMS())
- .append("\" name=\"").append(detail.getName()).append("\"");
- boolean isError = detail.getStatus().equals(TestCaseDetails.STATUS_ERROR);
- if (isError || detail.getStatus().equals(TestCaseDetails.STATUS_FAILURE)) {
- testCaseDetails.append(">")
- .append(isError ? "<error message=\"" : "<failure message=\"")
- .append(StringEscapeUtils.escapeXml(detail.getErrorMessage())).append("\">")
- .append("<![CDATA[").append(StringEscapeUtils.escapeXml(detail.getStackTrace())).append("]]>")
- .append(isError ? "</error>" : "</failure>").append("</testcase>");
- } else {
- testCaseDetails.append("/>");
- }
- }
- testCaseDetails.append("</tests-details>");
- context.saveMeasure(getUnitTestResource(fileReport), new Measure(CoreMetrics.TEST_DATA, testCaseDetails.toString()));
- }
-
- private void saveClassMeasure(SensorContext context, TestSuiteReport fileReport, Metric metric, double value) {
- if (!Double.isNaN(value)) {
- context.saveMeasure(getUnitTestResource(fileReport), metric, value);
- }
- }
-
- private Resource<?> getUnitTestResource(TestSuiteReport fileReport) {
- return new JavaFile(fileReport.getClassKey(), true);
+ }.collect(project, context, reportsDir);
}
@Override