使用pytest+selenium编写网页UI自动化脚本和用例

1 UI自动化测试

UI自动化测试(User Interface Automation Testing)是一种通过编写脚本或使用自动化测试工具,对界面(UI)进行自动化测试的方法。原理主要是模拟用户打开客户端或网页的UI界面,自动化执行用户界面上的操作,如点击按钮、输入文本、选择但下拉框/单选,多选项等,并检查测试对象的响应行为是否符合预期。

比如一些常用的测试框架或者工具(robotframework,testng,pytest,selenium,appnium,playwright等)都支持UI界面的自动化测试,而这节内容主要介绍下pytest框架+selenium工具在web端的自动化实践。

                                                                        测试分层

2 安装所需的python包

pytest安装

使用pip命令安装: pip install pytest -i https://mirrors.aliyun.com/pypi/simple/

selenium安装

使用pip命令安装: pip install selenium -i https://mirrors.aliyun.com/pypi/simple/

目前最新版本4.23.1,需要适配python版本3.8+及以上版本

PS:安装在pytest工程所运行的python环境,python的安装目录或者虚拟环境目录,可以参考之前文章查看运行环境pycharm配置pytest运行环境)

3 selenium介绍

Selenium是一个用于Web应用程序的自动化测试工具,支持多平台(Windows、Linux和Mac)、多浏览器(IE,Mozilla Firefox、Safari、Google Chrome、Opera、Edge)、多语言(Java、Python、C#、JavaScript、Ruby),能够让测试脚本像真实用户一样在浏览器中操作。

核心组件:

Selenium IDE:Selenium Suite下的开源Web自动化测试工具,是Firefox的一个插件,具有记录和回放功能,无需编程即可创建测试用例。

Selenium WebDriver:Selenium 2.0及以后版本的核心,通过原生浏览器支持或浏览器扩展直接控制浏览器,取代了Selenium RC中的JavaScript注入技术。

Selenium Grid:一种自动化测试辅助工具,能够加快Web应用的功能测试,支持并行执行多个测试事例。

3.1 配置操作系统环境支持使用selenium打开浏览器

以下介绍以在mac系统上配置打开safari浏览器和谷歌浏览器举例。

配置MAC系统safari浏览器支持selenium打开

safari浏览器从10及以上版本通常内置了对WebDriver的支持,不需要下载浏览器的驱动,但是需要配置浏览器支持使用selenium打开。如果不配置执行程序会报以下错误:

配置步骤:

打开Safari浏览器。

点击菜单栏上的“Safari浏览器”,然后选择“偏好设置”(Preferences)。

在偏好设置窗口中,点击“高级”(Advanced)标签页。

勾选“在菜单栏中显示‘开发’菜单”(Show Develop menu in menu bar)。

关闭偏好设置窗口,然后点击菜单栏上的“开发”(Develop)菜单。

勾选“允许远程自动化”(Allow Remote Automation)。

配置后我们使用selenium打开safari浏览器

首先导入selenium.webdriver,然后我们打开浏览器,等待一段时间后使用quit函数退出浏览器。

from selenium import webdriver
import time

# 创建Safari浏览器的WebDriver实例
drive
<think>好的,我现在需要帮助用户了解如何使用pytest、AllureSelenium编写UI自动化测试脚本。首先,我需要回顾用户提供的引用内容,确保回答准确并正确引用。 用户引用了四个资源,主要涉及环境搭建、框架工具、显式等待PO模式。首先,我应该整理这些信息,分步骤说明如何创建测试脚本。 第一步,环境搭建。根据引用12,需要安装pytestselenium、allure-pytest等库。需要确认安装命令是否正确,比如使用pip安装这些包。 第二步,创建测试用。引用3提到了显式等待的使用,这部分很重要,需要在代码示中展示如何利用WebDriverWait。同时,引用4提到了PO模式,但用户的问题可能不需要深入PO模式,但可以简要提及作为扩展。 第三步,添加Allure报告。需要说明如何在测试中使用装饰器,比如@allure.feature@allure.story,以及生成报告的命令行步骤。 第四步,断言测试逻辑。确保测试用中有正确的断言,比如检查页面标题或元素是否存在。 另外,需要注意代码示的正确性,比如WebDriverWait的使用,以及正确的导入语句。引用3中的代码示有一个URL错误(www.TESTcsdn.com),可能需要指出或更正。 可能还需要提到目录结构,比如将测试用放在tests目录下,使用pytest的默认发现规则。 最后,生成相关问题,涵盖环境搭建、元素定位、报告优化PO模式等方面,帮助用户进一步学习。 需要确保回答结构清晰,分步骤说明,并正确引用来源。同时检查LaTeX格式是否符合要求,但用户的问题可能不涉及数学公式,所以可能不需要使用。但根据系统指令,所有行内数学表达式必须用$...$,但这里可能不涉及,所以重点放在代码块引用上。</think>### 如何用 pytest + Allure + Selenium 编写 UI 自动化测试脚本 #### 1. 环境搭建 - **安装依赖库**: ```bash pip install pytest selenium allure-pytest webdriver-manager ``` 引用 pytest 作为测试框架,Selenium 用于浏览器操作,Allure 生成可视化报告[^1][^2]。 #### 2. 创建基础测试用 ```python # test_login.py import allure import pytest from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC @allure.feature("登录功能测试") class TestLogin: @pytest.fixture(scope="class") def setup(self): driver = webdriver.Chrome() driver.maximize_window() yield driver driver.quit() @allure.story("管理员登录成功场景") def test_admin_login(self, setup): driver = setup driver.get("https://example.com/admin/login") # 显式等待输入框加载完成[^3] username = WebDriverWait(driver, 10).until( EC.presence_of_element_located((By.ID, "username")) ) username.send_keys("admin") password = driver.find_element(By.ID, "password") password.send_keys("123456") driver.find_element(By.CSS_SELECTOR, "button[type='submit']").click() # 断言登录后跳转到仪表盘页面 assert "dashboard" in driver.current_url allure.attach(driver.get_screenshot_as_png(), name="登录成功截图", attachment_type=allure.attachment_type.PNG) ``` #### 3. 配置 Allure 报告 - 在项目根目录创建 `pytest.ini`: ```ini [pytest] addopts = --alluredir=./allure-results ``` - 运行测试并生成报告: ```bash pytest test_login.py --alluredir=./allure-results allure serve ./allure-results ``` #### 4. 关键优化点 - **显式等待**:使用 `WebDriverWait` 确保元素加载完成,避免隐式等待导致的全局延迟。 - **PO模式**:可通过 `base_page.py` 封装公共方法(如元素定位、截图),提升代码复用性[^4]。 - **异常处理**:结合 `pytest.mark.xfail` 标记预期失败的用。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

科雷learning

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值