• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

Pytest自动化测试框架完美结合Allure

武飞扬头像
荔枝味奶糖
帮助1

简介

Allure Framework是一种灵活的、轻量级、多语言测试报告工具。

不仅可以以简洁的网络报告形式非常简洁地显示已测试的内容,

而且还允许参与开发过程的每个人从日常执行中提取最大程度的有用信息和测试。

学新通

从开发/测试的角度来看:

Allure报告可以快速查看到缺陷点,可以将测试未通过划分为Bug和中断的测试。

还可以配置日志,步骤,固件,附件,时间,历史记录,以及与TMS的集成和Bug跟踪系统,以便掌握所有信息。

从管理者的角度来看:

Allure提供了一个清晰的全局,涵盖了所涵盖的功能,缺陷聚集的位置,执行时间表,以及许多其他方便的事情。

独特的模块化和可扩展性,确保你能够进行适当的微调,以使更适合你自己。

官方文档:Allure Framework


部署使用

Pytest作为一个高扩展性、功能强大的自动化测试框架,自身的测试结果是较为简单的,如果想要一份完整测试报告需要其他插件的支持。

如果你对测试报告要求没那么高,你可以使用 pytest-html 插件,基本覆盖了测试报告的常规内容。

但是如果你想查看清晰的测试过程、多维度的测试报告、自定义一些输出,以及与用例和缺陷系统集成等,那 allure-python 将是你的"不二人选"。

注意:allure-pytest 从1.7之后已弃用,从2.0版本开始迁移至 allure-python 项目(即使用allure2),另外要运行allure命令行也需要Java的支持。

1、安装:

1)  allure-pytest插件:

pip install -U allure-pytest

这将安装allure-pytest和allure-python-commons程序包,以生成与allure2兼容的报告数据。

2)  allure工具:

官方下载地址:Releases · allure-framework/allure2 · GitHub

解压软件包(建议直接放到Python文件夹下),然后添加bin目录到环境变量中,最后使用 allure --version 验证是否安装成功。

学新通

2、基本使用

>>> 要使allure侦听器能够在测试执行过程中收集结果,只需添加 --alluredir  选项并提供路径即可存储结果。

pytest --alluredir=<directory-with-results>

如果你运行后进行了用例更改,那么下次运行可能还是会查看到之前记录,可添加 --clean-alluredir 选项清除之前记录。

pytest --alluredir=<directory-with-results> --clean-alluredir

>>> 要在测试完成后查看实际报告,你需要使用allure命令行应用程序从结果生成报告。

1)  在默认浏览器中显示生成的报告

allure serve <my-allure-results>

2)  要从现有的Allure结果生成报告,可以使用以下命令:

allure generate <directory-with-results>

默认报告将生成到allure-report文件夹,你可以使用 -o 标志更改目标文件夹:

allure generate <directory-with-results> -o <directory-with-report>

3)  生成报告后,可以在默认系统浏览器中将其打开,只需运行:

allure open <directory-with-report>

你也可以找到该目录,使用浏览器打开该目录下index.html。注意:有时打开会找不到数据或者乱码,如果你使用的是pycharm,请在pycharm中右击打开。

学新通

4)  如果要删除生成的报告数据,只需运行:

allure report clean

 默认情况下,报告命令将在 allure-results 文件夹中查找报告,如果要从其他位置使用报告,则可以使用 -o 选项。

5)  你也可以使用 allure help 命令查看更多帮助。

学新通


测试报告

你可以在allure报告中看到所有默认的pytest状态:只有由于一个断言错误而未成功进行的测试将被标记为失败,其他任何异常都将导致测试的状态为坏。

示例:

  1.  
    # test_sample.py
  2.  
    import pytest
  3.  
     
  4.  
    # 被测功能
  5.  
    def add(x, y):
  6.  
    return x y
  7.  
     
  8.  
    # 测试类
  9.  
    class TestAdd:
  10.  
     
  11.  
    # 跳过用例
  12.  
    def test_first(self):
  13.  
    pytest.skip('跳过')
  14.  
    assert add(3, 4) == 7
  15.  
     
  16.  
    # 异常用例
  17.  
    def test_second(self):
  18.  
    assert add(-3, 4) == 1
  19.  
    raise Exception('异常')
  20.  
     
  21.  
    # 成功用例
  22.  
    def test_three(self):
  23.  
    assert add(3, -4) == -1
  24.  
     
  25.  
    # 失败用例
  26.  
    def test_four(self):
  27.  
    assert add(-3, -4) == 7
学新通

