minecraft-src/net/minecraft/gametest/framework/JUnitLikeTestReporter.java
2025-07-04 03:45:38 +03:00

79 lines
3 KiB
Java

package net.minecraft.gametest.framework;
import com.google.common.base.Stopwatch;
import java.io.File;
import java.time.Instant;
import java.time.format.DateTimeFormatter;
import java.util.concurrent.TimeUnit;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
public class JUnitLikeTestReporter implements TestReporter {
private final Document document;
private final Element testSuite;
private final Stopwatch stopwatch;
private final File destination;
public JUnitLikeTestReporter(File destination) throws ParserConfigurationException {
this.destination = destination;
this.document = DocumentBuilderFactory.newInstance().newDocumentBuilder().newDocument();
this.testSuite = this.document.createElement("testsuite");
Element element = this.document.createElement("testsuite");
element.appendChild(this.testSuite);
this.document.appendChild(element);
this.testSuite.setAttribute("timestamp", DateTimeFormatter.ISO_INSTANT.format(Instant.now()));
this.stopwatch = Stopwatch.createStarted();
}
private Element createTestCase(GameTestInfo testInfo, String name) {
Element element = this.document.createElement("testcase");
element.setAttribute("name", name);
element.setAttribute("classname", testInfo.getStructure().toString());
element.setAttribute("time", String.valueOf(testInfo.getRunTime() / 1000.0));
this.testSuite.appendChild(element);
return element;
}
@Override
public void onTestFailed(GameTestInfo testInfo) {
String string = testInfo.id().toString();
String string2 = testInfo.getError().getMessage();
Element element = this.document.createElement(testInfo.isRequired() ? "failure" : "skipped");
element.setAttribute("message", "(" + testInfo.getTestBlockPos().toShortString() + ") " + string2);
Element element2 = this.createTestCase(testInfo, string);
element2.appendChild(element);
}
@Override
public void onTestSuccess(GameTestInfo testInfo) {
String string = testInfo.id().toString();
this.createTestCase(testInfo, string);
}
@Override
public void finish() {
this.stopwatch.stop();
this.testSuite.setAttribute("time", String.valueOf(this.stopwatch.elapsed(TimeUnit.MILLISECONDS) / 1000.0));
try {
this.save(this.destination);
} catch (TransformerException var2) {
throw new Error("Couldn't save test report", var2);
}
}
public void save(File destination) throws TransformerException {
TransformerFactory transformerFactory = TransformerFactory.newInstance();
Transformer transformer = transformerFactory.newTransformer();
DOMSource dOMSource = new DOMSource(this.document);
StreamResult streamResult = new StreamResult(destination);
transformer.transform(dOMSource, streamResult);
}
}