首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
聊聊Web自动化测试:黑盒、白盒、α测试、β测试、冒烟测试、回归测试
Selenium三剑客:WebDriver、IDE、Grid一网打尽
Selenium开发环境搭建
下载安装浏览器驱动:教你解决最麻烦的版本匹配问题
第一个Selenium测试:Selenium测试流程、源码分析
实现元素定位:掌握Selenium八大定位方法
通过打车生活案例,深入剖析WebDriver运行原理
掌握WebDriver核心方法和属性的使用
掌握WebElement核心方法和属性的使用
form表单:熟练掌握form表单操作步骤
掌握checkbox和radiobutton的定位技巧
下拉列表:熟练使用Select类,来实现下拉列表定位
弹框处理:掌握alert、confirm、prompt三种弹出的用法
Selenium三种等待方式:剖析原理、用法和应用场景
Selenium等待条件:掌握17种元素等待条件
掌握鼠标单击、双击、右击,键盘输入、键盘组合键的应用
熟练执行JavaScript的方法和技巧,掌握JavaScript操作滚动条
Selenium屏幕截图:实现屏幕截屏、按照日期时间格式保存图片
掌握frame、iframe定位,熟练frame的切入和切出
下载安装Selenium IDE:下载安装Chrome、Firefox插件IDE
熟练Selenium IDE菜单栏、工具类、命令窗口的使用
Selenium IDE实现录制和回放及脚本导出
项目环境搭建:安装JDK、MySQL、Tomcat和测试系统
需求分析和用例设计:深度挖掘需求,掌握测试用例设计范式
项目架构设计:掌握分层设计思想,合理设计目录和包结构
解决验证码问题-方案一:使用pytesseract和Pillow实现验证码识别
解决验证码问题-方案二:通过第三方AI库识别验证码
实现工具类:设计获得验证码、随机字符串生成、cookie操作工具类
完成用户注册测试用例:解决验证码、等待弹框等复杂内容
完成用户登录测试用例:实现登录成功和失败测试
完成管理员登录测试用例:完成验证码正确和错误测试用例
完成文章分类测试用例:解决测试用例依赖问题
完成添加、删除文章测试用例
unittest简介:测试用例、测试套件、测试运行器、测试加载器
unittest中的方法:掌握各种setup、teardown和断言方法
测试用例、测试套件和测试加载器:掌握加载测试用例的四种方法
使用unittest重构测试用例:掌握使用unittest模块的方法和技巧
为项目添加测试报告:使用第三方模块实现测试报告
pytest框架简介:pytest安装、用例编写规则、执行用例
pytest标记:查找测试策略、标记测试函数
pytest参数化处理:使用参数化装饰器、解析列表、元组、字典等数据
pytest Fixture:使用fixture实现用例之间的调用
pytest setup 和 teardown
pytest allure生成测试报告
使用pytest重构项目:实现用例依赖、测试报告、数据参数化
logging模块简介:日志的作用、等级和常用函数
logging日志格式输出:日志发生的时间、文件、模块、行号等信息格式输出
logging模块四大组件:Logger、Handler、Formatter、Filter的用法
为项目添加日志:将日志应用到项目
使用csv模块读取CSV文件,使用pytest参数化实现DDT
使用json模块读取json文件,使用pytest参数化实现DDT
使用xlrd模块读取excel文件,使用pytest参数化实现DDT
Selenium读取数据库数据:将数据保存到数据库,实现数据驱动的测试
Selenium DDT:使用DDT模块实现数据驱动的测试
使用DDT思想重构项目:使用数据库保存数据,将数据驱动思想应用到项目
POM设计模式简介:理解页面-对象-模型设计模式,实现代码的松耦合
设计BasePage类:设计基类,提高项目的代码重用性
设计项目页面对应的PO类:使用POM设计模式设计PO类
设计项目测试用例:将POM设计模式应用到项目
Selenium Grid下载安装:配置Java运行环境,下载安装Selenium Grid
Selenium注册node节点
使用Selenium执行远程测试
Jenkins环境搭建:下载安装Jenkins
在Jenkins中运行项目
邮件通知:实现邮件通知功能
定时运行项目,实现真正的自动化测试
当前位置:
首页>>
技术小册>>
Selenium自动化测试实战
小册名称:Selenium自动化测试实战
### 章节:pytest allure生成测试报告 在自动化测试领域,测试报告的生成是验证测试执行结果、分析测试数据以及向项目利益相关者展示测试进展的重要环节。`pytest`作为Python中一个成熟且广泛使用的测试框架,其灵活性和扩展性使得它能够轻松集成多种测试报告工具。`Allure Framework`就是这样一个强大的工具,它支持轻量级、灵活的轻量级测试报告生成,特别适用于敏捷团队和持续集成环境。本章节将详细介绍如何在`pytest`测试中集成`Allure`以生成丰富、易于理解的测试报告。 #### 一、Allure Framework简介 Allure Framework是一个灵活的轻量级多语言测试报告工具,支持TestNG(Java)、pytest(Python)、TestRail等测试框架。它提供了详细的测试结果,包括失败的测试截图、详细的日志记录、步骤执行时间等,有助于开发者快速定位问题,同时也便于非技术背景的团队成员理解测试过程和结果。Allure报告支持多种格式导出,包括HTML、XML等,便于集成到CI/CD流程中。 #### 二、环境准备 在使用`pytest-allure`之前,需要确保你的测试环境中已经安装了以下软件或库: 1. **Python**:确保Python环境已安装,推荐Python 3.x版本。 2. **pytest**:Python的测试框架,可通过`pip install pytest`安装。 3. **pytest-allure-adaptor**:pytest的Allure适配器,允许pytest测试与Allure报告生成器集成。可通过`pip install pytest-allure-adaptor`或`pip install allure-pytest`(后者是更常见的安装方式)安装。 4. **Allure Commandline**:用于生成和查看Allure报告的命令行工具。可以从[Allure官网](https://docs.qameta.io/allure/#_installing_allure_commandline)下载对应操作系统的版本并解压到系统路径中,或者通过包管理器安装(如果可用)。 #### 三、pytest-allure的基本使用 安装好上述组件后,就可以开始在你的pytest测试中使用Allure了。以下是一些基本用法: ##### 1. 标记测试用例 使用`@allure.feature`和`@allure.story`等装饰器来标记测试用例,帮助组织测试报告的结构。 ```python import allure import pytest @allure.feature('用户管理') class TestUser: @allure.story('用户注册') def test_user_registration(self): # 测试逻辑 assert True @allure.story('用户登录') def test_user_login(self): # 测试逻辑 assert True ``` ##### 2. 标记测试步骤 使用`@allure.step`装饰器来标记测试中的关键步骤,这些步骤将在测试报告中显示为可折叠的区块,方便查看每一步的执行情况。 ```python import allure def test_with_steps(): with allure.step("步骤1: 打开登录页面"): # 模拟打开登录页面 pass with allure.step("步骤2: 输入用户名和密码"): # 模拟输入用户名和密码 pass with allure.step("步骤3: 提交表单"): # 模拟提交表单 pass assert True # 假设测试通过 ``` ##### 3. 附加信息 Allure支持向测试报告中添加多种附加信息,如环境信息、截图、日志等。 - **环境信息**:使用`allure.environment`添加。 - **截图**:通过`pytest-html`等插件或在测试失败时自动捕获屏幕截图(需要额外配置)。 - **日志**:使用`allure.attach.file`或`allure.attach.text`将日志信息附加到测试报告中。 #### 四、生成报告 完成测试编写和标记后,就可以使用Allure命令行工具生成测试报告了。 1. **运行pytest测试**:首先,使用pytest运行你的测试,并通过`--alluredir`参数指定一个目录来保存测试数据(这些数据将被用来生成报告)。 ```bash pytest --alluredir=/path/to/allure-results ``` 2. **生成报告**:然后,使用Allure命令行工具的`report generate`命令,指定之前pytest生成的测试数据目录作为输入,并指定一个目录来存放生成的HTML报告。 ```bash allure serve /path/to/allure-results ``` 或者,如果你希望生成HTML文件而不是直接启动服务,可以使用`allure generate`命令,然后手动打开生成的HTML文件。 ```bash allure generate /path/to/allure-results -o /path/to/report/html ``` #### 五、报告解读 生成的Allure报告通常包括以下几个部分: - **概述**:显示测试执行的总览,包括测试用例数、通过数、失败数等。 - **特征**(Features):按`@allure.feature`标记的分组展示测试用例。 - **故事**(Stories):在特征下,按`@allure.story`进一步细分测试用例。 - **测试用例**:每个测试用例的详细信息,包括步骤、日志、截图等。 - **图表**:提供测试执行时间、成功率等统计图表。 #### 六、最佳实践 1. **详细标记**:尽可能详细地使用`@allure.feature`、`@allure.story`等装饰器来标记测试用例,这有助于生成结构清晰的测试报告。 2. **合理使用步骤**:在测试用例内部使用`@allure.step`来标记关键步骤,这有助于追踪测试流程。 3. **附加信息丰富**:在测试报告中附加环境信息、截图、日志等,有助于问题复现和定位。 4. **持续集成**:将测试报告生成集成到CI/CD流程中,自动在每次构建后生成报告,并通知相关人员。 #### 七、总结 通过`pytest-allure`的集成,我们可以为`pytest`测试生成结构清晰、信息丰富的测试报告。这不仅有助于我们分析测试结果,提升测试效率,还能更好地与项目利益相关者沟通测试进展。希望本章节的内容能够帮助你更好地使用`pytest-allure`来生成高质量的测试报告。
上一篇:
pytest setup 和 teardown
下一篇:
使用pytest重构项目:实现用例依赖、测试报告、数据参数化
该分类下的相关小册推荐:
机器学习算法原理与实战
Python面试指南
Python与办公-玩转PPT
剑指Python(万变不离其宗)
实战Python网络爬虫
Python与办公-玩转PDF
Python神经网络入门与实践
Python合辑13-面向对象编程案例(上)
Python合辑14-面向对象编程案例(下)
Python与办公-玩转Word
Python高并发编程与实战
Python合辑12-面向对象