小笔记-简单但够用系列_allure定制化报告-pytest

2023-11-05 22:20

本文主要是介绍小笔记-简单但够用系列_allure定制化报告-pytest,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • allure 安装
  • allure 报告定制
    • 可能需要注意的模块问题
    • 简单够用的定制操作
      • 用例分组
      • 用例描述
      • 用例等级
      • 用例步骤
      • logo定制
        • 启用自定义模块
        • 修改 css 配置文件
  • 生成 allure 报告

allure 安装

allure 安装文件下载路径

https://github.com/allure-framework/allure2/releases/tag/2.14.0

解压后对其 bin 目录 配置系统环境变量即可在命令行中调用。

>E:\python_project\pythonProject> allure --version
>2.14.0

allure 报告定制

  • 原始报告
    定制前1
    定制前2

  • 定制报告
    定制后1
    定制后2

对于原始的报告,内容是非常单薄的,而且缺少必要的描述,只有编写用例的人才知道这个用例时什么,并不明了。因此需要进行定制化的添加内容。

可能需要注意的模块问题

pytest-allure-adaptor 模块,一个在网上资料经常出现的东西,利用这个模块也可以进行报告的定制化。但不建议使用,因为版本的兼容问题可能会导致安装后出现运行报错。
对于简单够用的来说,直接使用 allure 模块即可。

import  allure

简单够用的定制操作

用例分组

  • feature
    一般用在模块或者类前,分组级别较高。
    @allure.feature("模块t1")
    class Test_t1:
    
  • story
    一般用在用例前,作为用例的名称。
    @allure.story('测试用例 002')
    def test_002(self):
    
  • title
    一般用在用例前,与 story 作为用例的名称。
    @allure.title('测试用例 003')
    def test_003(self):
    

@allure.story() 与 @allure.title() 的区别在于使用 story 的用例其执行结果会统一归在一个组中,而使用 title 的用例则会按照执行顺序显示。具体可看前面的定制后的报告图。

用例描述

  • description
    使用 @allure.description 对用例进行描述说明。
    @allure.description("测试用例的描述")
    def test_020(self):
    

用例等级

  • severity
    用 @allure.severity(allure.severity_level.NORMAL) 对用例的严重等级进行标记。用例的严重级从大到小有以下几级:BLOCKER 、CRITICAL 、NORMAL 、MINOR 、TRIVIAL。
    @allure.severity(allure.severity_level.CRITICAL)
    def test_020(self):
    

用例步骤

对于用例的步骤有两种方法可以标记:

  • @allure.step(‘test step 1’)
    这种方式是用于对方法的嵌套,如:

    @allure.step('步骤1:1')
    def step1(self):print('1')
    @allure.step('步骤2:2')
    def step2(self):print('2')
    @allure.title('测试用例 001')
    def test_001(self):self.step1()self.step2()
    

    在这里插入图片描述

  • with allure.step(‘test step 1’)
    这种方式是用在用例内部的,需要将对应的步骤代码写到 with allure.step() 下,效果请见 定制报告图2 ,代码应用如下:

    def test_020(self):with allure.step('步骤1:输出用例编号'):print("020")with allure.step('步骤2:执行断言'):assert url == 'test.com'

报告内容的定制代码行数,可能不比单纯的用例代码行数少,要做出详细、令人一目了然且满意的报告,也并不简单,需要耗费不少的时间。

报告的语言显示可以在页面左侧菜单下选择。
若生成的报告打开时,数据一直显示加载中,不能正常查看,则为打开方式的问题,使用pycharm打开报告,然后选择浏览器打开即可。

logo定制

修改对应的 css 配置文件,可对报告的 logo 及菜单栏标题进行定制修改。

启用自定义模块
plugins:- junit-xml-plugin- xunit-xml-plugin- trx-plugin- behaviors-plugin- packages-plugin- screen-diff-plugin- xctest-plugin- jira-plugin- xray-plugin- custom-logo-plugin
修改 css 配置文件
.side-nav__brand {background: url(logo.png) no-repeat left center !important;margin-left: 15px;width: 240px;height: 75px;
}
.side-nav__brand span{display: none;
}
.side-nav__brand:after {content: "DFDK";margin-left: 20px;width: 68px;height: 86px;position: fixed;top: 36px;left: 31px;font-size: 42px;font-weight: 300;
}

修改后重新生成报告即可应用。

生成 allure 报告

对于报告的生成,若所选择的数据目录或报告输出目录不存在,需要先创建目录。

import pytest
import os
if __name__ == '__main__':pytest.main(['-v','-s','--count','1','--repeat-scope','session','--html=result2V.html','test_data.py','--alluredir','./temp'])## --count 为循环执行次数## --repeat-scope 为指定循环的范围,session为循环的是会话循环, 1 2 1 2 1 2,若不指定,则默认为用例循环,及 1 1 1 2 2 2## --clean-alluredir 如需生成的报告只有最新的数据,可添加该参数os.system('allure generate ./temp -o ./report --clean')## --clean 每次生成报告都会将已有的报告删除,若需要保留每次的报告,需要指定新的目录或者报告名称

这篇关于小笔记-简单但够用系列_allure定制化报告-pytest的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/352851

相关文章

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

Pytest多环境切换的常见方法介绍

《Pytest多环境切换的常见方法介绍》Pytest作为自动化测试的主力框架,如何实现本地、测试、预发、生产环境的灵活切换,本文总结了通过pytest框架实现自由环境切换的几种方法,大家可以根据需要进... 目录1.pytest-base-url2.hooks函数3.yml和fixture结论你是否也遇到过

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

springboot简单集成Security配置的教程

《springboot简单集成Security配置的教程》:本文主要介绍springboot简单集成Security配置的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录集成Security安全框架引入依赖编写配置类WebSecurityConfig(自定义资源权限规则

如何使用Python实现一个简单的window任务管理器

《如何使用Python实现一个简单的window任务管理器》这篇文章主要为大家详细介绍了如何使用Python实现一个简单的window任务管理器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 任务管理器效果图完整代码import tkinter as tkfrom tkinter i

C++中函数模板与类模板的简单使用及区别介绍

《C++中函数模板与类模板的简单使用及区别介绍》这篇文章介绍了C++中的模板机制,包括函数模板和类模板的概念、语法和实际应用,函数模板通过类型参数实现泛型操作,而类模板允许创建可处理多种数据类型的类,... 目录一、函数模板定义语法真实示例二、类模板三、关键区别四、注意事项 ‌在C++中,模板是实现泛型编程

最新Spring Security实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)

《最新SpringSecurity实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)》本章节介绍了如何通过SpringSecurity实现从配置自定义登录页面、表单登录处理逻辑的配置,并简单模拟... 目录前言改造准备开始登录页改造自定义用户名密码登陆成功失败跳转问题自定义登出前后端分离适配方案结语前言

使用EasyExcel实现简单的Excel表格解析操作

《使用EasyExcel实现简单的Excel表格解析操作》:本文主要介绍如何使用EasyExcel完成简单的表格解析操作,同时实现了大量数据情况下数据的分次批量入库,并记录每条数据入库的状态,感兴... 目录前言固定模板及表数据格式的解析实现Excel模板内容对应的实体类实现AnalysisEventLis