標籤:項目 click back ons eth code normal nat sse
測試驅動android開發
在安卓模擬器或者真機上跑測試案例速度很慢。構建、部署、啟動app,通常需要花費一分鐘或者更久。這不是TDD(測試驅動開發)模式.Robolectric提供一種更好的方式。
可能你一直嘗試在java IDE中使用junit或者testng直接跑測試案例,但是一直報java.lang.RuntimeException: Stub!
異常。
這個異常是因為在jdk中沒有android運行環境。而現在Robolectric這款android單元測試工具,類比了android sdk中的jar包,可以直接在jvm中運行測試案例,這樣就大大節省了時間。一個Robolectric測試案例如下:
// Test class for MyActivity @RunWith(RobolectricTestRunner.class) public class MyActivityTest { @Test public void clickingButton_shouldChangeResultsViewText() throws Exception { Activity activity = Robolectric.buildActivity(MyActivity.class).create().get(); Button pressMeButton = (Button) activity.findViewById(R.id.press_me_button); TextView results = (TextView) activity.findViewById(R.id.results_text_view); pressMeButton.performClick(); String resultsText = results.getText().toString(); assertThat(resultsText, equalTo("Testing Android Rocks!")); } }
SDK,Resource和Native Method類比
Robolectric可以處理控制項展示、資源載入和很多使用native C實現的真機上的其他功能。所以我們可以使用Robolectric來類比真機上的大部分操作。我們可以很方便地擷取Robolectric的源碼,直接查看它的類比機制,所以使用Robolectric,我們也可以類比錯誤條件和一些真實的感應器訊號。
脫離模擬器執行測試案例
Robolectric允許我們在項目工程中或者持續整合(CI如hudson、jenkins)中使用jvm來執行測試案例,所以就省掉了打包、安裝的過程,將測試案例的執行時間由分鐘級降到秒級。
不再需要Mock架構
使用一些Mock架構,如Mockito或者Android Mock等,可以類比出android運行環境,達到和Robolectric相同的效果。這是一個有效方法,但是使用這種方法寫出的測試案例,很多情況下就是開發代碼的反實現。
Robolectric的測試風格更偏向於黑箱測試,robolectric式的測試案例更加關注與app的表現,而不是android運行環境的實現,所以使用robolectric寫出的測試案例更有效。當然這也是看測試人員的喜好,如果喜歡可以同時使用Robolectric和mock架構。
測試驅動android