日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

comparator 多个条件控制_JUnit5学习之四:按条件执行

發(fā)布時間:2024/7/19 编程问答 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 comparator 多个条件控制_JUnit5学习之四:按条件执行 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

歡迎訪問我的GitHub

https://github.com/zq2599/blog_demos

內(nèi)容:所有原創(chuàng)文章分類和匯總,及配套源碼,涉及Java、Docker、Kubernetes、DevOPS等;

本篇概覽

本文是《JUnit5學(xué)習(xí)》系列的第四篇,有時咱們希望測試方法僅在一定條件下才執(zhí)行,例如有的測試方法只適合Linux環(huán)境,這就是按條件執(zhí)行的需求,本篇的主要內(nèi)容就是學(xué)習(xí)如何為測試方法設(shè)置前提條件,只有滿足了這些條件測試才會被執(zhí)行,本篇大綱如下:

  • 自定義測試方法的執(zhí)行順序
  • 按操作系統(tǒng)設(shè)置條件
  • 按JAVA環(huán)境設(shè)置條件
  • 按系統(tǒng)屬性設(shè)置條件
  • 按環(huán)境變量設(shè)置條件
  • 自定義條件
  • 源碼下載

    如果您不想編碼,可以在GitHub下載所有源碼,地址和鏈接信息如下表所示(
    https://github.com/zq2599/blog_demos):

    • 這個git項(xiàng)目中有多個文件夾,本章的應(yīng)用在junitpractice文件夾下,如下圖紅框所示:
    • junitpractice是父子結(jié)構(gòu)的工程,本篇的代碼在conditional子工程中,如下圖:

    自定義測試方法的執(zhí)行順序

    今天要寫的測試方法很多,為了管理好這些方法,在學(xué)習(xí)按條件執(zhí)行之前先來看看如何控制測試方法的執(zhí)行順序:

    • 給測試類添加注解TestMethodOrder,注解的value是OrderAnnotation.class
    • 給每個測試方法添加Order注解,value值是數(shù)字,越小的value越優(yōu)先執(zhí)行
    • 使用方法如下圖所示:
    接下來的實(shí)戰(zhàn)中,咱們就用上述方法控制測試方法的執(zhí)行順序;

    按操作系統(tǒng)設(shè)置條件

    • 注解EnabledOnOs指定多個操作系統(tǒng),只有當(dāng)前操作系統(tǒng)是其中的一個,測試方法才會執(zhí)行;
    • 注解DisabledOnOs指定多個操作系統(tǒng),只要當(dāng)前操作系統(tǒng)是其中的一個,測試方法就不會執(zhí)行;
    • 測試代碼如下:
    @Test @Order(1) @EnabledOnOs(OS.WINDOWS) @DisplayName("操作系統(tǒng):只有windows才會執(zhí)行") void onlyWindowsTest() { assertEquals(2, Math.addExact(1, 1)); } @Test @Order(2) @EnabledOnOs({OS.WINDOWS, OS.LINUX}) @DisplayName("操作系統(tǒng):windows和linux都會執(zhí)行") void windowsORLinuxTest() { assertEquals(2, Math.addExact(1, 1)); } @Test @Order(3) @DisabledOnOs({OS.MAC}) @DisplayName("操作系統(tǒng):只有MAC才不會執(zhí)行") void withoutMacTest() { assertEquals(2, Math.addExact(1, 1)); }
    • 我這里是windows操作系統(tǒng),上述三個方法執(zhí)行結(jié)果如下:

    按JAVA環(huán)境設(shè)置條件

    • 注解EnabledOnJre指定多個JRE版本,只有當(dāng)前JRE是其中的一個,測試方法才會執(zhí)行;
    • 注解DisabledOnJre指定多個JRE版本,只要當(dāng)前JRE是其中的一個,測試方法就不會執(zhí)行;
    • 注解EnabledForJreRange指定JRE版本的范圍,只有當(dāng)前JRE在此范圍內(nèi),測試方法才會執(zhí)行;
    • 注解DisabledForJreRange指定JRE版本的范圍,只要當(dāng)前JRE在此范圍內(nèi),測試方法就不會執(zhí)行;
    • 測試代碼如下:
    @Test @Order(4) @EnabledOnJre({JRE.JAVA_9, JRE.JAVA_11}) @DisplayName("Java環(huán)境:只有JAVA9和11版本才會執(zhí)行") void onlyJava9And11Test() { assertEquals(2, Math.addExact(1, 1)); } @Test @Order(5) @DisabledOnJre({JRE.JAVA_9}) @DisplayName("Java環(huán)境:JAVA9不執(zhí)行") void withoutJava9Test() { assertEquals(2, Math.addExact(1, 1)); } @Test @Order(6) @EnabledForJreRange(min=JRE.JAVA_8, max=JRE.JAVA_11) @DisplayName("Java環(huán)境:從JAVA8到1之間的版本都會執(zhí)行") void fromJava8To11Test() { assertEquals(2, Math.addExact(1, 1)); }1234567891011121314151617181920212223
    • 我這里是JDK8,執(zhí)行結(jié)果如下:

    按系統(tǒng)屬性設(shè)置條件

    • 注解EnabledIfSystemProperty指定系統(tǒng)屬性的key和期望值(模糊匹配),只有當(dāng)前系統(tǒng)有此屬性并且值也匹配,測試方法才會執(zhí)行;
    • 注解DisabledIfSystemProperty指定系統(tǒng)屬性的key和期望值(模糊匹配),只要當(dāng)前系統(tǒng)有此屬性并且值也匹配,測試方法就不會執(zhí)行;
    • 測試代碼如下:
    @Test @Order(7) @EnabledIfSystemProperty(named = "os.arch", matches = ".*64.*") @DisplayName("系統(tǒng)屬性:64位操作系統(tǒng)才會執(zhí)行") void only64BitArch() { assertEquals(2, Math.addExact(1, 1)); } @Test @Order(8) @DisabledIfSystemProperty(named = "java.vm.name", matches = ".*HotSpot.*") @DisplayName("系統(tǒng)屬性:HotSpot不會執(zhí)行") void withOutHotSpotTest() { assertEquals(2, Math.addExact(1, 1)); }
    • 上述測試方法執(zhí)行結(jié)果如下:

    按環(huán)境變量設(shè)置條件

    • 注解EnabledIfEnvironmentVariable指定環(huán)境變量的key和期望值(模糊匹配),只有當(dāng)前系統(tǒng)有此環(huán)境變量并且值也匹配,測試方法才會執(zhí)行;
    • 注解DisabledIfEnvironmentVariable指定環(huán)境變量的key和期望值(模糊匹配),只要當(dāng)前系統(tǒng)有此環(huán)境變量并且值也匹配,測試方法就不會執(zhí)行;
    • 測試代碼如下:
    @Test @Order(9) @EnabledIfEnvironmentVariable(named = "JAVA_HOME", matches = ".*") @DisplayName("環(huán)境變量:JAVA_HOME才會執(zhí)行") void onlyJavaHomeExistsInEnvTest() { assertEquals(2, Math.addExact(1, 1)); } @Test @Order(10) @DisabledIfEnvironmentVariable(named = "GOPATH", matches = ".*") @DisplayName("環(huán)境變量:有GOPATH就不執(zhí)行") void withoutGoPathTest() { assertEquals(2, Math.addExact(1, 1)); }
    • 上述測試方法執(zhí)行結(jié)果如下:

    自定義條件(從junit5.7版本開始)

    • 前面的條件注解很豐富,但終究是固定、有限的,無法滿足所有場景,它們不夠用時,咱們還可以自定義前提條件,即EnabledIfDisabledIf注解;
    • 有兩個關(guān)鍵點(diǎn)要格外注意,首先是EnabledIf和DisabledIf的package,注意是org.junit.jupiter.api.condition,不要用這個:org.springframework.test.context.junit.jupiter.EnabledIf,一旦用錯,執(zhí)行測試時會拋出異常;
    • 第二個要注意的是EnabledIf和DisabledIf對應(yīng)的junit版本,它們是從5.7版本版本才開始的,而本文用的SpringBoot版本是2.3.4.RELEASE,間接依賴的junit版本是5.6.2,因此,必須在pom.xml中做下圖紅框中的修改,將間接依賴去掉,并主動依賴5.7.0,才能將junit從5.6.2升級到5.7,這樣才能用上EnabledIf和DisabledIf:
    • EnabledIf的用法很簡單,value是個存在的方法的名字,該方法必須返回boolean類型,demo如下,customCondition是個很簡單的方法,被用來做是否執(zhí)行單元測試的判斷條件:
    boolean customCondition() { return true; } @Test @Order(11) @EnabledIf("customCondition") @DisplayName("自定義:customCondition返回true就執(zhí)行") void onlyCustomConditionTest() { assertEquals(2, Math.addExact(1, 1)); } @Test @Order(12) @DisabledIf("customCondition") @DisplayName("自定義:customCondition返回true就不執(zhí)行") void withoutCustomConditionTest() { assertEquals(2, Math.addExact(1, 1)); }
    • 上述測試方法執(zhí)行結(jié)果如下:
    • 前面的代碼中,EnabledIf和DisabledIf注解被用來修飾方法,其實(shí)它們還可以修飾類,用于控制整個類是否執(zhí)行單元測試,不過修飾類的時候,對應(yīng)的自定義方法必須是static類型;
    • 前面的代碼中,customCondition方法和使用它的EnabledIf注解在同一個類中,其實(shí)它們也可以在不同的類中,不過此時EnabledIf注解的value要給出:包名、類名、方法名,如下所示,注意類名和方法名之間的連接符是#
    @Test @Order(12) @DisabledIf("com.example.Conditions#customCondition") @DisplayName("自定義:customCondition返回true就不執(zhí)行") void withoutCustomConditionTest() { assertEquals(2, Math.addExact(1, 1)); }
    • 以上就是常用的按條件執(zhí)行單元測試的各種實(shí)例了,希望本文能給您提供參考,助您在各種場景更加精確的控制用例的執(zhí)行邏輯;

    歡迎關(guān)注我的公眾號:程序員欣宸

    總結(jié)

    以上是生活随笔為你收集整理的comparator 多个条件控制_JUnit5学习之四:按条件执行的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。