python Allure插件
allure介绍
- allure是一个轻量级,灵活的,支持多语言的测试报告工具
- 多平台的,奢华的report框架
- 可以为dev/qa提供详尽的测试报告、测试步骤、log
- 也可以为管理层提供high level统计报告
- java语言开发的,支持pytest,javascript,PHP,ruby等
- 可以集成到Jenkins
- 文档:https://demo.qameta.io/allure/
allure安装
- https://github.com/allure-framework/allure2/releases 下载allure2.7.zip包
- 解压->进入bin目录->运行allure.bat
- 把bin目录加入PATH环境变量
pytest使用allure
- 安装:pip install allure-pytest
- 使用:
在测试执行期间收集结果:- pytest --alluredir=/tmp/my_allure_results
查看测试报告: - 方式一:测试完成后查看实际报告,在线看报告,会直接打开默认浏览器展示当前报告
- allure serve /tmp/my_allure_results
- 方式二:从结果生成报告,这是一个启动tomcat的服务,需要两个步骤:生成报告,打开报告
- 生成报告:allure generate ./result/ -o ./report/ --clean(注意:覆盖路径加--clean)
- 打开报告:allure open -h 127.0.0.1 -p 8883 ./report/
- pytest --alluredir=/tmp/my_allure_results
pytest-allure插件
allure报告的生成
allure特性分析
allure常用的特性
- 场景:希望在报告中看到测试功能,子功能或场景、测试步骤、包括测试附加信息
- 解决:@Feature,@story,@step,@attach
- 步骤:
- import allure
- 功能上加上@allure.feature('功能名称')——定义模块的名称
- 子功能上加@allure.story('子功能名称')——定义方法的名称
- 步骤上加@allure.step('步骤细节')
- @allure.attach('具体文本信息'),需要附加的信息,可以是数据,文本,图片,视频,网页
- 如果只测试登录功能运行的时候可以加限制过滤:
- pytest 文件名 --allure-features'购物车功能'--allure-stories'加入购物车'(注意这里的allure_features中间不是下划线)
- pytest 文件名 --allure-features'购物车功能'--allure-stories'加入购物车'(注意这里的allure_features中间不是下划线)
feature/story
@allure.feature 与@allure.story的关系
- feature相当于一个功能,一个大的模块,将case分类到某个feature中,在报告中behaviors中显示,想到于testsuite
- story相当于对应这个功能或者模块下的不同场景、分支功能,属于feature之下的结构,报告在features中显示,相当于testcase
- feature与story类似于父与子关系
step
- 测试过程中每个步骤,一般放在具体逻辑方法中
- 可以放在关键步骤中,在报告中显示
- 在app,web自动测试当中,建议每切换到一个新的页面当做一个step
- 用法:
- allure.step()只能以装饰器的形式放在类或者方法上面
- with allure.step():可以放在测试用例方法里面,但测试步骤的代码需要被该语句包含
issue,testcase
- 关联测试用例
- 关联bug
- 执行的时候需要加个参数
- --allure-link-pattern=issue:http://www.mytesttracker.com/issue/{}
代码:
- --allure-link-pattern=issue:http://www.mytesttracker.com/issue/{}
- 执行的时候需要加个参数
按重要性级别进行一定范围测试
- 通常测试有P0、冒烟测试、验证上线测试。按重要级别来分别执行的,比如上线要把主流程和重要模块都跑一遍
- 解决:
- 通过附加pytest.mark标记
- 通过allure.feature,allure.story
- 也可以通过allure.severity来附加标记
- 级别:Trivial不重要,Minor不太重要,Normal正常问题,Critacal:严重,Blocker:阻塞
- 步骤:
- 在方法,函数和类上面加
- @allure.severity(allure.severity_level.TRIVIAL)
- 执行时
- pytest -s -v 文件名 --allure-severities normal,critical
- 在方法,函数和类上面加
pycharm可以直接配置运行参数(右击->edit)
前端自动化测试——截图
- 场景:前端自动化测试经常需要附加图片或html,在适当的地方、适当的时机截图
- 解决:
- @allure.attach显示许多不同类型的提供的附件,可以补充测试、步骤或测试结果
- 步骤:
- 在测试报告里附加网页:
- allure.attach(body(内容),name,attachment_type,extension):
- allure.attach('首页',这是错误页的结果信息',allure.attachment_type.HTML)
- 在测试报告里附加图片:
- allure.attach.file(sourse,name,attachment_type,extension):
- allure.attach.file("./result/b.png",attachment_type=allure.attachment_type.PNG)
- 在测试报告里附加网页: