python web自动化(Pytest实战)

news/2024/9/20 1:31:48/ 标签: 自动化, pytest, python, 开发语言

1.UnitTest框架与Pytest框架对⽐

                1) unittest框架介绍
                Unittest则是Python语⾔的标准单元测试框架。 Unittest⽀持⾃动化测试,测试⽤例的初                始化、关闭和测试⽤例的聚合等功能,它有⼀个很重要的特性:它是通过类(class)的⽅                   式,将测试⽤例组织在⼀起

                2) pytest框架介绍:

                        Pytest是Python的另⼀个第三⽅单元测试库。提供更简单、更灵活、更强⼤的测试                    框架,以便于编写和执⾏测试⽤例。它提供了许多有⽤的功能和插件,能够⾃动发现                    测试⽤例、丰富的断⾔⽀持、参数化测试、丰富的插件系统等等,使得测试更加容易 管 

                    理和执⾏。

                        

                pytest 安装和配置:

                1.使⽤命令进⾏安装: pip install pytest 2.验证安装成功的命令: pytest --version 3.运                     ⾏模式的配置,把pycharm的运⾏模式改为pytest

                 pytest框架默认的⽤例运⾏规则:

                1.pytest将在当前⽬录及其⼦⽬录中运⾏所有格式为 test**.py 或者 **test.py ⽂件

                2.测试⽅法/测试函数 默认必须是 test开头

                3.测试类必须是 Test开头

                4. 测试类不能有构造⽅法__init__

2.Pytest的常⽤应⽤

               断⾔pytest

                借助Python的运算符号 和 assert关键字 来实现的。

                

python">def test_kkk_01():
print("kkk")
# 测试相等
assert 1 == 2

        

        pytest框架的常⽤参数:


                -s 输出打印信息到控制台:pytest.main(['-s'])

                 " -s" 参数 ⽤于关闭捕捉,从⽽输出打印信息到控制台

                -v ⽤于显示具体的⽤例执⾏信息:pytest.main(['-v'])

                -k 运⾏名称中包含某字符串的测试⽤例:pytest.main(['-k','kkk'])
 

                -q 简化输出信息:pytest.main(['-q'])

                -x 失败就退出:pytest.main(['-x'])



                指定⽬录以及特定类或⽅法执⾏:

                 pytest.main(['-s','./doc/test_112233.py::TestShopping::test03'])

                ⽣成简单的测试报告:

                    pytest.main(['--junit-xml=./report/junit_report01.xml'])

                ⽤例失败控制:

                在第N个很⽤例失败之后,结束测试执⾏:

                pytest.main(['--maxfail=2'])

                通过标记表达式取执⾏:
                这条命令会执⾏被装饰器 @pytest.mark.smoke 装饰的所有测试⽤例

                注:需要先在pytest.ini ⽂件中注册⾃定义标记

                pytest.main(['-m','smoke'])

                

                多进程运⾏⽤例:

                        

python"># 单线程运行方式# pytest.main(['-vs', 'test_02 多线程执行用例.py'])# 将测试执行发送给多个cpu# pytest.main(['-vs', '-n', '3', 'test_02 多线程执行用例.py'])# 使用与计算机具有cpu内核一样多的进程# pytest.main(['-vs', '-n', 'auto', 'test_02 多线程执行用例.py'])

                        

重新运⾏失败⽤例:
 

python"> # 在每次重跑之间,增加⼀次延迟时间pytest.main(['--reruns', '3','--reruns-delay','2','test_rerun.py'])# 重新运⾏所有测试失败⽤例pytest.main(['--reruns', '3', 'test_rerun.py'])

 pytest的 setup 和 teardown 函数

           setup_module/teardown_module: 在当前⽂件中,所有的⽤例执⾏之前执⾏

python"># ---> 在当前⽂件中,所有的⽤例执⾏之前/后执⾏
# def setup_module(module):
# print("setup_module --->")
# #
# def teardown_module(module):
# print("teardown_module --->")


        setup_function/teardown_function: 在每个测试函数之前和之后执⾏
        

