Pytest单元测试框架-allure测试报告
Allure Test Report
对于不同的编程语言,有很多很酷的测试框架。不幸的是,它们中只有少数能够提供测试执行输出的良好表示。Qameta软件测试团队正在致力于Allure——一个开源框架,旨在创建测试执行报告,让团队中的每个人都清楚。
参考文章:
pytest与allure(/əˈlo͝or/)中间的火花
安装配置allure:https://github.com/allure-framework/allure2/releases/tag/2.13.5
- 下载后解压文件并添加到对应操作系统的环境变量中
安装allure-pytest插件:
pip install allure-pytest添加allure测试结果报告存放路径
pytest --alluredir=./report/allure_report_01(此方法会运行测试文件,并得到结果汇总到报告中,你还需执行下一步)查看实际的报告(在浏览器显示,这样会在本地启用个web服务):
allure serve ./report/allure_report_01生成测试报告(每次生成前清空测试报告目录):
allure generate ./report/allure_report_01/ -o ./report01/ --clean注意事项
如果直接执行
pytest --alluredir=report,将会直接在当前目录下新建一个report的目录,并会运行pytest测试;
定制allure报告
给allure报告中的测试方法添加描述: 只需要在测试函数/方法下加上
"""描述的内容"""def test_sum(self):
""" 这部分内容将显示在 allure报告中"""
# assert进行断言
assert 1 == 2
测试步骤描述:在测试方法之前添加
@allure.step('步骤描述')内容#!/usr/bin/env/python3
# -*- coding:utf-8 -*-
"""
@project: pytest_study
@author: zy7y
@file: test_09.py
@ide: PyCharm
@time: 2020/7/27
""" import allure
import pytest @allure.step('第一步')
def passing_step():
pass @allure.step('第二步')
def step_with_nested_steps():
nested_step() @allure.step('第二.1步')
def nested_step():
nested_step_with_arguments(1, 'abc') @allure.step('第二.2步')
def nested_step_with_arguments(arg1, arg2):
pass def test_with_imported_step():
passing_step() def test_with_nested_steps():
passing_step()
step_with_nested_steps()

步骤可以有一个描述行,该描述行支持传递的位置参数和关键字参数的占位符。关键字参数的默认参数也将被捕获。
import allure @allure.step('测试步骤标题中的占位符, 第一个参数: "{0}", 第二个参数keyword: "{key}"')
def step_with_title_placeholders(arg1, key=None):
pass def test_steps_with_placeholders():
step_with_title_placeholders(1, key='something')
step_with_title_placeholders(2)
step_with_title_placeholders(3, 'anything')
ids测试用例标题: 每条用例ids关键字参数的内容将被填充到allure报告中
@pytest.mark.parametrize('username, password, expect',
[('admin', '123456', '登录成功'),
('admin', '111111', '密码错误')], ids=["正常登录测试用例标题", "密码错误登录测试用例"])
def test_login(username, password, expect):
if username == 'admin' and password == '123456':
assert expect == '登录成功'
else:
assert expect == '密码错误'

向allure某个测试用例/函数/方法中添加附件:
arllure.attcah(body, name, attachment_type, extension)或者添加本地附件allure.attach.file(source, name, attachment_type, extension)body- 需要写入的文件内容name- 文件名称attachment_type- 文件类型allure.attachment_typeextension- 文件后缀名source- 文件所在路径
import allure
import pytest @pytest.fixture
def attach_file_in_module_scope_fixture_with_finalizer(request):
# 添加一个txt文件,文件名称为 file_name, 文件里面的内容为:allure文本附件内容
allure.attach('allure文本附件内容', 'file_name', allure.attachment_type.TEXT) def test_multiple_attachments(attach_file_in_module_scope_fixture_with_finalizer):
# 本地上传一个图片文件给allure,
allure.attach.file('./Snipaste_2020-07-27_23-29-48.png', name='allure专用', attachment_type=allure.attachment_type.PNG)
allure.attach('<head></head><body> a page </body>', 'html附件', allure.attachment_type.HTML)

