Bootstrap

『App自动化测试之Appium应用篇』| 继承于selenium常用的元素定位方法有哪些?如何使用?

1 关于APP

  • 在了解元素等位前,我们先了解下app的一些类型,只有了解这些app的类型才能针对性的选择元素定位方法;
  • 因为不同类型的app的定位方式可能存在差异性;
  • 我们了解到APP可以分为原生APPWeb APP、混合APP

1.1 原生APP

  • 而原生APP是基于AndroidiOS平台官方的语言、类库、工具进行开发的APP
  • 这类APP的定位方式一般就只有三种,为id、class_name、Xpath

1.2 Web APP

  • Web APP一般是Web开发语言,通过浏览器运行;
  • 那么就支持selenium的常见8中元素等位方式了:
# id
# class_name
# Xpath
# name
# tag_name
# link_text
# partial_link_text
# CSS

1.3 混合APP

  • 这个其实就是用了原生APP的方法,还用到了HTML5的方法;
  • 那么这种APP就要根据实际情况来定,要么8种元素定位方法都可以用到,要么只能用到部分。

2 测试对象

2.1 获取包信息

  • 我们这里使用真机进行测试;
  • 安装包为taobao,自行下载即可;
  • 下载后查看对应的包名和活动窗口名:
aapt dump badging taobao.apk
F:\monkey_test>aapt dump badging taobao.apk
package: name='com.taobao.taobao' versionCode='609' versionName='10.31.1' compileSdkVersion='33' compileSdkVersionCodename='13'
install-location:'auto'
sdkVersion:'21'
targetSdkVersion:'33'
uses-permission: name='com.coloros.mcs.permission.RECIEVE_MCS_MESSAGE'
uses-permission: name='android.permission.READ_CONTACTS'
uses-permission: name='android.permission.CAMERA'
uses-permission: name='android.permission.INTERNET'
uses-permission: name='android.permission.ACCESS_NETWORK_STATE'
uses-permission: name='android.permission.GET_TASKS'
uses-permission: name='android.permission.ACCESS_WIFI_STATE'
uses-permission: name='android.permission.WRITE_EXTERNA
  • 得到重要的两个信息:
appPackage='com.taobao.taobao'
appActivity='com.taobao.tao.welcome.Welcome'

2.2 真机配置

  • 手机上打开USB调试;
  • 打开USB安装;
  • 打开USB调试(安全设置);
  • 注意本文使用的是xiaomi手机。

2.3 启动服务

  • 启动appium服务:
C:\Windows\System32>appium
[Appium] Welcome to Appium v2.2.3
[Appium] Attempting to load driver uiautomator2...
[Appium] Requiring driver at C:\Users\Administrator\.appium\node_modules\appium-uiautomator2-driver
[Appium] Appium REST http interface listener started on http://0.0.0.0:4723
[Appium] You can provide the following URLs in your client code to connect to this server:
[Appium]        http://172.16.1.33:4723/
[Appium]        http://127.0.0.1:4723/ (only accessible from the same host)
[Appium]        http://172.28.128.1:4723/
[Appium] Available drivers:
[Appium]   - uiautomator2@2.34.2 (automationName 'UiAutomator2')
[Appium] No plugins have been installed. Use the "appium plugin" command to install the one(s) you want to use.

2.4 启动session

  • 脚本或打开appium-inspecotr,配置相关信息如下:
{
  "platformName": "Android",
  "appium:automationName": "uiautomator2",
  "appium:deviceName": "xxxx", # 这是设备名称,填写自己的即可
  "appium:appPackage": "com.taobao.taobao",
  "appium:appActivity": "com.taobao.tao.welcome.Welcome",
  "appium:noReset": true
}
  • 启动session后如下界面:
    在这里插入图片描述

3 元素定位

  • 关于WebAPP之前提及这个和selenium元素定位是一样的,这里可不过多介绍;
  • 这里主要了解下原生APP的常用的三种方式。

3.1 id定位

  • 这种对应方式无疑对测试人员来说是最喜欢的方式了;
  • 因为如果是不变的id属性,那么久代表了唯一性,后续不管元素的位置如何变化,属性不变,对代码的维护成本就小很多了;
  • 比如我们打开软件后,有一个同意的界面,通过appium-inspecotr可以看到元素的属性:
    在这里插入图片描述
  • 我们可以提炼出【同意】按钮的属性为:
id:com.taobao.taobao:id/provision_positive_button
  • 那我们可以使用的定位方式为id,代码如下:
driver.find_element(AppiumBy.ID, "com.taobao.taobao:id/provision_positive_button").click()

3.2 class_name定位

  • class_name就是根据元素类型进行定位;
  • 加入类型class_name比较多的话,可使用下标就行选择,比如:
driver.find_element(AppiumBy.CLASS_NAME, "content-desc")[1].click()

3.3 Xpath定位

3.3.1 id定位

  • 假如id是唯一的,比如之前我们定位的【同意】这个按钮:
    在这里插入图片描述
  • 定位方式直接写为:
driver.find_element(AppiumBy.XPATH, 
"//android.widget.TextView[@resource-
id='com.taobao.taobao:id/provision_positive_button']").click()

3.3.2 class标签定位

  • 如果class作为标签定位,那么:
driver.find_element(AppiumBy.XPATH, 
"classxxxx").click()

3.3.3 class属性定位

  • 如果class作为属性定位,那么:
driver.find_element(AppiumBy.XPATH, 
"//*[@class='xxxx']").click()

3.3.4 text唯一性定位

  • 如果元素的text是唯一的,直接使用text文本进行定位;
  • 定位方法为:
driver.find_element(AppiumBy.XPATH, 
"//*[@text='xxxx']").click()

3.3.5 模糊匹配法

  • 可以使用contains
  • 语法为:
driver.find_element(AppiumBy.XPATH, 
"//*[contains(@resource-id, 'xxx')]").click()

driver.find_element(AppiumBy.XPATH, 
"//*[contains(@text, 'xxx')]").click()

driver.find_element(AppiumBy.XPATH, 
"//*[contains(@class, 'xxx')]").click()

3.3.6 组合定位

  • 就是把几种定位方式结合在一起,任意进行组合;
  • 比如:
el = '//*[@text="xxx" and @index="yyy"]'
driver.find_element(AppiumBy.XPATH, el).click()

3.3.7 层级定位

  • 层级定位就是除了以上这些方法都不容易定位的时候会用到;
  • 一般使用逻辑是找这个元素的父子层级进行定位。

悦读

道可道,非常道;名可名,非常名。 无名,天地之始,有名,万物之母。 故常无欲,以观其妙,常有欲,以观其徼。 此两者,同出而异名,同谓之玄,玄之又玄,众妙之门。

;