python"># ---> 在每个测试函数之前和之后执⾏
# def setup_function(function):
# print("setup_function --->")
# #
# def teardown_function(function):
# print("teardown_function --->")

setup_method/teardown_method:在每个测试函数之前和之后执⾏(现在常用的方法)

python"># ---> 在每个测试函数之前和之后执⾏(在类中每次都执⾏,在类的外⾯,只执⾏⼀次)
class TestDemo:
def setup_method(self):
print("setup --->")
def teardown_method(self):
print("teardown --->")
# --- 测试⽤例 ---
def test_multiply_3_4(self):
print("test_multiply_3_4")
assert multiply(3, 4) == 12




                

  修改pytest框架的基本规则 

        我们在pytest.ini中修改规则

                

python">[pytest]
addopts = -vs
testpaths = ./testcase_set
python_files = demo_*.py
python_classes = Demo*
python_functions = demo*

        

python">[pytest]
; 01 命令行参数,默认加到执行过程中
addopts = -vs
; 02 指定要运行的测试目录
testpaths = ./testcase_set
; 03 指定要运行的测试文件规则
python_files = demo_*.py
; 04 指定要运行的类名规则
python_classes = Demo_*
; 05 指定要运行的测试用例名称规则
python_functions = demo*

                

                

3.Pytest⾼阶⽤法之函数数据参数化

                        parametrize⽅法:

                        

python">parametrize(argnames, argvalues, indirect=False, ids=None, scope=None)argnames:参数名
argvalues:参数对应值,类型必须为list
当参数为⼀个时格式: [value]
当参数个数⼤于⼀个时,格式为:[(param_value1,param_value2.....),
(param_value1,param_value2.....)]使用方法
@pytest.mark.parametrize(argnames,argvalues)

代码示例:(单个参数)

python">
import pytestdef get_data():return [("qsdd的账号", "qsdd的密码"), ("wang的账号", "wang的密码"), ("yeye的账号", "yeye的密码")]@pytest.mark.parametrize('get_value', get_data())  # 第一个值,用引号括起来,是自定义的参数
def test_login01(get_value):print(f"获取的账号信息:{get_value[0]}")print(f"获取的密码信息:{get_value[1]}")if __name__ == '__main__':pytest.main(['-vs', 'test_01 单个参数接收函数传值.py'])

多个参数:

        

