一. 层级定位和list
先通过find_element_by_XXX找到父级元素webelement,再通过webelement.find_element_by_XXX寻找子元素
二. 滑动屏幕
滑动接口:
swipe(起始X,起始Y,结束X,结束Y)
结束X - 起始X:X轴滑动的距离
结束Y - 起始Y:Y轴滑动的距离
Q:手机的屏幕尺寸有很多,如何兼容?进入app时的导航页面
原理:
1. 先获取设备的屏幕大小(宽、高)
2. 再设置滑动的距离与屏幕大小的百分比
3. 调用滑动接口执行滑动操作
获取当前窗口大小的接口:
get_window_size:返回窗口的宽和高
滑动接口:
swipe(起始X,起始Y,结束X,结束Y)
实例:
#获取屏幕尺寸 size = self.driver.get_window_size() #swipe还有一个参数duration,单位是ms,防止操作过快 #向左滑动 self.driver.swipe(size["width"]*0.9, sie["height"]*0.5, size["width"]*0.1, size["height"]*0.5, 200) #向右滑动 self.driver.swipe(size["width"]*0.1, sie["height"]*0.5, size["width"]*0.9, size["height"]*0.5, 200)
多个屏幕需要滑屏时,最好在每个页面滑屏操作之后,利用time.sleep()稍微等待一下,防止操作过快
三. 模拟触屏
TouchAction类
将一系列的动作放在一个链条中,然后将该链条传递给服务器。服务器接收到该链条后,解析各个动作,逐个执行
短按(press)
长按(longPress)
点击(tap)
移动到(move to) x, y为相对上一个坐标的移动距离
等待(wait)
释放(release)
执行(perform)
取消(cancel)
实例
#引入TouchAction from appium.webdriver.common.touch_action import TouchAction ta = TouchAction(driver) #获取九宫格的起点坐标和大小 ele = driver.find_element_by_id("com.xxzb.fenwoo:id/gesturepwd_create_lockview") #九宫格的大小 size = ele.size #获取坐标:九宫格起点坐标 start_point = ele.location #参数是元素或者坐标,没有元素取坐标,wait是为了防止操作过快,单位是ms,绘制九宫格最后要释放release()(即抬起),完成后要perform() ta.press(x=start_point["x"] + size["width"]*1/6, y=start_point["y"] + size["height"]*1/6).wait(200).\ move_to(x=size["width"]*2/6, y=0).wait(200).\ move_to(x=size["width"]*2/6, y=0).wait(200).\ move_to(x=-size["width"]*2/6, y=size["height"]*2/6).wait(200).\ move_to(x=0, y=size["height"]*2/6).wait(200).\ release().wait(200).\ perform()
四. 多点触控
MultiAction类,引入
from appium.webdriver.common.multi_action import MultiAction
五. 安装/卸载/关闭/启动
启动Activity:
driver.start_activity()
在当前app打开一个activity,或者新打开一个应用并启动一个activity,仅支持Android
安装应用:
driver.install_app('path/to/my.apk')
卸载应用:
driver.remove_app('com.example.android.apis')
关闭应用:
driver.close_app()
应用是否已安装:检测应用是否已被安装
driver.is_app_installed('com.example.android.apis')
六. 拉取/推送文件
拉取(pull)文件
从设备上拉取文件
driver.pull_file('Library/AddressBook/AddressBook.sqlitedb')
推送(push)文件
推送文件到设备
data = "some data for the file"
path = "/data/local/tmp/file.txt"
driver.push_file(path, data.encode('base64'))
七. 锁定/将应用切换至后台
锁定屏幕(IOS):
driver.lock(秒)
将应用切换至后台:
background_app({"timeout": secs})
将当前的应用切换到后台,然后可以让其在指定时间内回到前台,或者让它一直留在后台
传递给这个方法的参数有两种类型:
一个整型(秒):表示后台状态维持多久。 -1表示持续置于后台。这种风格的参数已经被废弃
一个看起来像("timeout": secs)的对象。里面的secs是含义和第一个类型一样的整型数字(即表示置于后台多少秒),或者为null(表示持续置于后台)
driver.background_app(5) #置于后台,持续5s
driver.background_app(-1) #持续置于后台
driver.background_app({"timeout": None}) #持续置于后台
driver.background_app({"timeout": 5}) #置于后台5s,5s后自动回到前台
八. 打开通知栏/摇一摇
打开通知栏:仅支持Android
driver.open_notifications()
摇一摇:模拟摇晃设备的操作
driver.shake()
九. 手势
捏(Pinch)手势:缩小(默认缩小一倍)
在屏幕上使用捏(Pinch)手势
driver.pinch(element=el)
放大屏幕(Zoom)(默认放大一倍)
在屏幕上使用放大手势
driver.zoom(element=el)
scroll:滚动
十. 按键操作
按键发送(Android):
driver.press_keycode(键的keycode)
十一. 上下文切换
可用的上下文(Contexts)
列出所有可用的上下文(contexts)
driver.contexts
当前上下文(context):列出当前的上下文(context)
driver.current_context
切换至默认的上下文(context)
切换回默认的上下文(context) (注:一般就是原生上下文 "NATIVE_APP")
driver.switch_to.content(None)
当前Activity:获取当前的Activity。仅支持Android
driver.current_activity
当前包名(package):获取当前包名(package)。仅支持Android
driver.current_package
步骤:
1. 识别当前是否有webview,是否需要进入webview页面当中进行元素操作
识别方式一:看class或者content-desc是否包含WebView字段
方式二:
tips:
1) 在手机/模拟器中点击关于手机中的版本号5下,出来开发者选项
2) 在开发者选项中勾选上显示布局边界
3) 如果是html的界面,那界面不会有布局边界显示,如有则说明是native的界面
2. 获取所有的contexts
常见问题
contexts只能获取NATIVE_APP,无法获取WEBVIEW
使用uiautomatorview定位元素,显示class值为:android.webkit.WebView
但是driver.contexts只打印了 'NATIVE_APP'
解决办法:
1) app打包的时候需要开放webview的debug属性 setWebContentDebuggingEnabled(true),这个直接让开发加上就好
2) 模拟器的contexts中有webview,但有些手机没有,官方给出的答案是:需要将手机root,然后再去获取