兩分鐘搞懂UiAutomator、UiAutomator2、Bootstrap的關係
很多同學經過一段時間的學習之後都明白了Appium的基本原理,但是越學習到後面發現出現的很多陌生名詞無法弄清楚其具體作用,今天這篇文章的目的就是為了讓大家來弄懂三個高頻名詞:UiAutomator、UiAutomator2、Bootstrap。
首先來說下UiAutomator和bootstrap:
UiAutomator是Android自動化測試框架,是谷歌在Android4.1版本釋出時推出的一款用Java編寫的UI測試框架。其最大的特點就是可以跨程序操作,我們可以使用UiAutomator框架提供的一些方便的API來對安卓應用進行一系列的自動化測試操作,如點選、滑動、鍵盤輸入、長按以及常用的斷言方法等。可以替代以前繁瑣的手工測試。
Bootstrap是Appium在初始化的時候推送到安卓手機上的一個UiAutomator測試指令碼,該指令碼的唯一一個測試方法所做的事情是在手機端開啟一個SocketServer(通訊模組),用來監聽Appium從PC端過來的命令傳送給UiAutomator來執行處理。
下圖為官方提供的原理圖:
WebDriver script:
我們的測試指令碼(java or python)
Appium:
會首先開啟一個監聽4723埠的server,接收測試指令碼傳送過來的對應請求,再講對應的請求傳送給中介軟體Bootstrap.jar(注意這裡的請求不是整個指令碼檔案,而是對應的命令請求,比如:點選一個元素就是一條請求)
Bootstrap.jar:
監聽4724埠由appium傳送過來的相關請求,並且將請求轉換成UiAutomator可以識別的命令發給UiAutomator進行處理
UiAutomator2:
說到這裡相信大家已經瞭解了這兩者的關係,那為什麼還會有UiAutomator2,難道是UiAutomator的升級版本?沒錯!
appium在最近有加入了UiAutomator2(也可稱為UiAutomator V2)來支援實現Android端自動化,原理同之前的UiAutomator+Bootstrap有很大的不同:
為了能夠支援UiAutomator2,Appium引入了appium-uiautomator2-server
以下是其官網的wiki介紹,英文基礎較好的同學可以去看看
肯定還是有比較多同學對英文犯暈的,那我就給大家翻譯翻譯下:
1、Appium使用UiAutomator2的目的是為了替換掉之前的UiAutomator+Bootstrap模式
2、Bootstrap是基於UiAutomator V1(即為UiAutomator)的,但是UiAutomator很多Api基本上官方不再維護了
3、UiAutomator V2修復了UiAutomator V1中遇到的大多數問題,最重要的是實現了與Android系統更新的分離
有看到我們公開課的同學或者VIP課程的同學比較清楚:在獲取到toast資訊的時候需要將automationName設定成UiAutomator2,就是因為在UiAutomator2上新增了AccessibilityService服務,可以實現Toast的獲取。
以下是其使用原理圖:
WebDriver script:
不用多說,就是我們的執行指令碼
Appium:
客戶端傳遞desired capabilities屬性配置給Appium Server來建立一個會話,Appium Server會呼叫appium-uiautomator2-driver,同時將UiAutomator2 server的兩個apk安裝到測試裝置上
1、appium-uiautomator2-server-vx.x.x.APK
2、appium-uiautomator2-server-debug-androidTest.apk
UiAutomator2 server兩個apk的作用:
1、UiAutomator2 驅動模組,負責建立會話,安裝UiAutomator2-server.apk到裝置上,開啟Netty(這是一個通訊框架,相當於Bootstrap使用的SocketServer升級版本)
2、UiAutomator2伺服器模組,當驅動模組創初始化完畢,伺服器就會監聽PC端Appium傳送過來的請求,將請求傳送給真正底層的UiAutomator2。