基于Java匯總Spock框架Mock靜態(tài)資源經(jīng)驗
前面講了 Spock框架Mock對象方法經(jīng)驗總結(jié)
一、靜態(tài)方法
Mock靜態(tài)方法我們使用PowerMock
結(jié)合Mockito
的方案,首先在測試類增加如下注解:
@RunWith(PowerMockRunner.class) @PowerMockRunnerDelegate(Sputnik.class) @PrepareForTest([NewUtil.class, HttpBase.class]) @PowerMockIgnore(["javax.management.*"]) @SuppressStaticInitializationFor(["com.funtester.util.NewUtil", "com.funtester.util.HttpBase"])
@RunWith
和@PowerMockRunnerDelegate
注解內(nèi)容不用改動,直接復制即可,@PrepareForTest
注解后面的類就是需要被Mock的類。@PowerMockIgnore這個注解用于忽略一些檢查和異常。@SuppressStaticInitializationFor
這個注解處理類的初始化,這個注解后面跟的是不需要進行初始化的類的包路徑,在現(xiàn)在的實踐中通常和@PrepareForTest
后面的類是一致的。
其次我們需要在類初始化代碼中對這個類進行Mock,語法如下:
PowerMockito.mockStatic(HttpBase.class) PowerMockito.mockStatic(NewUtil.class)
下面演示一下如何自定義靜態(tài)方法的行為:
? ? ? ? PowerMockito.when(HttpBase.fetchServiceNames()).thenReturn(["service-prod", "api-pro", "prod", "service-prd", "write-pro"])
定義靜態(tài)方法行為和非靜態(tài)方法行為,在語法上是一致的,
二、混合場景
當一個測試用例中,既要Mock靜態(tài)方法,也要Mock對象方法,就必須使用PowerMock提供的能力。原因之前提過,主要是因為增加了類注解之后,Spock
和Mockito
一的Mock對象和定義方法的功能會無法運行,這個沒找到具體的文檔做出區(qū)分,所以如果遇到混合場景,建議使用PowerMock進行對象的Mock。
使用語法上,就是混合了PowerMock
處理靜態(tài)和非靜態(tài)資源,以及行為模擬的語法。
Demo如下:
@RunWith(PowerMockRunner.class) @PowerMockRunnerDelegate(Sputnik.class) @PrepareForTest([NewUtil.class, HttpBase.class]) @PowerMockIgnore(["javax.management.*"]) @SuppressStaticInitializationFor(["com.funtester.util.newinterface.NewUtil", "com.funtester.util.slowapi.HttpBase"]) class TaskScheduledTest extends Specification { ? ? @Shared ? ? def service = PowerMockito.mock(IService) ? ? def drive = new TaskScheduled(IService: service, cid: "") ? ? def setupSpec() { ? ? ? ? PowerMockito.mockStatic(HttpBase.class) ? ? ? ? PowerMockito.mockStatic(NewUtil.class) ? ? ? ? PowerMockito.when(HttpBase.fetch()).thenReturn(["ood", "ero"]) ? ? ? ? Mockito.when(newutil.filter(Mockito.any())).thenReturn(true) ? ? ? ? Mockito.when(newser.selectAll()).thenReturn([new NewInterface() { ? ? ? ? ? ? { ? ? ? ? ? ? ? ? setUrl("/abc") ? ? ? ? ? ? ? ? setNname("test") ? ? ? ? ? ? ? ? setMethod("GET") ? ? ? ? ? ? } ? ? ? ? }, new NewInterface() { ? ? ? ? ? ? { ? ? ? ? ? ? ? ? setUrl("/abcd") ? ? ? ? ? ? ? ? setNname("test") ? ? ? ? ? ? ? ? setMethod("POST") ? ? ? ? ? ? } ? ? ? ? }, new NewInterface() { ? ? ? ? ? ? { ? ? ? ? ? ? ? ? setUrl("/abce") ? ? ? ? ? ? ? ? setNname("test") ? ? ? ? ? ? ? ? setMethod("GET") ? ? ? ? ? ? } ? ? ? ? }]) ? ? ? ? //這里因為send方法中用到了這個靜態(tài)方法 ? ? ? ? PowerMockito.when(NewUtil.getsAll(anyList(), anyBoolean())).thenReturn([new NewInterface() { ? ? ? ? ? ? { ? ? ? ? ? ? ? ? setUrl("/abc") ? ? ? ? ? ? ? ? setNname("test") ? ? ? ? ? ? ? ? setMethod("GET") ? ? ? ? ? ? } ? ? ? ? }, new NewInterface() { ? ? ? ? ? ? { ? ? ? ? ? ? ? ? setUrl("/abc") ? ? ? ? ? ? ? ? setNname("test") ? ? ? ? ? ? ? ? setMethod("GET") ? ? ? ? ? ? } ? ? ? ? }]) ? ? } ? ? def "Send"() { ? ? ? ? given: ? ? ? ? drive.send() ? ? } ? ? def "day"() { ? ? } }
PS:在Mockito高版本的依賴mockito-inline中,也是支持對靜態(tài)類和靜態(tài)方法的Mock的,但在Spock中極難使用,資料說是因為項目pom中的Spock版本與Mockito版本不一致導致的,嘗試了幾個組合依然無法解決,又有人言,跟Groovy依賴的版本也有關(guān)系,直接破防,放棄了這個方案。
到此這篇關(guān)于基于Java匯總Spock框架Mock靜態(tài)資源經(jīng)驗的文章就介紹到這了,更多相關(guān)Spock框架Mock靜態(tài)資源經(jīng)驗匯總內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java字符串拼接+和StringBuilder的比較與選擇
Java 提供了兩種主要的方式:使用 "+" 運算符和使用 StringBuilder 類,本文主要介紹了Java字符串拼接+和StringBuilder的比較與選擇,感興趣的可以了解一下2023-10-10使用java?-jar命令啟動Spring?Boot應用時指定特定配置文件的幾種實現(xiàn)方式
這篇文章主要介紹了在使用java-jar命令啟動SpringBoot應用時,指定特定配置文件的幾種方式,文中通過代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考借鑒價值,需要的朋友可以參考下2025-01-01springboot yml配置文件使用@project.xxxx@啟動報錯Do not
這篇文章主要介紹了springboot yml配置文件使用@project.xxxx@啟動報錯Do not use @ for indentation問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07