python单元测试框架pytest的使用示例

首先祝大家国庆节日快乐,这个假期因为我老婆要考注会,我也跟着天天去图书馆学了几天,学习的感觉还是非常不错的,这是一篇总结。

这篇博客准备讲解一下pytest测试框架,这个框架是当前最流行的python语言最流行的单测框架,不掌握可不行,首先这个框架属于第三方模块,需要通过pip安装即可

pip install pytest

下面我们进入正题

一、介绍pytest的运行规则

1、测试文件的名称必须要以test_*.py的格式,或者*_test.py的格式

2、测试类的名称必须要以Test开头,且这个类还不能有构造方法(__init__)

3、测试函数的名称必须要以test开头

pytest默认的就按照上面的三条规则来执行案例,当然我们可以自定义运行规则,这个我们后面在讲,这个不重要,看一个最简单的例子

import os
import pytest

# pytest是python的单元测试框架

def func(x):
  return x + 1

def test_a():
  print("____test_a____")
  assert func(2) == 5

def test_b():
  print("____test_b____")
  assert func(2) == 3

if __name__ == '__main__':
  pytest.main(["-s","pytest1.py"])

二、介绍pytest的前置条件和后置条件,类似unittest的testfixture(测试固件)

如果同学们之前用过unittest测试框架,对测试固件这个这个名词就不会陌生了,如果不清楚,可以看下之前我写的unittest测试框架的博客(https://www.cnblogs.com/bainianminguo/p/11616526.html)

pytest框架的测试固件有两种,一种函数级别的,一种是类级别,执行的顺序如下

a、执行类的前置条件

b、执行函数的前置条件

c、执行函数的后置条件

d、执行类的后置条件

使用也非常简单,当时函数的命名一定要和我下面的备注保持完全一致

# pytest的前置和后置条件

# 1、函数级别 setup teardown
# 运行于测试方法的开始和结束
# 运行一个测试用例,会运行一次setup和teardown

# 2、类级 setup_class  teardown_class
# 运行于测试类的开始和结束
# 一个测试类只运行一次setup_class teardown_class

1、函数式的案例--函数级别的前置条件&后置条件

import os
import pytest

def func(x):
  return x + 1

def test_a():
  print("____test_a____")
  assert func(2) == 5

def test_b():
  print("____test_b____")
  assert func(2) == 3

def setup():
  print("函数级别的前置")

def teardown():
  print("函数级别的后置")

执行结果如下

2、类式的案例--函数级别的前置条件&后置条件

class Testclass:
  def test_a(self):
    print("____test_a____")
    assert func(2) == 5

  def test_b(self):
    print("____test_b____")
    assert func(2) == 3

  def setup(self):
    print("函数级别的前置")

  def teardown(self):
    print("函数级别的后置")
if __name__ == '__main__':
  pytest.main(["-s","pytest2.py"])

执行结果如下

3、类级别的前置条件&后台置条件

import pytest

def func(x):
  return x + 1

class Testclass:
  def test_a(self):
    print("____test_a____")
    assert func(2) == 5

  def test_b(self):
    print("____test_b____")
    assert func(2) == 3

  def setup(self):
    print("函数级别的前置")

  def teardown(self):
    print("函数级别的后置")

  def setup_class(self):
    print("类级别的前置")

  def teardown_class(self):
    print("类级别的后置")
if __name__ == '__main__':
  pytest.main(["-s","pytest3.py"])

结果如下

三、介绍如何修改pytest的配置文件

我们在博客的第一部分介绍了pytest框架的运行规则,这里我们可以修改pytest的配置文件,改变框架运行规则

首先我们要在案例的目录下创建一个pytest.ini的配置文件

内容如下

# 创建pytest.ini文件
# [pytest]
# addopts=-s
#这个先这样写,这个主要是执行参数

# testpaths = testcase
# 只执行这个目录下的文件
#
# python_files = test_*.py
#执行的文件的名字

# python_classes = Test_*
#执行类的名字

# python_functions = test_*
# 执行函数的名字

配置文件截图

通过上面的步骤,我们就可以改变pytest的运行规则

四、介绍pytest的断言

pytest的断言是用python的断言,他不像unittest框架,他自己实现了断言

# -*- coding:utf-8 -*-

# pytest是使用python自带的断言
import pytest

def func(x):
  return x + 1

def test_a():
  print("____test_a____")
  assert func(2) == 5

def test_b():
  print("____test_b____")
  assert not func(2) == 3

def test_c():
  print("____test_b____")
  assert func(2) in ["a","b","c"]

def test_d():
  print("____test_b____")
  assert func(2) not in ["a","b","c"]

if __name__ == '__main__':
  pytest.main(["-s","pytest5.py"])  

五、介绍pytest的标记(mark)

1、可以实现给函数打标记,实现哪些标记执行,哪些标记不执行

一个函数可以打多个标记,一个标记同时可以给多个函数打标记。只需要让这个标记的装饰器函数装饰我们的测试类或者测试函数

class Test_mark():
  @pytest.mark.test01
  def test_a(self):
    print("mark test a")

  @pytest.mark.test02
  def test_b(self):
    print("mark test b")

if __name__ == '__main__':
  pytest.main(['-s',"pytest6.py"])

还有其它的执行方式

# pytest -m test01

# pytest -n "test01 or test02"

# pytest -m "not test01"

2、标记可以实现不跳过某个、某些案例的作用

# -*- coding:utf-8 -*-

import pytest

# skip跳过执行某个案例
@pytest.mark.skip(reson="只是这个函数用例不执行")
def test_a():

  print("testa")

def test_b():
  print("testb")

@pytest.mark.skip(reson="整个类下的案例都不会执行")
class Test_skip():
  def test_a(self):
    print("testa")

  def test_b(self):
    print("testb")

# 可以根据条件判断,为真,则不执行
@pytest.mark.skipif(1 > 2,reson="整个类下的案例满足条件都不会执行")
class Test_skipif():
  def test_a(self):
    print("testa")

  def test_b(self):
    print("testb")

六、介绍pytest的数据参数化

1、传入单个参数

# pytest的数据参数化

# 1、传入单个参数
#
# pytest.mark.parametrize(argnames,argvalues)
# argnames  参数的名称
#
# argvalues 参数对应的值,类型必须是可迭代的类型,一般使用list

@pytest.mark.skip(reson="只是这个函数用例不执行")
def test_a():
  print("testa")

@pytest.mark.parametrize("name",["cui1","cui2","cui3","cui4"])
def test_b(name):
  print("testb----->{name}".format(name = name))

if __name__ == '__main__':
  pytest.main(["-s", "pytest8.py"])

实现的效果name作为参数的名称,这个案例会执行4次,参数分别是name=“cui1”\name="cui2"\....

2、传入多个参数

import pytest

# pytest的数据参数化

# 1、传入多个参数
#
# pytest.mark.parametrize((argnames1,argnames2),[(argvalues1,argvalues1),(argvalues1,argvalues1)],(argvalues1,argvalues1)]])

@pytest.mark.skip(reson="只是这个函数用例不执行")
def test_a():
  print("testa")

@pytest.mark.parametrize(("name","age"),[("cui1",12),("cui2",13),("cui3",14)])
def test_b(name,age):
  print("testb----->{name}----->{age}".format(name = name,age = age))

if __name__ == '__main__':
  pytest.main(["-s", "pytest9.py"])

实现的效果如下

七、介绍pyest的常用第三方插件

1、美化pytest的输出报告插件

# pip install pytest-html

# 用来美化输出报告的插件
# 只需要在配置文件中加这个配置即可
#
# addopts=-s --html=report.html

效果

2、失败案例重试插件,下面的示例实现的就是失败重启3,失败后间隔2s在进行重试

# pip install pytest-rerunfailures
# 失败重试的第三方插件
# 只需要在配置文件中加这个配置即
# --reruns 3 --reruns-delay 2

至此,pytest的框架基本使用已经讲解清楚,小伙伴们还有不清楚的吗?欢迎大家来沟通!!!

到此这篇关于python单元测试框架pytest的使用示例的文章就介绍到这了,更多相关python单元测试框架pytest内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • python中pytest收集用例规则与运行指定用例详解

    前言 上篇文章相信大家已经了解了pytest在cmd下结合各种命令行参数如何运行测试用例,并输出我们想要看到的信息.那么今天会讲解一下pytest是如何收集我们写好的用例?我们又有哪些方式来运行单个用例或者批量运行用例呢?下面将为大家一一解答! pytest收集用例原理分析 首先我们按照如下目录结构新建我们的项目 [pyttest搜索测试用例的规则] |[测试用例目录1] | |__init__.py | |test_测试模块1.py | |test_测试模块2.py |[测试用例目录2] |

  • Python 测试框架unittest和pytest的优劣

    一.Unittest Unittest是Python标准库中自带的单元测试框架,Unittest有时候也被称为PyUnit,就像JUnit是Java语言的标准单元测试框架一样,Unittest则是Python语言的标准单元测试框架. Unittest支持自动化测试,测试用例的初始化.关闭和测试用例的聚合等功能,它有一个很重要的特性:它是通过类(class)的方式,将测试用例组织在一起. 示例: 运行结果 注:unittest有一个关联模块unittest2,但unittest2仅适用于Pytho

  • python的pytest框架之命令行参数详解(上)

    前言 pytest是一款强大的python自动化测试工具,可以胜任各种类型或者级别的软件测试工作.pytest提供了丰富的功能,包括assert重写,第三方插件,以及其他测试工具无法比拟的fixture模型.pytest是一个软件测试框架,是一款命令行工具,可以自动找到测试用例执行,并且回报测试结果.有丰富的基础库,可以大幅度提高用户编写测试用例的效率.具备扩展性,用户可以自己编写插件,或者安装第三方提供的插件.可以很容易地与其他工具集成到一起使用.比如持续集成,web自动化测试等. 下面列举了

  • python pytest进阶之fixture详解

    前言 学pytest就不得不说fixture,fixture是pytest的精髓所在,就像unittest中的setup和teardown一样,如果不学fixture那么使用pytest和使用unittest是没什么区别的(个人理解). fixture用途 1.做测试前后的初始化设置,如测试数据准备,链接数据库,打开浏览器等这些操作都可以使用fixture来实现 2.测试用例的前置条件可以使用fixture实现 3.支持经典的xunit fixture ,像unittest使用的setup和te

  • python pytest进阶之xunit fixture详解

    前言 今天我们再说一下pytest框架和unittest框架相同的fixture的使用, 了解unittest的同学应该知道我们在初始化环境和销毁工作时,unittest使用的是setUp,tearDown方法,那么在pytest框架中同样存在类似的方法,今天我们就来具体说明. 先附上官方文档的一段说明 1.每个级别的setup/teardown都可以多次复用 2.如果相应的初始化函数执行失败或者被跳过则不会执行teardown方法 3.在pytest4.2之前,xunit fixture 不遵

  • python pytest进阶之conftest.py详解

    前言 前面几篇文章基本上已经了解了pytest 命令使用,收集用例,finxture使用及作用范围,今天简单介绍一下conftest.py文件的作用和实际项目中如是使用此文件! 实例场景 首先们思考这样一个问题:如果我们在编写测试用的时候,每一个测试文件里面的用例都需要先登录后才能完成后面的操作,那么们该如何实现呢?这就需要我们掌握conftest.py文件的使用了. 实例代码 创建如下一个目录 ConftestFile |conftest.py |test_file_01.py |test_f

  • python的pytest框架之命令行参数详解(下)

    前言 上篇说到命令行执行测试用例的部分参数如何使用?今天将继续更新其他一些命令选项的使用,和pytest收集测试用例的规则! pytest执行用例命令行参数 --collect-only:罗列出所有当前目录下所有的测试模块,测试类及测试函数 --tb=style:屏蔽测试用例执行输出的回溯信息,可以简化用例失败时的输出信息.style可以是 on,line,short,具体区别请自行体验 --lf:当一次用例执行完成后,如果其中存在失败的测试用例,那么我们可以使用此命令重新运行失败的测试用例 我

  • python单元测试框架pytest的使用示例

    首先祝大家国庆节日快乐,这个假期因为我老婆要考注会,我也跟着天天去图书馆学了几天,学习的感觉还是非常不错的,这是一篇总结. 这篇博客准备讲解一下pytest测试框架,这个框架是当前最流行的python语言最流行的单测框架,不掌握可不行,首先这个框架属于第三方模块,需要通过pip安装即可 pip install pytest 下面我们进入正题 一.介绍pytest的运行规则 1.测试文件的名称必须要以test_*.py的格式,或者*_test.py的格式 2.测试类的名称必须要以Test开头,且这

  • python单元测试框架pytest介绍

    pytest是python语言中一款强大的单元测试框架,用来管理和组织测试用例,可应用在单元测试.自动化测试工作中. unittest也是python语言中一款单元测试框架,但是功能有限,没有pytest灵活. 就像:苹果电脑mac air和mac pro一样.都是具备同样的功能,但是好用,和更好用. 本文包含以下几个内容点: 1)pytest的简单示例 2)pytest的安装 3)pytest的特征.与unittest的区别. 4) pytest如何自动识别用例. 5)pytest框架中,用例

  • Python自动化测试框架pytest的详解安装与运行

    目录 1. pytest的介绍 2. pytest的安装 1. 使用以下命令进行安装 2. 检查是否成功安装正确版本 3. pytest识别测试的条件 4. pytest的运行 4.1 Pycharm中调用 4.2 Python代码中调用 4.3 使用命令行调用 常用参数列表 参数演示示例: 1. pytest的介绍 pytest是一个非常成熟的全功能的python测试工具,它主要有以下特征: 简单灵活,容易上手: 支持简单的单元测试和复杂的功能测试 显示详细的断言失败信息 能自动识别测试模块和

  • Python测试框架pytest高阶用法全面详解

    目录 前言 1.pytest安装 1.1安装 1.2验证安装 1.3pytest文档 1.4 Pytest运行方式 1.5 Pytest Exit Code 含义清单 1.6 如何获取帮助信息 1.7 控制测试用例执行 1.8 多进程运行cases 1.9 重试运行cases 1.10 显示print内容 2.Pytest的setup和teardown函数 函数级别setup()/teardown() 类级别 3.Pytest配置文件 4 Pytest常用插件 4.1 前置条件: 4.2 Pyt

  • Python测试框架pytest介绍

    目录 一.Pytest简介 二.Pytest安装 三.Pytest测试执行 四.测试类主函数 五.断言方法 六.常用命令详解 七.接口调用 一.Pytest简介 Pytest is a mature full-featured Python testing tool that helps you write better programs.The pytest framework makes it easy to write small tests, yet scales to support

  • Python测试框架pytest核心库pluggy详解

    目录 代码案例 实例化: 添加到钩子定义中 (add_hookspecs) 注册插件 register 运行插件 pm.hook.myhook 代码案例 import pluggy # HookspecMarker 和 HookimplMarker 实质上是一个装饰器带参数的装饰器类,作用是给函数增加额外的属性设置 hookspec = pluggy.HookspecMarker("myproject") hookimpl = pluggy.HookimplMarker("m

  • python单元测试框架unittest基本用法案例

    目录 案例1 2.生成测试报告 断言基本操作 数据驱动 ddt data 巩固 总结 unittest是python单元测试框架,类似于JUnit框架 意义: 灵活的组织ui接口测试自动化用例 让用例高效的执行 方便验证测试用例的结果 集成html形式测试报告 一个class继承unittest.TestCase类,即是一个个具体的TestCase(类方法名称必须以test开头,否则不能被unittest识别) 每一个用例执行的结果的标识,成功是. ,失败为F,出错是E 每一个测试以test01

  • 详解python单元测试框架unittest

    一:unittest是python自带的一个单元测试框架,类似于java的junit,基本结构是类似的. 基本用法如下: 1.用import unittest导入unittest模块 2.定义一个继承自unittest.TestCase的测试用例类,如 class abcd(unittest.TestCase): 3.定义setUp和tearDown,这两个方法与junit相同,即如果定义了则会在每个测试case执行前先执行setUp方法,执行完毕后执行tearDown方法. 4.定义测试用例,

  • Python单元测试unittest的具体使用示例

    Python中有一个自带的单元测试框架是unittest模块,用它来做单元测试,它里面封装好了一些校验返回的结果方法和一些用例执行前的初始化操作. unittest是python的标准测试库,相比于其他测试框架是python目前使用最广的测试框架. unittest有四个比较重要的概念是test fixture, test case, test suite, test runner, . 在说unittest之前,先说几个概念: TestCase 也就是测试用例 TestSuite 多个测试用例

  • python flask框架实现重定向功能示例

    本文实例讲述了python flask框架实现重定向功能.分享给大家供大家参考,具体如下: flask 重定向: from flask import * app = Flask(__name__) @app.route('/') def index(): return redirect(url_for('login')) @app.route('/login') def login(): return render_template('login.html') if __name__ == '_

随机推荐