ADB驱动 + Uiautomator2 环境搭建(python自动化)

ADB驱动 + Uiautomator2 环境搭建

ADB驱动

ADB驱动下载

百度搜索ADB驱动下载并安装,我用的是adb1.4.3版本的,低版本有部分指令不兼容,比较麻烦。

  • 可以去官网下载,也可以在各种软件网下载。搞颜色的,搜索能力都不差,对吧。
    在这里插入图片描述

ADB安装

下载好后,点击 .exe 可执行文件,将会弹出蓝色窗口,一直 y y y就好了。
在这里插入图片描述
随后转入设备驱动程序安装向导(ADB驱动也不是特别大,直接跟着默认走就好了,现在都0202年了):
在这里插入图片描述
给ADB驱动配环境变量,如何配置环境变量就不详讲了。
在这里插入图片描述
这样,我们的ADB驱动就搞好了。可以去命令行测试,要将移动端用手机接入PC中
常用的几条ADB指令,我只是像写个自动化脚本,所有没过多研究有哪些指令(有接触到其他的在补充)
要注意是否有其他程序占有了ADB的端口号,默认是“5037”

  • adb devices 应该是获取手机的序列号。
    在这里插入图片描述
    ADB也可以用压缩包喔,只用在环境变量中添加adb文件夹的地址即可

Uiautomator2 安装

uiautomator2下载

进入命令框输入:pip install -i https://pypi.tuna.tsinghua.edu.cn/simple uiautomator2
之前已经写过了如何镜像了 传送门

Python调用 uiautomator2模块

import uiautomator2


安装ATX手机插件

在命令行输入 python -m uiautomator2 init 给你的手机下载并安装 atx-agent 软件,一定要安装的喔
在这里插入图片描述                                                             在这里插入图片描述


查看

我们将把这个序列号用在ATX WEditor下的(下图的红框框内)
在这里插入图片描述

综合(都配置好的前提)

  • 在命令行处使用 adb devices 获取序列号
  • 在命令行处输入 python -m weditor 将会通过默认浏览器打开 http://localhost:17310/这一网址
    在这里插入图片描述
  • 在刚才讲的红框处,输入自己的序列号
  • 点击 Connect 按键,启动,启动成功后会多片树叶
  • 开始编写python脚本,像d(XXXXXYYYYY)这一串,可以在 http://localhost:17310/ 的代码处复制
    和python里的pyautogui模块控制鼠标键盘是类似的

实测有用的函数

初始化

#用IPV4来连接,可在ATX那个APP上看到
d = uiautomator2.connect(“192.168.0.100”)
#只要单台移动设备是可以不用填写,多台设备就需要在方法内加入对应的序列号了
d = uiautomator2.connect_usb(‘5165vsdbsb’)

开/关屏幕

#唤醒屏幕
d.screen_on()
#关闭屏幕
d.screen_off()

打开/关闭应用

  • 手机端先打开相应的应用,然后在命令行输入“ adb shell dumpsys window w |findstr / |findstr name=”得到当前打开APP的安装包名。
  • 例如今日校园:mSurface=Surface(name=adb shell dumpsys window w |findstr / |findstr name=)

#打开应用
d.app_start(‘com.wisedu.cpdaily/com.wisorg.wisedu.home.ui.HomeActivity’)
#关闭应用(关闭应用时,应返回桌面后再关闭应用)
d.app_stop(‘com.wisedu.cpdaily/com.wisorg.wisedu.home.ui.HomeActivity’)

滑动

#滑屏解锁屏幕
d.swipe(0.224, 0.751, 0.766, 0.534)

点击

#在手机屏幕上找XXXX文字的按钮进行点击,支持中文
d(text=“XXXX”).click()
d(text=“你好,世界”).click()

