Appium UiAutomator2驱动:Settings API介绍

一、什么是Settings API

AppiumUiAutomator2驱动支持各种能力参数,在创建客户端和服务端会话的时候,以键值对的方式进行协商。当会话建立之后,如何对这些能力参数进行调整呢?

针对上述场景的需要,Appium引入了一系列的扩展API接口,允许在会话建立后,在执行过程中对参数(能力)进行调整。这些API接口统称为Settings API,被改动的参数称为Settings

Settings有三个重点的概念:

  • Settings是可变的,会话期间可以通过Settings API接口进行更改;

  • Settings只跟会话期间设置的内容相关,通常新的会话需要重新设置,但是借助某些驱动,一些设置可以在会话之间保持;

  • Settings只是调整测试期间Appium服务端的行为,而不涉及被测设备和被测应用(APP)。

二、Python客户端如何使用Settings API

有2种方式来使用Settings:1)建立会话时通过能力参数传入;2)会话执行过程中通过专门的接口进行修改。备注:本文所有测试代码的前提是已经安装Appium和相关环境(例如JDKAndroid SDKAVD模拟器),可以参考Appium环境搭建

2.1 建立会话时通过能力参数传入

键值对的方式为"appium:settings[<name>]":"<value>",其中<name>Settings的名称,<value>是待设置的值。以actionAcknowledgmentTimeout参数为例,它表示等待一个动作执行确认的超时时间,例如模拟按钮的点击操作,操作完成后结果通知到客户端的超时时间。该参数的默认值是3秒,示例如下:


import pytest

from appium import webdriver
from appium.options.android import UiAutomator2Options
from appium.webdriver.appium_service import AppiumService

# 开启服务端
APPIUM_HOST = '127.0.0.1'
APPIUM_PORT = 4723
@pytest.fixture(scope="session")
def start_appium_service():
 server = AppiumService()
 server.start(args=['--address', APPIUM_HOST, '-p', str(APPIUM_PORT)], timeout_ms=60000)
 yield server
 server.stop()

# 创建客户端到服务端的会话
def create_appium_session_by_api(custom_opts = None, appium_host = APPIUM_HOST, appium_port = APPIUM_PORT):
 options = UiAutomator2Options()
 if custom_opts is not None:
 options.load_capabilities(custom_opts)
 return webdriver.Remote(f'http://{appium_host}:{appium_port}', options=options)

def test_set_settings_in_capabilities(start_appium_service):
 custom_opts = {
 "appium:settings[actionAcknowledgmentTimeout]": 4321,
 "appium:avd": "testPhone",
 }

 driver = create_appium_session_by_api(custom_opts)
 settings = driver.get_settings()

 assert settings["actionAcknowledgmentTimeout"] == 4321

2.2 会话执行过程中通过接口更改

执行过程中更改需要使用客户端webdriver提供的接口,本文使用的是Python,具体的修改接口是update_settings,获取所有参数的接口是get_settings,示例如下:


import pytest

from appium import webdriver
from appium.options.android import UiAutomator2Options
from appium.webdriver.appium_service import AppiumService

# 开启服务端
APPIUM_HOST = '127.0.0.1'
APPIUM_PORT = 4723
@pytest.fixture(scope="session")
def start_appium_service():
 server = AppiumService()
 server.start(args=['--address', APPIUM_HOST, '-p', str(APPIUM_PORT)], timeout_ms=60000)
 yield server
 server.stop()

# 创建客户端到服务端的会话
def create_appium_session_by_api(custom_opts = None, appium_host = APPIUM_HOST, appium_port = APPIUM_PORT):
 options = UiAutomator2Options()
 if custom_opts is not None:
 options.load_capabilities(custom_opts)
 return webdriver.Remote(f'http://{appium_host}:{appium_port}', options=options)

