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