pytest总结

news2024/9/23 21:29:58

在这里插入图片描述


这里写目录标题

  • 一、pytest的命名规则
  • 二、界面化配置
    • 符合命名规则的方法前面会有运行标记
  • 三、pytest的用例结构
    • 三部分组成
  • 四、pytest的用例断言
    • 断言写法:
  • 五、pytest测试框架结构
  • 六、pytest参数化用例
    • 1、pytest参数化实现方式
    • 2、单参数:每一条测试数据都会生成一条测试用例
    • 3、多参数:
      • ids:为测试用例起名字
      • ids有中文的情况
    • 4、笛卡儿积
  • 七、标记测试用例
  • 八、pytest设置跳过、预期失败用例
    • 1、skip的使用场景:
    • 2、skipif的使用场景:
    • 3、xfail的使用场景:
  • 九、pytest运行测试用例
    • 1、运行多个测试包
    • 2、运行多个测试模块
    • 3、运行多个测试类
    • 4、运行多个测试方法
    • 5、运行单个测试方法
    • 6、运行结果分析
  • 十、pytest命令行常用参数
    • 1、-x:
    • 2、--maxfail=2:用例允许失败1条,第2条失败时,stop
    • 3、-k:执行测试用例中,包含“tup”的用例(采用双引号)
    • 4、-k:执行测试用例中,除了“tup”之外的用例(采用双引号)
    • 5、--collect-only:只收集不运行
  • 十一、python执行pytest
    • 1、使用main函数
      • a、pytest.main() :执行当前目录下符合规则的所有测试用例
      • b、运行某一条用例
      • c、运行某个标签
    • 2、使用python -m pytest调用pytest
    • 十二、pytest异常处理
    • try...except
    • pytest.raises()
      • 1、捕获异常:意料之内的异常,不会报错
      • 2、捕获异常:意料之外的异常,会报错
      • 3、捕获多个异常
      • 4、捕获异常后获取异常值和异常类型

一、pytest的命名规则

文件: test开头或者_test结尾
类名 : Test开头
方法名 :test_开头
特别注意:测试类中不能定义__init__()方法

二、界面化配置

在这里插入图片描述

符合命名规则的方法前面会有运行标记

在这里插入图片描述

三、pytest的用例结构

三部分组成

用例名称
用例步骤
用例断言

class TestXXX:
    def setup(self):
        #资源准备
        pass

    def teardown(self):
        #资源销毁
        pass

    def test_xxx(self):
        #测试步骤1
        #测试步骤2
        #断言 实际结果 对比  期望结果
        logging.info('这是xxx测试用例')
        assert 1==1

四、pytest的用例断言

断言(assert),是一种在程序中的一阶逻辑(如:一个结果为真或假的逻辑判断式),目的为了表示与验证软件开发者预期的结果。当程序执行到断言的位置时,对应的断言应该为真。若断言不为真时,程序会中止执行,并给出错误信息。

断言写法:

assert 表达式
assert 表达式,描述:当断言成功时,描述语句不会执行;当断言失败时,描述语句会执行。

class TestDemo:
    def test_c(self):
        assert 1==1

    def test_c1(self):
        assert 'abc1' in 'abcdef' , 'abc不在abcdef中'

五、pytest测试框架结构

setup_module/teardown_module:全局模块级,只运行一次
setup_class/teardown_class:类级,只在类中前后运行一次
setup_function/teardown_function:函数级别:在类外
setup_method/teardown_method:方法级别,在类中。类中每个方法执行前后
setup/teardown:在类中,在每个测试方法前后执行

六、pytest参数化用例

通过参数的方式传递数据,从而实现数据和脚本的分离
并且可以实现用例的重复生成和执行

1、pytest参数化实现方式

装饰器:pytest.mark.parametrize

2、单参数:每一条测试数据都会生成一条测试用例

#单参数
import pytest
search_list=['appium','selenium','pytest']

# 两组测试数据:两条测试用例
@pytest.mark.parametrize('search_key',['java','appium'])
def test_search_params(search_key):
    assert search_key in search_list

在这里插入图片描述

3、多参数:

ids:为测试用例起名字

注意:ids 列表参数的个数要与参数值的个数一致

import pytest

#测试数据有2个参数
@pytest.mark.parametrize("username,password",
                         [["kobe",666],["kd",111],[" ",888]],
                         ids=['success','fail','username is None'])
