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

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)或id(resource-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 导致失败,稳定性比功能逻辑更重要。










