Python测试框架--Allure

2024-06-17 16:28
文章标签 python 框架 测试 allure

本文主要是介绍Python测试框架--Allure,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

严格意义上讲 Allure 不算是测试框架,但是它是生成漂亮测试报告的开源工具,搭配 Pytest 测试框架食用更搭。

  也就是说 Allure 是在 Pytest 执行完生成的测试数据的基础上,对测试数据进行处理统计,生成格式统一、美观的测试报告。

一、Allure初识

1. 什么是 Allure

  Allure 是由Qameta Software团队开源的一款旨在于解决让每个人能更容易生成并更简洁阅读的测试报告框架。它支持大多数的测试框架,如:Pytest、TestNG等,简单易用便于集成。

2. Allure环境搭建

  工欲善其事必先利其器,Allure 框架基于其他的测试框架使用,例如:Pytest。


# windows envsource env/Scripts/activate# 安装 pytest 和 pytest-allure-adaptorpip3 install pytest# Allure Pytest Adaptor是Pytest的一个插件(比较旧的一个插件)# allure-pytest 比较新一点,建议使用pip3 install pytest-allure-adaptorpip3 instal allure-pytest# 安装Allure工具,主要是讲pytest的测试数据转换成HTML数据# linux环境安装# 现将allure源添加到linux的源里sudo apt-add-repository ppa:qameta/allure# 更新本地源sudo apt-get update# 安装allure,[allure无法使用的解决方案](https://askubuntu.com/questions/1168821/allure-report-installed-but-not-findable)sudo apt-get install allure# 上面的方法不行的话,用下面的方法curl -o allure-2.6.0.tgz -Ls https://dl.bintray.com/qameta/generic/io/qameta/allure/allure/2.6.0/allure-2.6.0.tgzsudo tar -zxvf allure-2.6.0.tgz -C /opt/sudo ln -s /opt/allure-2.6.0/bin/allure /usr/bin/allureallure --version# Windows 下安装就麻烦点,可以使用 Scoop 工具(Chocolatey工具不知道为什么安装不了),不管了官方推荐使用 Scoop 安装就使用 Scoop 安装得了# 先安装[Scoop](https://juejin.cn/post/6844904017823285262)# 检查sccop是否安装成功scoop --version# 安装 allurescoop install allure# 查看allure是否安装成功allure --version

二、Pytest集成Allure

   Allure要生效需要在测试文件和测试通配文件(conftest.py)中配置 allure。

1. allure的特性

Aullre的几个特性:


@allure.feature # 用于定义被测试的功能,被测产品的需求点@allure.story # 用于定义被测功能的用户场景,即子功能点with allure.step # 用于将一个测试用例,分成几个步骤在报告中输出allure.attach # 用于向测试报告中输入一些附加的信息,通常是一些测试数据信息@pytest.allure.step # 用于将一些通用的函数作为测试步骤输出到报告,调用此函数的地方会向报告中输出步骤

2. pytest集成allure

测试文件示例,生成测试数据,进一步生成 allure 测试报告


#!/usr/bin/env python# -*- encoding: utf-8 -*-"""@File : test_allure_shopping.py@Time : 2019/12/1017:34@Author : Crisimple@Github : https://crisimple.github.io/@Contact : Crisimple@foxmail.com@License : (C)Copyright 2017-2019, Micro-Circle@Desc : None"""import pytestimport allure# allure.feature 定义功能@allure.feature("报告购物车")class TestAllure(object):# 定义用户场景@allure.story("加入购物车")def test_add_goods_cart(self):# 调用步骤函数login("crisimple", "123456")# 将测试用例分成几个步骤,将测试步骤打印到测试报告中,步骤二with allure.step("浏览商品"):# allure.attach--打印一些附加信息allure.attach("商品1", "C")allure.attach("商品2", "C")# 步骤三with allure.step("加入商品"):allure.attach("商品1", 2)allure.attach("商品2", 3)# 步骤四with allure.step("校验商品"):allure.attach("商品1加入成功", "共2个")allure.attach("商品2加入失败", "共0个")@allure.story("继续购物")def test_continue_shopping_cart(self):login("crisimple", "123456")allure.attach("商品3", 4)print("继续购物成功")@allure.story("减少商品失败")def test_edit_shopping_cart(self):login("crisimple", "123")assert 0@pytest.mark.skip(reason="删除购物车不执行")@allure.story("删除购物车")def test_delete_shopping_cart(self):login("crisimple", "123")print()# 将函数作为一个步骤,调用此函数时,报告中输出一个步骤,步骤名称通常时函数名,这样的函数通常称为步骤函数@allure.step("用户登录")def login(user, passwd):if user == "crisimple" and passwd == "123456":print(user, passwd)print("登录成功")else:print(user, passwd)print("登录失败,请重新尝试")

三、Allure生成测试报告

1. pytest生成测试报告


# 执行全部的测试用例pytest ./Allure/test_allure_shoping.py --alluredir ./Allure/result/# 执行指定features或者stories执行一部分测试用例,比如执行‘报告购物车’下的‘加入购物车’子功能的测试用例pytest ./Allure/test_allure_shopping.py --allure_features="报告购物车" --allure_stories="加入购物车" ../Allure/part_

2. Allure生成测试报告


# 生成测试报告allure generate ./Alluer/result/ -o ./Allure/report/ --clean# 打开测试报告allure open -h 127.0.0.1 -p 8083 ./Allure/report/

打开测试报告,牛皮的是可以切换中文版本 

 


Overview(概览)Categories(类别)Behavior(功能)Suites(测试套件)Graphs(图标)Timeline(时间刻度)Packages(测试包)

四、Allure与Jenkins结合

  对于成规模的测试团队会把自动化测试部署集成到Jenkins中,构建成自动化部署。

4.1 Jenkins配置Allure

安装Allure插件

 

4.2 创建job

配置路径必须配置一致

source env/bin/activateecho "**************Welcome to env**************"echo "**************pytest create test data**************"pytest /完整路径/Allure/test_allure_shopping.py --alluredir ${WORKSPACE}/allure-results/echo "**************report has generated done**************"

4.3 执行工程

立即构建工程即可。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

这篇关于Python测试框架--Allure的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Python Websockets库的使用指南

《PythonWebsockets库的使用指南》pythonwebsockets库是一个用于创建WebSocket服务器和客户端的Python库,它提供了一种简单的方式来实现实时通信,支持异步和同步... 目录一、WebSocket 简介二、python 的 websockets 库安装三、完整代码示例1.

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Python使用自带的base64库进行base64编码和解码

《Python使用自带的base64库进行base64编码和解码》在Python中,处理数据的编码和解码是数据传输和存储中非常普遍的需求,其中,Base64是一种常用的编码方案,本文我将详细介绍如何使... 目录引言使用python的base64库进行编码和解码编码函数解码函数Base64编码的应用场景注意

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很