JUnit5最终版本即将来临 (当前是M4),我已经开始研究如何编写扩展。

JUnit5中 ,您没有使用RunnersRulesClassRules等,而是只有一个Extension API来实现自己的扩展。

JUnit5提供了多个接口来挂钩其生命周期。 例如,您可以挂钩到“ 测试实例后处理”以在测试实例上调用自定义初始化方法,或者通过“ 参数解析”来在运行时动态解析测试方法参数。 当然,到目前为止,典型的操作如在执行所有测试之前,执行测试之前,执行测试之后进行挂接等等,可以在http://junit.org/junit5/docs/找到完整列表。 当前/用户指南/#extensions-lifecycle-callbacks

但是在每个过程中都在过程的哪一点执行? 为了测试它,我刚刚创建了一个扩展,该扩展实现了所有接口,并且每个方法都会打印出谁。

public class LoggerExtension implements TestInstancePostProcessor, ParameterResolver, BeforeAllCallback,BeforeEachCallback, BeforeTestExecutionCallback, AfterEachCallback, AfterTestExecutionCallback, AfterAllCallback,TestExecutionExceptionHandler {@Overridepublic void postProcessTestInstance(Object testInstance, ExtensionContext context) throws Exception {System.out.println("Test Instance Post-processing called");}@Overridepublic boolean supports(ParameterContext parameterContext, ExtensionContext extensionContext)throws ParameterResolutionException {System.out.println("Parameter Resolver Supports called");return parameterContext.getParameter().getType().equals(String.class);}@Overridepublic Object resolve(ParameterContext parameterContext, ExtensionContext extensionContext)throws ParameterResolutionException {System.out.println("Resolver called");return "Hello World";}@Overridepublic void beforeAll(ContainerExtensionContext context) throws Exception {System.out.println("Before All called " + context.getTestClass().get());}@Overridepublic void beforeEach(TestExtensionContext context) throws Exception {System.out.println("Before Each called");}@Overridepublic void beforeTestExecution(TestExtensionContext context) throws Exception {System.out.println("Before Test Execution called");}@Overridepublic void afterEach(TestExtensionContext context) throws Exception {System.out.println("After Each called");}@Overridepublic void afterTestExecution(TestExtensionContext context) throws Exception {System.out.println("After Test Executon called");}@Overridepublic void afterAll(ContainerExtensionContext context) throws Exception {System.out.println("After All called");}@Overridepublic void handleTestExecutionException(TestExtensionContext context, Throwable throwable) throws Throwable {System.out.println("Test Execution Exception called");throw throwable;}
}

然后,我创建了一个包含两个测试的JUnit5测试套件:

@ExtendWith(LoggerExtension.class)
public class AnotherLoggerExtensionTest {@Testpublic void test4() {System.out.println("Test 4");}}
@ExtendWith(LoggerExtension.class)
public class LoggerExtensionTest {@Testpublic void test1() {System.out.println("Test 1");}@Testpublic void test2(String msg) {System.out.println("Test 2 " + msg);}@Testpublic void test3() {System.out.println("Test 3");throw new IllegalArgumentException("");}}
@RunWith(JUnitPlatform.class)
@SelectClasses({LoggerExtensionTest.class, AnotherLoggerExtensionTest.class})
public class LoggerExtensionTestSuite {
}

那么在执行此套件之后,输出是什么? 让我们来看看它。 请注意,出于可读性考虑,我在终端输出上添加了一些标注。

Before All called class AnotherLoggerExtensionTest
Test Instance Post-processing called
Before Each called
Before Test Execution called
Test 4
After Test Execution called
After Each called
After All called// <1>Before All called class LoggerExtensionTest
Test Instance Post-processing called
Before Each called
Before Test Execution called
Test 1
After Test Execution called
After Each called// <2>Test Instance Post-processing called
Before Each called
Before Test Execution called
Parameter Resolver Supports called
Resolver called
Test 2 Hello World
After Test Execution called
After Each called// <3>Test Instance Post-processing called
Before Each called
Before Test Execution called
Test 3
Test Execution Exception called
After Test Execution called
After Each called// <4>After All called

<1>运行它的第一个测试是AnotherLoggerExtensionTest 。 在这种情况下,只有一个简单的测试,因此扩展的生命周期为BeforeAllTest Instance-Post-ProcessingBefore EachBefore Test Execution ,然后执行测试本身,然后执行所有After回调。

<2>然后执行LoggerExtensionTest 。 第一次测试不是参数化测试,因此不会调用与参数解析有关的事件。 在执行test方法之前,将调用测试实例后处理 ,然后再引发所有事件之前。 最终,所有后续事件都将执行测试。

<3>第二个测试包含需要参数解析。 参数解析器Before事件之后和执行测试本身之前运行。

<4>最后一次测试将引发异常。 在执行测试之后但在After事件之前调用Test Execution Exception

最后要注意的是, BeforeAllAfterAll事件是按测试类而不是套件执行的。

本示例中使用的JUnit版本是org.junit.jupiter:junit-jupiter-api:5.0.0-M4

