JUnit 5簡明教程

来源:https://www.cnblogs.com/okokabcd/archive/2022/07/13/16475909.html
-Advertisement-
Play Games

目前項目的目錄結構 簡要說明 因為項目是要分兩塊部署在不同的伺服器上的 task_producer是作為任務發佈者部署 task_customer是作為任務消費者 兩塊之前的消息通信的話,目前選用的是redis的隊列來進行的 消費者目前的代碼還沒有開始就暫時不展示了,下麵僅說明發佈者的目錄結構 cl ...


概述

寫測試用例對於開發來說有2點好處,一是開發階段寫完的功能可以快速驗證,第二就是在後期需求變動或修改BUG後可以快速測試當前改動是否帶來其它問題。下麵就瞭解一下Junit5寫測試用例。

準備

創建一個maven項目

mkdir junit5-tutorial
cd junit5-tutorial

mkdir -p src/main/java
mkdir -p src/test/java

mkdir -p src/main/resources
mkdir -p src/test/resources

# 編寫pom.xml
vi pom.xml

添加依賴

  • 引入第三方斷言庫assertj
  • 支持json測試
  • 支持xml測試

pom.xml

<?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>com.example.xxx</groupId>
    <artifactId>junit5-tutorial</artifactId>
    <version>1.0-SNAPSHOT</version>

    <name>junit5-tutorial</name>

    <url>https://www.xxx.com</url>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.source>17</maven.compiler.source>
        <maven.compiler.target>17</maven.compiler.target>
    </properties>

    <build>
        <pluginManagement>
            <plugins>
                <!-- 在這裡聲明的目的是使用指定的版本 -->
                <!-- 執行測試用例任務的插件,預設綁定test生命周期的test階段 -->
                <plugin>
                    <artifactId>maven-surefire-plugin</artifactId>
                    <version>3.0.0-M6</version>
                </plugin>
                <!-- 用來執行編譯任務的插件,預設綁定default生命周期compile階段 -->
                <plugin>
                    <artifactId>maven-compiler-plugin</artifactId>
                    <version>3.10.1</version>
                </plugin>
            </plugins>
        </pluginManagement>

    </build>

    <dependencyManagement>
        <dependencies>
            <!-- XML Unit - Dependency Management -->
            <dependency>
                <groupId>net.bytebuddy</groupId>
                <artifactId>byte-buddy</artifactId>
                <version>1.12.10</version>
            </dependency>
            <dependency>
                <groupId>net.bytebuddy</groupId>
                <artifactId>byte-buddy-agent</artifactId>
                <version>1.12.10</version>
                <scope>test</scope>
            </dependency>

            <!-- Mockito Dependency -->
            <dependency>
                <groupId>org.mockito</groupId>
                <artifactId>mockito-junit-jupiter</artifactId>
                <version>4.5.1</version>
                <scope>test</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <dependencies>

        <dependency>
            <groupId>org.assertj</groupId>
            <artifactId>assertj-core</artifactId>
            <version>3.22.0</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>io.github.classgraph</groupId>
            <artifactId>classgraph</artifactId>
            <version>4.8.146</version>
        </dependency>
        <dependency>
            <groupId>org.junit.jupiter</groupId>
            <artifactId>junit-jupiter</artifactId>
            <version>5.8.2</version>
        </dependency>

        <!-- JSON Unit - Dependencies -->
        <dependency>
            <groupId>net.javacrumbs.json-unit</groupId>
            <artifactId>json-unit-assertj</artifactId>
            <version>2.33.0</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.13.2.2</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.datatype</groupId>
            <artifactId>jackson-datatype-jsr310</artifactId>
            <version>2.13.2</version>
        </dependency>

        <!-- XML Unit - Dependencies -->
        <dependency>
            <groupId>org.xmlunit</groupId>
            <artifactId>xmlunit-assertj</artifactId>
            <version>2.9.0</version>
            <scope>test</scope>
        </dependency>

    </dependencies>
</project>

創建一個User

public record User(String name, Integer age, Boolean blocked, LocalDate birthDate) {
}

測試

測試用例命名最佳實踐

首先測試類名應該以Test結尾,測試用例名稱最好遵從以下規則

  1. 測試名稱應表達特定要求
  2. 測試名稱應包含預期的輸入或預期的結果
  3. 測試名稱應以陳述的形式

具體參考:https://osherove.com/blog/2005/4/3/naming-standards-for-unit-tests.html

斷言

@Test
@DisplayName("User should be at least 18")
void user_should_be_at_least_18() {
    // junit5 的斷言
    assertTrue(user.age() >= 18);
    // assertj 的斷言
    assertThat(user.age()).isGreaterThanOrEqualTo(18);
}

顯示名稱

測試類和測試方法可以聲明自定義顯示名稱,可以使用空格、特殊字元、甚至emojis表情符號,這些名稱會在runner和測試報告中顯示。

