2分pk10大小 _《带你装B,带你飞》pytest成魔之路4

  • 时间:
  • 浏览:0
  • 来源:辽宁生活网_辽宁人的网上生活家园

1. 简介

fixture是pytest的有另一十几个 闪光点,pytest要精通要怎样会能不学习fixture呢?跟着我同去深入学习fixture吧。人太好unittest和nose都支持fixture,要怎样让pytest做得更炫。

fixture是pytest特有的功能,它用pytest.fixture标识,定义在函数前面。在你编写测试函数的日后,给你将此函数名称做为传入参数,pytest将会以依赖注入办法,将该函数的返回值作为测试函数的传入参数。

fixture有明确的名字,在其他函数,模块,类或整个工程调用它一定会被激活。

fixture是基于模块来执行的,每个fixture的名字就可不还都能能触发有另一十几个 fixture的函数,它自身也可不还都能能调用其他的fixture。

亲戚亲戚亲戚朋友可不还都能能把fixture看做是资源,在你的测试用例执行日后可不还都能能去配置哪此资源,执行日后可不还都能能去释放资源。比如module类型的fixture,适合于哪此其他测试用例都只可不还都能能执行一次的操作。

fixture还提供了参数化功能,根据配置和不同组件来选取不同的参数。

fixture主要的目的是为了提供這個 可靠和可重复性的手段去运行哪此最基本的测试内容。比如在测试网站的功能时,每个测试用例全部一定会登录和退出,利用fixture就可不还都能能只做一次,要怎样让每个测试用例全部一定会做这两步也是冗余。

pytest 提供的 fixture 实现 unittest 中 setup/teardown 功能,可不还都能能在每次执行case日后初始化数据。不同点是,fixture 可不还都能能只在执行某十几个 特定 case 前运行,只可不还都能能在运行 case 前调用即可。比 setup/teardown 使用起来更灵活。上一篇讲到用例加setup和teardown可不还都能能实现在测试用例日后或日后加入其他操作,但這個 是整个脚本全局生效的,将会我可不还都能能实现以下场景:用例1可不还都能能先登录,用例2没有 登录,用例3可不还都能能先登录。很显然这就无法用setup和teardown来实现了。这本来本篇学习的目的,自定义测试用例的预置条件

