詳解python uiautomator2 watcher的使用方法
該方是基于uiautomator2如下版本進行驗證的:
PS C:\windows\system32> pip show uiautomator2 Name: uiautomator2 Version: 1.2.2 Summary: Python Wrapper for Android UiAutomator2 test tool Home-page: https://github.com/codeskyblue/uiautomator2 Author: codeskyblue Author-email: codeskyblue@gmail.com License: MIT Location: c:\program files\python36\lib\site-packages Requires: six, progress, whichcraft, logzero, lxml, adbutils, retry, Pillow, requests, humanize Required-by: weditor, atx
下面貼出githup上關(guān)于該方法的使用
Watcher
You can register watchers to perform some actions when a selector does not find a match.
Register Watcher
When a selector can not find a match, uiautomator2 will run all registered watchers.
Click target when conditions match
d.watcher("AUTO_FC_WHEN_ANR").when(text="ANR").when(text="Wait") \
.click(text="Force Close")
# d.watcher(name) ## creates a new named watcher.
# .when(condition) ## the UiSelector condition of the watcher.
# .click(target) ## perform click action on the target UiSelector.
There is also a trick about click. You can use click without arguments.
d.watcher("ALERT").when(text="OK").click()
# Same as
d.watcher("ALERT").when(text="OK").click(text="OK")
Press key when a condition becomes true
d.watcher("AUTO_FC_WHEN_ANR").when(text="ANR").when(text="Wait") \
.press("back", "home")
# d.watcher(name) ## creates a new named watcher.
# .when(condition) ## the UiSelector condition of the watcher.
# .press(<keyname>, ..., <keyname>.() ## press keys one by one in sequence.
Check if the named watcher triggered
A watcher is triggered, which means the watcher was run and all its conditions matched.
d.watcher("watcher_name").triggered
# true in case of the specified watcher triggered, else false
Remove a named watcher
# remove the watcher
d.watcher("watcher_name").remove()
List all watchers
d.watchers
# a list of all registered watchers
Check for any triggered watcher
d.watchers.triggered
# true in case of any watcher triggered
Reset all triggered watchers
# reset all triggered watchers, after that, d.watchers.triggered will be false.
d.watchers.reset()
Remove watchers
# remove all registered watchers
d.watchers.remove()
# remove the named watcher, same as d.watcher("watcher_name").remove()
d.watchers.remove("watcher_name")
Force to run all watchers
# force to run all registered watchers
d.watchers.run()
注:里面涉及的watcher_name可以自定義,可以做到見名知意即可
watcher的使用是要先注冊(第9行至20行均是注冊watcher的方法),然后激活watcher(第56行),注意這個激活方法只是一個瞬時激活,就是說使用之后即銷毀,不會一直存于后臺。那這樣的話在實際的使用場景中怎么使用這個功能呢,下面看一段腳本 1 # -*- coding:utf-8 -*-
import uiautomator2 as u2
import time
d = u2.connect()
cfg = MTBFConfig()
package = cfg.getstr("Admit", "pkg", "config")
PACKAGELIST = package.split(",")
print(PACKAGELIST)
d.watcher("ALLOW").when(text="ALLOW").click(text="ALLOW")
#d.watchers.run()
print(d.watchers)
time.sleep(2)
pkglen = len(PACKAGELIST)
print(("There are %d package for test") %pkglen)
class Admit(object):
def main(self):
for i in range(pkglen):
k = 0
for j in range(5):
if d.info['currentPackageName'] != PACKAGELIST[i]:
d.app_start(PACKAGELIST[i])
print(PACKAGELIST[i])
time.sleep(1)
k += 1
if k == 3:
print("Can not enter "+ str(PACKAGELIST[i]))
return False
if PACKAGELIST[i] == 'com.google.android.contacts':
print("hello")
if d(description = "Open navigation drawer").exists(timeout = 5):
d(description = "Open navigation drawer").click()
if d(text = "Settings").exists(timeout = 5):
d(text = "Settings").click()
if d(resourceId="android:id/title", text = "Import").exists(timeout=5):
d(resourceId="android:id/title", text = "Import").click()
time.sleep(3)
if d(resourceId = "android:id/button1", text = "OK").exists(timeout = 5):
d(resourceId = "android:id/button1", text = "OK").click()
time.sleep(1)
d.watchers.run() //在上面OK點擊之后會彈出一個權(quán)限訪問的許可,所以這個時候需要激活一次watcher把彈框關(guān)掉,以便不影響后續(xù)測試,所以就一個原則,哪里可能會有彈框就在哪里激活watcher
if __name__=="__main__":
ad = Admit()
ad.main()
總結(jié)
以上所述是小編給大家介紹的python uiautomator2 watcher的使用方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
python3 破解 geetest(極驗)的滑塊驗證碼功能
這篇文章主要介紹了python3 破解 geetest(極驗)的滑塊驗證碼功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2018-02-02
PyCharm Python Console中文輸出亂碼問題及解決
這篇文章主要介紹了PyCharm Python Console中文輸出亂碼問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07
pytest生成Allure報告以及查看報告的實現(xiàn)
本文主要介紹了pytest生成Allure報告以及查看報告的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-02-02
Python標準庫學習之operator.itemgetter函數(shù)的使用
operator.itemgetter是Python標準庫operator模塊中的一個函數(shù),本文主要介紹了Python標準庫學習之operator.itemgetter函數(shù)的使用,具有一定的參考價值,感興趣的可以了解一下2024-07-07
pytorch如何保存訓練模型參數(shù)并實現(xiàn)繼續(xù)訓練
這篇文章主要介紹了pytorch如何保存訓練模型參數(shù)并實現(xiàn)繼續(xù)訓練問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-09-09