定制测试标题(测试函数在allure中的显示方式)内容:
@allure.title()@allure.title('测试标题:测试打开blog')
@allure.step('3. 点击回车')
def test_open_blog(browse_driver):
browse_driver.find_element_by_id('su').click()
#allure.dynamic.title('在成功完成测试后,标题被替换为这一行。')

添加链接:
@allure.link或者@allure.issue或者@allure.testcase# 显示链接
@allure.link('https://www.baidu.com/')
def test_with_link():
pass @allure.link('https://www.youtube.com/watch?v=Su5p2TqZxKU', name='allure.link 实现的,传递了一个url,一个name')
def test_with_named_link():
pass # 可以用来放禅道bug地址,它的图标是个虫子挺好的
@allure.issue('https://www.baidu.com', '这就是显示图标,点击可以访问链接的 allure.issue')
def test_with_issue_link():
pass # 链接栏下方显示 测试用例标题, 点击实现跳转
@allure.testcase(TEST_CASE_LINK, '测试用例标题')
def test_with_testcase_link():
pass

按标签分组执行:
@allure.featureand@allure.story@allure.story('epic_1')
def test_with_epic_1():
pass @allure.story('story_1')
def test_with_story_1():
pass @allure.story('story_2')
def test_with_story_2():
pass @allure.feature('feature_2')
@allure.story('story_2')
def test_with_story_2_and_feature_2():
pass # pytest test_09.py --allure-stories story_1,story_2 只执行 含这两个标签的 # pytest test_09.py --allure-features feature2 --allure-stories story2
按严重度(优先级)分组执行:
@allure.severity# test.py
import allure @allure.severity('blocker')
def test_with_no_severity_label():
pass @allure.severity(allure.severity_level.TRIVIAL)
def test_with_trivial_severity():
pass @allure.severity(allure.severity_level.NORMAL)
def test_with_normal_severity():
pass @allure.severity(allure.severity_level.NORMAL)
class TestClassWithNormalSeverity(object): def test_inside_the_normal_severity_test_class(self):
pass @allure.severity(allure.severity_level.CRITICAL)
def test_inside_the_normal_severity_test_class_with_overriding_critical_severity(self):
pass # 将执行严重性为NORML、CRITICAL的方法/类/函数
# pytest tests.py --allure-severities normal,critical
严重度(优先级)解释:
BLOCKER = 'blocker' 系统阻断 对应bug优先级: 马上解决
CRITICAL = 'critical' 严重缺陷 -
NORMAL = 'normal' 普通 - 可倒数第三执行 正常处理
MINOR = 'minor' 易用性问题
TRIVIAL = 'trivial' 易用性问题
关于bug严重度、优先级可以看这里:http://blog.sina.com.cn/s/blog_4adc4b090102wucf.html
Pytest单元测试框架-allure测试报告的更多相关文章
- Pytest单元测试框架:插件-allure-pytest环境搭建并在本地生成一个测试报告
之前写了allure-pytest的官方文档啃的内容,有些交流的朋友,实践起来没什么头绪,所以就有了这篇文章,也给自己填个坑 第一步:搭建Allure.JDK环境 1. 搭建JDK环境 不装jdk你会 ...
- Pytest单元测试框架-测试用例运行规则
1.Pytest测试用例运行规则 在pytest单元测试框架下面执行用例,需要满足以下几个特点: 1. 文件名以test_*.py开头或者*_test.py 2. 测试类.测试函数以test开头 3. ...
- Pytest单元测试框架-Pytest环境安装
unittest是python自带的单元测试框架,它封装好了一些校验返回的结果方法和一些用例执行前的初始化操作,使得单元测试易于开展,因为它的易用性,很多同学也拿它来做功能测试和接口测试,只需简单开发 ...
- Pytest单元测试框架之简单操作示例
前言: Pytest是第三方单元格测试框架,更加简单,灵活,而且提供了更多丰富的扩展: Pytest与UnitTest框架的区别 UnitTest测试用例执行顺序是依照ascii码执行,而Pytest ...
- Pytest单元测试框架——Pytest+Allure+Jenkins的应用
一.简介 pytest+allure+jenkins进行接口测试.生成测试报告.结合jenkins进行集成. pytest是python的一种单元测试框架,与python自带的unittest测试框架 ...
- Pytest 单元测试框架
1.pytest 是 python 的第三方单元测试框架,比自带 unittest 更简洁和高效 2.安装 pytest pip install pytest 3.验证 pytest 是否安装成功 p ...
- Pytest单元测试框架之FixTure基本使用
前言: 在单元测试框架中,主要分为:测试固件,测试用例,测试套件,测试执行及测试报告: 测试固件不难理解,也就是我们在执行测试用例前需要做的动作和测试执行后的需要做的事情: 比如在UI自动化测试中,我 ...
- Pytest单元测试框架-学习
pytest: Python的一个单元测试框架,基于UnitTest二次开发,语法上更加简洁,可以用来做Python开发项目的单元测试,UI自动化.接口自动化测试等,有很多的插件访问Pytest插件汇 ...
- Pytest单元测试框架生成HTML测试报告及优化
一.安装插件 要生成html类型的报告,需要使用pytest-html插件,可以在IDE中安装,也可以在命令行中安装.插件安装 的位置涉及到不同项目的使用,这里不再详述,想了解的可自行查询. IDE中 ...
随机推荐
- 记Centos7和RHEL连接不上网络
一 .前言 我是把Linux系统安装在虚拟机中的,用的是VMware. 在终端工具和操作界面中. VMware里面采用的网络适配器是NAT技术. 标题中的Centos和RHEL区别就不多说了,自行百度 ...
- vs2019使用github
本人操作系统win10 第一步,下载vs github插件 直接看图 下载完成后,需要关闭所有vs2019窗口,之后会弹出下面的窗口,点击modify,完成之后,重新打开vs就安装好了 下面就可以在v ...
- 有效提高java编程安全性的12条黄金法则
安全性是软件开发中最复杂,最广泛和最重要的考量之一.Java是具有许多内置安全性功能的开发平台,java在长期的发展过程中,已经经过了很多高强度的安全测试,并经常更新安全漏洞.并且Java生态系统还包 ...
- PHP 反序列化漏洞入门学习笔记
参考文章: PHP反序列化漏洞入门 easy_serialize_php wp 实战经验丨PHP反序列化漏洞总结 PHP Session 序列化及反序列化处理器设置使用不当带来的安全隐患 利用 pha ...
- 采用 Unicode 标点属性方式的正则表达式,可以去掉所有的标点符号,
public class Test { public static void main(String[] args) { String str = "!!!??!!!!%*)%¥!KTV去符 ...
- static关键字有何魔法?竟让Spring Boot搞出那么多静态内部类
生命太短暂,不要去做一些根本没有人想要的东西.本文已被 https://www.yourbatman.cn 收录,里面一并有Spring技术栈.MyBatis.JVM.中间件等小而美的专栏供以免费学习 ...
- CentOS7 源码编译安装Nginx
源码编译安装nginx 1.下载nginx源码包(这里以nginx-1.18.0为例) wget http://nginx.org/download/nginx-1.18.0.tar.gz 2 ...
- 【JVM之内存与垃圾回收篇】JVM与Java体系结构
JVM与Java体系结构 前言 作为Java工程师的你曾被伤害过吗?你是否也遇到过这些问题? 运行着的线上系统突然卡死,系统无法访问,甚至直接OOMM! 想解决线上JVM GC问题,但却无从下手. 新 ...
- threadLocal源码土话解说
前言 废话不多说,先了解什么是threadLocal,下面是threadLocal类的说明注释, 这段话大致(猜的)意思是,改类为线程提供了一个局部变量,但是呢,这个变量和普通的变量又有所不同,怎么不 ...
- 用Python把20年的GDP、人口以及房价数据进行了可视化
前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者:CDA数据分析师 提到一线城市,大家马上会想到北上广深这四个超级大都 ...