本文件說明如何使用 Robo 指令碼,這是用於自動執行行動應用程式的手動 QA 工作,並啟用持續整合 (CI) 和預先發布測試策略的測試。舉例來說,您可以使用 Robo 指令碼測試一般使用者歷程,或提供特定使用者介面 (UI) 輸入內容,例如使用者名稱和密碼。Robo 指令碼是 Robo 測試的一項功能,
Robo 指令碼會使用 Robo 測試做為測試引擎。Robo 指令碼最基本的形式,是由一系列的 UI 動作組成,例如輸入文字「使用者名稱」,然後輕觸「確定」按鈕。Robo 指令碼也可以包含等待元素顯示、輕觸元素中的特定位置,以及執行 Android Debug Bridge (adb
) 殼層指令等動作。
相較於傳統測試架構,Robo 指令碼具備下列優點:
功能 | 說明 |
高度完善 | Robo 指令碼可容許應用程式版本和應用程式不穩定性之間的結構和行為有顯著差異。 |
開放式 | Robo 指令碼完成後,基本 Robo 測試可接手並繼續測試應用程式。這種持續測試方法可支援多種重要用途。舉例來說,您可以使用 Robo 指令碼執行自訂登入流程,將應用程式帶入特定狀態。 |
可錄製 | 因此您不必手動編寫 Robo 指令碼。你可以使用 Android Studio 中的 Robo 指令碼錄製工具錄製這些內容。建立或修改 Robo 指令碼時,通常不需要具備任何行動應用程式開發知識。 |
彈性 | Robo 指令碼可與遊戲中常見的非原生 UI 元素互動。 |
Robo 指令碼會在 Robo 測試期間依條件觸發,讓使用者擴充 Robo 的行為,通常是為了擴大涵蓋範圍或鎖定特定功能。與傳統測試架構不同,Robo 指令碼支援下列功能:
- 各種觸發條件,例如特定應用程式套件名稱是否處於啟用狀態,或是特定元素是否顯示在畫面上。
- 執行控制項,例如執行作業數量上限、優先順序、相關檢索階段。
- 非傳統的動作類型 (條件式、忽略元素、關閉畫面)。
建議您盡可能使用 Robo 指令碼,因為這類指令碼可以輕鬆維護。舉例來說,您可以使用 Robo 指令碼執行下列操作:
- 瀏覽重要的工作流程,瞭解應用程式功能的核心。舉例來說,您可以執行登入作業、在首次啟動後設定應用程式的狀態,以及註冊新使用者。
- 請將 Robo 聚焦在應用程式的特定部分,充分運用 Robo 測試時間。Robo 指令碼會引導 Robo 測試到達應用程式的相關部分,並在該處恢復全自動檢索。
- 將應用程式帶入特定狀態或畫面來執行分析,例如分析應用程式內訊息、隱私權政策或遊戲的特定層級。
- 執行端對端檢測測試,無論 Robo 指令碼完成後是否要讓 Robo 測試恢復全自動檢索。
使用更進階的 Robo 指令碼功能執行以下操作:
- 在 Robo 開始檢索測試中的應用程式之前或檢索完成後執行動作,例如在檢索前清除測試中的應用程式資料,或變更裝置設定。
- 變更檢索期間 Robo 行為的層面,特別是:
- 讓 Robo 忽略某些 UI 小工具或應用程式畫面。
- 在 Robo 從特定畫面回溯時,提供要執行的自訂動作。
- 在檢索期間遇到特定應用程式畫面時,讓 Robo 執行特定動作。
- 完全自訂 Robo 執行檢索的方式。舉例來說,您可以結合條件式和非條件式動作,在整個檢索期間將測試中的應用程式保持在背景中,同時執行裝置操作,並關閉隨時顯示的任何彈出式對話方塊。
請注意,Robo 指令碼無法取代所有類型的測試。您仍需要單元測試來找出應用程式中的低階邏輯錯誤;這些測試通常不需要 Android 或 iOS 環境。建議您使用指定目標檢測設備測試來補充 Robo 指令碼測試,而這些測試可以包含關於商業邏輯的具體、詳細斷言,這類測試最好在程式碼中表示。
後續步驟
如要瞭解 Robo 指令碼的結構、功能、用途和動作,請參閱 Robo 指令碼參考指南。