def test_login1(username,password):
    print(f'登录的用户名:{username},密码:{password}')

在这里插入图片描述

ids有中文的情况

import pytest

@pytest.mark.parametrize("username,password",
                         [["kobe",666],["kd",111],[" ",888]],
                         ids=['成功','失败','用户名为空'])
def test_login(username,password):
    print(f'登录的用户名:{username},密码:{password}')

需要在conftest.py中定义pytest_collection_modifyitems方法

def pytest_collection_modifyitems(items):
    """
    测试用例收集完成时,将收集到的用例名name和用例标识nodeid的中文信息显示在控制台上
    """
    for i in items:
        i.name=i.name.encode('utf-8').decode('unicode-escape')
        i._nodeid=i.nodeid.encode('utf-8').decode('unicode-escape')

在这里插入图片描述

4、笛卡儿积

两组数据a=[1,2,3],b=[a,b,c]
对应的有几组组合形式?

(1,a)(1,b)(1,c)
(2,a)(2,b)(2,c)
(3,a)(3,b)(3,c)

import pytest

@pytest.mark.parametrize('a',[1,2,3])
@pytest.mark.parametrize('b',['aa','bb','cc'])
def test_params1(a,b):
    print(f'笛卡儿积形式参数化中,a={a},b={b}')

在这里插入图片描述

七、标记测试用例

场景:只执行符合要求的某一部分用例可以把一个web项目划分为多个模块,然后指定模块名执行
解决:在测试用例方法上加@pytest.mark.标签名
执行:-m 执行自定义标记的相关用例

import pytest
#测试数据:整型
@pytest.mark.int
def test_int():
    assert isinstance(2,int)

#测试数据:字符串
@pytest.mark.str
def test_str():
    assert isinstance('str',str)

#测试数据:浮点型
@pytest.mark.float
def test_float():
    assert isinstance('2.7',float)

执行测试用例

D:\pytest_project\test_params>pytest test_mark.py -vs -m int

测试结果

在这里插入图片描述
执行用例会出现警告,解决方法:在pytest.ini中将标签注册

在这里插入图片描述

再次执行,没有警告了
在这里插入图片描述

八、pytest设置跳过、预期失败用例

这是pytest的内置标签,可以处理一些特殊的测试用例
skip:始终跳过该测试用例
skipif:遇到特定情况跳过该测试用例
xfail:遇到特定情况,产生一个”预期失败“输出

1、skip的使用场景:

1、调试时不想运行这个测试用例
2、标记无法在某些平台运行的测试用例
3、在某些版本中执行,其他版本中跳过

import pytest

@pytest.mark.skip
def test_aaa():
    print("代码未开发完")
    assert True

@pytest.mark.skip(reason="代码没有实现")
def test_bbb():
    assert False

执行测试用例:测试用例跳过图标默认置灰

在这里插入图片描述

案例:做判断

def check_login():
    return False

def test_function():
    print("start")
    #如果未登录,则跳过后续步骤
    if not check_login():
        pytest.skip("unsupported configuration")
    print("end")

2、skipif的使用场景:

import sys
print(sys.platform)

@pytest.mark.skipif(sys.platform == 'darwin', reason="does not run on mac")
def test_case1():
    assert True
@pytest.mark.skipif(sys.platform == 'win', reason="does not run on windows")
def test_case2():
    assert True
@pytest.mark.skipif(sys.version_info < (3, 6), reason="requires python3.6 or higher")
def test_case3():
    assert True

3、xfail的使用场景:

import pytest

@pytest.mark.xfail
def test_aaa():
    print("test_xfail1 方法执行")
    assert 2 == 2

xfail =pytest.mark.xfail

@xfail(reason="bug")
def test_hello4():
    assert 0

九、pytest运行测试用例

1、运行多个测试包

目录结构
在这里插入图片描述

运行测试用例:

D:\pytest_project>pytest demo_plugin

2、运行多个测试模块

运行测试用例:

D:\pytest_project>pytest demo_plugin/demo1

3、运行多个测试类

运行测试用例:

D:\pytest_project>pytest demo_plugin/demo2/test_demo2.py

4、运行多个测试方法

运行测试用例:

D:\pytest_project>pytest demo_plugin/demo2/test_demo2.py::TestB

5、运行单个测试方法

