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