JUnit 5 –架构

现在我们知道如何设置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,因此它们可以与测试执行交互,例如,通过启动单个测试并显示其结果。

有道理吧?

junit-5体系结构

我们的一线开发人员将看不到大多数这种结构。 我们的项目只需要测试对我们正在使用的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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/354642.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端程序员书桌上不可缺少的CSS书籍

作为前端,CSS不仅要会,而且要精通,随着各种浏览器规范参差不齐和网页交互多元化的趋势越来越复杂,前端程序员必须要将CSS基础知识打牢。由于现在的框架越来越多,导致很大一部分程序员的工作只是拿着现成的组件布局&…

nodejs 进阶:图片缩小

demo 效果: 代码: /*** Created by ZXW on 2017/10/30.*/ var fs require(fs); var gm require(gm);gm(./不饿.jpg).resize(50, 50,"!").write(./不饿1.jpg, function (err) {if (!err) console.log(done);});2017-10-30 22:10:46转载于:ht…

可能是最先出来的关于介绍使用Vue3的一本书

Vue3 release版本已发布有几个月了,不少公司都已经开始使用vue3开发项目了,市场上的主流的框架如:Vant,Element UI,Taro也都发布了支持Vue3的版本。Vue3很多的开发优势自不必再说,学习上手vue3已经成为每个…

CSGL

glShadeModel void glShadeModel(GLenum mode) GL_FLAT/【GL_SMOOTH】 着色技术选择 glClearDepth GL.glClearDepth(depth); glClearDepth:设置深度缓存的清除值 参数 depth 指定清除深度缓存时使用的深度值。 说明 本函数指定用glClear清除深度缓存时所使用的深度值…

强大的Canvas开源库Fabric.js简介与开发指南

什么是Fabric.js?Fabric.js 是一个强大且简单的Javascript HTML5 Canvas库。官网地址:http://fabricjs.com/为什么要使用Fabric.js?Canvas提供一个好的画布能力, 但是Api不够友好。绘制简单图形其实还可以, 不过做一些复杂的图形绘制, 编写一…

模拟qq斗地主-准备发牌抢地主都是农民下一轮准备

为什么要搞这样一个项目?? 1,满足自己的java网络多线程编程的欲望!因为之前一直都是搞web开发,服务器和客户端数据交流人家web服务器早就给你搞好了,比如tomcat,jetty...等等,其实之前脑子里就有…

rube3xxx_Rube GoldbergSpring整合

rube3xxxSpring Integration为集成系统所涉及的一些复杂性提供了非常好的抽象-Spring Integration从Integration的角度完美地满足了Facade的定义-简化了对复杂基础系统的访问。 为了说明这一点,请考虑一个简单的系统,该系统仅接收一条消息,然…

纯CSS实现React Logo图形,内含详细解析

以上是将要实现的效果&#xff0c;Javascript框架React的Logo图形&#xff0c;首先我们来拆解下&#xff0c;它包括三个交叉的椭圆和中间一个圆点&#xff0c;所以我们Html元素可以用以下代码实现&#xff1a;<div class"main"><div class"ellipse ell…

二次优化大招(由泰勒公式推出最值条件)

经过前两篇的铺垫&#xff0c;这一篇迎来了高潮。先说一句&#xff1a;特征值大法好&#xff01; 在开始正文之前&#xff0c;先看以下简单的推导 有了这些&#xff0c;理解下面的泰勒公式推出最值条件就容易了 转载于:https://www.cnblogs.com/Mr-ZeroW/p/7764916.html

前端自动化测试浅析

前言&#xff1a;测试简介前端常见的问题&#xff1a;修改某个模块功能时&#xff0c;其它模块也受影响&#xff0c;很难快速定位bug多人开发代码越来越难以维护不方便迭代&#xff0c;代码无法重构代码质量差增加自动化测试后&#xff1a;我们为核心功能编写测试后可以保障项目…

使用SpringData出现java.lang.AbstractMethodError

