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()函数的更多相关文章

  1. 『德不孤』Pytest框架 — 11、Pytest中Fixture装饰器(一)

    目录 1.Fixture装饰器的用途 2.Fixture参数说明 3.Fixture装饰器简单应用 4.yield执行后置函数 1.Fixture装饰器的用途 做测试前后的初始化设置,如测试数据准备, ...

  2. 『德不孤』Pytest框架 — 2、Pytest的基本使用

    目录 1.Pytest安装 2.Pytest常用插件 3.Pytest运行的第一个例子 4.Pytest框架的运行方式 5.在PyCharm中以Pytest的方式运行测试用例 1.Pytest安装 C ...

  3. 『德不孤』Pytest框架 — 1、Pytest测试框架介绍

    目录 1.什么是单元测试框架 2.单元测试框架主要做什么 3.单元测试框架和自动化测试框架有什么关系 4.Pytest测试框架说明 5.Pytest框架和Unittest框架区别 (1)Unittes ...

  4. 『德不孤』Pytest框架 — 14、Pytest中的conftest.py文件

    目录 1.conftest.py文件介绍 2.conftest.py的注意事项 3.conftest.py的使用 4.不同位置conftest.py文件的优先级 5.conftest.py中Fixtu ...

  5. 『德不孤』Pytest框架 — 3、Pytest的基础说明

    目录 1.Pytest参数介绍 2.Pytest框架用例命名规则 3.Pytest Exit Code说明 4.pytest.ini全局配置文件 5.Pytest执行测试用例的顺序 1.Pytest参 ...

  6. 『德不孤』Pytest框架 — 5、Pytest失败重试

    Pytest失败重试就是,在执行一次测试脚本时,如果一个测试用例执行结果失败了,则重新执行该测试用例. 前提: Pytest测试框架失败重试需要下载pytest-rerunfailures插件. 安装 ...

  7. 『德不孤』Pytest框架 — 4、Pytest跳过测试用例

    目录 1.无条件跳过skip 2.有条件跳过skipif 3.练习 自动化测试执行过程中,我们常常出现这种情况:因为功能阻塞,未实现或者环境有问题等等原因,一些用例执行不了, 如果我们注释掉或删除掉这 ...

  8. 『德不孤』Pytest框架 — 9、Pytest测试报告

    目录 1.pytest-html插件 2.Allure测试报告 (1)Allure框架说明 (2)Allure框架的使用 1.pytest-html插件 Pytest可以通过命令行方式,生成xml/h ...

  9. 『德不孤』Pytest框架 — 12、Pytest中Fixture装饰器(二)

    目录 5.addfinalizer关键字 6.带返回值的Fixture 7.Fixture实现参数化 (1)params参数的使用 (2)进阶使用 8.@pytest.mark.usefixtures ...

随机推荐

  1. Java流程控制02:Scanner进阶

    Scanner进阶使用 import java.util.Scanner;​public class Demo04 {    public static void main(String[] args ...

  2. mac不能用ip访问项目的, 还有80端口不能开启的问题

    开启80端口 参考这篇文章 解决mac无法使用80端口问题,亲测可用 1. 防火墙设置问题 2. 网卡问题 3. 服务器地址配置问题

  3. JSP、Servlet和Spring MVC

    感谢原博主!!!https://blog.csdn.net/whut2010hj/article/details/80874008 版权声明:本文为博主原创文章,遵循CC 4.0 BY版权协议,转载请 ...

  4. Ubuntu下Java JDK安装

    1.仓库安装 待更新 2.手动安装 1.下载linux平台sdk. 官网:https://www.oracle.com/technetwork/java/javase/downloads/index. ...

  5. 关于单调性优化DP算法的理解

    Part1-二分栈优化DP 引入 二分栈主要用来优化满足决策单调性的DP转移式. 即我们设\(P[i]\)为\(i\)的决策点位置,那么\(P[i]\)满足单调递增的性质的DP. 由于在这种DP中,满 ...

  6. LeetCode随缘刷题之字符串转换整数

    package leetcode.day_01_29; import java.util.regex.Matcher; import java.util.regex.Pattern; /** * 请你 ...

  7. (一)什么是Rabbitmq

    1.初识MQ 1.1.同步和异步通讯 微服务间通讯有同步和异步两种方式: 同步通讯:就像打电话,需要实时响应. 异步通讯:就像发邮件,不需要马上回复. 两种方式各有优劣,打电话可以立即得到响应,但是你 ...

  8. 正则表达式以及re模块的使用

    内容概要 正则表达式简介 字符组 特殊符号 量词 贪婪匹配与非贪婪匹配 取消转义 正则表达式简介 '''正则表达式是一门语言,如果想在python中使用,需要导入re模块''' # 什么是正则表达式? ...

  9. 让数据可视化变得简单 – JavaScript 图形库

    作者 | 董叶 公司决策层会围绕着数据来制定相应的策略,数据的重要性与日俱增,政府.金融机构.互联网大厂正在以前所未有的速度收集数据,面对扑面而来的数据,没有抽象.视觉层的帮助,我们很难快速理解掌握其 ...

  10. c++ Message与Folder 拷贝 析构(没有动态空间的类)

    c++ Message与Folder 拷贝 析构(没有动态空间的类) 1.两个类里边分别保存一个对方的set表,当前类有拷贝或者销毁时需要更新另一个类的set表. 2.两个类都需要访问对方的priva ...