现在我们知道如何设置JUnit 5并使用它编写一些测试 ,下面让我们看一下。 在本文中,我们将讨论JUnit 5架构以及采用这种方式的原因。

总览

这篇文章是有关JUnit 5的系列文章的一部分:

  • 设定
  • 基本
  • 建筑
  • 条件
  • 注射

JUnit 4

忽略Hamcrest,JUnit 4没有依赖关系,并将所有功能捆绑在一个工件中。 这完全违反了单一责任原则,它表明:开发人员,IDE,构建工具,其他测试框架,扩展; 它们都依赖于相同的工件。

在这组开发人员中,有一次是表现最出色的开发人员。 他们通常依赖于JUnit的公共API,仅此而已。

但是其他测试框架和扩展,尤其是IDE和构建工具则不同:它们深入到JUnit的内部。 非公共类,内部API甚至私有字段都不安全。 这样,它们最终取决于实现细节,这意味着JUnit维护者无法在需要时轻松更改它们,从而阻碍了进一步的开发。

当然,这些工具的开发人员并没有这样做。 为了实现我们非常重视的所有闪亮功能,他们必须使用内部功能,因为JUnit 4没有足够丰富的API来满足其要求。

JUnit Lambda团队着手使用JUnit 5使事情变得更好。

JUnit 5

分离问题

退后一步,很容易找出至少两个独立的问题:

  1. 两次写入测试的API
  2. 发现和运行测试的机制

再仔细一点看第二点,我们可能会问“哪个测试?”。 好吧,当然是JUnit测试。 “是的,但是哪个版本?” 错误……“什么样的测试?” 等待,让我……“只是ust脚的@Test注释过的旧方法? 那lambdas呢?” 好,好,闭嘴!

为了使测试的具体变体与运行它们的关注脱钩,这一点被分解:

  1. 两次写入测试的API
  2. 发现和运行测试的机制
    1. 发现和运行特定测试变体的机制(例如,JUnit 5)
    2. 协调特定机制的机制
    3. 他们之间的API

建筑

JUnit的体系结构是这种思路的结果:

junit5-api(1)
开发人员用来编写测试的API。 包含我们讨论JUnit 5基础时看到的所有注释,断言等。
junit-enginge-api(2c)
所有测试引擎都必须实现API,因此可以以统一的方式对其进行访问。 引擎可能会运行典型的JUnit测试,但实现可以运行由TestNG , Spock , Cucumber等编写的测试。
junit5-engine(2a)
运行JUnit 5测试的junit-engine-api的实现。
junit4-engine(2a)
运行用JUnit 4编写的测试的junit-engine-api的实现。这里,JUnit 4工件(例如junit-4.12 )充当开发人员针对(1)实施测试的API,但还包含如何运行测试。 该引擎可以看作是版本5的JUnit 4的适配器。
junit-launcher(2b)
使用ServiceLoader发现测试引擎的实现并安排其执行。 它为IDE和构建工具提供了API,因此它们可以与测试执行交互,例如,通过启动单个测试并显示其结果。

有道理吧?

我们的一线开发人员将看不到大多数这种结构。 我们的项目只需要测试对我们正在使用的API的依赖即可; 我们的工具将附带其他所有内容。

API生命周期

现在,关于每个人都在使用的内部API。 团队也想解决这个问题,并为其API创建了生命周期。 就在这里,直接从源进行解释:

内部
除JUnit本身外,不得用于任何其他代码。 可能被删除,恕不另行通知。
不推荐使用
如果不再使用,则可能会在下一个次要版本中消失。
实验性
旨在提供我们需要反馈的实验性新功能。
保持
适用于至少在当前主版本的下一个次要版本中不会以向后不兼容的方式更改的功能。 如果计划删除,它将首先降级为“ 已弃用”
稳定
适用于在当前主要版本中不会以向后不兼容的方式更改的功能。

公开可见的类将使用@API(usage)进行注释,其中用法是这些值之一。 按照计划,这样做可以使API调用者更好地了解他们正在进入的领域,并且团队可以自由地更改或删除不受支持的API。

开放测试联盟

不过,还有一件事。 JUnit 5体系结构使IDE和构建工具可以将其用作各种测试框架的基础(假设它们提供了相应的引擎)。 这样,工具就不必实施特定于框架的支持,而是可以统一地发现,执行和评估测试。

还是可以?

测试失败通常用异常表示,但是不同的测试框架和断言库不共享相同的集合。 取而代之的是,大多数实现自己的变体(通常扩展AssertionError或RuntimeException),这使互操作性比必要的更为复杂,并防止工具进行统一处理。

为了解决这个问题,JUnit Lambda团队拆分了一个单独的项目, 即JVM的开放测试联盟 。 这是他们的建议:

基于最近与IDE以及Eclipse,Gradle和IntelliJ的构建工具开发人员的讨论,JUnit Lambda团队正在研究一个开源项目的提案,以为在JVM上测试库提供最小的通用基础。

该项目的主要目标是使测试框架(如JUnit,TestNG,Spock等)和第三方断言库(如Hamcrest,AssertJ等)能够使用IDE和构建工具可以一致支持的一组通用异常。跨所有测试方案的方式–例如,用于一致处理失败的断言和失败的假设以及在IDE和报告中可视化测试执行。

到目前为止,所提到的项目的反应还不充分,即大多缺乏反应。 如果您认为这是一个好主意,则可以通过与所选框架的维护者一起提出来支持它。

反射

