【发布时间】:2026-02-10 07:25:02
【问题描述】:
我正在使用以下方法以编程方式运行 JUnit 测试:
String res = runProcess("java -classpath " + dirPath + ";" + classpath + " org.junit.runner.JUnitCore "+ getClassName(filePath));
private static String runProcess(String command) throws Exception {
Process process = Runtime.getRuntime().exec(command);
String inputStr = IOUtils.toString(process.getInputStream());
process.waitFor();
return inputStr;
}
但是,它会输出很多附加信息,例如失败次数、运行所用时间和 junit 信息。
示例输出如下所示:
JUnit version 4.12
.E
Time: 0.011
There was 1 failure:
1) test10(ErrorTestLang)
java.lang.AssertionError: Contract failed: compareTo-equals on fraction1 and fraction4
at org.junit.Assert.fail(Assert.java:88)
at org.junit.Assert.assertTrue(Assert.java:41)
at ErrorTestLang.test10(ErrorTestLang.java:32)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
at org.junit.runners.Suite.runChild(Suite.java:128)
at org.junit.runners.Suite.runChild(Suite.java:27)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
at org.junit.runner.JUnitCore.run(JUnitCore.java:115)
at org.junit.runner.JUnitCore.runMain(JUnitCore.java:77)
at org.junit.runner.JUnitCore.main(JUnitCore.java:36)
FAILURES!!!
Tests run: 1, Failures: 1
我的目标是以编程方式多次运行 JUnit 测试套件,因为我以编程方式修改它并确保结果仍然相同。也就是说,即使我删除了一些未使用/“死”的代码行,所有相同的断言都会失败/通过。
因此,我对输出的部分感兴趣:
java.lang.AssertionError: Contract failed: compareTo-equals on fraction1 and fraction4
因为我会将其与其他结果进行比较,并且不想考虑运行时间或行号等细节。
有没有让JUnit输出更简洁的标志?
【问题讨论】:
-
我不明白您为什么要以这种方式启动 JUnit。几乎所有 IDE 都有一个运行 JUnit Test 的插件,您可以像自己的“启动器”一样轻松地启动它。还有一些插件会在每次更改代码库后运行受影响的测试(例如,infinitest 用于 eclipse 和 netbeans)...
标签: java unit-testing parsing testing junit