From b357d557084c444e5d519c2e7841f50a99cb7f2e Mon Sep 17 00:00:00 2001 From: Alexander Kriegisch Date: Mon, 4 Dec 2023 11:57:04 +0700 Subject: [PATCH] [SUREFIRE-2219] Add test stdErr/stdOut output to ReportTestCase TestSuiteXmlParser no longer ignores the 'system-out' and 'system-err' tags from the Surefire report XML. It parses them and sets the corresponding properties in ReportTestCase. --- .../surefire/report/ReportTestCase.java | 20 +++++++++++++++++++ .../surefire/report/TestSuiteXmlParser.java | 11 ++++++++++ 2 files changed, 31 insertions(+) diff --git a/surefire-report-parser/src/main/java/org/apache/maven/plugins/surefire/report/ReportTestCase.java b/surefire-report-parser/src/main/java/org/apache/maven/plugins/surefire/report/ReportTestCase.java index cb652bc96a..c2ed821756 100644 --- a/surefire-report-parser/src/main/java/org/apache/maven/plugins/surefire/report/ReportTestCase.java +++ b/surefire-report-parser/src/main/java/org/apache/maven/plugins/surefire/report/ReportTestCase.java @@ -41,6 +41,8 @@ public final class ReportTestCase { private String failureErrorLine; private String failureDetail; + private String systemOut; + private String systemErr; private boolean hasFailure; @@ -138,6 +140,24 @@ public ReportTestCase setError(String message, String type) { return setFailureMessage(message).setFailureType(type); } + public String getSystemOut() { + return systemOut; + } + + public ReportTestCase setSystemOut(String message) { + systemOut = message; + return this; + } + + public String getSystemErr() { + return systemErr; + } + + public ReportTestCase setSystemErr(String message) { + systemErr = message; + return this; + } + public ReportTestCase setSkipped(String message) { hasFailure = false; hasError = false; diff --git a/surefire-report-parser/src/main/java/org/apache/maven/plugins/surefire/report/TestSuiteXmlParser.java b/surefire-report-parser/src/main/java/org/apache/maven/plugins/surefire/report/TestSuiteXmlParser.java index d651b3e64c..be2d5335ff 100644 --- a/surefire-report-parser/src/main/java/org/apache/maven/plugins/surefire/report/TestSuiteXmlParser.java +++ b/surefire-report-parser/src/main/java/org/apache/maven/plugins/surefire/report/TestSuiteXmlParser.java @@ -171,6 +171,11 @@ public void startElement(String uri, String localName, String qName, Attributes testCase.setError(attributes.getValue("message"), attributes.getValue("type")); currentSuite.incrementNumberOfErrors(); break; + case "system-out": + case "system-err": + currentElement = new StringBuilder(); + parseContent = true; + break; case "skipped": String message = attributes.getValue("message"); testCase.setSkipped(message != null ? message : "skipped"); @@ -210,6 +215,12 @@ public void endElement(String uri, String localName, String qName) throws SAXExc testCase.setFailureDetail(currentElement.toString()) .setFailureErrorLine(parseErrorLine(currentElement, testCase.getFullClassName())); break; + case "system-out": + testCase.setSystemOut(currentElement.toString()); + break; + case "system-err": + testCase.setSystemErr(currentElement.toString()); + break; case "time": try { defaultSuite.setTimeElapsed(Float.parseFloat(currentElement.toString()));