最近学习一下SpringData&#xff0c;在添加SpringData支持的时候&#xff0c;出现了这样的问题&#xff1a; SpringData需要的jar有:spring-data-jpa.jar spring-data-commons.jar slf4j-api.jar 没有添加slf4j也会出现一个异常&#xff0c;不过那个异常说的非常明确&#xf…

2021这份电子书单请收好(品类齐全)!

2021年已经快过去一个月了&#xff0c;今年的读书计划有没有安排上&#xff0c;这里有份长长的书单&#xff0c;多年的积累&#xff0c;品类齐全&#xff0c;赶快从中挑几本加入今年的读书计划里。•《货币战争2&#xff1a;金权天下》 - 宋鸿兵.mobi•《圣经》中英对照豪华版 …

在Kotlin中使用libGDX

最近&#xff0c;我一直在阅读有关不同语言的信息&#xff0c;以及它们可以为已经拥挤的软件开发人员带来什么&#xff0c;而一种语言对我来说很突出&#xff1a;Kotlin。 &#xff08; https://kotlinlang.org/ &#xff09; 这是一种相对较新的语言&#xff08;成立于2011年…

【重学JS系列】slice用法大合集

让我们回顾下slice的日常用法slice 工作原理在深入研究一些更高级的用法之前&#xff0c;让我们看一下slice方法的基础知识。如MDN文档&#xff0c;slice 是数组上的一个方法&#xff0c;它最多有两个参数:arr.slice([begin[, end]])begin从该索引处开始提取原数组中的元素,如果…

【Github开源】一站搞定各种开发文档

开发者的苦恼&#xff1a;经常要在多个API文档中切换&#xff0c;浏览器书签栏收藏各种语言相关的接口说明文档。无意中在Github上发现DevDocs[1]这个开源项目&#xff0c;它是一个把所有开发相关的文档以web的形式做了一个综合的网站&#xff0c;并提供搜索&#xff0c;离线访…

javafx 表单_JavaFX 2:创建登录表单

javafx 表单在本教程中&#xff0c;我将使用JavaFX 2和CSS设计一个外观漂亮的Login Form 。 它是经典的登录表单&#xff0c;带有用户名和密码以及登录按钮。 为了遵循本教程&#xff0c;我强烈建议您查看以下这些教程&#xff1a; Eclipse IDE中的JavaFX 2入门 JavaFX 2&…

【详细教程】教你如何使用Node + Express + Typescript开发一个应用

Express是nodejs开发中普遍使用的一个框架&#xff0c;下面要谈的是如何结合Typescript去使用。 目标 我们的目标是能够使用Typescript快速开发我们的应用程序&#xff0c;而最终我们的应用程序却是编译为原始的JavaScript代码&#xff0c;以由nodejs运行时来执行。 初始化设置…

结构型模式 适配器模式

结构型模式 适配器模式 适用于&#xff1a; 是将一个类的接口转换成客户希望的另外一个接口。使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。 /*** 结构型模式 适配器模式* Adapter模式也叫适配器模式&#xff0c;是构造型模式之一&#xff0c;通过Adapter模式可…

乐哥学AI_Python(二):Numpy索引,切片,常用函数

Numpy的索引和切片 ndarray对象的内容可以通过索引和切片查看和修改。 索引&#xff1a;ndarray对象中的元素索引基于0开始 切片&#xff1a;对数组里某个片段区域的描述 数组的切片也可以理解为原始数组的局部视图&#xff0c;都是指向内存中的原始数组&#xff0c;所以不同于…

仅使用HTML和CSS实现的标签云效果

标签云的效果在博客和网站上不难见到&#xff0c;它其实就是带有超链接的某些关键字&#xff0c;为了达到强调主题的作用。通常出现概率比较大或者受欢迎的标签文字显示比较大&#xff0c;相反的就显示的小。来源于TagCrowd.com我们就不去深入研究标签云带来的效率上的提升和可…