翻译自: https://www.javacodegeeks.com/2017/06/lifecycle-junit-5-extension-model.html

JUnit 5扩展模型的生命周期相关推荐

  1. 扩展 junit 框架_JUnit 5扩展模型的生命周期

    扩展 junit 框架 JUnit5最终版本即将来临 (当前是M4),我已经开始尝试如何编写扩展了. 在JUnit5中 ,您没有使用Runners , Rules , ClassRules等,而是只有 ...

  2. JUnit 5 –扩展模型

    我们已经对Java最普遍的测试框架的下一个版本了解很多. 现在让我们看一下JUnit 5扩展模型,该模型将允许库和框架将自己的实现添加到JUnit中. 总览 设定 基本 建筑 扩展模型 条件 注射 - ...

  3. ASP.NET的网页代码模型及生命周期

    第4章  ASP.NET的网页代码模型及生命周期 从本章开始,就进入了ASP.NET应用程序开发的世界.在了解了C#的结构,以及面向对象的概念后,就可以从面向对象的思想开发ASP.NET应用程序.在A ...

  4. JVM 学习一:JVM 的构架模型及生命周期

    JVM 的架构模型 Java 编译器输入的指令流基本上是一种基于栈的指令集架构,另外一种指令集架构则是基于寄存器的指令集架构. 具体来说,这两种架构之间的区别: 基于栈式架构的特点: 设计和实现更简单 ...

  5. 机器学习模型的生命周期

    动动发财的小手,点个赞吧! 您的模型如何变化?Source[1] 诞生 当我们构建.训练.拟合或估计我们的模型时,这些数字工具就诞生了.这个阶段几乎从拥有分析目标.数据.计算机.算法以及数据科学家现在 ...

  6. 【笔记】【一文搞定】java - 多线程:内存模型、生命周期、方法/关键词、并发问题、线程池、案例

    参考: Java内存模型(JMM)详解 - https://zhuanlan.zhihu.com/p/518758482 线程安全性详解(原子性.可见性.有序性) - https://blog.csd ...

  7. 扩展 junit 框架_JUnit 5 –扩展模型

    扩展 junit 框架 我们已经对Java最普遍的测试框架的下一个版本了解很多. 现在,让我们看一下JUnit 5扩展模型,该模型将允许库和框架将自己的实现添加到JUnit中. 总览 建立 基本 建筑 ...

  8. 软件工程生命周期模型_软件生命周期模型比较| 软件工程

    软件工程生命周期模型 软件生命周期模型 (Software Lifecycle Models) There are five software lifecycle models that are co ...

  9. 软件开发生命周期中的设计阶段_什么是软件生命周期模型?软件测试和软件开发的关系分析!...

    软件生命周期这个词,对于大部分人应该比较陌生,但却不容忽视!正因为它的重要性,才有许多不同的软件开发生命周期模型,但是它们都有一个共同的特点,那就是在生命周期中的某一时刻,软件都会被测试.今天我就和大 ...

最新文章

  1. 关于ORM中只有XML没有映射实体的思考?期待大家的建议
  2. [转]Mysql Join语法解析与性能分析
  3. 爬虫+pyecharts数据分析实例:当当网
  4. 地理在计算机中的应用,计算机在地理教学中应用形式之一:适合于大班教学的演示型...
  5. Javascript闭包简单理解
  6. cad相对坐标快捷键_CAD里面绝对、相对、极坐标是什么?如何区别
  7. VC MakeUp 操作XML
  8. TrueCrypt编译记录
  9. creo扫描选择多条链作为轨迹_Creo与Proe可变截面扫描关系式雨伞建模实例-一加一学院...
  10. Ubuntu20安装RTL8811/RTL8812无线网卡驱动
  11. css多棱柱立体旋转
  12. 开心农场违规 恐面临关停危险
  13. 向量的加减(运算符重载)
  14. 目的路径太长如哈删除_文件名超长导致文件无法删除怎么办?
  15. 【实战技能】非技术背景经理的技术管理
  16. win10平板模式_win10电脑投屏到手机
  17. 计算机速录教程,亚伟中文速录机培训教程(60版).doc
  18. 2022夏PAT甲级题解 by小柳2022.6.7
  19. SPFA 跑得快,跑得快。最小花费问题
  20. VMware虚拟机NAT模式下连不上网

热门文章

  1. Java中的ThreadPoolExecutor类
  2. Java的系统Property
  3. vue中设置子组件的点击事件不影响父组件的点击事件
  4. 第四章使用jQuery操作DOM元素
  5. python的三元运算
  6. 三条中线分的六个三角形_八年级数学上册:三角形已知两条边如何求第三边
  7. spingmvc 通过xml配置redis jedispol 有密码 通过xml配置redis中的 jedispool(有密码)
  8. IntelliJ IDEA 项目结构旁边出现 0%methods,0% lines covered 解决
  9. Spring中@Autowired、@Qualifier、@Resource的区别
  10. springboot2.5.5配置druid数据源1.2.8与jdbc