def test_set_settings(start_appium_service):
 custom_opts = {
 "appium:avd": "testPhone",
 }

 driver = create_appium_session_by_api(custom_opts)

 settings = driver.get_settings()
 assert settings["actionAcknowledgmentTimeout"] == 3000

 modify_args = {
 "actionAcknowledgmentTimeout": 4321,
 }
 driver.update_settings(modify_args)

 settings = driver.get_settings()
 assert settings["actionAcknowledgmentTimeout"] == 4321

三、Settings参数详解

目前UiAutomator2支持的Settings参数具体描述如下,可以参考官方文档

参数名称 参数类型 参数详解
actionAcknowledgmentTimeout long 等待动作完成并通知的超时时间,单位是毫秒。动作包括点击操作、文本设置操作、菜单按压操作等。以便Appium框架能够判断动作是否已经成功。通常不建议修改该参数,默认值是3000
allowInvisibleElements boolean XML源码树是否包含对用户不可见的元素(元素的displayed属性是false)。该值默认是false
ignoreUnimportantViews boolean 使能或禁止布局层次结构压缩。如果使能布局层次结构压缩,则布局层次结构从Acessibility框架派生,只会包含对uiautomator测试重要的节点。任何导致视图呈现或层次搜索效率降低的节点都会被移除。该值默认是false
elementResponseAttributes string 包含在查找元素接口(findElement)响应中的元素属性名称,多个属性名称以分号分隔。默认只包含元素的UUID,可以指定把如下属性项添加进来:name, text, rect, enabled, displayed, selected, attribute/<element_attribute_name>。此外,要使用此参数功能,需要shouldUseCompactResponses参数设置为false
enableMultiWindows boolean 在构建XML页面源码时是否包含用户可以交互的所有窗口(例如屏幕键盘)。默认值是false,页面源码仅包含一个活动的应用程序窗口。
enableTopmostWindowFromActivePackage boolean 在交互和页面源检索中,是否限制活动包中具有最高Z-order的窗口。默认值是false,并且活动应用程序窗口(可能不一定具有此顺序)包含在页面源中。
enableNotificationListener boolean 是否启动toast通知侦听器用于侦听新的toast通知。默认此侦听器处于启用状态,并且UiAutomator2 server会将toast消息的文本包含到XML页面源。
keyInjectionDelay long 注入文本输入时,按键之间的延时时间。单位是毫秒,默认是0
scrollAcknowledgmentTimeout long 滚动条滑动动作通知的超时时间,单位是毫秒,通常不建议修改该参数,默认值是200
shouldUseCompactResponses boolean elementResponseAttributes参数联合使用。如果shouldUseCompactResponses设置为false,那么查找元素接口的响应报文中,会包含elementResponseAttributes参数指定的属性。默认值是true
waitForIdleTimeout long 用于等待用户界面进入空闲状态的超时。默认情况下,除了UiDevice之外的所有核心uiautomator对象都将在开始搜索对象定位器(object's locator)指定的部件(widgest)之前执行此等待。一旦检测到空闲状态或超时(以先发生的为准),对象将开始等待选择器找到匹配项。如果在测试中遇到跟可访问性元素交互时时间延迟过长的情况,请考虑降低此设置的值。默认情况下为10000,单位是毫秒。
waitForSelectorTimeout long 等待部件在用户界面变成可见(以便被选择器匹配)的超时时间。当使用选择器匹配目标时,因为用户界面的内容是动态的,有时目标不见不会立马在用户界面可见,因此无法被选择器检测到。本参数允许uiautomator框架等待选择器去匹配,直到达到超时时间。单位是毫秒,默认是1000
normalizeTagNames boolean 如果设置为true,在页面源码XML文档中,对于用于标记名的元素类型名称,执行unicodeascii标准化。当应用程序中有包含Unicode编码的类型名时,该选项是必要的。默认值是false
shutdownOnPowerDisconnect boolean 被测设备与电源断开之后(例如只有电池供电时),是否要关闭被测设备上的UiAutomator2 server。默认值是true
simpleBoundsCalculation boolean 是否将元素边界计算为绝对值(参数值为true),或检查元素是否被其他元素遮盖导致隐藏(参数值false)。参数设置为true可以改善XML页面源码生成的性能,但会降低边界的精度。所以慎用。
trackScrollEvents boolean 是否使用滚动事件跟踪(true时启用,默认值)。启用之后就可以用于计算contentSize元素属性,另一方面,使能该参数会增加所有滚动动作的延迟。
wakeLockTimeout long UiAutomator2 server持有唤醒锁的时间(获取唤醒锁,是为了防止被测设备在运行测试过程中进入睡眠)。默认情况下UiAutomator2 server持有唤醒锁24小时。该参数单位是毫秒,将该值设置为0,会强制UiAutomator2 server释放唤醒锁。备注:唤醒锁(wake lock)是安卓的一种机制,防止设备在运行过程中进入睡眠状态。
serverPort int 被测设备上启动UiAutomator2 server的端口号,不要把这个值和appioum:systemPort混淆了,appioum:systemPortAppium服务端的UiAutomator2 driver用于与UiAutomator2 server通信使用的端口。本参数的设置范围是1024~65535,默认值是6790
mjpegServerPort int MJPEG屏幕截图每秒钟最大的截图数量,默认值是10,范围是1~60
mjpegScalingFactor int MJPEG屏幕截图对截图的缩放比例(百分比形式)。参数值范围是1~100,默认值是50,也就是默认情况下,会按照原图一半的比例生成截图。
mjpegServerScreenshotQuality int MJPEG屏幕截图对截图有损压缩的比例(百分比形式)。参数值范围是1~100,默认值是50,也就是默认情况下,会按照原图质量的一半的比例进行压缩生成截图。
mjpegBilinearFiltering boolean MJPEG屏幕截图对大小调整是否使用双线性滤波算法,默认值是false。如果设置为true,可以改善生成的缩放位图的质量,但是对性能有损耗。
useResourcesForOrientationDetection boolean 定义UiAutomator2 server用于检测被测设备方向的策略。默认情况下(false)使用被测设备的旋转值来达到此目的,因此对于某些设备该方法(旋转值)可能无法正常工作,可能导致纵向被检测为横向(或发过来)。在这种情况下,就需要设置本参数为true
enforceXPath1 boolean UiAutomator2 server4.25.0版本开始,XPath2就是默认和推荐的元素定位解析器。如果某些场景下需要使用XPath1。可以使能本参数。该参数只在通过XPATH方式定位查找元素的时候生效,因此可以在测试脚本中使能该参数,XPATH方式查找完元素后,关闭该参数。
limitXPathContextScope boolean 由于历史原因,UiAutomator2驱动限制了基于元素内容来搜索元素父元素的范围,这也就意味着findElement(By.xpath, "//root").findElement(By.xpath, "./..")这种调用方式不会成功,因为驱动只会从目的XML源码中收集root的后继元素。limitXPathContextScope参数设置为false可以改变这种行为,变成搜索整个XML页面源码。该参数默认是true
disableIdLocatorAutocompletion boolean 根据安卓国际标准,元素的资源id命名需要有形如<packageName>:id/的前缀以防止命名冲突。但是并非所有的应用都按照此标准执行,而UiAutomator2驱动会检测传入的id是否包含如上形式的前缀,没有的话会自动加上。因此对于某些未按照标准要求使用id命名的应用会存在问题,可以使能本参数(设置为true),关闭自动添加前缀功能。该参数默认值是false
includeExtrasInPageSource boolean XML页面源码结果中是否包含extra元素属性,包含的话,XPath定位器就可以通过extra来定位元素。如果extra属性很大,使能该功能可能会影响性能。该参数默认是false
snapshotMaxDepth int 源码树快照的最大深度,默认是70,该参数的范围是1~500。如果该值较低,可能导致源码树上部分元素丢失;如果该值太高,可能导致堆栈溢出错误。需要UiAutomator2驱动版本在2.27.0及以上支持该参数。

附录

  1. 官方文档参考
  2. 本文原始路径
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容