从TestNG报告中获得控制台输出,可以通过使用TestNG的监听器来实现。TestNG提供了IReporter接口,可以自定义报告生成器来获取控制台输出。以下是一种实现方法:
import org.testng.IReporter;
import org.testng.ISuite;
import org.testng.xml.XmlSuite;
import java.util.List;
import java.util.Map;
public class ConsoleReporter implements IReporter {
@Override
public void generateReport(List<XmlSuite> xmlSuites, List<ISuite> suites, String outputDirectory) {
// 遍历所有的测试套件
for (ISuite suite : suites) {
Map<String, ISuiteResult> results = suite.getResults();
// 遍历每个测试套件的结果
for (ISuiteResult result : results.values()) {
ITestContext context = result.getTestContext();
// 获取控制台输出的日志
List<String> logOutput = context.getFailedTests().getAllResults().stream()
.flatMap(testResult -> testResult.getTestContext().getFailedTests().getAllResults().stream())
.map(ITestResult::getThrowable).map(Throwable::getMessage).collect(Collectors.toList());
// 打印控制台输出
for (String log : logOutput) {
System.out.println(log);
}
}
}
}
}
<suite name="Sample Suite">
<listeners>
<listener class-name="com.example.ConsoleReporter"/>
</listeners>
...
</suite>
这样,当测试运行完成后,你就可以从TestNG报告中获得控制台输出了。
值得注意的是,该方法只能获取到测试中失败的日志输出,如果你想获取所有测试的日志输出,可以在代码中适当调整。另外,需要将com.example.ConsoleReporter
替换为你自己定义的报告生成器类的完整路径。
领取专属 10元无门槛券
手把手带您无忧上云