共计 3077 个字符,预计需要花费 8 分钟才能阅读完成。
你好啊,我是大阳。
有小伙伴编程但不进行单元测试的吗?许可我,看完这个专栏《JUnit5 教程》,进步编码调试效率,跟 bug 说拜拜。
1. JUnit5 架构
JUnit 5 是 Java 应用程序应用最宽泛的测试框架。很长一段时间以来,JUnit 始终在完满地实现它的工作。
与以前的 JUnit 版本不同,JUnit 5 由三个不同子项目的几个不同模块组成。
JUnit 5 = JUnit Platform + JUnit Jupiter + JUnit Vintage
JUnit Platform是在 JVM 上启动测试框架的根底。它还定义了 TestEngine
(测试引擎) 用于开发在平台上运行的测试框架的 API。此外,该平台还提供了一个控制台启动器,用于从命令行启动平台,并提供 JUnit 平台套件引擎(JUnit Platform Suite Engine),用于应用平台上的一个或多个测试引擎运行自定义测试套件。能够应用风行的 IDE(IntelliJ IDEA、Eclipse、NetBeans 和 Visual Studio Code)和构建工具(参见 Gradle、Maven 和 Ant)来创立你的测试示例。
JUnit Jupiter是用于在 JUnit 5 中编写测试和扩大的新编程模型和 扩大模型的组合。Jupiter 子项目提供了一个TestEngine
(测试引擎)用于在平台上运行基于 Jupiter 的测试。
JUnit Vintage提供了一个TestEngine
(测试引擎)用于在平台上运行基于 JUnit 3 和 JUnit 4 的测试。但要求 JUnit 4.12 或更高版本呈现在类门路或模块门路中。
JUnit 5 在运行时须要 Java 8(或更高版本)。
2. 第一个测试示例
2.1 依赖援用
咱们应用 maven 构建第一个 JUnit5 测试实例。首先在 maven 的 pom 文件中引入依赖:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>cn.dayangshuo</groupId>
<artifactId>cn.dayangshuo.junit5-tutorial</artifactId>
<version>1.0.0</version>
<properties>
<java.version>1.8</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<junit.jupiter.version>5.8.2</junit.jupiter.version>
<junit.platform.version>1.8.2</junit.platform.version>
</properties>
<dependencies>
<!--junit-jupiter-->
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter</artifactId>
<version>${junit.jupiter.version}</version>
<scope>test</scope>
</dependency>
<!--junit-platform-suite-->
<dependency>
<groupId>org.junit.platform</groupId>
<artifactId>junit-platform-suite</artifactId>
<version>${junit.platform.version}</version>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<source>${java.version}</source>
<target>${java.version}</target>
<encoding>${project.build.sourceEncoding}</encoding>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.22.2</version>
</plugin>
</plugins>
</build>
</project>
咱们次要引入了两个依赖 junit-jupiter 和junit-platform-suite。
其中 junit-jupiter 是由三个依赖组成,别离是:
- junit-jupiter-api:是所有外围注解所在的主模块,如 @Test、生命周期办法注解和断言。
- junit-jupiter-engine:它具备在运行时执行测试所需的测试引擎实现。
- junit-jupiter-params:参数化测试组件。
而 junit-platform-suite 模块提供的 @Suite 反对能够让 JUnitPlatform 运行器能够进行分组测试。
2.2 测试示例
第一个测试示例,首先在 main>java>cn.dayangshuo.junit5 创立简略的两数相加办法类:
package cn.dayangshuo.junit5;
/**
* @author DAYANG
*/
public class Calculator {
// 两数相加
public static int add(int a, int b) {return a + b;}
}
测试示例:
package cn.dayangshuo.junit5.tests;
import cn.dayangshuo.junit5.Calculator;
import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.Test;
/**
* @author DAYANG
*/
public class SimpleTests {
@Test
void addsTwoNumbers() {Assertions.assertEquals(2, Calculator.add(1, 1), "1 + 1 should equal 2");
}
}
好啦,这样咱们就实现了第一个 JUnit5 测试示例,接下来咱们探讨 JUnit5 测试阶段的生命周期,以及一些和 JUnit4 不同的注解的应用办法。