一、元素属性介绍
1、元素属性
2、查看各定位方式执行效率
二、iOS常用定位方法
1、accessibility_id
2、class_name
3、Xpath
4、ios_class_chain(类型链)
5、ios_predicate(谓词)
一个页面最基本组成单元是元素,想要定位一个元素,我们需要特定的信息来说明这个元素的唯一特征。
iOS自动化元素查找工具,我使用的是Appium的inspector。最新版的appium自动展示多种元素定位表达式,还可以查看每种定位表达式的执行效率。
1、元素属性
type
元素类型,与className作用一致,如:XCUIElementTypeButton
value
一般不用
name
元素的文本内容,可用作 AccessibilityId定位方式,如:ClearEmail
label
绝大多数情况下,与 name 作用一致
enabled
元素是否可点击,一般值为true或者false
visible
元素是否可见,一般值为true或者false
2、查看各定位方式执行效率
Appium的inspector功能中,选择某个元素后在“selected Element”中会展示多个定位表达式,而且点击定位表达式后面的“Get Timing”,可以显示每个定位表达式的执行时间。
iOS自动化测试元素定位的accessibility_id主要使用元素的label或name(两个属性的值都一样)属性进行定位。
例如:第一张截图中label或name都是“我的功能”
driver.find_element_by_accessibility_id("我的功能")
driver.find_element(MobileBy.ACCESSIBILITY_ID, "我的功能")
class_name定位方法使用元素的type属性,type属性表示控件类型,一般不具有唯一性,因此class_name不常用。
例如:type属性为:XCUIElementTypeButton
driver.find_element_by_class_name("XCUIElementTypeButton")
driver.find_element(MobileBy.CLASS_NAME, "XCUIElementTypeButton")
Appium对app原生环境的xpath定位方法执行效率很低,从iOS 10开始使用的 XCUITest 框架原生不支持,定位速度很慢,官方不推荐这种方式。但是在实际使用中,当其他定位方式都不能找到元素时,可以尝试xpath定位。
例如:第一张截图中“我的功能”定位
driver.find_element_by_xpath("//XCUIElementTypeStaticText[@name='我的功能']")
driver.find_element(MobileBy.XPATH, "//XCUIElementTypeStaticText[@name='我的功能']")
ios_class_chain仅支持iOS 10或以上,且仅限于WebDriverAgent 框架中使用。此方法用于替代xpath,但该方法还有待完善,没有纳入官方文档。
Github说明地址:https://github.com/appium/appium-xcuitest-driver
例如:第一张截图中“我的功能”定位
driver.find_element_by_ios_class_chain('**/XCUIElementTypeStaticText[`label == "我的功能"`]')
driver.find_element(MobileBy.IOS_CLASS_CHAIN, '**/XCUIElementTypeStaticText[`label == "我的功能"`]')
iOS Predicate 即谓词逻辑。ios_predicate定位方法支持iOS所有的版本,也就是能适配XCUITest 和 UIAutomation底层测试框架,使用的就是iOS编程语言,因此可以把此方法作为首选定位方式。
谓词表达式由属性、运算符和值构成。
1.1、常用的属性
在上面的表格中已经介绍,可以使用的元素属性:type、value、name、label、enabled、visible
1.2、运算符
1.2.1、比较运算符
比较运算符 >, <, ==, >=, <=, !=
可用于数值和字符串的比较,如:label == ‘我的功能’,label >= 500
示例:
driver.find_element_by_ios_predicate("label == '我的功能'")
driver.find_element(MobileBy.IOS_PREDICATE, "label == '我的功能'")
driver.find_element_by_ios_predicate("type == 'XCUIElementTypeButton' AND value == 'ClearEmail'")
常用的范围运算符有:
示例:
driver.find_element(MobileBy.IOS_PREDICATE, "name IN {'id_cell', 'id_alert'}")
driver.find_element_by_ios_predicate("value BETWEEN {5, 7}")
1.2.3、字符串相关
包含某个字符串:label CONTAINS ‘软件’
以某个字符串开头:label BEGINSWITH ‘自动’
以某个字符串结束:label ENDSWITH ‘测试’
扩展:在三个关键字后加上[c]、或者[d]、[cd]
[c]:表示不区分大小写,可用于字母的校验;
[d]:不区分发音符号,即没有重音符号($、#等);
[cd]:既不区分大小写,也不区分发音符号;
例如:name CONTAINS[c] ABcd 和 name CONTAINS abcd是等同的
示例:
driver.find_element_by_ios_predicate("label CONTAINS ‘软件’")
1.2.4、模糊匹配:LIKE
模糊匹配也可以称为通配符匹配,?代表一个字符,*代表多个字符。
示例:现有元素的label属性:“自动化软件测试”
label LIKE ‘自动化软件测试’ # 完全匹配
label LIKE ‘自动化?件测试’ # ? 匹配一个字符
label LIKE ‘自动化??测试’ # 两个?号匹配两个字符
label LIKE ‘自?化?件测试’
label LIKE ‘*软件测试’ # *代表多个字符
label LIKE ‘自动化软件*’
label LIKE ‘自动化*件测*’
示例:
driver.find_element(MobileBy.IOS_PREDICATE, "label LIKE ‘*软件测试")
1.2.5、逻辑运算符
以字符串的匹配为例:匹配字符串“自动化软件测试”,以“自”开头,然后以“试”结尾。
表达式:label MATCHES ‘^自.+试$’
示例:
driver.find_element(MobileBy.IOS_PREDICATE, " label MATCHES ‘^自.+试$’")
符号说明: ^ 匹配字符串的开头
. 匹配任意字符,除了换行符
+ 匹配 1 个或多个的表达式。
$ 匹配字符串的末尾