junit5和junit4_JUnit 5 –架构

junit5和junit4

现在我们知道如何设置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-architecture

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

到目前为止,提到的项目的React还很差,即大多没有。 如果您认为这是一个好主意,则可以通过与所选框架的维护者一起提出来支持它。

反射

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

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

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

junit5和junit4

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

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

相关文章

华为配备鸿蒙系统的手机,华为P50/新平板双双来袭!全球首发鸿蒙系统:配置都非常强悍...

【12月12日讯】相信大家都知道,华为方面已经正式官宣,将会在12月16日正式推出鸿蒙系统首个手机Bate版本,但也有很多网友们担忧,华为手机在脱离了Android系统以后,鸿蒙OS系统是否真的可以击败Android系统,第…

【WebRTC---入门篇】(十八)WebRTC非音视频数据传输

WebRTC传输非音视频重要API createDataChannel options ordered 在传输非音视频的时候是否是按序到达的。 maxPacketLifeTime/maxRetransmits 最大包存活时间;最大传输次数。两者二选一 negotiated ID 唯一标识 DataChannel事件

datatable使用_使用Streamlit从简单的Python脚本创建交互式WebApp

如果有人告诉您可以使用150-200行代码创建交互式Web应用程序,该怎么办? 有趣的权利。 Streamlit为您提供了使用简单的python脚本和一些streamlit调用来创建漂亮的Web应用程序的相同机会。Streamlit是一个开放源代码框架,用于以最快的方式创建…

opengl如何画出一个球_OpenGL-Controlling and Monitoring the Pipeline

全球图形学领域教育的领先者、自研引擎的倡导者、底层技术研究领域的技术公开者,东汉书院在致力于使得更多人群具备内核级竞争力的道路上,将带给小伙伴们更多的公开技术教学和视频,感谢一路以来有你的支持。我们正在用实际行动来帮助小伙伴们…

【WebRTC---入门篇】(二十)WebRTC核心之SDP详解

SDK规范 会话层 媒体层 SDP规范相关参考 WebRTC中的SDP

junit5和junit4_JUnit 5 –条件

junit5和junit4最近,我们了解了JUnit的新扩展模型以及它如何使我们能够将自定义行为注入测试引擎。 我向你保证要看情况。 现在就开始吧! 条件允许我们在应该执行或不应该执行测试时定义灵活的标准。 它们的正式名称是“ 条件测试执行” 。 总览 本系列…

python opencv输出mp4_10分钟学会使用YOLO及Opencv实现目标检测

点击边框调出视频工具条 计算机视觉领域中,目标检测一直是工业应用上比较热门且成熟的应用领域,比如人脸识别、行人检测等,国内的旷视科技、商汤科技等公司在该领域占据行业领先地位。相对于图像分类任务而言,目标检测会更加复杂一…

捍卫者usb管理控制系统_捍卫Java

捍卫者usb管理控制系统因此,我们不时发布了一本电子书,名为“十大Java性能问题” 。 毫无例外,一些人回答了一些“问题是您正在使用Java”。 显然,Java一直在受到批评,人们已经预测了它的消亡已有一段时间了。 当然&a…

html怎么上传qq空间,qq空间怎么上传照片

当我们想要把照片上传到qq空间里,应该怎么办呢?下面就让学习啦小编告诉你空间上传照片的方法,希望对大家有所帮助。空间上传照片的方法打开QQ主界面,在主界面头像的右则有个小星星,那就是进入空间的快捷方式,点一下小…

android gridview控件使用详解_Android开发实现自定义日历、日期选择控件

点击上方蓝字关注 ??来源: wenzhihao123https://www.jianshu.com/p/a2f102c728ce前言最近项目需要日历效果,考虑用第三方的反而不太适合设计需求,修改复杂,与其这样不入自己重新写一个干净的控件。虽不是什么牛逼控件&#xff0…

HTML设置字体颜色1008无标题,如何在HTML中设置字体颜色,你知道这几种方式吗?...

color设置字体颜色在color设置字体颜色之前,我们首先了解color在css中有几种取值方式,一共有4种方式,若有不全还请在评论区告知谢谢,4种方式如下:十六进制、十进制、 英文单词、十六进制的缩写。现在让我们进入字体颜色…

gram矩阵_Skip-gram

Skip-gram标签(空格分隔):NLP一. skip-gram和cbow的对比 skip-gram与cbow相比,好处在于对于不常用的词,skip-gram的效果要更好;举个简单的例子,一个句子w1w2w3w4,window_size1;对于cbow&#xf…

C++ 11 深度学习(十五)多线程

线程创建 方式一:调用函数 #include<thread>void CreateThread() {int a100;cout<<"This is Thread: "<<a<<endl; }int main() {thread Threadone(CreateThread);//join是一种阻塞的方式&#xff0c;需要子线程处理完毕之后&#xff0c;…

计算机的好处和坏处的英语作文,电脑的利弊英语作文

电脑的利弊英语作文在学习、工作或生活中&#xff0c;大家都写过作文吧&#xff0c;通过作文可以把我们那些零零散散的思想&#xff0c;聚集在一块。那么你有了解过作文吗&#xff1f;下面是小编为大家整理的电脑的利弊英语作文&#xff0c;希望能够帮助到大家。Computer is in…

servlet容器_SpringBoot是否内置了Servlet容器?

SpringBoot是否内置了Servlet容器&#xff1f;SpringBoot内置了Servlet容器&#xff0c;这样项目的发布、部署就不需要额外的Servlet容器&#xff0c;直接启动jar包即可。SpringBoot官方文档上有一个小章节内置servlet容器支持用于说明内置Servlet的相关问题。在SpringBoot源码…

计算机专业开学要带电脑吗,大学上课要带电脑吗

大学刚开学&#xff0c;上课的时候学生们要不要带电脑呢&#xff0c;想必这个问题一直对还没进入大学的准大学生来说很困扰&#xff0c;下面是小编整理的详细内容&#xff0c;一起来看看吧&#xff01;大学上课要带电脑吗大学上课能否带电脑需要看老师的要求。大学课程书本知识…

突然讨厌做前端,讨厌代码_不要讨厌HATEOAS

突然讨厌做前端,讨厌代码或我如何学会不再担心和爱HATEOAS REST已成为实现Web服务的事实上的解决方案&#xff0c;至少已成为一种流行的解决方案。 这是可以理解的&#xff0c;因为REST在使用HTTP规范时提供了一定程度的自我文档。 它经久耐用&#xff0c;可扩展&#xff0c;并…

【WebRTC---进阶篇】(三)各流媒体服务器的比较

多人音视频架构 Mesh方案 多对多大多进行P2P,在国内P2P直连穿越会出现很大问题。 MCU方案 客户端连接后,对应每个终端都有一个模块进项上传。再将音视频进行拆分解码。进行混屏,压缩编码分别推动给每个终端。 SFU方案 sfu不进行编解码,只是进行转发。只对订阅的终端进行…

汇编 cmp_汇编复习

第一章计算机组成五部分&#xff1a;&#xff08;运算器、控制器&#xff09;、存储器、输入/输出设备↑↑ CPU ↑↑ ↑内存↑三条总线&#xff1a;控制总线、地址总线、数据总线不同进制及BCD码的转换特殊ascll ‘0’~‘9’—— 30H ~ 39H‘A’~‘F’—— 41H ~ 46H回车 —— …