【轉(zhuǎn)轉(zhuǎn)QA】UI專項-元素定位方式和思考

作者:鄒德龍
編稿:莊錦弟

前言:

要做好UI自動化測試,做好元素定位很重要,也經(jīng)常收到反饋說定位難,但是有些東西是可以提煉出來共同點的。接下來簡單看看android和ios可以分別怎么定位,以及實踐UI自動化以來提煉的思想:

一、Android定位

前置: adb命令、python3、可開啟開發(fā)者選項的安卓手機

工具: WEditor(支持windows/Mac雙平臺)

安裝: 安裝weditor,在終端中輸入

pip install weditor
圖片

元素定位開始:

1、手機連接安卓設(shè)備(安卓設(shè)備得開啟USB調(diào)試),部分手機得啟用視圖屬性檢查功能。

2、通過adb devices獲取到機器的設(shè)備號

圖片

3、啟動weditor,執(zhí)行

python -m weditor
圖片

4、啟動成功后頁面

1)選擇android

2)輸入adb devices獲取的設(shè)備號

圖片

3)點擊connect按鈕可鏈接設(shè)備,這時候設(shè)備會彈出軟件安裝申請,選擇安裝選項

圖片

5、打開想要抓取元素的APP的頁面,點擊 Dump Hierarchy按鈕刷新頁面,抓取頁面元素,若想切換別的頁面抓取,操作APP后點擊刷新按鈕即可。

圖片

報錯解決:

1、如果啟動報錯:atx-agent recover failed

pip install --upgrade --pre uiautomator2  

二、IOS定位

前置: python3、裝有WDA的Iphone手機

工具: tidevice 、appium 1.21.0

安裝:

1、安裝tidevice,在終端中輸入

pip install tidevice

2、appium 官網(wǎng)下載安裝即可(裝最新版本)

元素定位開始:

1、tidevice applist 查看安裝應用程序同時查看設(shè)備上的第三方應用包名,若提示信任彈窗,點擊信任

圖片

2、連接iOS設(shè)備,查看連接設(shè)備命令,查看設(shè)備UDID:

tidevice list 

采坑點:可能碰到驅(qū)動問題點電腦無法正常連接手機設(shè)備,可下載愛思助手工具自動修復驅(qū)動

圖片

3、啟動WDA

tidevice -u 設(shè)備UDID wdaproxy -B WDA包名 -p 8200

設(shè)備UDID :注意替換為自己設(shè)備UDID(例如:0000xxxxxxx ) WDA包名:替換wda為自己的包名(例如:xxxx.xctrunner) 啟動成功:

圖片

4、打開appium,注意為1.20.2版本及以上,啟動服務(wù)器

圖片

5、開始元素定位

1)打開appium啟動服務(wù),點擊File - New Session Windows - 輸入JSON Reoresentation 參數(shù) - 啟動會話

JSON Reoresentation 示例:

{    "deviceName": "xxxx",     # 通用 - 關(guān)于手機 - 名稱    "bundleId": "xxxxx",    # 應用包名    "platformversion": "14.4",    # 手機版本    "udid": "000080xxxxxxxxxxxE",    # UDID    "webDriverAgentUrl": "http://localhost:8200",    "platformName": "IOS",    "xcodeOrgId": "xxxxxx",   # xcodeOrgId    "automationName": "XCUITest",    "usePrebuiltWDA": true,    "useXctestrunFile": false,    "skipLogCapture": true}
圖片

2)啟動成功后即可開始抓取元素

圖片

三、提煉思想

大道至簡:用簡單好用高效的元素定位:

Android :id > text > img > ocr > xpath

IOS : name > text > img > ocr > xpath

Web/H5:name > id > text > selector

網(wǎng)絡(luò)延遲:finds 框架方法(查找元素設(shè)置超時時間,間隔性掃描元素若元素存在則執(zhí)行下一步,若超過指定時長未查找到元素則為失敗,推薦使用),element_is_existed 框架方法(設(shè)置元素最長尋找時間,找到元素則返回True ,未找到元素則返回False

模糊匹配:不要在一棵樹上吊死,模糊匹配,不同版本中text元素(例如原價、秒殺價等)可能只有部分文案變化部分文案固定不變,可用模糊匹配命中。

總結(jié):

  • 元素定位是UI自動化的基礎(chǔ)能力,先有元素后有操作。
  • 元素定位方式的選擇決定了Case的執(zhí)行效率和穩(wěn)定性, 也決定了哪些功能可以通過UI自動化實現(xiàn)覆蓋。
  • WEditor、Appium inspector 等只是獲取定位方式的工具。
  • 如果你想要做好元素定位,推薦大家多多學習各種控件的特性、實現(xiàn)方式 和 頁面布局思想~
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容