SpringBoot詳細(xì)講解斷言機(jī)制原理
JUnit 5 內(nèi)置的斷言可以分成如下幾個(gè)類別:
1.簡(jiǎn)單斷言
用來(lái)對(duì)單個(gè)值進(jìn)行簡(jiǎn)單的驗(yàn)證。如:
方法 | 說(shuō)明 |
---|---|
assertEquals | 判斷兩個(gè)對(duì)象或兩個(gè)原始類型是否相等 |
assertNotEquals | 判斷兩個(gè)對(duì)象或兩個(gè)原始類型是否不相等 |
assertSame | 判斷兩個(gè)對(duì)象引用是否指向同一個(gè)對(duì)象 |
assertNotSame | 判斷兩個(gè)對(duì)象引用是否指向不同的對(duì)象 |
assertTrue | 判斷給定的布爾值是否為 true |
assertFalse | 判斷給定的布爾值是否為 false |
assertNull | 判斷給定的對(duì)象引用是否為 null |
assertNotNull | 判斷給定的對(duì)象引用是否不為 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); } }
斷言判斷為假, 程序拋出異常后立即終止運(yùn)行, 余下的代碼都不會(huì)被執(zhí)行.
2.數(shù)組斷言
通過(guò) assertArrayEquals 方法來(lái)判斷兩個(gè)對(duì)象或原始類型的數(shù)組是否相等。
//不相等拋出異常 @Test public void array() { assertArrayEquals(new int[]{1, 2}, new int[] {1, 2, 3}); }
3.組合斷言
assertAll()方法接受多個(gè) org.junit.jupiter.api.Executable 函數(shù)式接口的實(shí)例作為要驗(yàn)證的斷言,可以通過(guò) lambda 表達(dá)式很容易的提供這些斷言。
//除非填寫(xiě)的斷言都為真, 否則拋出異常 @Test public void all() { assertAll("Math", () -> assertEquals(2, 1 + 1), () -> assertTrue(1 > 5), () -> assertNotNull(null) ); }
注意看, 第二個(gè)斷言為假,仍然會(huì)執(zhí)行第三個(gè)斷言, 也就是說(shuō)assertAll()方法b內(nèi)填寫(xiě)的斷言都會(huì)被執(zhí)行判斷
4.異常斷言
在JUnit4時(shí)期,想要測(cè)試方法的異常情況時(shí),需要用@Rule注解的ExpectedException變量還是比較麻煩的。而JUnit5提供了一種新的斷言方式Assertions.assertThrows(),配合函數(shù)式編程就可以進(jìn)行使用。
@Test public void exceptionTest() { ArithmeticException exception = Assertions.assertThrows( //當(dāng)沒(méi)有異常時(shí), 扔出斷言異常 ArithmeticException.class, () -> System.out.println(5/ 2)); }
5.超時(shí)斷言
JUnit5還提供了Assertions.assertTimeout()為測(cè)試方法設(shè)置了超時(shí)時(shí)間。
@Test@DisplayName("超時(shí)測(cè)試")public void timeoutTest() { //如果測(cè)試方法執(zhí)行時(shí)間超過(guò)設(shè)置的時(shí)間將會(huì)拋出異常 Assertions.assertTimeout(Duration.ofMillis(1000), () -> Thread.sleep(5000)); }
6.快速失敗
通過(guò) fail 方法直接使得測(cè)試失敗, 該斷言后續(xù)代碼不會(huì)執(zhí)行
@Test public void shouldFail() { System.out.println("123456"); fail("This should fail"); System.out.println("888888"); }
到此這篇關(guān)于SpringBoot詳細(xì)講解斷言機(jī)制原理的文章就介紹到這了,更多相關(guān)SpringBoot斷言機(jī)制內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot集成RabbitMQ的方法(死信隊(duì)列)
這篇文章主要介紹了SpringBoot集成RabbitMQ的方法(死信隊(duì)列),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05Spring Cloud之遠(yuǎn)程調(diào)用OpenFeign參數(shù)傳遞
本文介紹了Spring Cloud中使用OpenFeign進(jìn)行遠(yuǎn)程調(diào)用時(shí),參數(shù)傳遞的不同方式,包括傳遞單個(gè)參數(shù)、多個(gè)參數(shù)、對(duì)象和JSON數(shù)據(jù),感興的朋友一起看看吧2025-03-03MyBatisPlus?TypeHandler自定義字段類型轉(zhuǎn)換Handler
這篇文章主要為大家介紹了MyBatisPlus?TypeHandler自定義字段類型轉(zhuǎn)換Handler示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08Java實(shí)現(xiàn)復(fù)原IP地址的方法
這篇文章主要介紹了Java實(shí)現(xiàn)復(fù)原IP地址的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02使用ResponseEntity作為的返回值的應(yīng)用
這篇文章主要介紹了使用ResponseEntity作為的返回值的應(yīng)用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07SpringBoot使用編程方式配置DataSource的方法
這篇文章主要介紹了SpringBoot使用編程方式配置DataSource的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-01-01mybaties plus實(shí)體類設(shè)置typeHandler不生效的解決
這篇文章主要介紹了mybaties plus實(shí)體類設(shè)置typeHandler不生效的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08