Allure Test Report

对于不同的编程语言,有很多很酷的测试框架。不幸的是,它们中只有少数能够提供测试执行输出的良好表示。Qameta软件测试团队正在致力于Allure——一个开源框架,旨在创建测试执行报告,让团队中的每个人都清楚。

参考文章:

Allure官方文档:https://docs.qameta.io/allure/

https://blog.csdn.net/liuchunming033/article/details/79624474?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522159587092119725247663810%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=159587092119725247663810&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2allfirst_rank_ecpm_v3~pc_rank_v3-1-79624474.pc_ecpm_v3_pc_rank_v3&utm_term=allure&spm=1018.2118.3001.4187

pytest与allure(/əˈlo͝or/)中间的火花

  1. 安装配置allure:https://github.com/allure-framework/allure2/releases/tag/2.13.5

    • 下载后解压文件并添加到对应操作系统的环境变量中
  2. 安装allure-pytest插件:pip install allure-pytest

  3. 添加allure测试结果报告存放路径pytest --alluredir=./report/allure_report_01(此方法会运行测试文件,并得到结果汇总到报告中,你还需执行下一步)

  4. 查看实际的报告(在浏览器显示,这样会在本地启用个web服务):allure serve ./report/allure_report_01

  5. 生成测试报告(每次生成前清空测试报告目录):allure generate ./report/allure_report_01/ -o ./report01/ --clean

  6. 注意事项

如果直接执行pytest --alluredir=report,将会直接在当前目录下新建一个report的目录,并会运行pytest测试;

