前言
Android Studio 以簡化測試為設計宗旨。 您只需完成幾次點擊,便可建立一個在本地 JVM 上運行的 JUnit 測試,或建立一個在設備上運行的儀器測試
本地單元測試
適用場景:這些測試在計算機的本地 Java 虛擬機 (JVM) 上運行。 當您的測試沒有 Android 框架依賴項或當您可以模擬 Android 框架依賴項時,可以利用這些測試來盡量縮短執行時間。
在應用模塊的 build.gradle 文件中指定測試庫依賴項:
dependencies {
// Required for local unit tests (JUnit 4 framework)
testCompile 'junit:junit:4.12'
}
手動建立
- 在左側的 Project 窗口中,點擊下拉菜單并選擇 Project 視圖。
- 展開相應的模塊文件夾和嵌套的 src 文件夾。 要添加本地單元測試,請展開 test 文件夾和嵌套的 java 文件夾;要添加儀器測試,請展開 androidTest 文件夾和嵌套的 java 文件夾。
- 右鍵點擊 Java 軟件包目錄并選擇 New > Java Class。
- 命名文件,然后點擊 OK。
AS自動創建
- 打開包含您想測試的代碼的 Java 文件。
- 點擊您想測試的類或方法,然后按 Ctrl+Shift+T (??T)。
- 在出現的菜單中,點擊 Create New Test。
- 在 Create Test 對話框中,編輯任何字段并選擇任何要生成的方法,然后點擊 OK。
- 在Choose Destination Directory 對話框中,點擊與您想創建的測試類型對應的源集:androidTest 對應于儀器測試,test 對應于本地單元測試。
如圖:
[圖片上傳失敗...(image-49c0e7-1516945046776)]
編寫測試代碼
簡單寫一點點:
public class UtilsTest {
@Before
public void setUp() throws Exception {
MockitoAnnotations.initMocks(this);
System.out.println("setUp");
}
@Test
public void test1() throws Exception {
Assert.assertEquals(Utils.test1(),"is test1");
}
@Test
public void test2() throws Exception {
Assert.assertEquals(Utils.test2("1","2"),"21");
}
}
運行測試
要運行測試,請執行如下操作
- 點擊工具欄中的 Sync Project,確保您的項目已與 Gradle 同步。
- 以下列其中一種方式運行測試:
1).在 Project 窗口中,右鍵點擊測試,然后點擊
2).來測試該類中的所有方法。 要運行所有測試,右鍵點擊測試目錄,然后點擊 Run tests
- 以下列其中一種方式運行測試:
默認情況下,您的測試運行時使用的是 Android Studio 默認的運行配置。 如果您想更改某些運行設置(例如儀器運行器和部署選項),可以在 Run/Debug Configurations 對話框中編輯運行配置(點擊 Run > Edit Configurations)
編寫測試代碼詳解
Assert
[站外圖片上傳中...(image-bcceca-1516945046776)]
JUnit 中的注解及含義
[站外圖片上傳中...(image-cd8e55-1516945046776)]
超時
Junit 提供了一個指定超時參數。如果一個測試用例執行的毫秒數超過了指定的參數值,那么 Junit 將自動將它標記為失敗。
@Test(timeout=1000)
public void test() {
...
}
捕獲異常
@Test(expected = ArithmeticException.class)
public void testException() {
int b = 1/0;
System.out.println(b);
}