关于java:JUnit5教程1JUnit5架构和第一个测试示例

37次阅读

共计 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-jupiterjunit-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 不同的注解的应用办法。

正文完
 0