python">""""""import pytestdef get_data():return [("qsdd的账号", "qsdd的密码"), ("wang的账号", "wang的密码"), ("yeye的账号", "yeye的密码")]@pytest.mark.parametrize('get_value', get_data())  # 第一个值,用引号括起来,是自定义的参数
def test_login01(get_value):print(f"获取的账号信息:{get_value[0]}")print(f"获取的密码信息:{get_value[1]}")if __name__ == '__main__':pytest.main(['-vs', 'test_01 单个参数接收函数传值.py'])

引用框架的装饰器完成单个传值

        

python">""""""import pytest@pytest.mark.parametrize('get_value', [("qsdd的账号", "qsdd的密码"), ("qq的账号", "qq的密码"), ("ss的账号", "ss的密码")])
def test_login01(get_value):print(f"获取的账号信息:{get_value[0]}")print(f"获取的密码信息:{get_value[1]}")if __name__ == '__main__':pytest.main(['-vs', 'test_03 引用框架的装饰器完成单个传值.py'])

引用框架的装饰器完成多个传值           

python">""""""import pytest@pytest.mark.parametrize('username, password', [("qsdd的账号", "qsdd的密码"), ("qs的账号", "qs的密码"), ("dd的账号", "dd的密码")])
def test_login01(username, password):print(f"获取的账号信息:{username}")print(f"获取的密码信息:{password}")if __name__ == '__main__':pytest.main(['-vs', 'test_04 引用框架的装饰器完成多个传值.py'])

        

4.Pytest之Fixture介绍

                        什么是fixture:在软件测试中, Fixture 是⼀种⽤于管理测试环境和测试数据的机制。它允许在测试函数或⽅法运⾏之前和之后执⾏特定的代码,以确保测试的可重复性和⼀致性。 Fixture 主要⽤于设置测试环境、准备测试数据、执⾏清理操作等,以便测试能够按预期运⾏

简单理解: 就是可以⽤它对需要执⾏的测试⽤例,设置前置或者后置操作

                示例如下

        

python">""""""
import pytest"""fixturn 快速入门
"""@pytest.fixture
def first_fix():return ['a']def test_01(first_fix):first_fix.append("qsdd")print("first_fix: ", first_fix)def test_02(first_fix):first_fix.append("测试")print("first_fix: ", first_fix)if __name__ == '__main__':pytest.main(['-vs', "test_01_fixture简单演示.py"])

        2.fixture配置作⽤域       

python">""""""
import pytest"""
# 知识拓展:1.当用例很多的时候,每次通过传参来调用fixture,会很麻烦。
fixture里面有个参数autouse,默认是False,没有开启的,
可以设置为True开启自动使用fixture功能,
这样用例就不用每次都去传参了。2.fixture里面还有个参数,scope,
定义被标记方法的作用域:session > module > class > function3."function":作用于每个测试方法,每个test都运行一次
4."class":作⽤于整个类,每个class的所有test只运⾏⼀次 ⼀个类中可以有多个⽅法
5."module":作⽤于整个模块,每个module的所有test只运⾏⼀次;每⼀个.py⽂件调⽤⼀次,该⽂件内⼜有多个
function和class
6."session":作⽤于整个session(慎⽤),每个session只运⾏⼀次;是多个⽂件调⽤⼀次,可以跨.py⽂件调⽤,每
个.py⽂件就是module
"""@pytest.fixture(autouse=True, scope="session")
def fix01():print("session 级别的fixture")@pytest.fixture(autouse=True, scope="module")
def fix02():print("module 级别的fixture")@pytest.fixture(autouse=True, scope="class")
def fix03():print("class 级别的fixture")# 测试用例:def test_a():print("test_a 用例执行")def test_d():print("test_d 用例执行")class TestCase:def test_b(self):print("test_b 用例执行")def test_c(self):print("test_c 用例执行")if __name__ == '__main__':pytest.main(['-vs', "test_02_fixture的作用域.py"])


 

5.Conftest.py(重要)

        conftest.py是pytest特有的本地测试配置⽂件,既可以⽤来设置项⽬级的Fixture,也可以⽤来导⼊外部插件,还可以⽤来指定Hook函数(钩⼦函数)
         conftest.py⽂件名称是固定 , pytest会⾃动识别该⽂件, 只作⽤于它所在的⽬录及⼦⽬录

                

python">""""""
import pytest"""不能自定义名称: conftest.py
"""@pytest.fixture
def fix1():print("conftest 中的 fix1 方法")

python">""""""
import pytestdef test01(fix1):print("test01 测试用例执行")assert 1 == 1if __name__ == '__main__':pytest.main(['-vs'])

结果看出,可以调用conftest中的函数

        

6.Conftest.py+fixture+yield 实现⽤例前置后置

提前在conftest.py中配置好前置、后置操作(通过conftest.py+fixture+yield,可轻松实现⽤例前置后置,包括项⽬级的

                

python">""""""
import pytestdef test01(fix1):print("test01 测试用例执行")if __name__ == '__main__':pytest.main(['-vs'])

python">""""""
import pytest@pytest.fixture
def fix1():a = "123"print("\n 测试用例的前置步骤/条件")yield aprint("\n 测试用例的后置步骤/条件")

        


http://www.ppmy.cn/news/1463618.html

相关文章

瑞吉外卖项目学习笔记(一)

项目展示: 一、软件开发整体介绍 1.1 软件开发流程 作为软件开发人员,我们的主要工作是在 编码阶段 1.2 角色分工 1.3 软件环境 二、瑞吉外面项目介绍 2.1 项目介绍 系统管理后台页面: 移动端页面: 2.2 产品原型展示 产品原型是…

Python库之PyQuery的高级用法深度解析

Python库之PyQuery的高级用法深度解析 引言 PyQuery是一个强大的Python库,它提供了类似于jQuery的语法来解析和操作HTML和XML文档。虽然PyQuery的基本用法已经相当直观,但本文将深入探讨一些高级用法,帮助开发者更高效地处理复杂的HTML文档…

若依 ruoyi-vue SpringBoot聊天敏感词过滤sensitive-word

组件地址 https://github.com/houbb/sensitive-word 网上博客版本不是最新&#xff0c;查看官方文档&#xff0c;基于0.16.1整理总结&#xff0c;快速上手 pom文件引入 <dependency><groupId>com.github.houbb</groupId><artifactId>sensitive-word…

图像处理之计算物体的方向(C++)

图像处理之计算物体的方向&#xff08;C&#xff09; 文章目录 图像处理之计算物体的方向&#xff08;C&#xff09;前言一、PCA获取物体主要方向1.原理2.代码实现 二、Hu矩获取物体主要方向1.原理2.代码实现 总结 前言 在图像处理中&#xff0c;物体的方向&#xff08;倾斜角…

Python每秒1000次压测

Molotov是一个用Python编写的轻量级HTTP负载测试工具,旨在帮助开发者进行简单的性能测试和压力测试。它通过模拟大量并发用户访问来测试Web服务的响应时间、吞吐量以及稳定性。Molotov特别强调易用性和可扩展性,允许用户自定义场景和断言来更好地适应不同应用的测试需求。 安…

Docker拉取镜像报错:x509: certificate has expired or is not yet v..

太久没有使用docker进行镜像拉取&#xff0c;今天使用docker-compose拉取mongo发现报错&#xff08;如下图&#xff09;&#xff1a; 报错信息翻译&#xff1a;证书已过期或尚未有效。 解决办法&#xff1a; 1.一般都是证书问题或者系统时间问题导致&#xff0c;可以先执行 da…

深度学习模型在OCR中的可解释性问题与提升探讨

摘要&#xff1a; 随着深度学习技术在光学字符识别&#xff08;OCR&#xff09;领域的广泛应用&#xff0c;人们对深度学习模型的可解释性问题日益关注。本文将探讨OCR中深度学习模型的可解释性概念及其作用&#xff0c;以及如何提高可解释性&#xff0c;使其在实际应用中更可…

使用numpy手写一个神经网络

本文主要包含以下内容&#xff1a; 推导神经网络的误差反向传播过程使用numpy编写简单的神经网络&#xff0c;并使用iris数据集和california_housing数据集分别进行分类和回归任务&#xff0c;最终将训练过程可视化。 1. BP算法的推导过程 1.1 导入 前向传播和反向传播的总体…

Scala的简单认识

Scala编程基础 小白的Scala学习笔记 2024/5/21 上午某一时刻 文章目录 Scala编程基础spark是用Scala开发出来的Scala的优点 打开idea 搜索scala&#xff0c;安装 如果不小心点了取消&#xff0c;或者没有上图的提示&#xff0c;就在依赖里面添加 spark是用Scala开发出来的 类比…

Python中文件操作和异常处理

文章目录 一、文件操作1.概念2.文件3.二进制 二、基本文件操作三、乱码产生四、with open() as f五、代码实现文件复制粘贴六、try ... except ...七、代码比较 一、文件操作 1.概念 帮助我们把爬虫抓下来的数据&#xff0c;进行保存。 2.文件 在计算机中&#xff0c;没有p…

【荐闻】空中目标检测综述

https://t.zsxq.com/tgUjbhttps://t.zsxq.com/tgUjb 这篇综述论文全面回顾了空中目标检测的最新进展&#xff0c;包括五个不平衡问题、相关方法、实际应用和性能评估。以下是对论文内容的详细描述&#xff1a; 1&#xff09;引言&#xff1a;介绍了空中目标检测的概念&#x…

Windows11下使用Qt5.14.2编译QtXlsx驱动详细步骤

原有&#xff1a;由于系统需要将QTableWidget表格中的数据导出、在Windows下最开始使用Excel.Application组件实现了导出功能&#xff0c;后面将代码转换到Ubuntu20.04下进行编译&#xff0c;发现项目.pro文件中的QT axcontainer和代码.h文件中的#include <QAxObject>跟…

探索Java的DNA-JVM字节码深度解析

引言 在Java的世界里&#xff0c;JVM&#xff08;Java虚拟机&#xff09;是我们程序运行的心脏。而字节码&#xff0c;作为JVM的血液&#xff0c;携带着程序的执行指令。今天&#xff0c;我们将深入探索Java字节码的奥秘&#xff0c;一窥JVM如何将人类可读的代码转化为机器可执…

Java Web 应用开发基础 - JSP内置对象

每个JSP 页面在第一次被访问时&#xff0c;Web 容器都会把请求交给 JSP 引擎&#xff08;即一个 Java 程序&#xff09;去处理。JSP 引擎先将 JSP 翻译成一个 _jspServlet (实质上也是一个 Servlet) &#xff0c;然后按照Servlet的调用方式进行调用。 JSP 第一次访问时会翻译成…

202303青少年软件编程(Python)等级考试试卷(四级)

第 1 题 【单选题】 运行下列程序, 输出的结果是? ( ) def wenhao(name = zhejiang):print(hello + name)wenhao()A :hello B :hellozhejiang C :helloname D :程序将提示运行错误 正确答案:B 试题解析: 定义函数时, 可以指定形参的默认值。 如果在调用函数时给函数…

声学特征在膝关节健康诊断中的应用分析

关键词&#xff1a;膝关节声发射、膝关节生物标志物、因果关系、机器学习 声学膝关节健康评估长期以来一直被看作是一种替代临床可用医学成像工具的替代方法&#xff0c;如声发射技术是通过检测膝关节在运动过程中产生的微小裂纹或损伤引起的声波信号&#xff0c;从而评估关节的…

构建镜像时候出现奇怪的现象时候

一、背景 构建镜像时候&#xff0c;昨天还好好的&#xff0c;今天出现奇怪的现象 二、查看现象 docker system df#cache 显示600G 三、步骤 这操作比较轻微&#xff0c;20以前的缓存清理掉 docker builder prune --filter until480h # 清除20填以前的构建缓

基于EV54Y39A PIC-IOT WA的手指数量检测功能开发(MPLAB+ADC)

目录 项目介绍硬件介绍项目设计开发环境及工程参考总体流程图硬件基本配置光照传感器读取定时器检测逻辑 功能展示项目总结 &#x1f449; 【Funpack3-2】基于EV54Y39A PIC-IOT WA的手指数量检测功能开发 &#x1f449; Github: EmbeddedCamerata/PIC-IOT_finger_recognition 项…

OpenWrt 23.05 安装之后默认空间小 磁盘扩容 教程 软路由实测 系列六

1 安装fdisk opkg update opkg install fdisk #查看磁盘 rootOpenWrt:~# fdisk -l GPT PMBR size mismatch (246303 ! 250069679) will be corrected by write. The backup GPT table is not on the end of the device. Disk /dev/sda: 119.24 GiB, 128035676160 bytes, 25006…

JavaSE——集合框架二(2/6)-综合案例-斗地主游戏(做牌、洗牌、发牌、排序、看牌)

目录 需求与分析 具体实现 牌类定义 房间类定义 初步测试 启动游戏 运行案例 需求与分析 需求 总共有54张牌点数&#xff1a;"3","4","5","6","7","8","9","10","J",&qu…