Android自动化测试实践:uiautomator2 核心功能与应用指南

Android自动化测试实践:uiautomator2 核心功能与应用指南

uiautomator2 是一个用于Android应用的自动化测试Python库,支持多设备并行测试操作。它提供了丰富的API来模拟用户对App的各种操作,如安装、卸载、启动、停止以及清除应用数据等。此外,uiautomator2 支持多种设备连接方式,包括USB、模拟器默认连接以及通过WiFi(TCP/IP)连接。

核心功能:

  1. 设备连接与操作:支持USB和WiFi(TCP/IP)方式连接设备,提供了查看设备列表的命令和示例代码。
  2. 应用管理:能够安装和卸载应用,启动、停止以及获取正在运行的应用列表。
  3. 节点选择器:提供多种节点选择器,如基于文本、类名、描述、元素状态、包名、资源ID等来定位UI元素。
  4. 节点操作:支持获取匹配节点列表、节点存在性判断、节点计数,以及查找父级节点、子节点和同级元素。
  5. 事件操作:模拟用户交互,如点击、输入文本、滑动屏幕等。
  6. 坐标定位:获取元素坐标并执行坐标点击。
  7. 提示信息获取:能够获取系统提示语。

适用场景:

  • 自动化测试:为Android应用提供自动化测试解决方案,提高测试效率。
  • 应用开发:辅助开发者在开发过程中快速定位和测试UI元素。
  • 教育与研究:作为学习和研究Android自动化测试工具的资源。

使用注意:

  • 确保设备开启了开发者选项和USB调试。
  • 对于WiFi连接,需要先通过USB连接设备并设置TCP/IP端口,然后通过IP地址和端口号进行连接。

附加工具:

  • weditor:一个节点查看工具,帮助用户更方便地进行节点选择和测试。

img

APP的操作

url = "apk下载地址"
d.app_install(url)d.app_uninstall("包名")
d.app_start("包名")
d.app_stop("包名")
d.app_clear("包名")d.app_list_running() #获取正在运行的列表#获取正在运行的包名
print(d.app_current())

连接设备

查看设备列表

  • adb devices

  • 要使用 uiautomator2 查看设备列表,可以使用以下命令: python -m uiautomator2 init

USB模式

注意:开发者选项,打开USB调试

import uiautomator2 as u2# 注意网络代理
u2.wait_timeout = 20  # 设置等待时间为20秒
d = u2.connect_usb()

使用设备号连接

device = u2.connect("46d0c494") # usb连接,需要开启开发者模式,用atx也可以开启开发中模式,cmd输入adb devices获取设备号

模拟器连接

device = u2.connect() # 模拟器默认连接方式

wifi(tcpip )连接

  • USB连接手机,开发者选项,打开USB调试

  • adb tcpip 5555

  • 拔掉USB连接

  • adb connect 192.168.120.139:5555 连接设备

  • adb devices 查看设备列表

  • device = u2.connect(“192.168.0.187:5555”) # tcpip同个局域网连接

如果 adb 连接断开了,可以adb connect 192.168.0.187:5555 再次连接设备,未连接的话,

adb kill-server 重置主机

weditor工具-节点查看

#安装
pip install weditor==0.6.4 -i http://pypi.douban.com/simple --trusted-host pypi.douban.com 
#运行
python -m weditor 

image-20230615144526724

节点操作

选择器

多种节点选择器用于定位UI元素。

  • text、textContains、textMatches、textStartsWith用于根据文本内容定位元素;
  • className、classNameMatches用于根据类名定位元素;
  • description、descriptionContains、descriptionMatches、descriptionStartsWith用于根据元素描述定位元素;
  • checkable、checked、clickable、longClickable、scrollable、focused、selected、enabled、focusable用于根据元素状态定位元素;
  • packageName、packageNameMatches用于根据应用包名定位元素;
  • resourceId、resourceIdMatches用于根据资源ID定位元素;
  • index、instance用于根据元素在页面中的位置定位元素。

多个匹配

import uiautomator2 as u2# 连接设备
d = u2.connect_usb()# 获取所有匹配的节点(节点列表)
nodes = d(resourceId="com.ximalaya.ting.android:id/main_tv_name")
# 获取所有匹配的节点列表de 下标为2的节点
node_3 = d(resourceId="com.ximalaya.ting.android:id/main_tv_name",instance=2)# 判断节点是否存在
if nodes.exists:# 获取匹配的节点数量count = nodes.countprint("匹配的节点数量:", count)# 循环获取节点的text属性for node in nodes:text = node.info["text"]print("节点的text属性:", text)
else:print("没有匹配的节点")

查找父级节点(比较慢)

import uiautomator2 as u2# 连接设备
d = u2.connect_usb()# 获取节点对象
node = d(resourceId="com.example.app:id/parent_node")# 查找父级节点
parent_node = node.parent
print("父级节点:", parent_node)

查找子节点