我们已经看到了JUnit 5架构如何将用于编写测试的API和用于运行测试的引擎划分为单独的部分,将引擎进一步划分为API,使用它的启动器,以及针对不同测试框架的实现。 这为用户提供了精益的工件以进行测试(因为它们仅包含API),测试框架仅需为其API实现引擎(因为其余部分由JUnit处理),并且构建工具具有稳定的启动器来协调测试执行。

本系列中有关JUnit 5的下一篇文章将讨论其可扩展性。 敬请关注!

翻译自: https://www.javacodegeeks.com/2016/04/junit-5-architecture.html

JUnit 5 –架构相关推荐

  1. JUnit 5 – 早期试用体验 – 第2篇

    \ 主要结论 \\ JUnit 5就要来了!\\t 其中包含改进的API和扩展模型将大幅完善"JUnit工具".\\t 模块化的体系结构使得"JUnit平台"可 ...

  2. 关于JUnit5 你必须知道的(一) JUnit5架构和环境搭建

    由于工作中都是使用maven来构建项目,所以下面有关环境搭建都是使用的maven(IDE使用的idea) 凡是开发对于JUnit这个框架一定都不陌生,JUnit 作为一个单元测试框架已经诞生了数十年. ...

  3. junit5和junit4_JUnit 5 –架构

    junit5和junit4 现在我们知道如何设置JUnit 5并使用它编写一些测试 ,下面让我们看一下. 在本文中,我们将讨论JUnit 5架构以及采用这种方式的原因. 总览 这篇文章是有关JUnit ...

  4. 栋的月结 | 第二回合(定期更新、动态、架构、云技术、算法、后端、前端、收听/收看、英文、书籍、影视、好歌、新奇)[含泪总结.. 憋泪分享!]

    开篇词 大家好!以下是我在 2020 年 2 月 1 日至 29 日的所见.所闻.所学和所悟. 现在,我把它们安利给你们. 定期更新 原创专栏: 一文搞定 Linux 管理员手册:既简单又深刻 官方授 ...

  5. JUnit 5 初探

    1. JUnit 和 JUnit 5 相信很多软件开发对于单元测试和Junit都不会感到陌生.JUnit 是由两位编程大师Kent Back 和 Erich Gamma 在1997年编写的Java开源 ...

  6. 栋的周评 | 第五回合(定期更新、动态、架构、云技术、算法、后端、前端、收听/收看、英文、书籍、影视、好歌、新奇)

    开篇词 大家好!以下是我在 2020 年 1 月 27 日至 2 月 2 日的所见.所闻.所学和所悟. 现在,我把它们安利给你们. 定期更新 原创专栏: 栋的周评 一文搞定 Linux 管理员手册:既 ...

  7. 【Java从0到架构师】JDBC、Spring JDBC、JUnit

    JDBC 下载 MySQL 的 JDBC 实现(jar,驱动包) JDBC 使用 Statement 的常用 API ResultSet 的常用 API PreparedStatement 配置文件 ...

  8. junit5_了解JUnit的Runner架构

    junit5 几周前,我开始创建一个小的JUnit Runner( Oleaster ),它允许您使用Jasmine方式在JUnit中编写单元测试. 我了解到,创建自定义JUnit Runners实际 ...

  9. junit runner_了解JUnit的Runner架构

    junit runner 几周前,我开始创建一个小的JUnit Runner( Oleaster ),它允许您使用Jasmine方式在JUnit中编写单元测试. 我了解到,创建自定义JUnit Run ...

最新文章

  1. github上传本地代码失败
  2. FPGA中时钟相关概念
  3. mount挂载windows共享文件夹
  4. mysql select time,MySql查询时间段的方法
  5. 《交互式程序设计 第2版》一3.5 捕获简单用户交互行为
  6. rp-provide-from-last
  7. kmp算法详解php,php中字符串匹配KMP算法实现例子
  8. 大厂测试开发常见面试题收集(python,java,性能等)
  9. 浙江省职业技能考试大纲计算机,浙江省高校计算机等级考试大纲
  10. php程序里的configini_PHP: 配置文件 - Manual
  11. WinSCP 提示:你的Shell可能与本程序不兼容(推荐使用Bash)。
  12. Voleon Group:一家『纯』用机器学习策略的对冲基金
  13. Other - 个人对知识讨论、分享等平台上抄袭乱象的看法
  14. c语言仿qq截图源码,C#实现属于自己的QQ截图工具
  15. 【硕士论文】《动态场景下的语义三维地图构建 》西南科技大学 余东应
  16. 基于Android的家庭医生app
  17. 如何打开倾斜摄影数据osgb
  18. 手游联运平台是怎样开发的?
  19. 清华大学计算机学院武永卫,清华大学计算机科学与技术系导师简介:徐明伟
  20. 施工部署主要不包括_施工部署包括什么?

热门文章

  1. Oracle入门(五D)之如何设置show parameter显示隐含参数
  2. 阿里巴巴对Java编程【异常处理】的规约
  3. java中部的分页实现(二)
  4. Servlet使用适配器模式进行增删改查案例(DeptServiceImpl.java)
  5. 最全三大框架整合(使用映射)——struts.xml和web.xml配置
  6. SpringBoot整合Shiro实现登录认证和授权CHCache
  7. Thymeleaf模板引擎---SpringBoot
  8. charles抓包ios抓拍教程
  9. kali安装python3.7_Debian服务器之安装Python3.7
  10. maven项目不编译xml文件