一、什么是Android單元測(cè)試
Android單元測(cè)試是應(yīng)用測(cè)試策略中的基本測(cè)試。通過針對(duì)代碼創(chuàng)建和運(yùn)行單元測(cè)試,您可以輕松驗(yàn)證各個(gè)單元的邏輯是否正確。在每次構(gòu)建后運(yùn)行單元測(cè)試可幫助您快速捕捉和修復(fù)由應(yīng)用的代碼更改導(dǎo)致的軟件回歸。
單元測(cè)試通常以可重復(fù)的方式運(yùn)用盡可能小的代碼單元(可能是方法、類或組件)的功能。當(dāng)您需要驗(yàn)證應(yīng)用中特定代碼的邏輯時(shí),應(yīng)構(gòu)建單元測(cè)試。例如,如果您正在對(duì)某個(gè)類進(jìn)行單元測(cè)試,測(cè)試可能會(huì)檢查該類是否處于正確狀態(tài)。通常,代碼單元在隔離的環(huán)境中進(jìn)行測(cè)試;您的測(cè)試僅影響和監(jiān)控對(duì)該單元的更改。您可以使用依賴項(xiàng)提供器(如 Robolectric)或模擬框架將您的單元與其依賴項(xiàng)隔離開來。
注意:?jiǎn)卧獪y(cè)試不適用于測(cè)試復(fù)雜的界面互動(dòng)事件。對(duì)于此類事件,您應(yīng)改用界面測(cè)試框架,如自動(dòng)執(zhí)行界面測(cè)試中所述。
為了測(cè)試 Android 應(yīng)用,您通常會(huì)創(chuàng)建下面這些類型的自動(dòng)化單元測(cè)試:
本地測(cè)試:僅在本地計(jì)算機(jī)上運(yùn)行的單元測(cè)試。這些測(cè)試編譯為在 Java 虛擬機(jī) (JVM) 本地運(yùn)行,以最大限度地縮短執(zhí)行時(shí)間。如果您的測(cè)試依賴于 Android 框架中的對(duì)象,我們建議您使用 Robolectric。對(duì)于依賴于您自己的依賴項(xiàng)的測(cè)試,請(qǐng)使用模擬對(duì)象來模擬您的依賴項(xiàng)的行為。插樁測(cè)試:在 Android 設(shè)備或模擬器上運(yùn)行的單元測(cè)試。這些測(cè)試可以訪問插樁測(cè)試信息,如被測(cè)應(yīng)用的Context。您可以使用此方法來運(yùn)行具有復(fù)雜 Android 依賴項(xiàng)(需要更強(qiáng)大的環(huán)境,如 Robolectric)的單元測(cè)試。延伸閱讀:
二、為什么要進(jìn)行單元測(cè)試
使用單元測(cè)試可以提高開發(fā)效率,當(dāng)項(xiàng)目隨著迭代越來越大時(shí),每一次編譯、運(yùn)行、打包、調(diào)試需要耗費(fèi)的時(shí)間會(huì)隨之上升,因此,使用單元測(cè)試可以不需這一步驟就可以對(duì)單個(gè)方法進(jìn)行功能或邏輯測(cè)試。
同時(shí),為了能測(cè)試每一個(gè)細(xì)分功能模塊,需要將其相關(guān)代碼抽成相應(yīng)的方法封裝起來,這也在一定程度上改善了代碼的設(shè)計(jì)。因?yàn)槭菃蝹€(gè)方法的測(cè)試,所以能更快地定位到bug。
單元測(cè)試case需要對(duì)這段業(yè)務(wù)邏輯進(jìn)行驗(yàn)證。在驗(yàn)證的過程中,開發(fā)人員可以深度了解業(yè)務(wù)流程,同時(shí)新人來了看一下項(xiàng)目單元測(cè)試就知道哪個(gè)邏輯跑了多少函數(shù),需要注意哪些邊界——是的,單元測(cè)試做的好和文檔一樣具備業(yè)務(wù)指導(dǎo)能力。