use of org.apache.maven.plugins.surefire.report.ReportTestCase in project repairnator by Spirals-Team.
the class GatherTestInformation method businessExecute.
@Override
protected void businessExecute() {
this.getLogger().debug("Gathering test information...");
File rootRepo = new File(this.inspector.getJobStatus().getPomDirPath());
final List<File> surefireDirs = new ArrayList<File>();
try {
Files.walkFileTree(rootRepo.toPath(), new SimpleFileVisitor<Path>() {
public FileVisitResult preVisitDirectory(Path file, BasicFileAttributes attrs) throws IOException {
if (file.toString().endsWith(SUREFIREREPORT_PATH)) {
surefireDirs.add(file.toFile());
return FileVisitResult.SKIP_SUBTREE;
} else {
return FileVisitResult.CONTINUE;
}
}
});
} catch (IOException e) {
this.getLogger().warn("Error while traversing files to get surefire reports: " + e);
this.addStepError(e.getMessage());
}
for (File surefireDir : surefireDirs) {
SurefireReportParser parser = new SurefireReportParser(Arrays.asList(new File[] { surefireDir }), Locale.ENGLISH, null);
try {
List<ReportTestSuite> testSuites = parser.parseXMLReportFiles();
for (ReportTestSuite testSuite : testSuites) {
if (!skipSettingStatusInformation) {
this.nbTotalTests += testSuite.getNumberOfTests();
this.nbSkippingTests += testSuite.getNumberOfSkipped();
if (testSuite.getNumberOfFailures() > 0 || testSuite.getNumberOfErrors() > 0) {
File failingModule = surefireDir.getParentFile().getParentFile();
this.failingModulePath = failingModule.getCanonicalPath();
this.getInspector().getJobStatus().setFailingModulePath(this.failingModulePath);
this.writeProperty("failingModule", this.failingModulePath);
getLogger().info("Get the following failing module path: " + failingModulePath);
for (ReportTestCase testCase : testSuite.getTestCases()) {
if (testCase.hasFailure() || testCase.hasError()) {
// sometimes surefire reports a failureType on the form:
// "java.lang.NullPointerException:" we should avoid this case
String failureType = testCase.getFailureType();
if (failureType.endsWith(":")) {
failureType = failureType.substring(0, failureType.length() - 1);
}
this.failureNames.add(failureType);
FailureType typeTof = new FailureType(testCase.getFailureType(), testCase.getFailureMessage(), testCase.hasError());
FailureLocation failureLocation = null;
for (FailureLocation location : this.failureLocations) {
if (location.getClassName().equals(testCase.getFullClassName())) {
failureLocation = location;
break;
}
}
if (failureLocation == null) {
failureLocation = new FailureLocation(testCase.getFullClassName());
this.failureLocations.add(failureLocation);
}
failureLocation.addFailure(typeTof);
if (testCase.hasError()) {
failureLocation.addErroringMethod(testCase.getFullClassName() + "#" + testCase.getName());
} else {
failureLocation.addFailingMethod(testCase.getFullClassName() + "#" + testCase.getName());
}
}
}
}
}
this.nbErroringTests += testSuite.getNumberOfErrors();
this.nbFailingTests += testSuite.getNumberOfFailures();
}
if (this.nbFailingTests > 0) {
this.setPipelineState(PipelineState.HASTESTFAILURE);
} else if (this.nbErroringTests > 0) {
this.setPipelineState(PipelineState.HASTESTERRORS);
} else {
this.setPipelineState(PipelineState.NOTFAILING);
}
} catch (MavenReportException e) {
this.addStepError("Error while parsing files to get test information:", e);
} catch (IOException e) {
this.addStepError("Error while getting the failing module path: ", e);
}
}
if (!this.skipSettingStatusInformation) {
this.writeProperty("error-types", this.failureNames);
this.writeProperty("failing-test-cases", this.failureLocations);
this.writeProperty("totalNumberFailingTests", this.nbFailingTests);
this.writeProperty("totalNumberErroringTests", this.nbErroringTests);
this.writeProperty("totalNumberSkippingTests", this.nbSkippingTests);
this.writeProperty("totalNumberRunningTests", this.nbTotalTests);
this.inspector.getJobStatus().setFailureLocations(this.failureLocations);
Metrics metrics = this.inspector.getJobStatus().getMetrics();
metrics.setFailureNames(this.failureNames);
metrics.setNbFailingTests(this.nbErroringTests + this.nbFailingTests);
metrics.setNbRunningTests(this.nbTotalTests);
}
this.shouldStop = contract.shouldBeStopped(this);
}
use of org.apache.maven.plugins.surefire.report.ReportTestCase in project elastest-torm by elastest.
the class TJobExecOrchestratorService method saveTestResults.
public void saveTestResults(List<ReportTestSuite> testSuites, TJobExecution tJobExec) {
logger.info("Saving test results {} ", tJobExec.getId());
TestSuite tSuite;
TestCase tCase;
if (testSuites != null && testSuites.size() > 0) {
for (ReportTestSuite reportTestSuite : testSuites) {
tSuite = new TestSuite();
tSuite.setTimeElapsed(reportTestSuite.getTimeElapsed());
tSuite.setErrors(reportTestSuite.getNumberOfErrors());
tSuite.setFailures(reportTestSuite.getNumberOfFailures());
tSuite.setFlakes(reportTestSuite.getNumberOfFlakes());
tSuite.setSkipped(reportTestSuite.getNumberOfSkipped());
tSuite.setName(reportTestSuite.getName());
tSuite.setnumTests(reportTestSuite.getNumberOfTests());
tSuite = testSuiteRepo.save(tSuite);
for (ReportTestCase reportTestCase : reportTestSuite.getTestCases()) {
tCase = new TestCase();
// Remove parentheses
tCase.cleanNameAndSet(reportTestCase.getName());
tCase.setTime(reportTestCase.getTime());
tCase.setFailureDetail(reportTestCase.getFailureDetail());
tCase.setFailureErrorLine(reportTestCase.getFailureErrorLine());
tCase.setFailureMessage(reportTestCase.getFailureMessage());
tCase.setFailureType(reportTestCase.getFailureType());
tCase.setTestSuite(tSuite);
try {
Date startDate = this.elasticsearchService.findFirstMsgAndGetTimestamp(tJobExec.getMonitoringIndex(), this.tcStartMsgPrefix + tCase.getName() + " ", "test");
tCase.setStartDate(startDate);
Date endDate = this.elasticsearchService.findFirstMsgAndGetTimestamp(tJobExec.getMonitoringIndex(), this.tcFinishMsgPrefix + tCase.getName() + " ", "test");
tCase.setEndDate(endDate);
} catch (Exception e) {
logger.debug("Cannot save start/end date for Test Case {}", tCase.getName(), e);
}
testCaseRepo.save(tCase);
}
tSuite.settJobExec(tJobExec);
testSuiteRepo.save(tSuite);
tJobExec.getTestSuites().add(tSuite);
}
}
}
Aggregations