运行测试用例:

D:\pytest_project>pytest demo_plugin/demo2/test_demo2.py::TestB::test_d

6、运行结果分析

常用的:pass(通过)、fail(失败)、error(代码错误)
特殊的:warning(警告,例如pytest.ini中没有注册标签名)、deselect(跳过,加标签skip、skipif)

十、pytest命令行常用参数

-m:执行加标签的测试用例
-k:执行测试用例中包含某个关键字的测试用例(windows中关键字使用双引号)
-x:用例一旦运行失败,立刻停止运行(冒烟测试)
– maxfail=num:测试用例失败达到num个时,立刻停止运行
-v:打印详细信息
-s:打印输出日志
-n:并发执行测试用例
-lf:只执行上次用例失败的测试用例
-ff:先执行上次用例失败的测试用例,再执行其他的测试用例
–collect-only:测试平台,pytest自动导入功能

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2023/2/15 20:10
# @Author  : 杜兰特
# @File    : test_mark.py
import pytest
#测试数据:整型
@pytest.mark.int
def test_int():
    assert isinstance(2,int)

#测试数据:字符串
@pytest.mark.str
def test_str():
    assert isinstance('str',str)

#测试数据:浮点型
@pytest.mark.float
def test_float():
    assert isinstance('2.7',float)

#测试数据:列表
@pytest.mark.list
def test_list():
    assert isinstance('[1,2,3]',list)

#测试数据:元组
@pytest.mark.tuple
def test_tuple():
    assert isinstance('(1,)',tuple)

1、-x:

D:\pytest_project\test_params>pytest test_mark.py -x

在这里插入图片描述

2、–maxfail=2:用例允许失败1条,第2条失败时,stop

D:\pytest_project\test_params>pytest test_mark.py --maxfail=2

3、-k:执行测试用例中,包含“tup”的用例(采用双引号)

D:\pytest_project\test_params>pytest test_mark.py -k "tup"

在这里插入图片描述

4、-k:执行测试用例中,除了“tup”之外的用例(采用双引号)

D:\pytest_project\test_params>pytest test_mark.py -k "not tup"

在这里插入图片描述

5、–collect-only:只收集不运行

十一、python执行pytest

1、使用main函数

a、pytest.main() :执行当前目录下符合规则的所有测试用例

test_first.py文件

import pytest

def test_a():
    assert 1==1

def test_b():
    assert 1==2

class TestDemo:
    def test_c(self):
        assert 1==1

    def test_c1(self):
        assert 'abc1' in 'abcdef' , 'abc不在abcdef中'

class TestXXX:
    def setup(self):
        #资源准备
        pass

    def teardown(self):
        #资源销毁
        pass

    def test_xxx(self):
        #测试步骤1
        #测试步骤2
        #断言 实际结果 对比  期望结果
        assert 1==1


if __name__ == '__main__':
    pass
    #todo 1、运行当前目录下所有的用例
    pytest.main()   #相当于pytest.main(['./'])

执行测试用例

D:\pytest_project>python test_first.py

b、运行某一条用例

import pytest

if __name__ == '__main__':
    #todo 2、运行test_parameters.py::test_login中的某一条用例
    pytest.main(['test_params/test_parameters.py::test_login','-vs'])

执行测试用例

D:\pytest_project>python test_first.py

c、运行某个标签

import pytest

if __name__ == '__main__':
    #todo 3、运行某个标签
    pytest.main(['test_params/test_mark.py','-vs','-m','int'])

执行测试用例

D:\pytest_project>python test_first.py

2、使用python -m pytest调用pytest

D:\pytest_project>python -m pytest test_first.py

十二、pytest异常处理

try…except

pytest.raises()

可以捕获特定的异常
获取捕获的异常的细节(异常类型、异常信息)
发生异常,后面的代码将不会被执行

1、捕获异常:意料之内的异常,不会报错

import pytest
def test_raise():
    with pytest.raises(expected_exception=ValueError, match='must be 0 or None'):
        raise ValueError("value must be 0 or None")

2、捕获异常:意料之外的异常,会报错

def test_raise1():
    with pytest.raises(expected_exception=ValueError, match='must be 0 or None'):
        raise ZeroDivisionError("除数为0的")

3、捕获多个异常

def test_raise2():
    with pytest.raises(expected_exception=(ValueError,ZeroDivisionError), match='must be 0 or None'):
        raise ZeroDivisionError("value must be 0 or None")