import uiautomator2 as u2# 连接设备
d = u2.connect_usb()# 获取节点对象
node = d(resourceId="com.example.app:id/parent_node")child_nodes_0 = d(resourceId="com.example.app:id/parent_node").child(resourceId="com.example.app:id/child_node")# 查找所有子节点
child_nodes = node.child
print("所有子节点:", child_nodes)# 或者使用 children() 方法
child_nodes = node.children()
print("所有子节点:", child_nodes)

查找同级元素

text_view = my_icon.sibling(className='android.view.View')
text view.click()

查找(上下左右)的元素 (速度慢)

my = d(resourceId='com.example.app:id/button')
my.left().click()
my.right().click()
my.down().click()
my.up().click()

获取元素坐标

from uiautomator2 import Device# 连接设备
d = Device('设备序列号')# 获取元素
element = d(resourceId='com.example.app:id/button')# 获取元素中心坐标
x, y = element.center()
print(f"元素中心坐标为 ({x}, {y})")

事件操作

元素点击

# 获取元素
element = d(resourceId='com.example.app:id/button')
element.click()

坐标点击

d.click(500,500)

百分比点击

d.click(0.5,0.5)

输入

 node = d(longClickable="true",className="android.widget.EditText")node.send_keys("[炸弹]")

滑动屏幕

坐标系的起点是屏幕左上角(0,0),向右和向下为正坐标系

import uiautomator2 as u2# 获取屏幕的宽度和高度
screen_width = d.info["displayWidth"]
screen_height = d.info["displayHeight"]
# 计算起始点和终点的坐标
start_x = screen_width // 2
start_y = screen_height - 20  # 起始点的y坐标可以根据需要进行调整
end_x = start_x
end_y = start_y - (218 * 6)  # 终点的y坐标可以根据需要进行调整d = u2.connect_usb()# 执行滑动操作
d.swipe(start_x, start_y, end_x, end_y)

获取提示语

d.totast.get_message()

文档参考地址

  • https://blog.csdn.net/qq_32603969/article/details/121459006
  • https://www.jianshu.com/p/38f48390c538
  • 比较全面App自动化测试工具Uiautomator2
  • python+uiautomator2 实现多设备并行

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/38331.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

30个!2024重大科学问题、工程技术难题和产业技术问题发布

【SciencePub学术】中国科协自2018年开始,组织开展重大科技问题难题征集发布活动,引导广大科技工作者紧跟世界科技发展大势,聚焦国家重大需求,开展原创性、引领性研究,不断夯实高质量发展的科技支撑。 自2024年征集活动…

飞书文档转markdown 超级快捷方法。

直接使用那个github的高赞官方的工具转换,需要设置什么小应用那种东西,还要审批,社恐人表示怕了怕了。而且文档我分享出去,是有权限的,反正无论如何生成不了 我的方法是 直接全选,然后粘贴进Arya - 在线 …

C#的五大设计原则-solid原则

什么是C#的五大设计原则,我们用人话来解释一下,希望小伙伴们能学会: 好的,让我们以一种幽默的方式来解释C#的五大设计原则(SOLID): 单一职责原则(Single Responsibility Principle…

PCL 渐进形态过滤器实现地面分割

点云地面分割 一、代码实现二、结果示例🙋 概述 渐进形态过滤器:采用先腐蚀后膨胀的运算过程,可以有效滤除场景中的建筑物、植被、车辆、行人以及交通附属设施,保留道路路面及路缘石点云。 一、代码实现 #include <iostream> #include <pcl/io/pcd_io.h> #in…

【LeetCode】976. 三角形的最大周长

1. 题目 2. 分析 需要分析好再动手编程。 如果要构成三角形的最大周长&#xff0c;那么就需要尽可能用最长的边构建。所以可以先对数组排个序&#xff0c;然后基于排序得到的结果从大往小的逐个检查长度为3的窗口&#xff0c;判断该窗口的值是否满足三角形的构成条件&#x…

鸿蒙开发Ability Kit(程序访问控制):【安全控件概述】

安全控件概述 安全控件是系统提供的一组系统实现的ArkUI组件&#xff0c;应用集成这类组件就可以实现在用户点击后自动授权&#xff0c;而无需弹窗授权。它们可以作为一种“特殊的按钮”融入应用页面&#xff0c;实现用户点击即许可的设计思路。 相较于动态申请权限的方式&am…

构造,析构,拷贝【类和对象(中)】

P. S.&#xff1a;以下代码均在VS2019环境下测试&#xff0c;不代表所有编译器均可通过。 P. S.&#xff1a;测试代码均未展示头文件stdio.h的声明&#xff0c;使用时请自行添加。 博主主页&#xff1a;LiUEEEEE                        …

Excel_VBA编程

在Excel中&#xff0c;VBA&#xff08;Visual Basic for Applications&#xff09;是一种强大的工具&#xff0c;可以用来自动化各种任务。下面介绍一些常用的VBA函数和程序结构&#xff1a; 常用函数 MsgBox&#xff1a;用于显示消息框。 MsgBox "Hello, World!"In…