运行:

  1.  
    E:\workspace-py\Pytest>pytest test_sample.py --alluredir=report --clean-alluredir
  2.  
    ========================================================================== test session starts ==========================================================================
  3.  
    platform win32 -- Python 3.7.3, pytest-6.0.2, py-1.9.0, pluggy-0.13.0
  4.  
    rootdir: E:\workspace-py\Pytest
  5.  
    plugins: allure-pytest-2.8.18, assume-2.3.3, cov-2.10.1, html-3.0.0, rerunfailures-9.1.1, xdist-2.1.0
  6.  
    collected 4 items
  7.  
     
  8.  
    test_sample.py sF.F [100%]
  9.  
     
  10.  
    =============================================================================== FAILURES ================================================================================
  11.  
    __________________________________________________________________________ TestAdd.test_second __________________________________________________________________________
  12.  
     
  13.  
    self = <test_sample.TestAdd object at 0x000000000464F278>
  14.  
     
  15.  
    def test_second(self):
  16.  
    assert add(-3, 4) == 1
  17.  
    > raise Exception('异常')
  18.  
    E Exception: 异常
  19.  
     
  20.  
    test_sample.py:21: Exception
  21.  
    ___________________________________________________________________________ TestAdd.test_four ___________________________________________________________________________
  22.  
     
  23.  
    self = <test_sample.TestAdd object at 0x000000000464FD30>
  24.  
     
  25.  
    def test_four(self):
  26.  
    > assert add(-3, -4) == 7
  27.  
    E assert -7 == 7
  28.  
    E where -7 = add(-3, -4)
  29.  
     
  30.  
    test_sample.py:29: AssertionError
  31.  
    ======================================================================== short test summary info ========================================================================
  32.  
    FAILED test_sample.py::TestAdd::test_second - Exception: 异常
  33.  
    FAILED test_sample.py::TestAdd::test_four - assert -7 == 7
  34.  
    ================================================================ 2 failed, 1 passed, 1 skipped in 0.14s =================================================================
学新通

生成报告:

  1.  
    E:\workspace-py\Pytest>allure generate --clean report
  2.  
    Report successfully generated to allure-report

查看目录:

  1.  
    E:\workspace-py\Pytest>tree
  2.  
    文件夹 PATH 列表
  3.  
    卷序列号为 B2C1-63D6
  4.  
    E:.
  5.  
    ├─.idea
  6.  
    ├─.pytest_cache
  7.  
    │ └─v
  8.  
    │ └─cache
  9.  
    ├─allure-report
  10.  
    │ ├─data
  11.  
    │ │ ├─attachments
  12.  
    │ │ └─test-cases
  13.  
    │ ├─export
  14.  
    │ ├─history
  15.  
    │ ├─plugins
  16.  
    │ │ ├─behaviors
  17.  
    │ │ ├─jira
  18.  
    │ │ ├─junit
  19.  
    │ │ ├─packages
  20.  
    │ │ ├─screen-diff
  21.  
    │ │ ├─trx
  22.  
    │ │ ├─xctest
  23.  
    │ │ ├─xray
  24.  
    │ │ └─xunit-xml
  25.  
    │ └─widgets
  26.  
    ├─report
  27.  
    └─__pycache__
学新通

查看报告:

学新通

Overview:总览,显示用例执行情况、严重程度分布、环境信息等。
Categories:分类,按用例执行结果分类,异常错误和失败错误。
Suites:套件,按测试用例套件分类,目录 ->测试文件 -> 测试类 ->测试方法。
Graphs:图表,显示用例执行分布情况,状态、严重程度、持续时间、持续时间趋势、重试趋势、类别趋势、整体趋势。
Timeline:时间线,显示用例耗时情况,具体到各个时间点用例执行情况
Behaviors:行为,按用例行为举止分类(以标记文字形式显示,需要用例添加allure相关装饰器)
Package:配套,按目录形式分类,显示不同的目录用例执行情况。

用例详情:

学新通

Allure报告不仅能显示pytest不同执行结果状态,错误情况,固件等,还能捕获参数化测试所有参数名称和值。

用例:

  1.  
    # test_sample.py
  2.  
    import pytest
  3.  
    import allure
  4.  
     
  5.  
    # 被测功能
  6.  
    def add(x, y):
  7.  
    return x y
  8.  
     
  9.  
    # 测试类
  10.  
    @allure.feature("测试练习")
  11.  
    class TestLearning:
  12.  
    data = [
  13.  
    [3, 4, 7],
  14.  
    [-3, 4, 1],
  15.  
    [3, -4, -1],
  16.  
    [-3, -4, 7],
  17.  
    ]
  18.  
    @allure.story("测试用例")
  19.  
    @allure.severity(allure.severity_level.NORMAL)
  20.  
    @pytest.mark.parametrize("data", data)
  21.  
    def test_add(self, data):
  22.  
    assert add(data[0], data[1]) == data[2]
学新通

报告:

学新通

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhggbbkf
系列文章
更多 icon
同类精品
更多 icon
继续加载