4、捕获异常后获取异常值和异常类型

def test_raise2():
    with pytest.raises(ValueError) as exc_info:
        raise ValueError("value must be 42")
    assert exc_info.type is ValueError
    assert exc_info.value.args[0] == "value must be 42"

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/355406.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

第五十七章 树状数组(二)

第五十七章 树状数组&#xff08;二&#xff09;一、差分的缺陷二、树状数组与差分三、例题题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1提示样例 1 解释&#xff1a;数据规模与约定代码一、差分的缺陷 差分的作用是能够在O(1)的时间内给一段区间加上相同的数字&am…

【计算机网络】数据链路层(上)

文章目录数据链路层概述封装成帧透明传输差错检测奇偶校验循环冗余校验CRC可靠传输可靠传输基本概念实现机制 — 停止-等待协议实现机制 — 回退N帧协议实现机制 — 选择重传协议点对点协议PPP数据链路层概述 首先我蛮来看看数据链路层在网络体系结构中的地位。如图所示主机h1…

key的作用原理与列表的遍历、追加、搜索、排序

目录 一、key的作用原理 二、实现列表遍历并对在列表最前方进行追加元素 三、实现列表过滤搜索 1、用computed计算属性来实现 2、用watch监听输入值的变化来实现 四、按年龄排序输出列表 一、key的作用原理 1. 虚拟DOM中key的作用&#xff1a; key是虚拟DOM对象的标识&a…

博彩公司 BetMGM 发生数据泄露,“赌徒”面临网络风险

Bleeping Computer 网站披露&#xff0c;著名体育博彩公司 BetMGM 发生一起数据泄露事件&#xff0c;一名威胁攻击者成功窃取其大量用户个人信息。 据悉&#xff0c;BetMGM 数据泄漏事件中&#xff0c;攻击者盗取了包括用户姓名、联系信息&#xff08;如邮政地址、电子邮件地址…

Unity如何实现3D物体拆解组装

一.前言 最近有一个需求,是做一个发动机的拆卸和安装功能,其实是一个很简单的功能,但是其中有一个点我觉的非常有意思,就是拖拽组装时,物体如何精准拖到目标位置,思路有了,但是我一直找不到实现方式,早晨刷牙时无意间想到了叉乘,我才有了解决方案。就凭这一次的灵光乍…

AutoJs7、8版本快速接通vscode进行调试脚本

AutoJs7、8版本快速接通vscode进行调试脚本 作者:虚坏叔叔 博客:https://xuhss.com 早餐店不会开到晚上,想吃的人早就来了!😄 # AutoJs7、8快速接通vscode进行调试脚本一、下载AutoJs并安装 https://download.csdn.net/download/huangbangqing12/87449177 下载完成后,…

【图神经网络】图拉普拉斯滤波器如何实现全通、低通、高通滤波

【图神经网络】图拉普拉斯滤波器如何实现全通、低通、高通滤波 文章目录【图神经网络】图拉普拉斯滤波器如何实现全通、低通、高通滤波1. 前言2. 符号说明3. 三种滤波3.1 全通滤波3.2 低通滤波3.2.1 平滑信号分析3.2.2 广义拉普拉斯平滑滤波器3.3 高通滤波4. 总结1. 前言 GCN&…

同步互斥与通信

我们可以把多任务系统当作一个团队&#xff0c;里面的每一个任务都相当于团队里的一个人。团队成员之间要协调工作进度&#xff08;同步&#xff09;、争用会议室&#xff08;互斥&#xff09;、沟通&#xff08;通信&#xff09;。多任务系统所涉及的概念&#xff0c;都可以在…

Spring之事务底层源码解析

Spring之事务底层源码解析 1、EnableTransactionManagement工作原理 开启 Spring 事务本质上就是增加了一个 Advisor&#xff0c;当我们使用 EnableTransactionManagement 注解来开启 Spring 事务时&#xff0c;该注解代理的功能就是向 Spring 容器中添加了两个 Bean&#xf…

【算法基础】并查集⭐⭐⭐⭐⭐【思路巧,代码短,面试常考】

并查集,在一些有N个元素的集合应用问题中,我们通常是在开始时让每个元素构成一个单元素的集合,然后按一定顺序将属于同一组的元素所在的集合合并,其间要反复查找一个元素在哪个集合中。这一类问题近几年来反复出现在信息学的国际国内赛题中。其特点是看似并不复杂,但数据量…

