17370845950

JUnit的测试报告XML文件格式是什么样的
JUnit测试报告XML以为根元素,包含name、tests、failures、errors、skipped、time属性,每个含name、classname、time,失败时嵌套并含message、type和堆栈。

JUnit 的测试报告 XML 文件(通常由 maven-surefire-plugingradle test 生成)遵循一套约定俗成的结构,不是 W3C 官方标准,但被主流 CI 工具(如 Jenkins、GitLab CI)广泛支持。最常见的是 TEST-*.xml 格式,根元素为

下面是一个典型、精简但合法的 JUnit 测试报告 XML 示例,并附关键说明:



  
    
    
  
  
  
  
    
      java.lang.AssertionFailedError: Expected ArithmeticException
        at com.example.CalculatorTest.testDivideByZero(CalculatorTest.java:24)
    
  

是顶层容器

必须包含以下属性:

  • name:测试类全限定名(如 com.example.CalculatorTest
  • tests:总用例数(含成功、失败、错误、跳过)
  • failures:断言失败(AssertionError 类型)的数量
  • errors:非断言异常(如 NullPointerExceptionRuntimeException)的数量
  • skipped:被 @Disabled 或条件跳过的数量
  • time:执行总耗时(秒,保留三位小数)

描述单个测试方法

每个 必须有:

  • name:方法名(如 testAdd
  • classname:所属测试类全限定名(与 一致或嵌套类用 $ 分隔)
  • time:该用例耗时(秒)

若测试失败或出错,会嵌套 元素:

  • message 属性:简短失败原因(如 "Expected ArithmeticException"
  • type 属性:异常全类名(如 org.junit.jupiter.api.AssertionFailedError
  • 标签体:完整堆栈跟踪(缩进可选,但需是纯文本)

是可选元数据区

存放 JVM、系统、Maven 属性等,不参与统计,CI 工具可能用于归档或调试。

注意事项

  • JUnit 4 和 JUnit 5 生成的 XML 结构相同,差异仅在异常类型和部分属性值(如 type 值不同)
  • 一个测试类对应一个 TEST-*.xml 文件(Maven 默认命名规则:TEST-{全限定类名}.xml,斜杠转为下划线)
  • 若测试类含多个内部类,每个内部类单独生成一个 (可能拆分到多个文件)
  • 可选,用于捕获 System.out/System.err 输出,但默认不启用

基本上就这些。格式简单直接,重点是 testsuitetestcase 的属性统计必须准确,CI 才能正确解析成功率、趋势和失败详情。