appium基本使用(Android)
一.环境搭建
详情可见:https://www.cnblogs.com/lihongtaoya/p/16971096.html
二.元素定位
详情可见:https://www.cnblogs.com/lihongtaoya/p/16988850.html
三.启动app基本配置
1.使用时首先导入webdriver模块
from appium import webdriver
2.通过webdriver调用Remote()完成初始化配置
driver = webdriver.Remote(command_executor="http://127.0.0.1:4723/wd/hub", desired_capabilities=desired)
其中command_executor参数一般固定为http://127.0.0.1:4723/wd/hub,desired_capabilities则为字典类型的配置。
desired = {
"platformName": "Android", # 手机系统
"platformVersion": "11", # 手机系统版本
"deviceName": '90bf8faf', # 连接的设备(adb devices)
"automationName": "UiAutomator2", # 自动化测试框架 (1.4以上的appium不用写)
"appPackage": "app包名", # app包名
"appActivity": "app启动页名", # app的启动页面
"autoGrantPermissions": "true", # 默认允许app获取相关权限
"noReset": True # 保留登录模式
}
上述参数中是启动app的基本配置,其中app包名和页面名可通过dumpsys window|grep mCu指令来查看。
其它参数配置可参考这位大佬的博客:https://www.cnblogs.com/wysk/p/7346659.html
3.实例
from appium import webdriver # from selenium import webdriver
from appium.webdriver.common.appiumby import AppiumBy desired = {
"platformName": "Android", # 手机系统
"platformVersion": "11", # 手机系统版本
"deviceName": '90bf8faf', # 连接的设备(adb devices)
"automationName": "UiAutomator2", # 自动化测试框架 (1.4以上的appium不用写)
"appPackage": "app包名", # app包名
"appActivity": "app启动页名", # app的启动页面
"autoGrantPermissions": "true", # 默认允许app获取相关权限
"noReset": True # 保留登录模式
}
driver = webdriver.Remote(command_executor="http://127.0.0.1:4723/wd/hub", desired_capabilities=desired)
四.常用方法与属性
1.implicitly_wait():设置隐性等待
driver.implicitly_wait(20) # 设置隐性等待,单位为秒
具体等待用法可见:https://www.cnblogs.com/lihongtaoya/p/16725333.html
2.page_source:打印页面代码
print(driver.page_source) # 打印当前页面代码
使用场景:我们在用uiautomatorviewer工具定位app页面元素时,有的页面(登录页面)禁止截图,
无法定位到元素,这时就可以使用page_source来打印页面代码来手动定位
3.install_app("url"):安装app
方法一
driver.install_app(r"C:\Users\username\Desktop\1.apk") # 安装apk
方法二
os.system(r"adb install C:\Users\username\Desktop\1.apk")
4.remove_app("包名"):根据包名卸载app
driver.remove_app("包名") # 卸载app,app_id为包名,pm list packages可查看
5.is_app_installed("包名"):根据包名判断当前设备有没有安装app
driver.is_app_installed("tv.danmaku.bili") # 根据包名判断当前是否安装了软件,安装了返回true,否则返回flase
6.click():点击事件
7.send_key():输入
8.clear():清空
9.get_attribute("name") :获取元素值
10.text:获取文本值
11.size:获取元素宽高
12.tag_name:获取tabname属性
13.is_displayed():判断元素是否可见(隐藏返回false,非隐藏返回true)
14.get_attribute("checked") :判断单选框或复选框是否被选中(选中返回true,未选中返回false)
15.is_selected():判断下拉框
16.is_enabled():判断元素是否可点击,可点击返回true,不可点击返回false
17.hide_keyboard():隐藏键盘
driver.hide_keyboard() # 隐藏键盘(前提键盘弹出)
18.start_activity():打开填写的app页
driver.start_activity(app_package="包名", app_activity="页面名") # 打开设置的页面名和包名
19.current_activity:获取当前页面名
driver.current_activity
20.current_package:获取当前包名
driver.current_package
21.切换/查看视窗
# WebView.setWebContentsDebuggingEnabled(true) # 打开开发者模式
print(driver.current_context) # 查看当前所在的视窗
print(driver.contexts) # 查看当前页面有多少视窗,返回数组
print(driver.context) # 查看当前所在的视窗
driver.switch_to.context("context_name") # 切换视窗
1)若要切换到webview视窗内,需要让开发打开开发者模式:WebView.setWebContentsDebuggingEnabled(true)
才能用driver.contexts查看视窗,然后切换。
2)current_context与context均为查看当前视窗,无区别。
22.scroll(e2, e1):页面滑动
driver.scroll(e2, e1) # 页面滑动,从元素e2滑动到e1(可横向和纵向滑动)
23.drag_and_drop(e1, e2):元素拖拽
driver.drag_and_drop(e1, e2) # 将元素e1拖拽到元素e2
24.tap(positions: List[Tuple[int, int]], duration: Optional[int]):按住某个坐标点
driver.tap([(498, 276), (338, 276)], 3000) # 设置同时按住多个坐标,元组类型的坐标[(),()]。可设置按住时长ms。
25.swipe(start_x: int, start_y: int, end_x: int, end_y: int, duration: int = 0):坐标拖拽
driver.swipe(x1,y1,x2,y2,3000) #从(x1,y1)坐标拖拽到(x2,y2)坐标,可设置拖拽时长ms
26.flick(start_x: int, start_y: int, end_x: int, end_y: int):坐标拖拽
driver.flick(x1,y1,x2,y2) # 从(x1,y1)坐标拖拽到(x2,y2)坐标
与swipe()的区别在于不能自定义拖拽时长
27.wait_activity():设置页面等待
driver.wait_activity("页面名", timeout=5, interval=1) # 设置等待页面的出现,timeout为等待时长,interval每间隔多久设别一次(false或true)
28.background_app(ms):设置返回后台运行多少s后再返回app
driver.background_app(5) # 设置返回后台运行多少s,后在返回app
29.shake():摇一摇手机
driver.shake() # 摇一摇手机
30.open_notifications():打开设备通知栏
driver.open_notifications() # 打开设备通知栏
31.toggle_location_services():打开定位设置页
driver.toggle_location_services() # 打开定位设置页
32.location:返回元素坐标
element.location # 返回元素xy坐标
element.location.get('x') # 返回元素x坐标
element.location.get('y') # 返回元素y坐标
33.get_screenshot_as_base64():手机截屏
driver.get_screenshot_as_base64() # 手机截屏
详情可见:https://www.cnblogs.com/lihongtaoya/p/16759942.html
34.execute_script():执行js脚本
driver.execute_script() # 执行js脚本
35.get_window_size():获取当前屏幕的长和宽
driver.get_window_size() # 获取当前屏幕的长和宽
36.quit():关闭页面
driver.quit()
37.press_keycode() :短按键
driver.press_keycode(26) # 26为按键码,按键码详情可见:https://blog.csdn.net/weixin_43004606/article/details/113552686
38.long_press_keycode():长按键码
driver.long_press_keycode(26) # 长按键码
和press_keycode()的区别一个是长按(如长按关机键),一个是短按
39.w3c_actions用法
本来是想介绍MultiAction和TouchAction的使用的,但是两者在appium2.0以后就弃用了,所以本次就只
介绍w3c_actions的用法了。
使用时应先导入ActionChains模块
om selenium.webdriver import ActionChains
1)click():指定元素左击
action.w3c_actions.pointer_action.click(element) # 指定元素左击
2)context_click():指定元素右击
action.w3c_actions.pointer_action.context_click(element) # 指定元素右击
3)double_click():双击
4)click_and_hold():长按元素
action.w3c_actions.pointer_action.click_and_hold(element) # 设置长按元素
5)pause():设置等待时长
actions.w3c_actions.pointer_action.pause(5) # 当前状态等待5s
6)release():松开
actions.w3c_actions.pointer_action.release() # 松开元素
7)perform():执行鼠标事件
action.perform()
8)move_to_location():鼠标移动到指定坐标
actions.w3c_actions.pointer_action.move_to_location(x=971, y=256).click() # 鼠标移动到指定坐标
9)move_to():鼠标移动到指定元素
actions.w3c_actions.pointer_action.move_to(element=driver.find_element(AppiumBy.XPATH, '//*[@text="取消"]')).click() # 鼠标移动到指定元素上
10)pointer_down():按下
11)pointer_up():松开
实例用法
示例一:设置按下一个元素长按5s后松开
action.w3c_actions.pointer_action.click_and_hold(element) # 设置长按元素
actions.w3c_actions.pointer_action.pause(5) # 当前状态等待5s
actions.w3c_actions.pointer_action.release() # 松开元素
action.perform()
示例二:移动到某个元素上按下再松开
actions.w3c_actions.pointer_action.move_to(element=driver.find_elements(AppiumBy.XPATH, '//*[@resource-id="com.vivo.browser:id/image" and @class="android.widget.ImageView"]')[0]).pointer_down() # 按下
actions.w3c_actions.pointer_action.pointer_up() # 松开
示例三:从一个坐标点滑动到另一个坐标点然后再松开
actions.w3c_actions.pointer_action.move_to_location(x=500, y=1000).pointer_down().move_to_location(x=500,y=500).pointer_up()
40.页面放大和缩小
这里不做过多的介绍了,直接看实例代码
from selenium.webdriver import ActionChains # 放大
actions = ActionChains(driver)
actions.w3c_actions.devices = [] # 创建多devices集
fin1 = actions.w3c_actions.add_pointer_input('touch', 'fin1') # 添加一个虚拟设备,一个手指
fin2 = actions.w3c_actions.add_pointer_input('touch', 'fin2') # 添加一个虚拟设备,第二个手指
fin1.create_pointer_move(x=500, y=1000) # 手指一移动到某点
fin2.create_pointer_move(x=500, y=1000) # 手指二移动到某点
fin1.create_pointer_down() # 手指一按下
fin2.create_pointer_down() # 手指二按下
fin1.create_pointer_move(x=500, y=500) # 手指一移动
fin2.create_pointer_move(x=500, y=1500) # 手指二移动
fin1.create_pointer_up(0) # 松开手指一释放
fin2.create_pointer_up(0) # 松开手指二释放
actions.perform() # 执行
time.sleep(3)
# 缩小
action = ActionChains(driver)
action.w3c_actions.devices = []
fin1 = action.w3c_actions.add_pointer_input('touch', 'fin1')
fin2 = action.w3c_actions.add_pointer_input('touch', 'fin2')
fin1.create_pointer_move(x=500, y=500)
fin2.create_pointer_move(x=500, y=1500)
fin1.create_pointer_down()
fin2.create_pointer_down()
fin1.create_pointer_move(x=500, y=1000)
fin2.create_pointer_move(x=500, y=1000)
fin1.create_pointer_up(0)
fin2.create_pointer_up(0)
action.perform()
文章来源:https://www.cnblogs.com/lihongtaoya/ ,请勿转载
appium基本使用(Android)的更多相关文章
- Appium学习路—Android定位元素与操作
一.常用识别元素的工具 uiautomator:Android SDK自带的一个工具,在tools目录下 monitor:Android SDK自带的一个工具,在tools目录下 Appium Ins ...
- Appium+Robotframework实现Android应用的自动化测试-6:一个简单的例子
万事具备,只欠编码! 下面看一个简单的示例,这个示例验证Android手机自带的通讯录的添加联系人的操作是否成功.这个例子是Appium官网自带的示例,有兴趣的同学也可以自己下载来研究和学习,下载地址 ...
- Appium+Robotframework实现Android应用的自动化测试-4:AppiumLibrary介绍和安装
Appium是个好东东,Android,iOS都支持,并且居然RobotFramework也支持Appium了,这就是本文要介绍的AppiumLibrary. 通过前面的文章大家知道可以使用多种语言来 ...
- Appium+Robotframework实现Android应用的自动化测试-2:Windows中启动Appium和模拟器
一.启动Appium 安装好了之后,在桌面或者菜单中找到Appium,分别双击或点击打开Appium.exe,如果一切正常,接着会出现一个Appium启动后的界面窗口,如下图所示. 1.1 Andro ...
- Appium+Robotframework实现Android应用的自动化测试-1:Appium在Windows中的安装
让我们开始在Windows中开始安装Appium吧,Appium在OS X中的具体安装后面的文章会介绍. 另外,官网上说先要装Node.js,还要装Apache Ant和Apache Maven,Gi ...
- Appium TestNg Maven Android Eclipse java简单启动实例
环境准备 Eclipse + maven + appium + TestNg 确保已经在Eclipse 上面安装maven TestNg的插件 打开Eclipse,新建一个java项目,把项目转换成m ...
- Appium Server 传递Android参数
Appium server Capabilities 传递参数 Android 特定 Android Only Capability Description Values appActivit ...
- Appium学习——安装Android SDK
.下载Android SDK 下载地址:http://tools.android-studio.org/index.php/sdk 百度搜索Android SDK也可以. 下载之后,Android S ...
- Windows下Python3+nose+appium自动化测试之Android篇
[本文出自天外归云的博客园] 简介 以下用来做自动化测试的这款app叫最爱抓娃娃,以后会改名为网易抓娃娃. 下文提到的appiumier项目里会包含用来测试的apk包以及自动化测试代码. 先说一个坑 ...
- Appium原理初步--Android自动化测试学习历程
章节:自动化基础篇——Appium原理初步(第七讲) 本期关键词: Appium.跨语言跨平台.Bootstrap 主要讲解内容及笔记: 一.what is appium 一种封装了uiautomat ...
随机推荐
- vue项目Eslint和prettier结合使用
一.eslint介绍--代码语法检查工具 Eslint是一个代码检查工具,用来检查你的代码语法是否符合指定的规范,ECMAScript标准 二.prettier插件--代码格式化工具 prettier ...
- 16.MongoDB系列之分片管理
1. 查看当前状态 1.1 查看配置信息 mongos> use config // 查看分片 mongos> db.shards.find() { "_id" : & ...
- 驱动开发:内核枚举进程与线程ObCall回调
在笔者上一篇文章<驱动开发:内核枚举Registry注册表回调>中我们通过特征码定位实现了对注册表回调的枚举,本篇文章LyShark将教大家如何枚举系统中的ProcessObCall进程回 ...
- Codeforces Round #829 (Div. 2) A-E
比赛链接 A 题解 知识点:枚举. 只要一个Q后面有一个A对应即可,从后往前遍历,记录A的数量,遇到Q则数量减一,如果某次Q计数为0则NO. 时间复杂度 \(O(n)\) 空间复杂度 \(O(1)\) ...
- Mysql之MGR高可用实战案例
MGR高可用实战案例 1.环境准备 node1 rocky8.6 10.0.0.8 node2 rocky8.6 10.0.0.18 node3 rocky8.6 10.0.0.28 2.所有节点更改 ...
- jvm之垃圾收集二之常用垃圾收集器
前面简单介绍了如何确定对象是垃圾.什么时候回收.怎么回收,今天就来聊一聊java中常见的垃圾回收器,从Serial到G1,其中会着重解读CMS和G1的工作原理,包括如何安全的并发回收.cSet.r ...
- docker使用代理(in home)
docker 使用 http http_proxy https://docs.docker.com/config/daemon/systemd/ # 代理 和 国内 镜像源 不要 同时使用,... # ...
- onps栈使用说明(3)——tcp、udp通讯测试
4. tcp客户端 在协议栈源码工程下,存在一个用vs2015建立的TcpServerForStackTesting工程.其运行在windows平台下,模拟实际应用场景下的tcp服务器.当tcp客户端 ...
- ironic组件硬件自检服务——ironic-inspector
介绍 ironic-inspector是一个用于硬件自检的辅助型服务,它可以对被ironic组件管理的裸金属节点进行硬件自检,通过在裸金属节点上运行内存系统,发现裸金属节点的硬件信息,例如CPU数量和 ...
- @Retryable注解的使用
@Retryable 前言 在实际工作中,重处理是一个非常常见的场景,比如: 发送消息失败. 调用远程服务失败. 争抢锁失败. 这些错误可能是因为网络波动造成的,等待过后重处理就能成功.通常来说,会用 ...