这个 JUnit5 教程讨论了它如何适应 Java8 编码风格以及其他一些功能。 了解它与 JUnit 3 或 4 的区别。
JUnit5 是 Java 应用使用最广泛的测试框架。 长期以来,JUnit 一直在完美地完成其工作。 在这两者之间,JDK 8 带来了 Java 中非常令人兴奋的功能,最著名的是 lambda 表达式。 JUnit5 旨在适应 Java8 的编码风格以及其他一些功能,这就是为什么需要 Java8 在 JUnit5 中创建和执行测试(尽管可以执行用 JUnit 3 或 JUnit4 编写的测试以实现向后兼容) 。
Table of ContentsArchitectureInstallationAnnotationsWriting TestsTest SuitesAssertionsAssumptionsBackward CompatibilityConclusion
JUnit5 架构
由于与 JUnit4 相比,JUnit5 由来自三个不同子项目的几个不同模块组成:
JUnit5 = JUnit Platform + JUnit Jupiter + JUnit Vintage
为了能够启动 junit 测试,IDE,构建工具或插件需要包含和扩展平台 API。 它定义了TestEngine API,用于开发在平台上运行的新测试框架。
它还提供了一个控制台启动器,可以从命令行启动平台并为 Gradle 和 Maven 构建插件。
它包括用于编写测试的新编程和扩展模型。 它具有所有新的 junit 注解和TestEngine实现,以运行使用这些注解编写的测试。
其主要目的是支持在 JUnit5 平台上运行 JUnit 3 和 JUnit4 书面测试。 它具有向后兼容性。
安装
您可以在 Maven 或 Gradle 项目中使用 JUnit5,方法是至少包含两个依赖项,即 Jupiter 引擎依赖项和平台运行期依赖项。
//pom.xml<properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><maven.compiler.source>1.8</maven.compiler.source><maven.compiler.target>${maven.compiler.source}</maven.compiler.target><junit.jupiter.version>5.5.2</junit.jupiter.version><junit.platform.version>1.5.2</junit.platform.version></properties><dependencies><dependency><groupId>org.junit.jupiter</groupId><artifactId>junit-jupiter-engine</artifactId><version>${junit.jupiter.version}</version><scope>test</scope></dependency><dependency><groupId>org.junit.platform</groupId><artifactId>junit-platform-runner</artifactId><version>${junit.platform.version}</version><scope>test</scope></dependency></dependencies>//build.gradletestRuntime("org.junit.jupiter:junit-jupiter-engine:5.5.2")testRuntime("org.junit.platform:junit-platform-runner:1.5.2")
JUnit5 注解
JUnit5 提供了以下注解来编写测试。
| 注解 | 描述 |
|---|---|
@BeforeEach |
带注解的方法将在测试类中的每个测试方法之前运行。 |
@AfterEach |
带注解的方法将在测试类中的每个测试方法之后运行。 |
@BeforeAll |
带注解的方法将在测试类中的所有测试方法之前运行。 此方法必须是静态的。 |
@AfterAll |
带注解的方法将在测试类中的所有测试方法之后运行。 此方法必须是静态的。 |
@Test |
用于将方法标记为 junit 测试 |
@DisplayName |
用于为测试类或测试方法提供任何自定义显示名称 |
@Disable |
它用于禁用或忽略测试套件中的测试类或方法。 |
@Nested |
用于创建嵌套的测试类 |
@Tag |
用标签标记测试方法或测试类,以进行测试发现和过滤 |
@TestFactory |
标记方法为动态测试的测试工厂 |
在 JUnit5 中编写测试
在 JUnit4 和 JUnit5 之间,测试书写样式没有太大变化。 这是使用生命周期方法的示例测试。
import org.junit.jupiter.api.AfterAll;import org.junit.jupiter.api.AfterEach;import org.junit.jupiter.api.Assertions;import org.junit.jupiter.api.BeforeAll;import org.junit.jupiter.api.BeforeEach;import org.junit.jupiter.api.Disabled;import org.junit.jupiter.api.Tag;import org.junit.jupiter.api.Test;import com.howtodoinjava.junit5.examples.Calculator;public class AppTest {@BeforeAllstatic void setup(){System.out.println("@BeforeAll executed");}@BeforeEachvoid setupThis(){System.out.println("@BeforeEach executed");}@Tag("DEV")@Testvoid testCalcOne(){System.out.println("======TEST ONE EXECUTED=======");Assertions.assertEquals( 4 , Calculator.add(2, 2));}@Tag("PROD")@Disabled@Testvoid testCalcTwo(){System.out.println("======TEST TWO EXECUTED=======");Assertions.assertEquals( 6 , Calculator.add(2, 4));}@AfterEachvoid tearThis(){System.out.println("@AfterEach executed");}@AfterAllstatic void tear(){System.out.println("@AfterAll executed");}}
测试套件
使用 JUnit5 测试套件,您可以运行分散到多个测试类和不同包中的测试。 JUnit5 提供了两个注解:@SelectPackages和@SelectClasses以创建测试套件。
要执行套件,您将使用@RunWith(JUnitPlatform.class)。
@RunWith(JUnitPlatform.class)@SelectPackages("com.howtodoinjava.junit5.examples")public class JUnit5TestSuiteExample{}
此外,您可以使用以下注解来过滤测试包,类甚至测试方法。
@IncludePackages和@ExcludePackages过滤包@IncludeClassNamePatterns和@ExcludeClassNamePatterns过滤测试类@IncludeTags和@ExcludeTags过滤测试方法
@RunWith(JUnitPlatform.class)@SelectPackages("com.howtodoinjava.junit5.examples")@IncludePackages("com.howtodoinjava.junit5.examples.packageC")@ExcludeTags("PROD")public class JUnit5TestSuiteExample{}
阅读更多: JUnit5 测试套件
断言
断言有助于通过测试用例的实际输出来验证期望的输出。 为简单起见,所有 JUnit Jupiter 断言都是org.junit.jupiter.Assertions类中的静态方法,例如assertEquals(),assertNotEquals()。
void testCase(){//Test will passAssertions.assertNotEquals(3, Calculator.add(2, 2));//Test will failAssertions.assertNotEquals(4, Calculator.add(2, 2), "Calculator.add(2, 2) test failed");//Test will failSupplier<String> messageSupplier = ()-> "Calculator.add(2, 2) test failed";Assertions.assertNotEquals(4, Calculator.add(2, 2), messageSupplier);}
阅读更多: JUnit5 断言
假设
Assumptions类提供静态方法来支持基于假设的条件测试执行。 假设失败会导致测试中止。 通常在没有必要继续执行给定测试方法的情况下使用假设。 在测试报告中,这些测试将被标记为通过。
JUnit jupiter Assumptions类具有两个此类方法:assumeFalse()和assumeTrue()。
public class AppTest {@Testvoid testOnDev(){System.setProperty("ENV", "DEV");Assumptions.assumeTrue("DEV".equals(System.getProperty("ENV")), AppTest::message);}@Testvoid testOnProd(){System.setProperty("ENV", "PROD");Assumptions.assumeFalse("DEV".equals(System.getProperty("ENV")));}private static String message () {return "TEST Execution Failed :: ";}}
阅读更多: JUnit5 假设
JUnit 3 或 JUnit4 的向后兼容性
JUnit4 已经存在了很长时间,并且用 JUnit4 编写了许多测试。JUnitJupiter 也需要支持这些测试。 为此,开发了 JUnit Vintage 子项目。
JUnit Vintage 提供了TestEngine实现,用于在 JUnit5 平台上运行基于 JUnit 3 和 JUnit4 的测试。
总结
JUnit5 仍在开发中。 看起来如此令人兴奋且功能丰富。 现在,它可以通过第三方工具和 API 进行扩展。 作为一名测试作者,您可能不会有太大的不同,但是当您尝试扩展它或尝试开发任何 IDE 插件时,您会称赞它。
作为开发人员,您还可以考虑将测试模板添加到 Eclipse IDE 中以提高开发速度。
在评论中写下您对此 JUnit5 教程的想法。
学习愉快!