定制allure报告

  1. 给allure报告中的测试方法添加描述: 只需要在测试函数/方法下加上"""描述的内容"""

    def test_sum(self):
    """ 这部分内容将显示在 allure报告中"""
    # assert进行断言
    assert 1 == 2
  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')
  3. 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 == '密码错误'

  4. 向allure某个测试用例/函数/方法中添加附件:arllure.attcah(body, name, attachment_type, extension)或者添加本地附件allure.attach.file(source, name, attachment_type, extension)

    1. body - 需要写入的文件内容
    2. name - 文件名称
    3. attachment_type - 文件类型 allure.attachment_type
    4. extension - 文件后缀名
    5. 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)

  5. 定制测试标题(测试函数在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('在成功完成测试后,标题被替换为这一行。')

  6. 添加链接:@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

  7. 按标签分组执行:@allure.feature and @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
  8. 按严重度(优先级)分组执行:@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测试报告的更多相关文章

  1. Pytest单元测试框架:插件-allure-pytest环境搭建并在本地生成一个测试报告

    之前写了allure-pytest的官方文档啃的内容,有些交流的朋友,实践起来没什么头绪,所以就有了这篇文章,也给自己填个坑 第一步:搭建Allure.JDK环境 1. 搭建JDK环境 不装jdk你会 ...

  2. Pytest单元测试框架-测试用例运行规则

    1.Pytest测试用例运行规则 在pytest单元测试框架下面执行用例,需要满足以下几个特点: 1. 文件名以test_*.py开头或者*_test.py 2. 测试类.测试函数以test开头 3. ...

  3. Pytest单元测试框架-Pytest环境安装

    unittest是python自带的单元测试框架,它封装好了一些校验返回的结果方法和一些用例执行前的初始化操作,使得单元测试易于开展,因为它的易用性,很多同学也拿它来做功能测试和接口测试,只需简单开发 ...

  4. Pytest单元测试框架之简单操作示例

    前言: Pytest是第三方单元格测试框架,更加简单,灵活,而且提供了更多丰富的扩展: Pytest与UnitTest框架的区别 UnitTest测试用例执行顺序是依照ascii码执行,而Pytest ...

  5. Pytest单元测试框架——Pytest+Allure+Jenkins的应用

    一.简介 pytest+allure+jenkins进行接口测试.生成测试报告.结合jenkins进行集成. pytest是python的一种单元测试框架,与python自带的unittest测试框架 ...

  6. Pytest 单元测试框架

    1.pytest 是 python 的第三方单元测试框架,比自带 unittest 更简洁和高效 2.安装 pytest pip install pytest 3.验证 pytest 是否安装成功 p ...

  7. Pytest单元测试框架之FixTure基本使用

    前言: 在单元测试框架中,主要分为:测试固件,测试用例,测试套件,测试执行及测试报告: 测试固件不难理解,也就是我们在执行测试用例前需要做的动作和测试执行后的需要做的事情: 比如在UI自动化测试中,我 ...

  8. Pytest单元测试框架-学习

    pytest: Python的一个单元测试框架,基于UnitTest二次开发,语法上更加简洁,可以用来做Python开发项目的单元测试,UI自动化.接口自动化测试等,有很多的插件访问Pytest插件汇 ...

  9. Pytest单元测试框架生成HTML测试报告及优化

    一.安装插件 要生成html类型的报告,需要使用pytest-html插件,可以在IDE中安装,也可以在命令行中安装.插件安装 的位置涉及到不同项目的使用,这里不再详述,想了解的可自行查询. IDE中 ...

随机推荐

  1. msyql事务的四种隔离级别

    一.事务的基本要素(ACID) 1.原子性(Atomicity):事务开始后所有操作,要么全部做完,要么全部不做,不可能停滞在中间环节.事务执行过程中出错,会回滚到事务开始前的状态,所有的操作就像没有 ...

  2. scrapy 基础组件专题(七):scrapy 调度器、调度器中间件、自定义调度器

    一.调度器 配置 SCHEDULER = 'scrapy.core.scheduler.Scheduler' #表示scrapy包下core文件夹scheduler文件Scheduler类# 可以通过 ...

  3. python小游戏-水文

    脚本不会,全都白费.所以就去学习了简单的python,结果不慎学了python中的pygame,浪费了不少时间,没啥用如果不做游戏个人觉得最好别学,学爬虫她不香吗?不过也有一点收获,打飞机小游戏,源码 ...

  4. 网页排名算法PagaRank

    网页排名算法PageRank PageRank,网页排名,又叫做网页级别.是一种利用网页之间的超链接数据进行计算的方法.它是由Google的两位创始人提出的. 对于用户而言,网页排名一般是比较主观的, ...

  5. Vue小功能-视频播放之video.js

        最近在练手一个小项目,想给首页增加一个视频介绍(如下图).涉及到了vue视频播放的功能,所以在网上了解了一下.     相关的插件是Video.js,官网讲解比较详细,我罗列出来,可以根据自己 ...

  6. springboot使用maven命令打包jar及配置文件配置

    sspringboot项目如果不想每次修改配置文件就要重新打包jar的话,可以进行以下配置进行打包 1.在resources下新建assembly文件夹package.xml <?xml ver ...

  7. 基于Python的HTTP接口自动化测试框架实现

    今天我们来讲一下基于Python的HTTP接口自动化测试框架的实现,范例如下: 一.测试需求描述 对服务后台一系列的http接口功能测试. 输入:根据接口描述构造不同的参数输入值 输出:XML文件 e ...

  8. Burp Suite Sequencer Modules - 定序器模块

    Sequencer 主要用于处理和分析Tokens 目标网站:http://testaspnet.vulnweb.com/ (1)通过代理,拦截数据流. (2)Send to Sequencer,然后 ...

  9. 12C oracle 12.1.0.2版本打补丁

    从support  1454618.1文档 中可以下载到各版本的补丁和PSU. 此次采用的是28349311 版本号的psu 和28440711 版本号的jvm.opatch版本号6880880_12 ...

  10. Vue开发者必会的基础知识盘点

    你会Vue吗,你看以下知识点你掌握了多少?实际工作中是否运用的得心应手?如果是,那么恭喜你! Vue中的数据和DOM已经被关联起来,所有的东西都是响应式的.注意我们不再和HTML直接交互.一个Vue应 ...