app
的一些类型,只有了解这些app
的类型才能针对性的选择元素定位方法;APP
可以分为原生APP
、Web APP
、混合APP
。APP
是基于Android
或iOS
平台官方的语言、类库、工具进行开发的APP
;id、class_name、Xpath
。Web APP
一般是Web开发语言,通过浏览器运行;# id
# class_name
# Xpath
# name
# tag_name
# link_text
# partial_link_text
# CSS
APP
就要根据实际情况来定,要么8种元素定位方法都可以用到,要么只能用到部分。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'
USB
调试;USB
安装;USB
调试(安全设置);xiaomi
手机。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.
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
后如下界面:
WebAPP
之前提及这个和selenium
元素定位是一样的,这里可不过多介绍;APP
的常用的三种方式。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()
class_name
就是根据元素类型进行定位;class_name
比较多的话,可使用下标就行选择,比如:driver.find_element(AppiumBy.CLASS_NAME, "content-desc")[1].click()
id
是唯一的,比如之前我们定位的【同意】这个按钮:
driver.find_element(AppiumBy.XPATH,
"//android.widget.TextView[@resource-
id='com.taobao.taobao:id/provision_positive_button']").click()
class
作为标签定位,那么:driver.find_element(AppiumBy.XPATH,
"classxxxx").click()
class
作为属性定位,那么:driver.find_element(AppiumBy.XPATH,
"//*[@class='xxxx']").click()text
是唯一的,直接使用text
文本进行定位;driver.find_element(AppiumBy.XPATH,
"//*[@text='xxxx']").click()
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()
el = '//*[@text="xxx" and @index="yyy"]'
driver.find_element(AppiumBy.XPATH, el).click()
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。