#点击目标按钮
d(description=“XXXX”).click()
#根据Xpath的位置点击文件
d.xpath(’//*[@resource-id=“com.wisedu.cpdaily:id/lv_app_msg”]’).click()
#根据坐标的百分比点击
d.click(0.489, 0.535)

输入文字

d(resourceId=“com.location.XXXXXXXX”).set_text(‘hello world’)
在d(resourceId=“com.location.XXXXXXXX”)对应的文本框输入“hello world”

步骤

  1. 设置初始化(选着用wifi还是数据线)
  2. 开屏
  3. 实现模拟。。。
  4. 熄屏

打开ATX-Agent这款App

  1. 将手机插上电脑,并在手机端选择 数据传输方式
  2. 打开电脑端的CMD,并输入"python -m uiautomator2 init"
  3. 待加载完成后,打开手机端的ATX-Agent软件
  4. 点击"启动UIAUTOMATOR",即可完成手机端的ATX-Agent启动

不错的文章

值得参考的详细教程
指令集
adb大全

<think>好的,我现在需要回答用户关于uiautomator2结合pytest进行自动化测试封装的问题。首先,我应该回忆一下这两个工具的基本概念和它们各自的优势。uiautomator2是Android UI自动化测试框架,支持Python,可以操作设备进行点击、滑动等操作。而pytest是一个功能强大的Python测试框架,提供了丰富的插件和灵活的fixture机制,适合组织测试用例。 接下来,用户可能想知道如何将这两者结合起来进行封装,以提高测试效率和可维护性。因此,我需要分步骤解释封装的思路和关键点。可能需要包括环境搭建、设备初始化、元素封装、测试用例编写、断言机制、报告生成等方面。 首先,环境搭建部分需要说明安装uiautomator2和pytest的步骤,以及设备连接的方法。然后,设备初始化应该提到使用pytest的fixture来管理设备的启动和销毁,这样可以确保每个测试用例前后设备处于正确状态。 元素封装方面,需要强调使用Page Object模式,将页面元素和操作分离,这样当UI变化时只需修改对应页面类,而不影响测试用例。此外,定位元素的策略,比如通过resource-id、text等,也需要提及,可能还要提到如何处理动态元素或等待元素出现的情况。 测试用例编写部分,要结合pytest的特性,如参数化测试、标记用例等,说明如何组织测试用例,使其结构清晰。断言机制需要说明如何利用pytest的断言以及自定义的验证方法,确保测试结果的准确性。 报告生成方面,可以提到使用pytest-html等插件生成测试报告,方便查看结果。另外,异常处理和日志记录也是重要部分,需要在封装时考虑如何捕获异常、记录详细日志,便于问题排查。 可能还需要考虑持续集成,比如将自动化测试集成到Jenkins或GitHub Actions中,定期执行测试。此外,并发测试的问题,比如使用pytest-xdist插件并行执行用例,提高测试效率。 需要注意的是,用户可能对具体的代码示例感兴趣,但根据系统指令,不需要提供代码块,但可以提及关键代码结构。同时,要确保使用中文,并且数学公式或技术术语符合格式要求,比如用$...$包裹行内公式,独立公式用$$...$$,不过在这个问题中可能涉及较少数学公式,但技术名词如类名、方法名可能需要适当处理。 最后,要确保回答结构清晰,分点说明,帮助用户逐步理解整个封装过程,同时保持真实可靠,避免错误信息。可能需要检查是否有遗漏的关键点,比如数据驱动测试、Hook函数的使用、自定义fixture的作用域等。 总结一下,回答的结构应该是先介绍工具,再分步骤讲解封装的关键部分,每个部分详细说明其作用和实现方法,最后提到优化和扩展的可能性,比如持续集成和并发测试。这样用户能够系统地了解如何将uiautomator2和pytest结合起来进行有效的自动化测试封装。</think>以下是对`uiautomator2 + pytest`自动化测试封装的系统化介绍,分步骤说明关键要点: --- ### 1. **工具简介** - **uiautomator2**:基于Android UI的Python测试框架,支持控件定位(如`resource-id`、`text`)、操作(点击、滑动、输入)及断言。 - **pytest**:Python测试框架,提供`fixture`依赖管理、参数化测试、插件扩展(如报告生成)等功能。 --- ### 2. **环境搭建** 1. **安装依赖** ```bash pip install uiautomator2 pytest pytest-html ``` 2. **设备连接** 通过ADB连接设备:`adb devices`,确保设备唯一性。 --- ### 3. **核心封装思路** #### **3.1 设备初始化(Fixture管理)** - 使用`pytest.fixture`管理设备生命周期: ```python import pytest import uiautomator2 as u2 @pytest.fixture(scope="session") def device(): d = u2.connect() # 连接设备 d.app_start("com.example.app") # 启动被测应用 yield d d.app_stop("com.example.app") # 测试结束后关闭应用 ``` - `scope="session"`表示整个测试会话只初始化一次设备。 #### **3.2 页面对象模型(Page Object)** - **封装页面元素与操作**: ```python class LoginPage: def __init__(self, device): self.d = device def input_username(self, text): self.d(resourceId="com.example:id/username").set_text(text) def click_login(self): self.d(resourceId="com.example:id/login_btn").click() ``` - 页面元素通过`resource-id`定位,操作通过方法暴露,实现UI与逻辑分离。 #### **3.3 测试用例编写** - **结合pytest参数化与断言**: ```python import pytest @pytest.mark.parametrize("username, password", [("user1", "pass1"), ("user2", "pass2")]) def test_login(device, username, password): login_page = LoginPage(device) login_page.input_username(username) login_page.input_password(password) login_page.click_login() assert device(text="Welcome").exists() # 验证登录成功 ``` #### **3.4 异常处理与等待** - **隐式等待控件出现**: ```python d(resourceId="com.example:id/btn").wait(timeout=10) # 最多等待10秒 ``` - **捕获异常并截图**: ```python try: d.click(...) except u2.UiObjectNotFoundError: d.screenshot("error.png") pytest.fail("控件未找到") ``` --- ### 4. **测试执行与报告** 1. **命令行执行** ```bash pytest test_cases/ --html=report.html # 生成HTML报告 ``` 2. **并发执行(pytest-xdist)** ```bash pytest -n 4 # 启动4个进程并行测试 ``` --- ### 5. **进阶优化** - **数据驱动**:通过`YAML/JSON`文件管理测试数据。 - **Hook函数**:使用`pytest`的`conftest.py`定义全局前置/后置操作。 - **持续集成**:集成到`Jenkins`或`GitHub Actions`,定时执行测试。 --- ### 6. **优势总结** - **可维护性**:页面对象模型降低UI变动的影响。 - **灵活性**:pytest插件生态支持丰富扩展(如Allure报告)。 - **高效性**:并发执行减少测试耗时。 通过以上封装,可构建稳定、易扩展的Android自动化测试框架。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值