2. fixture scope 作用范围

 先看下 fixture 函数的定义:

  使用装饰器标记fixture的功能 可不还都能能使用此装饰器(带或不带参数)来定义fixture功能。 fixture功能的名称可不还都能能在日后使用 引用它会在运行测试日后调用它:test模块或类可不还都能能使用pytest.mark.usefixtures(fixturename标记。 测试功能可不还都能能直接使用fixture名称作为输入参数,在這個 具体情况下,夹具实例从fixture返回功能将被注入。

def fixture(scope="function", params=None, autouse=False, ids=None, name=None):
    """
    :arg scope:    可选四组参数:function(默认)、calss、module、package/session

    :arg params:   有另一十几个

可选的参数列表,它将意味多个参数调用fixture函数和所有测试使用它。

    :arg autouse:  将会为True,则fixture func将为所有测试激活可不还都能能都看它。将会为False(默认值),则可不还都能能显式激活fixture。

    :arg ids:      每个参数对应的字符串id列表,要怎样让它们是测试id的一每种。将会没有

提供id,它们将从参数中自动生成。

    :arg name:     fixture的名称。 这默认为装饰函数的名称。 将会fixture在定义它的同一模块中使用,夹具的功能名称将被请求夹具的功能arg遮蔽; 处里這個

疑问的這個

办法是将装饰函数命名 “fixture_ <fixturename>”要怎样让使用”@ pytest.fixture(name ='<fixturename>')”。
  """

 重点说下 scope 四组参数的意义:

  • function:每个办法(函数)一定会执行一次。

  • class:每个类一定会执行一次。类蕴藏多个办法调用,只在第有另一十几个 办法调用时执行。

  • module:有另一十几个 .py 文件执行一次。有另一十几个 .py 文件将会蕴藏多个类和办法。

  • package/session:多个文件调用一次,可不还都能能跨 .py 文件。

 在所可不还都能能调用的函数前面加个装饰器 @pytest.fixture()。举有另一十几个 简单的例子:

3. fixture 优点

1.firture相对于setup和teardown来说应该有以下几点优势:

  • 命名办法灵活,不局限于setup和teardown这十几个 命名
  • conftest.py 配置里可不还都能能实现数据共享,没有 import就能自动找到其他配置
  • scope=”module” 可不还都能能实现多个.py跨文件共享前置
  • scope=”session” 以实现多个.py跨文件使用有另一十几个 session来完成多个用例

4. fixture参数传入(scope=”function”)

类似另有另一十几个 的测试场景:宏哥这里就拿博客园举个例子:

测试用例1:可不还都能能登录博客园,发布随笔

测试用例2:没有 登录博客园,浏览文章

测试用例3:可不还都能能登录博客园,删除随笔

4.1 代码实现:

把有另一十几个 函数定义为Fixture很简单,没有 在函数声明日后去掉 “@pytest.fixture”。其他函数要来调用這個 Fixture,只用把它当做有另一十几个 输入的参数即可。

4.2 参考代码:

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

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2020-1-09
@author: 北京-宏哥
Project:《带你装B,带你飞》pytest修仙之路4 - fixture简介 & yield
'''
# 3.导入模块
#  content of  test_bjhg_class1.py

import pytest

# 不带参数时默认scope="function"
@pytest.fixture(scope='function')
def login():
    print("登录博客园")

def test_1(login):
    print('测试用例1,登录博客园日后发布随笔111')

def test_2():
    print('测试用例2,没有
登录博客园,浏览文章222')

def test_3(login):
    print('测试用例2,登录博客园日后删除随笔333')
if __name__ == "__main__":
    pytest.main(["-s", "test_bjhg_class1.py"])

4.3 运行结果:

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

下面是运行结果,test_1和test_3运行日后都调用了login,也本来login执行了两次。默认具体情况下,fixture是每个测试用例将会调用了该fixture就会执行一次的。

2.将会@pytest.fixture()顶端没有 参数,没有 默认scope=”function”,也本来此时的级别的function,针对函数有效。

5. conftest.py配置

5.1 conftest.py配置可不还都能能注意以下点:

conftest.py配置脚本名称是固定的,没有 改名称

conftest.py与运行的用例要在同有另一十几个 pakage下,要怎样让有init.py文件

没有 import导入 conftest.py,pytest用例会自动查找

1.顶端有另一十几个 测试场景是在同有另一十几个 .py文件中,多个用例调用有另一十几个 登陆功能,将会有多个.py的文件都可不还都能能调用這個 登陆功能励志的话 ,那就没有 把登陆写到用例顶端去了。

此时应该要有有另一十几个 配置文件,单独管理其他预置的操作场景,pytest顶端默认读取conftest.py顶端的配置

5.2 conftest.py

5.2.1 代码实现:

5.2.2 参考代码:
# coding=utf-8
# 1.先设置编码,utf-8可支持中英文,如上,一般插进第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2020-1-09
@author: 北京-宏哥
Project:《带你装B,带你飞》pytest修仙之路4 - fixture简介 & yield
'''
# 3.导入模块
#  content of  conftest.py

import pytest

# 不带参数时默认scope="function"
@pytest.fixture(scope='function')
def login():
    print("登录博客园")

5.3.1 代码实现:

5.3.2 参考代码:
# coding=utf-8
# 1.先设置编码,utf-8可支持中英文,如上,一般插进第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2020-1-09
@author: 北京-宏哥
Project:《带你装B,带你飞》pytest修仙之路4 - fixture简介 & yield
'''
# 3.导入模块
#  content of  test_fix1.py

import pytest

def test_1(login):
    print('测试用例1,登录博客园日后发布随笔111')

def test_2():
    print('测试用例2,没有
登录博客园,浏览文章222')

def test_3(login):
    print('测试用例2,登录博客园日后删除随笔333')
if __name__ == "__main__":
    pytest.main(["-s", "test_fix1.py"])
5.3.3 运行结果:

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

5.4.1 代码实现:

5.4.2 参考代码:
# coding=utf-8
# 1.先设置编码,utf-8可支持中英文,如上,一般插进第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2020-1-09
@author: 北京-宏哥
Project:《带你装B,带你飞》pytest修仙之路4 - fixture简介 & yield
'''
# 3.导入模块
#  content of  test_fix2.py

import pytest


def test_4(login):
    print('测试用例4,登录博客园日后修改头像444')

def test_5():
    print('测试用例5,没有
登录博客园,浏览首页555')

def test_6(login):
    print('测试用例6,登录博客园日后保存随笔666')
if __name__ == "__main__":
    pytest.main(["-s", "test_fix2.py"])
5.4.3 运行结果:

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

6. 小结

  将会你的系统进程运行再次出現了下面的错误,本来刚开始英文英文忘记去掉 ‘import pytest',太少太少太少忘记哦。

=================================== ERRORS ====================================
_________________ ERROR collecting test_fixture_decorator.py __________________
test_fixture_decorator.py:2: in <module>
    @pytest.fixture()
E   NameError: name 'pytest' is not defined
!!!!!!!!!!!!!!!!!!! Interrupted: 1 errors during collection !!!!!!!!!!!!!!!!!!!
=========================== 1 error in 0.36 seconds ===========================

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

您的肯定本来进步的动力。将会你感觉还不错,就请鼓励一下吧!记得随手点波  推荐  太少忘记哦!!!

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