好运pk10游戏_《带你装B,带你飞》pytest修仙之路5

  • 时间:
  • 浏览:2

1. 简介

  上一篇中,许多人 你都还可不可不可不可以 实现了在每个用例你都还可不可不可不可以 执行初始化操作,那末用例执行完你都还可不可不可不可以 如还要清除数据(或还原)操作,都还可不可不可不可以 使用 yield 来实现。fixture通过scope参数控制setup级别,既然有setup作为用例你都还可不可不可不可以 前的操作,用例执行完你都还可不可不可不可以 那肯定都是teardown操作。

这里用到fixture的teardown操作并都是独立的函数,用yield关键字呼唤teardown操作。fixture的teardown操作并都是独立的函数,都还可不可不可不可以 用yield关键字呼唤teardown操作。 

  许多人 你都还可不可不可不可以 学习的都是测试用例的前置固件,也好多好多 我最少“setup”。说到这,细心的你因为想到了,那有那末那此法律妙招 都还可不可不可不可以 表示出“teardown”?这好多好多 我许多人 今天学习的yield和addfinalizer。

yield

  yield是另2个关键字,它都是单独指在的,要写在fixtrue标记的固件中。

  许多人 在声明的固件myfixture中加入yield关键字,在它下面写测试用例执行后你都还可不可不可不可以 运行的代码;一些有关于固件的使用那末任何差别。还要说明的一些是许多人 在pytest主函数中增加了另2个参数“–setup-show”,他会显示出固件的执行清况 。

  fixture上面的teardown用yield来唤醒teardown的执行

  因为测试用例中的代码突然出现异常因为断言失败,都是然完会影响他的固件中yield后的代码执行;而且因为固件中的yield你都还可不可不可不可以 的代码也好多好多 我最少setup累积的带代码,突然出现错误或断言失败,那末yield后的代码将不必再执行,当然测试用例中的代码好多好多 我会执行。

  许多人 也都还可不可不可不可以 通过request.addfinalizer()的法律妙招 实现“teardown”

  许多人 在固件中传入request参数;又在固件中定义了另2个内置函数;最后将定义的内置函数换成到request的addfinalizer中

2. scope="function"

当 pytest.fixture(scope="function") 时,pytest的yieId 你是什么unittest的teartown。每个法律妙招 (函数)完会执行一次

1.新建 test_bjhg_function1.py文件,许多人 看一下是都是从前的。

2.1 代码实现:

2.2 参考代码:

# coding=utf-8
# 1.先设置编码,utf-8可支持中英文,如上,一般倒进第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2020-04-20
@author: 北京-宏哥
Project:《带你装B,带你飞》pytest修仙之路5 - yield操作
'''
# 3.导入模块
import pytest

@pytest.fixture(scope="function")
def login():
    print("登录成功")
    yield
    print("用例执行完成,收尾")

def test1(login):
    print('操作1')
    print("-----------------------------------------------")

def test2(login):
    print('操作2')
    print("-----------------------------------------------")

def test3(login):
    print('操作3')
    print("-----------------------------------------------")

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

2.3 运行结果:

运行代码后,控制台打印如下图的结果

从结果看出,实在test1,test2,test3另2个地方都调用了login函数,而且它会在每另2个用例前执行一次

2.因为test1不调用,test2(调用login),test3不调用,运行顺序会是如何的?

2.4 参考代码:

# coding=utf-8
# 1.先设置编码,utf-8可支持中英文,如上,一般倒进第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2020-04-20
@author: 北京-宏哥
Project:《带你装B,带你飞》pytest修仙之路5 - yield操作
'''
# 3.导入模块
import pytest

@pytest.fixture(scope="function")
def login():
    print("登录成功")
    yield
    print("用例执行完成,收尾")

def test1():
    print('操作1')
    print("-----------------------------------------------")

def test2(login):
    print('操作2')
    print("-----------------------------------------------")

def test3():
    print('操作3')
    print("-----------------------------------------------")

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

2.5 运行结果:

运行代码后,控制台打印如下图的结果

从结果看出,function级别的fixture在当前.py模块里,只会在用例(test_s2)第一次调用前执行一次

3.scope="module"

1.fixture参数scope=”module”,module作用是整个.py文件完会生效( 整个文件只会执行一次),用例调用时,参数写上函数名称就行

3.1 代码实现:

3.2 参考代码:

# coding=utf-8
# 1.先设置编码,utf-8可支持中英文,如上,一般倒进第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2020-04-20
@author: 北京-宏哥
Project:《带你装B,带你飞》pytest修仙之路5 - yield操作
'''
# 3.导入模块
import pytest

@pytest.fixture(scope="module")
def login():
    print("登录成功")
    yield
    print("用例执行完成,收尾")

def test1(login):
    print('操作1')
    print("-----------------------------------------------")

def test2(login):
    print('操作2')
    print("-----------------------------------------------")

def test3(login):
    print('操作3')
    print("-----------------------------------------------")

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

3.3 运行结果:

运行代码后,控制台打印如下图的结果

从结果看出,实在test1,test2,test3另2个地方都调用了login函数,而且它只会在第另2个用例前执行一次

2.因为test1不调用,test2(调用login),test3不调用,运行顺序会是如何的?

3.4 参考代码:

# coding=utf-8
# 1.先设置编码,utf-8可支持中英文,如上,一般倒进第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2020-04-20
@author: 北京-宏哥
Project:《带你装B,带你飞》pytest修仙之路5 - yield操作
'''
# 3.导入模块
import pytest

