扩展 junit 框架

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 框架

扩展 junit 框架_JUnit 5扩展模型的生命周期相关推荐

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

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

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

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

  3. JUnit 5扩展模型的生命周期

    JUnit5最终版本即将来临 (当前是M4),我已经开始研究如何编写扩展. 在JUnit5中 ,您没有使用Runners , Rules , ClassRules等,而是只有一个Extension A ...

  4. Django框架深入了解_01(Django请求生命周期、开发模式、cbv源码分析、restful规范、跨域、drf的安装及源码初识)

    阅读目录 一.Django请求生命周期: 二.WEB开发模式: 三.cbv源码分析: 四.认识RESTful 补充知识:跨域 五.基于原生django开发restful的接口 六.drf安装.使用.A ...

  5. Spring框架学习day_01: 框架配置方式/ 管理对象的作用域/ 生命周期/ 组件扫描/ 单例模式:“懒汉式“,“饿汉式“

    1. Spring框架的作用 Spring框架的主要作用是创建对象和管理对象. 创建对象:类似于User user = new User(); 管理对象:随时可以通过Spring框架获取对象,甚至Sp ...

  6. Spring框架:三种Spring Bean生命周期技术

    当使用术语"生命周期"时,Spring的家伙指的是您的bean的构造和破坏,通常这与Spring Context的构造和破坏有关. 在某些情况下,Bean生命周期的管理不是一件容易 ...

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

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

  8. Spring 框架基础(02):Bean的生命周期,作用域,装配总结

    本文源码:GitHub·点这里 || GitEE·点这里 一.装配方式 Bean的概念:Spring框架管理的应用程序中,由Spring容器负责创建,装配,设置属性,进而管理整个生命周期的对象,称为B ...

  9. bean的作用域_Spring 框架基础(02):Bean的生命周期,作用域,装配总结

    一.装配方式 Bean的概念:Spring框架管理的应用程序中,由Spring容器负责创建,装配,设置属性,进而管理整个生命周期的对象,称为Bean对象. 1.XML格式装配 Spring最传统的Be ...

最新文章

  1. 【Code forces】63B Settlers' Training
  2. MyBatis之传入参数——parameterType
  3. UVa11039 Building designing(贪心算法)
  4. 拉格朗日乘数法学习笔记
  5. AMD Cpu 性能分析
  6. Django复习:创建与使用
  7. 异步与延迟加载JavaScript的方法
  8. 中国的城市看多了,贴贴美国的城市,肯定对你的视觉产生冲击
  9. 如何让机器像人一样多角度思考?
  10. 《Android 应用案例开发大全(第3版)》——第2章,第2.8节壁纸中的着色器开发...
  11. vi/vim 基本使用方法
  12. radl (三) (转)
  13. 京东风格的移动端Vue组件库NutUI2.0来啦
  14. php编写解一元一次方程,一元一次方程及解法
  15. 关于网络传输单位的换算
  16. 期货ios模拟交易软件
  17. 鼠标修复DoubleClickFix
  18. 物联网入门教程【下】
  19. hive--union all后无数据/少数据
  20. 将IDEA上面写的代码上传到gitee仓库保姆式教程

热门文章

  1. 排列组合十一个性质公式及证明,错排数公式及证明
  2. CF1016F:Road Projects(树形dp)
  3. P3705-[SDOI2017]新生舞会【0/1分数规划,费用流】
  4. P3914-染色计数【树形dp】
  5. P3076,jzoj3187-的士【贪心】
  6. 欢乐纪中某A and B组赛【2019.1.23】
  7. nssl1216-码灵鼠【数学】
  8. jzoj3462-休息【归并排序,逆序对】
  9. POJ2446-Chessboard【最大匹配,二分图,奇偶建图】
  10. 洛谷P1120小木棒 爆搜+剪枝