SpringBoot詳細講解斷言機制原理
JUnit 5 內置的斷言可以分成如下幾個類別:
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); } }
斷言判斷為假, 程序拋出異常後立即終止運行, 餘下的代碼都不會被執行.
2.數組斷言
通過 assertArrayEquals 方法來判斷兩個對象或原始類型的數組是否相等。
//不相等拋出異常 @Test public void array() { assertArrayEquals(new int[]{1, 2}, new int[] {1, 2, 3}); }
3.組合斷言
assertAll()方法接受多個 org.junit.jupiter.api.Executable 函數式接口的實例作為要驗證的斷言,可以通過 lambda 表達式很容易的提供這些斷言。
//除非填寫的斷言都為真, 否則拋出異常 @Test public void all() { assertAll("Math", () -> assertEquals(2, 1 + 1), () -> assertTrue(1 > 5), () -> assertNotNull(null) ); }
註意看, 第二個斷言為假,仍然會執行第三個斷言, 也就是說assertAll()方法b內填寫的斷言都會被執行判斷
4.異常斷言
在JUnit4時期,想要測試方法的異常情況時,需要用@Rule註解的ExpectedException變量還是比較麻煩的。而JUnit5提供瞭一種新的斷言方式Assertions.assertThrows(),配合函數式編程就可以進行使用。
@Test public void exceptionTest() { ArithmeticException exception = Assertions.assertThrows( //當沒有異常時, 扔出斷言異常 ArithmeticException.class, () -> System.out.println(5/ 2)); }
5.超時斷言
JUnit5還提供瞭Assertions.assertTimeout()為測試方法設置瞭超時時間。
@Test@DisplayName("超時測試")public void timeoutTest() { //如果測試方法執行時間超過設置的時間將會拋出異常 Assertions.assertTimeout(Duration.ofMillis(1000), () -> Thread.sleep(5000)); }
6.快速失敗
通過 fail 方法直接使得測試失敗, 該斷言後續代碼不會執行
@Test public void shouldFail() { System.out.println("123456"); fail("This should fail"); System.out.println("888888"); }
到此這篇關於SpringBoot詳細講解斷言機制原理的文章就介紹到這瞭,更多相關SpringBoot斷言機制內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 總結Junit4,Junit5,Jupiter之間的聯系
- Java單元測試工具之JUnit的使用
- 單元測試 @mock與@SpringBootTest的使用
- JUnit5常用註解的使用
- springboot集成junit編寫單元測試實戰