SpringBoot詳細講解斷言機制原理
JUnit 5 內(nèi)置的斷言可以分成如下幾個類別:
1.簡單斷言
用來對單個值進行簡單的驗證。如:
| 方法 | 說明 |
|---|---|
| assertEquals | 判斷兩個對象或兩個原始類型是否相等 |
| assertNotEquals | 判斷兩個對象或兩個原始類型是否不相等 |
| assertSame | 判斷兩個對象引用是否指向同一個對象 |
| assertNotSame | 判斷兩個對象引用是否指向不同的對象 |
| assertTrue | 判斷給定的布爾值是否為 true |
| assertFalse | 判斷給定的布爾值是否為 false |
| assertNull | 判斷給定的對象引用是否為 null |
| assertNotNull | 判斷給定的對象引用是否不為 null |
JTest5
package com.limi.springboottest2;
import org.junit.jupiter.api.*;
import org.springframework.boot.test.context.SpringBootTest;
import static org.junit.jupiter.api.Assertions.*;
@SpringBootTest
public class JTest5 {
@Test
public void simple() {
assertEquals(3, 1 + 2, "simple math");
System.out.println(1);
assertNotEquals(3, 1 + 1);
System.out.println(2);
assertNotSame(new Object(), new Object());
System.out.println(3);
Object obj = new Object();
assertSame(obj, obj);
System.out.println(4);
assertFalse(3 > 2);
System.out.println(5);
assertTrue(1 < 2);
System.out.println(6);
assertNull(null);
System.out.println(7);
assertNotNull(new Object());
System.out.println(8);
}
}斷言判斷為假, 程序拋出異常后立即終止運行, 余下的代碼都不會被執(zhí)行.

2.數(shù)組斷言
通過 assertArrayEquals 方法來判斷兩個對象或原始類型的數(shù)組是否相等。
//不相等拋出異常
@Test
public void array() {
assertArrayEquals(new int[]{1, 2}, new int[] {1, 2, 3});
}

3.組合斷言
assertAll()方法接受多個 org.junit.jupiter.api.Executable 函數(shù)式接口的實例作為要驗證的斷言,可以通過 lambda 表達式很容易的提供這些斷言。
//除非填寫的斷言都為真, 否則拋出異常
@Test
public void all() {
assertAll("Math",
() -> assertEquals(2, 1 + 1),
() -> assertTrue(1 > 5),
() -> assertNotNull(null)
);
}

注意看, 第二個斷言為假,仍然會執(zhí)行第三個斷言, 也就是說assertAll()方法b內(nèi)填寫的斷言都會被執(zhí)行判斷
4.異常斷言
在JUnit4時期,想要測試方法的異常情況時,需要用@Rule注解的ExpectedException變量還是比較麻煩的。而JUnit5提供了一種新的斷言方式Assertions.assertThrows(),配合函數(shù)式編程就可以進行使用。
@Test
public void exceptionTest() {
ArithmeticException exception = Assertions.assertThrows(
//當(dāng)沒有異常時, 扔出斷言異常
ArithmeticException.class, () -> System.out.println(5/ 2));
}

5.超時斷言
JUnit5還提供了Assertions.assertTimeout()為測試方法設(shè)置了超時時間。
@Test@DisplayName("超時測試")public void timeoutTest() {
//如果測試方法執(zhí)行時間超過設(shè)置的時間將會拋出異常
Assertions.assertTimeout(Duration.ofMillis(1000), () -> Thread.sleep(5000));
}

6.快速失敗
通過 fail 方法直接使得測試失敗, 該斷言后續(xù)代碼不會執(zhí)行
@Test
public void shouldFail() {
System.out.println("123456");
fail("This should fail");
System.out.println("888888");
}
到此這篇關(guān)于SpringBoot詳細講解斷言機制原理的文章就介紹到這了,更多相關(guān)SpringBoot斷言機制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring Cloud之遠程調(diào)用OpenFeign參數(shù)傳遞
本文介紹了Spring Cloud中使用OpenFeign進行遠程調(diào)用時,參數(shù)傳遞的不同方式,包括傳遞單個參數(shù)、多個參數(shù)、對象和JSON數(shù)據(jù),感興的朋友一起看看吧2025-03-03
MyBatisPlus?TypeHandler自定義字段類型轉(zhuǎn)換Handler
這篇文章主要為大家介紹了MyBatisPlus?TypeHandler自定義字段類型轉(zhuǎn)換Handler示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-08-08
使用ResponseEntity作為的返回值的應(yīng)用
這篇文章主要介紹了使用ResponseEntity作為的返回值的應(yīng)用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07
SpringBoot使用編程方式配置DataSource的方法
這篇文章主要介紹了SpringBoot使用編程方式配置DataSource的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-01-01
mybaties plus實體類設(shè)置typeHandler不生效的解決
這篇文章主要介紹了mybaties plus實體類設(shè)置typeHandler不生效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08

