2月初, JUnit 5(又名JUnit Lambda)团队发布了一个alpha版本。 由于JUnit 4是我工具箱中使用最频繁的项目之一,因此我认为值得一看下一个主要版本。

我试用了最新版本,并记下了我在这里发现值得注意的更改。

安装JUnit 5

不用说,一个名为JUnit Lambda的项目需要Java 1.8或更高版本。 如果给出了,那么包括库就很简单了。 可从Sonatype的快照存储库( https://oss.sonatype.org/content/repositories/snapshots/org/junit/ )获取当前Alpha发布通道的最新版本。

可以使用Maven和Gradle消耗工件。 如果您希望手动维护依赖性,那么还有一个可用的zip发行版 ,其中包含编译和运行JUnit 5的所有内容。

在开发时,仅依赖org.junit:junit5-api模块就足够了。

请注意,在指定快照存储库时,应将其配置为从不缓存工件,以便始终使用最新版本。

从JUnit 4减轻负担

据我所知,新版本是对库的完全重写,对旧版本没有任何依赖性。 因此,您可以享受传统的免费测试(至少一段时间;-)。

但是,当然有一条迁移路径可以使两个版本共存,并使您能够在使用JUnit 5编写新测试的同时维护现有的测试代码库。

相同但不同

但是,让我们最后来看一下JUnit 5测试的样子。 乍一看,变化不大。 一个简单的测试课程…

class FirstTests {@Testvoid firstTest() {fail();}
}

…与JUnit 4测试几乎没有区别。

但是,您发现细微的差别了吗? 是的,测试不再需要公开,但是如果您愿意,当然可以。

尽管注释仍用于标识设置和拆除测试环境的方法,但其名称已更改。 @BeforeClass/AfterClass现在是@BeforeAll/AfterAll@Before/After现在是@BeforeEach/AfterEach

使用@Disabled批注仍然可以忽略测试。

@Test与@Test

如您所见,测试仍然使用@Test注释标记。 但是要小心,如果您碰巧在类路径上也有JUnit 4。 JUnit 5带来了自己的@Test批注,因此请确保导入正确的org.junit.gen5.api.Test 。 否则,JUnit 5测试运行程序将找不到您的测试。

需要注意的另一件事是新的@Test注释不提供其他服务。 如果你曾经使用timeoutexpected不时,你将需要更换他们的JUnit 5。

使用JUnit 5运行测试

难怪还没有IDE支持可以运行JUnit 5测试。 因此,我使用ConsoleRunner来执行实验。 以这种方式运行测试还需要三个模块:

  • org.junit:junit5-engine
  • org.junit:junit-launcher
  • org.junit:junit-console

我选择的IDE是Eclipse,为了从那里使用ConsoleRunner运行测试,我不得不手动扩展启动配置的Classpath 。 仅在添加包含已编译测试的test-classes输出文件夹之后,它们才会被拾取。 但是,这种怪异也可能是由于我对Maven的了解不足,或者是由于Eclipse Maven集成中的特殊性。

JUnit 5团队还提供了基本的插件来执行Maven和Gradle构建中的测试。 如果您想尝试一下,请参阅“ 构建支持”一章。

断言

乍一看,断言没有太大变化,只是断言现在位于org.junit.gen5.api.Assertions类中。

但是仔细观察发现, assertThat()已消失,并且不幸的是,它依赖于Hamcrest。 这些方法实际上复制了MatcherAssert提供的API,并将以前的JUnit版本绑定到Hamcrest库。 这种依赖性有时会导致类解析冲突。 特别是与其他库一起使用时,更糟糕的是,它们会自己包含Hamcrest的副本。

另一个更改是新的assertAll()方法,该方法用于对断言进行分组。 例如

assertAll( "names", () -> {assertEquals( "John", person.getFirstName() );assertEquals( "Doe", person.getLastName() );
} );

将报告一个MultipleFailuresError其中包含组中所有失败的断言。

然后,测试执行者有责任以适当的方式显示此故障。 但是,当前的ConsoleRunner实现尚未考虑分组故障,仅报告第一个故障:

Finished:    testNames [junit5:com...GroupAssertionsTest#testNames()]=> Exception: names (1 failure)expected: <John> but was: <Mary>

我的第一个未经过滤的想法是,如果需要对断言进行分组,则可能是将代码分成多个测试的标志。 但是我还没有真正使用分组的断言,并且在某些地方也完全可以使用它们。

测试异常

测试异常已经统一。 要更换expectedExpectedException现在有一个expectThrows断言评估lambda表达式,并验证它抛出指定类型的异常。

例如,

@Test
void testException() {Foo foo = new Foo();Throwable exception = expectThrows( IllegalStateException.class, foo::bar );assertEquals( "some message", exception.getMessage() );
}

…如果调用foo::bar()没有抛出IllegalStateException将失败。 否则,将返回抛出的异常,并且可以对其进行进一步验证。 如果抛出的异常assertThrows() ,则还有一个assertThrows()方法返回void。

再见亚军,规则和ClassRule

JUnit 5不再知道运行器,规则或类规则。 这些部分竞争的概念已由单个一致的扩展模型代替。

可以通过@ExtendWith注释测试类或测试方法来声明性地使用扩展。 例如,希望使用模拟实例初始化某些字段的测试可以使用Mockito扩展,如下所示:

@ExtendWith(MockitoExtension.class)
class MockedTest {@MockPerson person;// ...}

如果您对这个主题感兴趣,请继续关注有关扩展以及如何将现有规则迁移到我计划编写的自定义扩展的单独文章。

测试方法参数

在JUnit 5中,现在允许方法具有参数。 这允许在方法级别注入依赖项。

为了提供参数,所谓的解析器是必需的,它是实现MethodParameterResolver的扩展。 与所有其他扩展一样,要将解析器用于给定的方法或类,则需要使用@ExtendWith进行声明。 还有两个不需要明确声明的内置解析器。 它们提供类型为TestInfoTestReporter参数。

例如:

class MethodParametersTest {@Test// implicitly uses TestInfoParameterResolver to provide testInfovoid testWithBuiltIntParameterResolver( TestInfo testInfo ) {// ...}@Test@ExtendWith( CustomEnvironmentParameterResolver.class )// explicit resolver declared, could also be placed at class levelvoid testWithCustomParameterResolver( CustomEnvironment environment ) {// ...}
}

如果在运行时找不到匹配的参数解析器,则引擎将通过相应的消息使测试失败。

该文档指出,有计划提供其他扩展,其中还包括一个用于动态测试注册的扩展。 有了这个扩展,就有可能进行参数化测试。 考虑到测试方法已经接受了参数,参数化测试似乎也可以在方法级别上使用。

向后兼容

为了缩小差距,直到IDE本地支持JUnit 5为止,有一个JUnit 4 Runner能够执行为JUnit 5编写的测试。使用@RunWith(JUnit5.class)批注来运行测试类和测试套件。

通过该运行器,可以并排运行JUnit 4和5测试类。 在单个测试中混合使用新旧概念当然是超出范围的,例如,将@Rule@ExtendWith等共存。

Mockito和AssertJ等测试实用程序将继续使用新版本,而无需进行更改。 他们通过引发一个异常来与JUnit交互,即使在JUnit 5中,该异常仍然被认为是测试失败:)

JVM开放测试联盟

JUnit Lambda团队还为JVM建立了开放测试联盟 ,其目标是建立一个标准,以促进测试框架,断言库,模拟库,构建工具和IDE之间的交互。

主要目标是提供一个库,该库定义测试框架(例如JUnit,TestNG,Spock等)要使用的一组通用异常,以及断言库。 构建工具和IDE也将受益,因为它们可以依赖相同的类型集,而与测试框架无关。

可以以org.opentest4j库的形式获得实现草案,您可以猜到它是JUnit 5使用的。

外表

我的印象是建立了新版本的基本概念。 诸如@Test,设置和拆卸注释之类的东西,单个扩展模型的概念可能仍将保持其当前形状。

但是许多细节似乎尚未解决,API可能会发生变化,我认为这在开发周期的现阶段是可以理解的。 API的每个部分都标有@API注释 ,以指示其稳定性。

如果这篇文章引起了您的兴趣,并且您可能希望浏览文档以获取更多信息,那么还有很多值得探索的地方,例如:

  • 用于过滤测试执行的标签
  • 嵌套测试以对测试进行分组并表达测试组之间的关系
  • 可扩展的思路进行测试验证规则 (如@Test@BeforeEach不应该在同样的方法进行)
  • 在运行时动态注册测试
  • 注释有助于并行运行测试

第一个里程碑计划于2016年第一季度末发布。 此处提供了此发行版要解决的暂定项目列表。

翻译自: https://www.javacodegeeks.com/2016/02/junit-5-first-look-next-generation-junit.html

JUnit 5 –下一代JUnit的初步了解相关推荐

  1. junit5和junit4_JUnit 5 –下一代JUnit的初步了解

    junit5和junit4 2月初, JUnit 5(又名JUnit Lambda)团队发布了一个alpha版本. 由于JUnit 4是我工具箱中使用最多的项目之一,因此我认为值得一看下一个主要版本. ...

  2. java 计算器 junit测试_Java Junit测试

    使用junit做测试目的是尽量早的发现程序的bug,一个bug隐藏的时间越久,修复他的代价就越大. 1.Junit简介: Junit最初是由Erich Gamma 和 Kent Beck 编写的一个回 ...

  3. junit junit_穿越JUnit流

    junit junit 关于JUnit 5迁移的好处之一是,您可以在老式模式下运行JUnit 4测试,并且所有内容仍然兼容. 不利的一面是,某些注释和方法在JUnit 4和JUnit 5中具有相同的名 ...

  4. junit junit_使用junit做其他事情

    junit junit junit!=单元测试 Junit是Java单元测试框架. 通常,我们将它用于单元测试,但是很多时候我们也使用它来执行集成测试. 主要区别在于,单元测试测试单个单元,而集成测试 ...

  5. junit runner_了解JUnit的Runner架构

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

  6. JUnit 4 与 JUnit 3

    JUnit 是 Java? 语言事实上的 标准单元测试库.JUnit 4 是该库三年以来最具里程碑意义的一次发布.它的新特性主要是通过采用 Java 5 中的标记(annotation)而不是利用子类 ...

  7. JUnit 4和JUnit 5区别

    特征 JUNIT 4 JUNIT 5 声明一种测试方法 @Test @Test 在当前类中的所有测试方法之前执行 @BeforeClass @BeforeAll 在当前类中的所有测试方法之后执行 @A ...

  8. maven安装junit_JUnit安装Maven – JUnit 4和JUnit 5

    maven安装junit JUnit 4 and JUnit 5 are completely different frameworks. They both serve the same purpo ...

  9. junit5和junit4_JUnit声明异常– JUnit 5和JUnit 4

    junit5和junit4 We can test expected exceptions using JUnit 5 assertThrows assertion. This JUnit asser ...

最新文章

  1. Linux-makefile
  2. 【EXLIBRIS】二十唯识白话译本【ZZ】
  3. redis 的bitmap 开源包 bitmapist的应用
  4. Java里面的静态代码块
  5. 非法控制计算机信息系统罪的标准,非法获取计算机信息系统数据、非法控制计算机信息系统罪立案标准...
  6. Maven多工程项目
  7. RiskSense Spotlight:全球知名开源软件漏洞分析报告
  8. git21天打卡day12切换分支修改文件
  9. 最全加密算法之对称加密和非对称加密
  10. VIP视频会员,无限制看剧对人的自制力,产生了严重的考验和折磨
  11. 太极拳透劲的原理推测
  12. 解决Extraneous non-props attributes (border, class) were passed to component but could not be
  13. IDcard 验证代码----新身份证合法性验证
  14. 测试用例设计方法(转)
  15. 官网购买的个人版 ArcGIS Pro安装授权问题汇总(持续更新)
  16. LINUX IP 路由实现
  17. 苹果手机图片黑白互换_苹果与3周显卡互换
  18. ARP request或reply包丢失导致速率下降优化
  19. FCC JavaScript 算法和数据结构 正则表达式
  20. 计算机应用离线作业,计算机应用基础离线作业

热门文章

  1. 阿里巴巴对Java编程【集合处理】的规约
  2. 对ASCALL码的理解
  3. 使用jQuery操作DOM元素
  4. JSP的四大作用域和九大内置对象
  5. React中父子组件之间的通信
  6. 2019蓝桥杯省赛---java---C---9(等差数列)
  7. 2019蓝桥杯省赛---java---C---6(旋转)
  8. mysql 删除过期日志_【转】对mysql日志进行操作的总结包括 启用,过期自动删除 等...
  9. php access allow,PHP标头不适用于Access-Control-Allow-Origin
  10. 如何获得即时编译器(JIT)的汇编代码(linux环境下)