【python全栈系列】day07-python数据类型-集合

Python中的集合&#xff08;Set&#xff09;是一个无序的、不包含重复元素的数据结构。它主要用于数学上的集合操作&#xff0c;如并集、交集、差集和对称差集等。集合的基本用途包括去重和关系测试。 1、集合的特性 无序性&#xff1a;集合中的元素是无序的&#xff0c;这意…

gin-vue -admin 初始化安装后 进入 后台首页报错

报错原因&#xff1a; 因为 我是使用的phpstudy 小皮的数据库 默认的是MySam 的引擎 mysql 引擎需要是 innoDB 解决办法 &#xff1a; 在linux 的环境下 配置一个数据库 &#xff0c; 我是用的是vmware 虚拟机

深入理解分布式搜索引擎 ElasticSearch,并能基于 ELK+Kafka 搭建分布式⽇志收集系统

Elasticsearch是一个基于Lucene的分布式、多租户能力的全文搜索引擎。它提供了RESTful web接口和分布式多用户能力的全文搜索引擎&#xff0c;基于Apache许可证发行。以下是对Elasticsearch的深入理解以及如何基于ELK&#xff08;Elasticsearch、Logstash、Kibana&#xff09;加…

npm缓存深度解析:理解、使用与清除指南

&#x1f31f; npm缓存深度解析&#xff1a;理解、使用与清除指南 npm&#xff08;Node Package Manager&#xff09;是JavaScript编程语言的包管理器&#xff0c;广泛用于Node.js应用程序。它不仅帮助我们安装和管理项目依赖&#xff0c;还拥有一个强大的缓存机制来加速这一过…

[论文笔记] BlendedDataset blend goes out of bounds for list 34 for valid split

报错&#xff1a; Traceback (most recent call last):File "/mnt/cpfs/kexin/dlc_code/qwen2/Pai-Megatron-Patch/examples/qwen2/pretrain_qwen.py", line 211, in <module> (<megatron.core.datasets.gpt_dataset.GPTDataset object at 0x7f491886bf10&…

《昇思25天学习打卡营第8天|CarpeDiem》

《昇思25天学习打卡营第8天|CarpeDiem》 模型训练构建数据集定义神经网络模型定义超参、损失函数和优化器超参损失函数优化器 训练与评估 打卡 今天是昇思25天学习打卡营的第8天&#xff0c;终于迎来 模型训练 的部分了&#xff01;&#xff01;&#xff01; 兴奋 发癫 模型训…

SSH远程命令执行漏洞(CVE-2024-6387)验证

0x01、漏洞名称 OpenSSH远程代码执行漏洞 &#xff08;CVE-2024-6387&#xff09; 0x02、漏洞简介 ​ OpenSSH是SSH&#xff08;Secure SHell&#xff09;协议的开源实现&#xff0c;它通过不安全的网络在两个不受信任的主机之间提供安全的加密通信。OpenSSH 广泛用于基于Un…

数据库。

数据库安全性 论述题5’ 编程题10’ sql语言实现权限控制 一、概述 1、不安全因素 &#xff08;1&#xff09;⾮授权对数据库的恶意存取和破坏 &#xff08;2&#xff09;数据库中重要的数据泄露 &#xff08;3&#xff09;安全环境的脆弱性 2、⾃主存取控制⽅法 gr…

【ajax实战06】进行文章发布

本文章目标&#xff1a;收集文章内容&#xff0c;并提交服务器保存 一&#xff1a;基于form-serialize插件收集表单数据 form-serialize插件仅能收集到表单数据&#xff0c;除此之外的数据无法收集到 二&#xff1a;基于axios提交到服务器保存 三&#xff1a;调用alert警告…

基于KMeans的航空公司客户数据聚类分析

&#x1f490;大家好&#xff01;我是码银~&#xff0c;欢迎关注&#x1f490;&#xff1a; CSDN&#xff1a;码银 公众号&#xff1a;码银学编程 实验目的和要求 会用Python创建Kmeans聚类分析模型使用KMeans模型对航空公司客户价值进行聚类分析会对聚类结果进行分析评价 实…

Linux修炼之路之进程概念,fork函数,进程状态

目录 一&#xff1a;进程概念 二&#xff1a;Linux中的进程概念 三&#xff1a;用getpid(),getppid()获取该进程的PID,PPID 四&#xff1a;用fork()来创建子进程 五&#xff1a;操作系统学科的进程状态 六&#xff1a;Linux中的进程状态 接下来的日子会顺顺利利&#xf…

【区块链+基础设施】深证金融区块链平台 | FISCO BCOS应用案例

作为数据交换密集型行业&#xff0c;资本市场是区块链创新应用的重要领域&#xff0c;区块链技术可以有效解决诸多痛点问题。比 如&#xff0c;针对信息不对称的问题&#xff0c;区块链技术通过将整个企业的经营活动信息上链&#xff0c;有效降低尽调成本&#xff0c;为投融资决…