『德不孤』Pytest框架 — 10、setUp()和tearDown()函数
1、setUp()和tearDown()函数介绍
之前学过Unittest测试框架,知道前置setup()函数和后置teardown()函数非常好用,在每次用例开始前和结束后都去执行一次。
当然还有更高级一点的setupClass()函数和teardownClass()函数,需配合classmethod装饰器一起使用,在做Selenium自动化的时候,它的效率尤为突出,可以只启动一次浏览器执行多个用例。
2、setUp()和tearDown()函数作用
setup()函数主要是进行测试前的初始化工作,比如:在接口测试前面做一些前置的参数赋值,数据库操作等等。teardown()函数是测试后的清除工作,比如:参数还原或销毁,数据库的还原恢复等。
总结:setup()函数表示测试类中每个测试方法执行前都需要执行的操作,teardown()函数表示每个测试方法执行后都需要执行的操作。
3、setUp()和tearDown()函数说明
Pytest框架也有前置setup()函数和后置teardown()函数,并且还不止四个。
Pytest框架setUp()函数和tearDown()函数主要分为:模块级,类级,方法级,函数级。
说明每个级别的含义:
模块级:指的是一个
.py文件。类级:一个
.py文件中可以写多个类。(一般情况下只写一个类)方法级:类中定义的方法叫方法。
函数级:类外定义的方法叫函数。
Pytest框架提供的setUp()函数和tearDown()函数如下:
1)模块级与函数级,不定义在测试类中。
- 模块级:
setup_module()/teardown_module():开始于模块始末,全局的。 - 函数级:
setup_function()/teardown_function():只对函数用例生效(不在类中)。
2)类级与方法级,定义在类中。
- 类级:
setup_class()/teardown_class():只在类中前后运行一次(在类中)。 - 方法级:
setup_method()/teardown_method():开始于方法始末(在类中)。 - 自由的:
setup()/teardown():直接使用感觉和方法级前后置函数一样。
4、示例
(1)方法级
"""
setup_method()和 teardown_method()函数
需要定义在测试类中,定义在类外不起作用。
setup_method()定义场景,如:打开浏览器,加载网页等
teardown_method()场景,如:关闭浏览器等
"""
import pytest
# 测试类
class Test_setUp_tearDown:
# 方法级,前置函数
def setup_method(self):
print("setup_method(self):在每个测试方法之前执行")
# 方法级,后置函数
def teardown_method(self):
print("teardown_method(self):在每个测试方法之后执行\n")
# 测试用例a
def test_a(self):
print("test_a方法")
assert True
# 测试用例b
def test_b(self):
print("test_b方法")
assert True
if __name__ == '__main__':
pytest.main()
"""
执行结果:
setup_method(self):在每个测试方法之前执行
test_a方法
teardown_method(self):在每个测试方法之后执行
PASSEDsetup_method(self):在每个测试方法之前执行
test_b方法
teardown_method(self):在每个测试方法之后执行
"""
(2)类级
"""
setup_class()和 teardown_class()函数
需要定义在测试类中,定义在类外不起作用。
setup_class()定义场景,比如:创建日志对象,创建数据库的连接,创建接口的请求对象等。
teardown_class()定义场景,比如:销毁日志对象,销毁数据库的连接,销毁接口的请求对象。
"""
import pytest
class Test_setUp_tearDown:
# 方法级,前置函数
def setup_method(self):
print("setup_method(self):在每个测试方法之前执行")
# 方法级,后置函数
def teardown_method(self):
print("teardown_method(self):在每个测试方法之后执行\n")
# 类级,前置函数
def setup_class(self):
print("setup_class(self):每个测试类之前执行一次\n")
# 类级,后置函数
def teardown_class(self):
print("teardown_class(self):每个测试类之后执行一次")
# 测试用例a
def test_a(self):
print("test_a方法")
assert True
# 测试用例b
def test_b(self):
print("test_b方法")
assert True
if __name__ == '__main__':
pytest.main()
"""
执行结果:
setup_class(self):每个测试类之前执行一次
setup_method(self):在每个测试方法之前执行
test_a方法
teardown_method(self):在每个测试方法之后执行
PASSEDsetup_method(self):在每个测试方法之前执行
test_b方法
teardown_method(self):在每个测试方法之后执行
teardown_class(self):每个测试类之后执行一次
"""
(3)函数级
"""
setup_function()和 teardown_function()函数
需要定义在测试类外面,只负责函数的前后置。
对类中定义的方法,不起作用。
"""
import pytest
# 函数级,前置函数
def setup_function():
print("setup_function: 每个函数开始前都会执行")
# 函数级,后置函数
def teardown_function():
print("teardown_function: 每个函数结束都会执行\n")
# 测试用例a
def test_a():
print("test_a函数")
assert True
# 测试用例b
def test_b():
print("test_b函数")
assert True
# 测试类
class Test_setUp_tearDown:
# 测试用例a
def test_c(self):
print("test_c方法")
assert True
# 测试用例b
def test_d(self):
print("test_d方法")
assert True
if __name__ == '__main__':
pytest.main()
"""
执行结果:
setup_function: 每个函数开始前都会执行
test_a函数
teardown_function: 每个函数结束都会执行
PASSEDsetup_function: 每个函数开始前都会执行
test_b函数
teardown_function: 每个函数结束都会执行
PASSEDtest_c方法
PASSEDtest_d方法
PASSED
"""
(4)模块级
"""
setup_module()和 teardown_module()函数
需要定义在测试类外面,
对函数和类中定义的方法,都不起作用。
"""
import pytest
# 模块级,前置函数
def setup_module():
print("setup_module():在模块最之前执行\n")
# 模块级,后置函数
def teardown_module():
print("teardown_module:在模块之后执行")
# 函数级,前置函数
def setup_function():
print("setup_function: 每个函数开始前都会执行")
# 函数级,后置函数
def teardown_function():
print("teardown_function: 每个函数结束都会执行\n")
# 测试用例a
def test_a():
print("test_a函数")
assert True
# 测试用例b
def test_b():
print("test_b函数")
assert True
# 测试类
class Test_setUp_tearDown:
# 测试用例a
def test_c(self):
print("test_c方法")
assert True
# 测试用例b
def test_d(self):
print("test_d方法")
assert True
if __name__ == '__main__':
pytest.main()
"""
setup_module():在模块最之前执行
setup_function: 每个函数开始前都会执行
test_a函数
teardown_function: 每个函数结束都会执行
PASSEDsetup_function: 每个函数开始前都会执行
test_b函数
teardown_function: 每个函数结束都会执行
PASSEDtest_c方法
PASSEDtest_d方法
teardown_module:在模块之后执行
PASSED
"""
参考:https://blog.csdn.net/weixin_42550871/article/details/109107673
『德不孤』Pytest框架 — 10、setUp()和tearDown()函数的更多相关文章
- 『德不孤』Pytest框架 — 11、Pytest中Fixture装饰器(一)
目录 1.Fixture装饰器的用途 2.Fixture参数说明 3.Fixture装饰器简单应用 4.yield执行后置函数 1.Fixture装饰器的用途 做测试前后的初始化设置,如测试数据准备, ...
- 『德不孤』Pytest框架 — 2、Pytest的基本使用
目录 1.Pytest安装 2.Pytest常用插件 3.Pytest运行的第一个例子 4.Pytest框架的运行方式 5.在PyCharm中以Pytest的方式运行测试用例 1.Pytest安装 C ...
- 『德不孤』Pytest框架 — 1、Pytest测试框架介绍
目录 1.什么是单元测试框架 2.单元测试框架主要做什么 3.单元测试框架和自动化测试框架有什么关系 4.Pytest测试框架说明 5.Pytest框架和Unittest框架区别 (1)Unittes ...
- 『德不孤』Pytest框架 — 14、Pytest中的conftest.py文件
目录 1.conftest.py文件介绍 2.conftest.py的注意事项 3.conftest.py的使用 4.不同位置conftest.py文件的优先级 5.conftest.py中Fixtu ...
- 『德不孤』Pytest框架 — 3、Pytest的基础说明
目录 1.Pytest参数介绍 2.Pytest框架用例命名规则 3.Pytest Exit Code说明 4.pytest.ini全局配置文件 5.Pytest执行测试用例的顺序 1.Pytest参 ...
- 『德不孤』Pytest框架 — 5、Pytest失败重试
Pytest失败重试就是,在执行一次测试脚本时,如果一个测试用例执行结果失败了,则重新执行该测试用例. 前提: Pytest测试框架失败重试需要下载pytest-rerunfailures插件. 安装 ...
- 『德不孤』Pytest框架 — 4、Pytest跳过测试用例
目录 1.无条件跳过skip 2.有条件跳过skipif 3.练习 自动化测试执行过程中,我们常常出现这种情况:因为功能阻塞,未实现或者环境有问题等等原因,一些用例执行不了, 如果我们注释掉或删除掉这 ...
- 『德不孤』Pytest框架 — 9、Pytest测试报告
目录 1.pytest-html插件 2.Allure测试报告 (1)Allure框架说明 (2)Allure框架的使用 1.pytest-html插件 Pytest可以通过命令行方式,生成xml/h ...
- 『德不孤』Pytest框架 — 12、Pytest中Fixture装饰器(二)
目录 5.addfinalizer关键字 6.带返回值的Fixture 7.Fixture实现参数化 (1)params参数的使用 (2)进阶使用 8.@pytest.mark.usefixtures ...
随机推荐
- ApacheCN 深度学习译文集 20201229 更新
新增了七个教程: TensorFlow 和 Keras 应用开发入门 零.前言 一.神经网络和深度学习简介 二.模型架构 三.模型评估和优化 四.产品化 TensorFlow 图像深度学习实用指南 零 ...
- js判断变量是否为空字符串、null、undefined
let _isEmpty = (input) => { return input + '' === 'null' || input + '' === 'undefined' || input.t ...
- 【转】linux shell编程实例总结
查找当前目录中所有大于500M的文件,把这些文件名写到一个文本文件中,并统计其个数 find ./ -size +500M -type f | tee file_list | wc 在目录/tmp下找 ...
- 云端iclound使用-陈棚
使用NSmetadataQuery查询文档,增加,删除,编辑 界面设计完成后效果如图: 程序清单:FKDiary.h @interface FKDiary : UIDocument @property ...
- JAVA! static的作用
是静态修饰符,什么叫静态修饰符呢?大家都知道,在程序中任何变量或者代码都是在编译时由系统自动分配内存来存储的,而所谓静态就是指在编译后所分配的内存会一直存在,直到程序退出内存才会释放这个空间,也就是只 ...
- docker基础——1.原理解读
1. 相关内核知识 docker本质上是宿主机上的进程. 通过namespace实现资源隔离,通过cgroups实现资源限制,通过写时复制机制copy-on-write实现高效文件操作. 依赖kern ...
- 泛型、Junit
一. 泛型 1.泛型的好处 **1)编译时,检查添加元素的类型,提高了安全2)减少了类西较换的次数,提高效率 不使用泛型Dog -> Object -> Dog //放入到ArrayLis ...
- SpringMVC5中,@ModelAttribute注解详解
看这个注解的前提最好熟悉一下SpringMVC的model组件,该注解可以有五种使用方式: ①②③为 @ModelAttribute 跟@RequestMapping 分开修饰方法,被@ModelAt ...
- 帆软报表(finereport)图表钻取详细类别 当前页对话框展示
添加参数栏,季度下拉框的控件命名为 jd 这里添加雷达图做案例 编辑→特效→ 添加JavaScript 参数:wd 值:分类名 #取雷达图所点击的点 参数:jd 值:公式$j ...
- Solution -「多校联训」自动机
\(\mathcal{Description}\) Link. 有一个状态集为 \(V\) 的自动机,状态接收 (, ) 和 _(空格) 三种字符,分别编号为 \(0,1,2\),状态 \(u ...