@pytest.fixture(scope="module")
def login():
    print("登录成功")
    yield
    print("用例执行完成,收尾")

def test1():
    print('操作1')
    print("-----------------------------------------------")

def test2(login):
    print('操作2')
    print("-----------------------------------------------")

def test3():
    print('操作3')
    print("-----------------------------------------------")

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

3.5 运行结果:

运行代码后,控制台打印如下图的结果

从结果看出,module级别的fixture在当前.py模块里,只会在用例(test_s2)第一次调用前执行一次

4. yield执行teardown

  细心的童鞋因为小伙伴都还可不可不可不可以 看了,我前边的代码含有另2个yield关键字,许多人 怪怪的好奇是做那此的,一些小节你都还可不可不可不可以 我答疑解惑。实在好多好多 我用来唤醒teardown。

1.fixture上面的teardown用yield来唤醒teardown的执行

4.1 代码实现:

4.2 参考代码:

# coding=utf-8
# 1.先设置编码,utf-8可支持中英文,如上,一般倒进第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2020-04-20
@author: 北京-宏哥
Project:《带你装B,带你飞》pytest修仙之路5 - yield操作
'''
# 3.导入模块
import pytest

@pytest.fixture(scope="module")
def login():
    print("登录成功")
    yield
    print("执行teardown!")
    print("用例执行完成,收尾")

def test1(login):
    print('操作1')
    print("-----------------------------------------------")

def test2(login):
    print('操作2')
    print("-----------------------------------------------")

def test3(login):
    print('操作3')
    print("-----------------------------------------------")

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

4.3 运行结果:

运行代码后,控制台打印如下图的结果

5. yield遇到异常

1.因为其中另2个用例突然出现异常,不影响yield上面的teardown执行,运行结果互不影响,而且在用例删剪执行完你都还可不可不可不可以 ,会呼唤teardown的内容

5.1 代码实现:

5.2 参考代码:

# coding=utf-8
# 1.先设置编码,utf-8可支持中英文,如上,一般倒进第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2020-04-20
@author: 北京-宏哥
Project:《带你装B,带你飞》pytest修仙之路5 - yield操作
'''
# 3.导入模块
import pytest

@pytest.fixture(scope="module")
def login():
    print("登录成功")
    yield
    print("执行teardown!")
    print("用例执行完成,收尾")

def test1(login):
    print('操作1')
    print("-----------------------------------------------")
    # 因为第另2个用例异常了,不影响一些的用例执行
    raise NameError  # 模拟异常

def test2(login):
    print('操作2')
    print("-----------------------------------------------")

def test3(login):
    print('操作3')
    print("-----------------------------------------------")

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

5.3 运行结果:

运行代码后,控制台打印如下图的结果

2.因为在setup就异常了,那末是不必去执行yield上面的teardown内容了

3.yield也都还可不可不可不可以 配合with的话使用,以下是官方文档给的案例

# 官方文档案例
# content of test_yield2.py

import smtplib
import pytest

@pytest.fixture(scope="module")
def smtp():
    with smtplib.SMTP("smtp.gmail.com") as smtp:
        yield smtp  # provide the fixture value

6.addfinalizer终结函数

1.除了yield都还可不可不可不可以 实现teardown,在request-context对象中注册addfinalizer法律妙招 也都还可不可不可不可以 实现终结函数。

# 官方案例

# content of conftest.py
import smtplib
import pytest

@pytest.fixture(scope="module")
def smtp_connection(request):
    smtp_connection = smtplib.SMTP("smtp.gmail.com", 587, timeout=5)
    def fin():
        print("teardown smtp_connection")
        smtp_connection.close()
    request.addfinalizer(fin)
    return smtp_connection  # provide the fixture value

2.yield和addfinalizer法律妙招 都是在测试完成后呼叫相应的代码。而且addfinalizer不同的是:

  • 他都还可不可不可不可以 注册多个终结函数。

  • 那此终结法律妙招 突然会被执行,无论在你都还可不可不可不可以 的setup code有那末抛出错误。一些法律妙招 对于正确关闭所有的fixture创建的资源非常便利,即使其一在创建或获取时失败

7.小结

 好了,今天的分享就到这里吧!!!谢谢各位的耐心阅读。有什么的问题加群交流讨论!!!

您的肯定好多好多 我我进步的动力。因为你感觉还不错,就请鼓励一下吧!记得随手点波  推荐  都是时候忘记哦!!!

别忘了点 推荐 留下您来过的痕迹

参考文档:https://docs.pytest.org/en/latest/