參數化測試

參數化測試可以用不同的參數多次運行測試。它們和普通的@Test方法一樣聲明,但是使用@ParameterizedTest註解。還必須聲明至少一個將為每次調用提供參數的來

使用@ValueSource來指定參數來源

它可以指定一個原生類型的數組,並且只能為每次調用提供一個參數

@ParameterizedTest
@ValueSource(ints = {20, 50, 80})
void test_value_source(int age) {
    assertThat(age).isGreaterThanOrEqualTo(18);
}


讀取CSV文件內容作為參數來源

它可以讓你使用classpath中的csv文件。csv文件中的每一行都會導致參數測試的一次調用

src/test/resources/friends.csv

name,age
lisa,20
hans,30
hanna,40
@ParameterizedTest
@CsvFileSource(resources = "/friends.csv", numLinesToSkip = 1)
void test_value_source_by_csv_file_source(String name, int age) {
    assertThat(age).isGreaterThanOrEqualTo(18);
}

標簽

我們可以給測試類或測試用例上面通過@Tag加標簽,執行測試的時候可以指定標簽,從而達到為測試用例分組的目的。
下麵就給測試類打上一個integration的標簽

@Tag("integration")
class User01Test {
    // ...
}

可以使用如下命令來指定要執行的測試用例:

mvn test -Dgroups="integration"

左側只執行了Running com.example.xxx.User01Test一個測試類,右側則執行了3個

總結

本文介紹瞭如何使用Junit5寫測試用例。

參考

  1. Unit test naming best practices Unit test naming best practices - Stack Overflow
  2. https://osherove.com/blog/2005/4/3/naming-standards-for-unit-tests.html
  3. AssertJ Homepage https://assertj.github.io/doc/
  4. Gradle: https://stackoverflow.com/a/64986861
  5. https://junit.org/junit5/docs/current/user-guide/#running-tests-tag-expressions
  6. further reading
  7. JUnit 5 User Guide
  8. JUnit 5 中文文檔 https://doczhcn.gitbook.io/junit5/
  9. AssertJ - fluent assertions java library
  10. Jupiter / JUnit 5 - Testcontainers
  11. awaitility/awaitility: Awaitility is a small Java DSL for synchronizing asynchronous operations (github.com)

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在我們進行前後端聯調時,往往會出現後端給到的數據在前端不能直接做渲染的情況 這個時候就需要處理後端返回的數據,轉換數據結構前端再做渲染操作 當然如果和後端關係好~也可以讓後端改成你想要的樣子 以下簡單介紹遇到過的情況和相應的處理 覺得有用的話也可以自行封裝成工具類 後端返回線性結構數據,需根據rol ...
  • @import ​ Sass 拓展了 @import 的功能,允許其導入 SCSS 或 Sass 文件。被導入的文件將合併編譯到同一個 CSS 文件中,另外,被導入的文件中所包含的變數或者混合指令 (mixin) 都可以在導入的文件中使用。 例如: public.scss $font-base-co ...
  • 在平時,我非常喜歡利用 CSS 去構建一些有意思的圖形。 我們首先來看一個簡單的例子。首先,假設我們實現一個 10x10 的格子: 此時,我們可以利用一些隨機效果,優化這個圖案。譬如,我們給它隨機添加不同的顏色: 雖然利用了隨機,隨機填充了每一個格子的顏色,看著有那麼點意思,但是這隻是一幅雜亂無章的 ...
  • 簡單的封裝一下axios請求,包含了請求前的處理,返回結果和請求異常處理 import axios from "axios"; import store from "../store.js"; //封裝axios axios.defaults.headers["Content-Type"] = "a ...
  • 本文簡介 點贊 + 收藏 + 關註 = 學會了 這次會使用css畫出一個格子背景。並且一步步分析如何實現~ 思路 直接給答案:通過2個相等的直角三角形拼接,形成一個正方形。 三角形可以使用 background-image 的漸變來實現。 html, body { margin: 0; width: ...
  • 一、初識HTML 初始基本標簽代碼解釋 點擊查看代碼 <!--DOCTYPE:告訴瀏覽器我們要使用什麼規範--> <!DOCTYPE html> <html lang="en"> <!--生成註釋快捷鍵Ctrl + / 或 command + /--> <!--head標簽代表網頁頭部--> <he ...
  • python數據類型 進位轉換 變數 常量 運算符 ...
  • Java面向對象(五) 十六、面向對象特征之三: 多態性 16.1 多態性的定義: 對象的多態性:父類的引用指向子類的對象(或子類的對象賦給父類的引用)。 可以直接應用在抽象類和介面上。 Java 引用變數有兩個類型:編譯時類型和運行時類型。 編譯時類型由聲明該變數時使用的類型決定,運行時類型由實際 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...