51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 4526|回复: 1
打印 上一主题 下一主题

[原创] 如何通过python生成Allure报告

[复制链接]
  • TA的每日心情
    无聊
    12 小时前
  • 签到天数: 1052 天

    连续签到: 2 天

    [LV.10]测试总司令

    跳转到指定楼层
    1#
    发表于 2021-5-26 09:56:52 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    前言
      自动化执行结果都需要有个报告来展示,常用的报告有HTMLTestRunner,pytest-html,Allure。这三种报告各有不同,本文主要介绍如何通过python来生成Alluer报告。

      Allure
      Alluer属于一种开源的测试框架,可以基于多种语言进行使用,如java的junit,python的pytest。alluer生成的报告内容比较美观,目前测试中常用的测试报告。Allure的环境是基于java环境的,前提条件需要将java的环境安装完成(下载JDK,配置环境变量)。
      下载地址:https://github.com/allure-framework/allure2
      下载完成进行解压,并将allure路径下的bin文件进行放入到环境变量中。打开终端查看是否配置完成,,返回了版本号,说明已经配置完成了。
    E:\>allure --version
    2.13.1




      由于我们是通过pytest进行生成alluer报告的,也需要进行安装alluer在pytest中的第三方插件allure-pytest
      安装插件:pip install allure-pytest
      先编写几个测试用例:
    import pytest

    class TestCase:
        def test_01(self):
            print('---用例01---')
            assert 1
        def test_02(self):
            print('---用例02---')
            assert 1
        def test_03(self):
            print('---用例03---')
            assert 0
    if __name__ == '__main__':
        pytest.main(['-s'])




      生成报告
      用例编写完成后,想要生成allure报告,需要输入命令。
    --alluredir ./report/result
    # 其中./report/result表示将生成的报告存放目录




      注意:这里通过allure-pytest只是帮助我们将测试结果创建出来,但是无法生成HTML格式且生成的测试数据不会清空,而是以追加的形式。
      执行完成上述命令,可以看到在当前目录中生成了report文件,文件下展示的有一些json文件,这些文件属于我们执行的测试结果内容。


      想要生成对应的测试报告,需要再次在终端中输入对应命令。

      方法一:
    allure generate 生成测试结果数据 -o 生成报告的路径 --clean
    # --clean表示:如果已经存在生成报告路径文件夹时,再次使用会提示添加--clean参数来重写
    # 如以下编写用例命令
    allure generate report/result/ -o report/html --clean




      打开生成的报告路径中的HTML文件,就可以看到allure报告内容了。


      如果不想去打开html报告的话,也可以通过打开终端执行命令进行自动打开alluer报告。
    allure open  生成报告的路径地址
    E:\auto_test\test_01>allure generate report/result/ -o report/html --clean
    Report successfully generated to report\html
    # 这样就会自动打开allure报告信息




      方法二:
      有人说上面的方法有点复杂,那安静在介绍一种,当pytest携带allure的参数执行完测试结果后,直接打开终端输入命令就可以打开报告内容。
    E:\auto_test\test_01>allure serve report/result
    Generating report to temp directory...
    Report successfully generated to C:\Users\HAIYAN~1\AppData\Local\Temp\6715359970756727599\allure-report
    Starting web server...
    # 命令中allure serve 表示确定一个allure的服务,后面跟的是报告的路径内容





      allure中增加描述信息
      光看页面美观不能展示allure强大,allure也可以对报告中增加一些测试详情,如用例标题哈,测试步骤等内容。

      用例标题
      在allure中增加用例标题,需要在代码中导入allure模块。
      使用方法直接在需要装饰的用例上使用装饰器。
    import allure

    class TestCase:

        @allure.title('登录用例')
        def test_01(self):
            print('---用例01---')
            assert 1

        def test_02(self):
            print('---用例02---')
            assert 1

        @allure.title('退出登录用例')
        def test_03(self):
            print('---用例03---')
            assert 1




      通过上述代码可以看出用例1和用例3中增加了标题内容,我们直接执行生成测试报告。先生成测试结果,在启动allure直接打开报告内容。


      通过打开的报告发现,标题内容已经成功添加上去了。


      测试模块中增加标签
      allure可以在测试模块中增加测试标签内容。
      通过装饰器的方法来放在对应的测试用例中,这里allure.step()由于需要标记在测试步骤中,由于加入到测试用例中,使用了with的方法来操作。
    import pytest
    import allure
    class TestCase:
        @allure.title('登录用例')
        def test_01(self):
            '''登录用例_操作步骤'''
            with allure.step('输入正确的用户名'):
                print('输入用户名')
            with allure.step('输入正确的密码'):
                print('输入密码')
            with allure.step('点击登录'):
                print('点击登录!')
            assert 1
        @allure.title('退出登录用例')
        def test_02(self):
            '''退出登录_操作步骤'''
            with allure.step('点击退出按钮'):
                print('成功点击退出按钮')
            assert 1
    if __name__ == '__main__':
        pytest.main(['-s'])




      直接通过生成报告,通过报告内容可以看出在用例中添加的详细内容,已经全部都展示出来了。


      总结
      通过整篇文章相信对allure也有了一定的了解,可以看出allure确实是比unittest和pytest-html强大很多。希望本篇文章对您有所帮助。
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2021-6-9 14:08
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    2#
    发表于 2021-6-2 11:56:29 | 只看该作者
    allure是必须掌握的知识点
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-27 21:47 , Processed in 0.060803 second(s), 22 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表