二叉树的相关列题!!

对于二叉树&#xff0c;很难&#xff0c;很难&#xff01;笔者也是感觉很难&#xff01;虽然能听懂课程&#xff0c;但是&#xff0c;对于大部分的练习题并不能做出来&#xff01;所以感觉很尴尬&#xff01;&#xff01;因此&#xff0c;笔者经过先前的那篇博客&#xff0c;已…

Windows下编译安装Redis

Windows下安装Redis1.下载cygwin2.安装cygwin3.下载Redis4.编译Redis5.运行redis6.报错&#xff1a;继上次Windows下安装MySQL后&#xff0c;今天安装Redis发现也复杂许多&#xff0c;github上有几个仓库似乎提供了windows一键安装版&#xff0c;但是到 5.0版本就不更新了……所…

python机器学习

机器学习可分为两大类&#xff0c;分别为监督学习与非监督学习 监督学习 监督学习是机器学习的类型&#xff0c;其中机器使用“标记好”的训练数据进行训练&#xff0c;并基于该数据&#xff0c;机器预测输出。标记的数据意味着一些输入数据已经用正确的输出标记。 在监督学习…

设计模式之策略模式与责任链模式详解和应用

目录1.策略模式1.1 目标1.2.内容定位1.3.定义1.4.应用场景1.5.促销优惠业务场景1.6 用策略模式实现选择支付方式的业务场景1.7 策略模式在框架源码中的体现1.8 策略模式的优缺点2 责任链模式2.1 责任链楼式的应用场景2.2 利用责任链模式进行数据校验拦截2.3 责任链模式和建造者…

实战打靶集锦-006-Stapler

**写在前面&#xff1a;**记录博主的一次打靶经历。 目录1. 主机发现2. 端口发现3. 服务枚举4. 服务探查4.1 FTP探查4.1.1 匿名登录4.1.2 Elly用户4.1.3 John用户4.1.4 EXP搜索4.2 dnsmasq探查4.2.1 基础信息获取4.2.2 EXP搜索4.3 WEB应用探查4.3.1 浏览器访问4.3.2 目录扫描4.…

Nacos超简单-管理配置文件

优点理论什么的就不说了&#xff0c;按照流程开始配配置吧。登录Centos&#xff0c;启动Naocs&#xff0c;使用sh /data/soft/restart.sh将自动启动Nacos。访问&#xff1a;http://192.168.101.65:8848/nacos/账号密码&#xff1a;nacos/nacos分为两部分&#xff0c;第一部分准…

【RabbitMQ】Windows 安装 RabbitMQ

文章目录工具下载Eralng 安装与配置RabbitMQ 安装工具下载 RabbitMQ 3.7.4版本 网盘链接&#xff1a;https://pan.baidu.com/s/1pO6Q8fUbiMrtclpq2KqVVQ?pwdgf29 提取码&#xff1a;gf29 Eralng 网盘链接&#xff1a;https://pan.baidu.com/s/1irf8fgK77k8T9QzsIRwa7g?pwd9…

广度优先搜索(BFS)-蓝桥杯

一、BFS搜索的原理BFS搜索的原理&#xff1a;“逐层扩散”&#xff0c;从起点出发&#xff0c;按层次从近到远&#xff0c;逐层先后搜索。编码&#xff1a;用队列实现。应用&#xff1a;BFS一般用于求最短路径问题&#xff0c;BFS的特点是逐层搜索&#xff0c;先搜到的层离起点…

Prometheus 记录规则和警报规则

前提环境&#xff1a; Docker环境 涉及参考文档&#xff1a; Prometheus 录制规则Prometheus 警报规则 语法检查规则 promtool check rules /path/to/example.rules.yml一&#xff1a;录制规则语法 groups 语法&#xff1a; groups:[ - <rule_group> ]rule_group…

Redis 强化

(Redis入门使用查看)https://blog.csdn.net/weixin_73849581/article/details/128390152?spm1001.2014.3001.5501缓存使用原则什么时候,什么样的数据能够保存在Redis中?1.数据量不能太大2.使用越频繁,Redis保存这个数据越值得3.保存在Redis中的数据一般不会是数据库中频繁修改…