PythonUI自动化测试教程_Selenium与Appium应用实战

14次阅读

python ui自动化测试核心是用代码模拟用户操作:Selenium用于Web(需WebDriver+显式等待+元素定位),appium用于移动(需配置desired_caps+原生交互方法),统一用pytest管理用例与Allure报告,注重稳定性与可维护性。

PythonUI自动化测试教程_Selenium与Appium应用实战

Python UI自动化测试的核心是用代码模拟真实用户操作,Selenium 用于 Web 应用,Appium 用于移动应用(ios/android),两者都通过 WebDriver 协议驱动浏览器或设备。

用 Selenium 实现 Web 页面自动化

先安装依赖:pip install selenium,再下载对应浏览器的 WebDriver(如 ChromeDriver)。关键步骤是:启动驱动、打开网页、定位元素、执行操作(点击、输入、提交等)、断言结果。

  • 定位元素推荐用 find_element(By.ID, "xxx")find_element(By.XPATH, "//button[@class='submit']"),比旧版 find_element_by_id 更稳定
  • 等待页面加载完成别用 time.sleep(),改用显式等待:WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.ID, "login-btn")))
  • 登录、搜索、表单提交这类高频场景,建议封装成函数,比如 def login(username, password):,方便复用和维护

用 Appium 测试 Android/iOS App

Appium 是跨平台的移动自动化框架,底层也基于 WebDriver。需安装 Appium Desktop 或命令行服务,并配置好手机环境(Android SDK、adb、真机或模拟器;iOS 需 xcode 和 WebDriverAgent)。

  • 启动会话前要准备 desired_caps 字典:指定平台("platformName": "Android")、设备名("deviceName": "Pixel_4_API_30")、App 路径或包名("appPackage" + "appActivity"
  • 元素定位方式与 Selenium 类似,但移动端常用 accessibility_id(对应 content-desc 或 label)或 idResource-id),XPath 在复杂层级中仍有效
  • 处理 Toast、权限弹窗、滑动、多点触控等原生交互,要用 Appium 特有方法,例如 driver.swipe(start_x, start_y, end_x, end_y, duration)

统一管理测试用例与报告

pytest 替代 unittest,结构更简洁,支持参数化(@pytest.mark.parametrize)、fixture 复用(如 driver 初始化/关闭)、插件扩展(allure 生成美观报告)。

立即学习Python免费学习笔记(深入)”;

  • 把 driver 创建逻辑抽到 conftest.py 的 fixture 中,所有测试函数自动获取实例,避免重复代码
  • 截图辅助排查:在异常时自动保存截图,driver.get_screenshot_as_file(f"screenshots/{test_name}_{int(time.time())}.png")
  • 运行时加 --alluredir=./allure-results,再用 allure serve ./allure-results 查看交互式报告

避开常见坑点

UI 自动化容易因环境、网络、动态 ID 导致失败,稳定性比功能逻辑更重要。

  • 避免硬编码 XPath 中的索引(如 [2]),改用文本、属性组合定位,比如 //android.widget.Button[@text="确认" and @enabled="true"]
  • Web 页面 iframe 内元素必须先 switch_to.frame(),操作完记得切回默认内容 switch_to.default_content()
  • Appium 连接真机后报错“Could not proxy command”,大概率是 app 处于后台或被系统杀掉,加 "noReset": True 或重启 app
text=ZqhQzanResources