iOS自动化测试元素定位

一、元素属性介绍

  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常用定位方法

  1、accessibility_id

  iOS自动化测试元素定位的accessibility_id主要使用元素的label或name(两个属性的值都一样)属性进行定位。

  例如:第一张截图中label或name都是“我的功能”

driver.find_element_by_accessibility_id("我的功能")
driver.find_element(MobileBy.ACCESSIBILITY_ID,  "我的功能")

  2、class_name

  class_name定位方法使用元素的type属性,type属性表示控件类型,一般不具有唯一性,因此class_name不常用。

  例如:type属性为:XCUIElementTypeButton

driver.find_element_by_class_name("XCUIElementTypeButton")
driver.find_element(MobileBy.CLASS_NAME, "XCUIElementTypeButton")

  3、Xpath

  Appium对app原生环境的xpath定位方法执行效率很低,从iOS 10开始使用的 XCUITest 框架原生不支持,定位速度很慢,官方不推荐这种方式。但是在实际使用中,当其他定位方式都不能找到元素时,可以尝试xpath定位。

  例如:第一张截图中“我的功能”定位

driver.find_element_by_xpath("//XCUIElementTypeStaticText[@name='我的功能']")
driver.find_element(MobileBy.XPATH, "//XCUIElementTypeStaticText[@name='我的功能']")

  4、ios_class_chain(类型链)

  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 == "我的功能"`]')

  5、ios_predicate(谓词)

  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'")

   1.2.2、范围运算符

   常用的范围运算符有:

范围运算符

说明

实例

IN

用于字符串的范围核对

name IN {'Alan','May'}

BETWEEN

用于数值的范围核对

name BETWEEN {3,10}

   示例:

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、字符串相关

字符串相关

运算符

说明

CONTAINS

表示包含某个字符串

BEGINSWITH

表示以某个字符串开头

ENDSWITH

表示以某个字符串结束

   以字符串“自动化软件测试”为例:

  • 包含某个字符串: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、逻辑运算符

逻辑运算符

说明

实例

AND

逻辑与:必须同时满足所有条件

type == XCUIElementTypeStaticText AND label CONTAINS '测试

&&

type == XCUIElementTypeStaticText && label CONTAINS '测试

OR

逻辑或:只需要满足一个条件即可

enabled == true OR visible == false

||

enabled == true || visible == false

NOT

逻辑非:取反

 

!

 

 

   1.2.6、正则表达式:MATCHES

   以字符串的匹配为例:匹配字符串“自动化软件测试”,以“自”开头,然后以“试”结尾。

   表达式:label MATCHES ‘^自.+试$’

   示例:

driver.find_element(MobileBy.IOS_PREDICATE, " label MATCHES ‘^自.+试$’")

    符号说明: ^  匹配字符串的开头

           .   匹配任意字符,除了换行符

           +  匹配 1 个或多个的表达式。

           $  匹配字符串的末尾

    关于正则匹配更多的说明可以参考:https://www.jianshu.com/p/7fa6fe0b39af

 

posted @ 2021-09-03 00:33  飞翔的猪~  阅读(1430)  评论(0编辑  收藏  举报