pytest之allure(六)之集成缺陷管理系统和测试管理系统(@allure.link()、@allure.issue()、@allure.testcase())

前言

allure测试报告框架提供了@allure..link、@allure.issue、@allure.testcase 这三个装饰器,可以用来与缺陷管理系统和测试管理系统集成。

三个装饰器源码

def link(url, link_type=LinkType.LINK, name=None):
    return safely(plugin_manager.hook.decorate_as_link(url=url, link_type=link_type, name=name))


def issue(url, name=None):
    return link(url, link_type=LinkType.ISSUE, name=name)


def testcase(url, name=None):
    return link(url, link_type=LinkType.TEST_CASE, name=name)

知识点

  • issue()和testcase()其实调用的也是link(),只是link_type不一样
  • 必传参数 url:跳转的链接
  • 可选参数 name:显示在allure报告的名字,如果不传就是显示完整的链接;建议传!!不然可读性不高
  • 可以理解成:三个方法是一样的,我们都提供跳转链接和名字,只是链接的type不一样,最终显示出来的样式不一样而已【type不一样,样式不一样】
  • 如果你喜欢,只用@allure.link()也可以
  • 而出现三个装饰器的原因是为了更好地将链接分类【访问连接、Bug链接、测试用例链接】

举例

# file_name: test_allure_links.py


import pytest
import allure


@allure.link("https://www.cnblogs.com/lwjnicole/")
def test_with_link():
    """
    @allure.link() 指定与测试用例关联的链接,比如需求地址
    :return:
    """
    assert True


@allure.link("https://www.cnblogs.com/lwjnicole/", name="点我访问")
def test_with_link_named():
    """
    @allure.link() 通过指定name的方式来指定关联链接,测试报告中用name替换实际URL展示
    :return:
    """
    assert True


@allure.issue("https://www.cnblogs.com/lwjnicole/p/14472386.html")
def test_with_issue_link():
    """
    @allure.issue() 可以与缺陷管理系统相关联,指定与该测试用例相关联的bug链接地址
    :return:
    """
    assert True


@allure.testcase("https://www.cnblogs.com/lwjnicole/p/14466997.html")
def test_with_testcase_link():
    """
    @allure.testcase() 可以与测试用例管理工具相关联,指定与该测试用例关联的测试用例地址
    :return:
    """
    assert True


if __name__ == '__main__':
    pytest.main(['-s', 'test_allure_links.py'])

执行命令:

> pytest test_allure_links.py --alluredir=./report/result_data

> allure serve ./report/result_data

查看测试报告展示效果:

1、装饰器: @allure.link("https://www.cnblogs.com/lwjnicole/") 

 @allure.link() 指定与测试用例关联的链接,比如需求地址

 2、装饰器: @allure.link("https://www.cnblogs.com/lwjnicole/", name="点我访问") 

  @allure.link() 通过指定name的方式来指定关联链接,测试报告中用name替换实际URL展示

 3、装饰器: @allure.issue("https://www.cnblogs.com/lwjnicole/p/14472386.html") 

 @allure.issue() 可以与缺陷管理系统相关联,指定与该测试用例相关联的bug链接地址

这个测试报告中可以看到,通过装饰器@allue.issue可以指定bug的链接地址,并且会在测试报告的Links部分展示,链接的左边会带上一个bug的小图标。

4、装饰器:  @allure.testcase("https://www.cnblogs.com/lwjnicole/p/14466997.html") 

 @allure.testcase() 可以与测试用例管理工具相关联,指定与该测试用例关联的测试用例地址

总结

综上,allure可以使用@allure..link、@allure.issue、@allure.testcase 这三个装饰器,与缺陷管理系统和测试管理系统进行集成,做到更好的自动化管理。

posted @ 2021-08-19 12:55  习久性成  阅读(203)  评论(0编辑  收藏  举报