美文网首页
pytest-测试报告

pytest-测试报告

作者: 是立品啊 | 来源:发表于2021-03-10 10:05 被阅读0次

    pytest-html生成测试报告插件

    在pytest中,我们使用pytest-html该插件来生成插件。

    下载

    pip install pytest-html
    pip37 install -i https://pypi.doubanio.com/simple pytest-html
    python -m pip install -i https://pypi.doubanio.com/simple pytest-html
    
    

    使用

    在配置文件中配置:

    [pytest]
    addopts = --html=report/report.html
    

    意思是在执行测试用例的时候,需要生成HTML报告。将报告生成到项目根目录下的report文件夹中,报告的名字是report.html

    allure生成测试用例报告的框架插件

    我们使用pytest框架搭配allure框架,生成一个比pytest-html生成的测试报告,漂亮100倍的测试报告。

    下载

    pip install -i https://pypi.doubanio.com/simple allure-pytest
    

    使用

    在配置文件的addopts参数后,追加

    [pytest]
    addopts = --alluredir ./report/allure_html
    

    意思,将allure生成的测试报告数据,创建到项目的根目录下的report/allure_html目录中。

    注意:

    1. allure-pytest模块只能帮我们将测试报告的数据创建出来,但是无法生成HTML格式的测试报告。
    2. 生成的数据当再次运行的时候,不会清空,而是以追加的方式

    allure插件的安装

    前提是,allure插件依赖Java环境。

    1. Windows安装allure

      1. 将压缩包解压合到合适目录
      2. 将安装目录中的bin目录添加到系统的环境变量中
      3. 测试:终端执行allure --version,返回版本即可
    2. mac安装allure

      1. 将tgz压缩包解压合到合适目录
      2. 将安装目录中的bin目录添加到系统的环境变量中:/etc/profile
      PATH='/usr/local/src/python36/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:C:\Program Files\allure-2.10.0\bin'
      

    allure插件读取json/txt文件生成测试报告

    allure generate report/result -o report/allure_html --clean
    

    使用

    1. 首先将终端的路径切换到项目的根目录下
    1. 使用命令生成测试报告
    allure generate report/allure_html -o report/allure_report
    
    • report/allure_html 数据来源
    • -o report/allure_report 生成测试报告到哪个目录

    注意,如果再次运行上述命令,需要加上--clean, --clean就是清空并覆盖报告

    allure generate report/allure_html -o report/allure_report --clean
    

    allure工具的问题及解决

    如果生成的报告展示时,无数据,就终端执行下面的命令:

    allure open report/allure_html
    

    allure工具生成的测试报告在report/allure_html

    title和描述

    为了allure报告更加美观,我们可以为用例函数和用例方法,添加title和description,提高可读性:

    import pytest
    import allure
    
    
    @allure.title("主页用例")
    @allure.description("测试主页的用例")
    def test_index():
        assert 1
    
    @allure.title("数据库用例")
    @allure.description("测试数据库的用例")
    def test_db():
        assert 0
    
    @allure.title("测试登录功能的类")
    class TestCaseLogin:
    
        @allure.title("登录用例1")
        @allure.description("登录用例1的描述")
        def test_login_01(self):
            print('test case -01')
            assert 1
    
        @allure.title("登录用例2")
        @allure.description("登录用例2的描述")
        def test_login_02(self):
            print('test case -02')
            assert 1
    

    feature和story

    import pytest
    import allure
    
    
    @allure.feature("其他用例")
    class TestOthers(object):
    
        @allure.story("其他用例类下的主页用例")
        @allure.title("主页用例")
        @allure.description("测试主页的用例")
        def test_index(self):
            assert 1
    
        @allure.story("其他用例类下的数据库用例")
        @allure.title("数据库用例")
        @allure.description("测试数据库的用例")
        def test_db(self):
            assert 0
    
    
    @allure.feature("登录功能")
    @allure.title("测试登录功能的类")
    class TestCaseLogin:
    
        @allure.story("登录用例1")
        @allure.title("登录用例1")
        @allure.description("登录用例1的描述")
        def test_login_01(self):
            print('test case -01')
            assert 1
    
        @allure.story("登录用例2")
        @allure.title("登录用例2")
        @allure.description("登录用例2的描述")
        def test_login_02(self):
            print('test case -02')
            assert 1
    
    image.png

    SEVERITY

    allure中对bug的严重(severity)级别也有定义,allure使用severity来标识测试用例或者测试类的bug级别,分为blocker,critical,normal,minor,trivial5个级别。一般,bug分为如下几个级别:

    • Blocker级别:中断缺陷(客户端程序无响应,无法执行下一步操作),系统无法执行、崩溃或严重资源不足、应用模块无法启动或异常退出、无法测试、造成系统不稳定。
    • Critical级别:即影响系统功能或操作,主要功能存在严重缺陷,但不会影响到系统稳定性。比如说一个服务直接不可用了,微信不能发消息,支付宝不能付款这种,打开直接报错。
    • Major:即界面、性能缺陷、兼容性。如操作界面错误(包括数据窗口内列名定义、含义是否一致)、长时间操作无进度提示等。
    • Normal级别:普通缺陷(数值计算错误),是指非核心业务流程产生的问题,比如说知乎无法变更头像,昵称等。这个要看自己的定义。
    • Minor/Trivial级别:轻微缺陷(必输项无提示,或者提示不规范),比如各种影响体验,但不影响使用的内容。
    import pytest
    import allure
    
    
    @allure.feature("其他用例")
    class TestOthers(object):
    
        @allure.severity(allure.severity_level.BLOCKER)
        @allure.story("其他用例类下的主页用例")
        @allure.title("主页用例")
        @allure.description("测试主页的用例")
        def test_index(self):
            assert 1
        @allure.severity(allure.severity_level.CRITICAL)
        @allure.story("其他用例类下的数据库用例")
        @allure.title("数据库用例")
        @allure.description("测试数据库的用例")
        def test_db(self):
            assert 0
    
    
    @allure.feature("登录功能")
    @allure.title("测试登录功能的类")
    class TestCaseLogin:
        @allure.severity(allure.severity_level.MINOR)
        @allure.story("登录用例1")
        @allure.title("登录用例1")
        @allure.description("登录用例1的描述")
        def test_login_01(self):
            print('test case -01')
            assert 1
        @allure.severity(allure.severity_level.TRIVIAL)
        @allure.story("登录用例2")
        @allure.title("登录用例2")
        @allure.description("登录用例2的描述")
        def test_login_02(self):
            print('test case -02')
            assert 1
    
        @allure.severity(allure.severity_level.NORMAL)
        @allure.story("登录用例3")
        @allure.title("登录用例3")
        @allure.description("登录用例3的描述")
        def test_login_03(self):
            print('test case -03')
            assert 0
    
    image.png

    优点:我们能通过查看severity的图,来清晰看到都不同的bug分布和级别,从而方便我们优先修复哪
    些bug

    dynamic

    该参数常用于跟参数化搭配,为用例添加一些相关信息

    import pytest
    import allure
    
    l = [
        {"url": "baidu.com", "title": "百度", "desc": "测试百度接口", 'method':"get", 'severity': "NORMAL"},
        {"url": "zhihu.com", "title": "知乎", "desc": "测试知乎接口", 'method':"get", 'severity': "TRIVIAL"},
    ]
    
    @pytest.mark.parametrize("item", l)
    def test_case(item):
        print(item['url'])
        allure.dynamic.title(item['title'])
        allure.dynamic.description(item['desc'])
        assert 1
    

    相关文章

      网友评论

          本文标题:pytest-测试报告

          本文链接:https://www.haomeiwen.com/subject/nbaxqltx.html