接口自动化 - pytest-fixture -scope作用范围
接口自动化-pytest中的fixture - scope
介绍
fixture文章中介绍的比较少,同学们可以去搜索下fixture的详解或者去看看源码
在这之前博主都是用的unittest单元测试框架去写的接口自动化,感觉也挺好用,但是得知pytest的fixture以及allure后,则出现了真香警告!!
先说fixture源码中包含了几大核心,我摘出了源码中的一部分
def fixture(
fixture_function: Optional[_FixtureFunction] = None,
*,
scope: "Union[_Scope, Callable[[str, Config], _Scope]]" = "function",
params: Optional[Iterable[object]] = None,
autouse: bool = False,
ids: Optional[
Union[
Iterable[Union[None, str, float, int, bool]],
Callable[[Any], Optional[object]],
]
] = None,
name: Optional[str] = None,
)
1、scope 2、params 3、autouse 4、ids
本文章对第一条 scope进行详细解释,因过于详细,非精简版内容,适合小白进行观看
scope:是控制fixture的作用范围
scope中包含了4个功能
1、function
每一个函数都会调用,使用方式:在fixture函数上面增加@pytest.fixture() 括号中不用加function,不传的话默认为function
2、class
每一个类调用一次,每个类下的方法是funtion概念 使用方式:在fixture函数当面增加@pytest.fixture('class')
3、module
每一个py文件调用一次,里面的方法和类,是class和function概念 使用方式:在fixture函数当面增加@pytest.fixture('module')
4、session
多个py文件调用一次,每个py文件都是module的概念 使用方式:在fixture函数当面增加@pytest.fixture('session')
详解
函数调用fixture函数的时候,是前置的
一、function
下列代码中,可以看到,我们设置了个fixture-function函数,然后pytest中每个函数都可以调用fixture-function
import pytest
@pytest.fixture()
def getsql_project(): #在我们需要设置的fxture上方增加@pytest.fixture()装饰器
project_id = 335
project_id2 = 332
print('验证是否前置的执行')
return project_id,project_id2 def test_set_project1(getsql_project): #我们要用fixture函数的时候,直接在括号中调用就好了
print('第一个id是',getsql_project[0]) def test_set_project2(getsql_project):
print('第二个id是', getsql_project[1]) if __name__ == '__main__':
pytest.main(["-s","test_fixture.py"])
返回结果如下
============================= test session starts =============================
collecting ... collected 2 items test_fixture_scope.py::test_set_project1 验证是否前置的执行
PASSED [ 50%]第一个id是 335 test_fixture_scope.py::test_set_project2 验证是否前置的执行
PASSED [100%]第二个id是 332 ============================== 2 passed in 0.08s ============================== Process finished with exit code 0
可以看到,每个方法都调用了一次fixture函数
二、class
一个类下只会触发一次
import pytest
@pytest.fixture(scope='class')
def getsql_project(): #在我们需要设置的fxture上方增加@pytest.fixture()装饰器
project_id = 335
project_id2 = 332
print('验证是否前置的执行')
return project_id,project_id2 class Test_fixture: def test_set_project1(self,getsql_project): #我们要用fixture函数的时候,直接在括号中调用就好了
print('第一个id是',getsql_project[0]) def test_set_project2(self,getsql_project):
print('第二个id是', getsql_project[1]) if __name__ == '__main__':
pytest.main(["-s","test_fixture.py"])
返回结果
============================= test session starts =============================
collecting ... collected 2 items test_fixture_scope.py::Test_fixture::test_set_project1
test_fixture_scope.py::Test_fixture::test_set_project2 ============================== 2 passed in 0.09s ============================== Process finished with exit code 0
验证是否前置的执行
PASSED [ 50%]第一个id是 335
PASSED [100%]第二个id是 332
可以看到,验证是否前置的执行,只被执行了一次,意味着我们2个方法都调用了fixture函数,实际只被执行了一次
三、module
一个py文件下只会执行一次
我们首先看下,我们有多个类,每个类都调用下fixture函数
import pytest
@pytest.fixture(scope='module')
def getsql_project(): #在我们需要设置的fxture上方增加@pytest.fixture()装饰器
project_id = 335
project_id2 = 332
print('验证是否前置的执行')
return project_id,project_id2 class Test_fixture:
def test_set_project1(self,getsql_project): #我们要用fixture函数的时候,直接在括号中调用就好了
print('第一个类id1',getsql_project[0])
def test_set_project2(self,getsql_project):
print('第一个类id2', getsql_project[1])
if __name__ == '__main__':
pytest.main(["-s","test_fixture.py"]) class Test_fixture2:
def test_set_project3(self,getsql_project): #我们要用fixture函数的时候,直接在括号中调用就好了
print('第二个类id1',getsql_project[0])
def test_set_project4(self,getsql_project):
print('第二个类id2', getsql_project[1])
if __name__ == '__main__':
pytest.main(["-s","test_fixture.py"])
返回结果(可以看出,验证是否前置执行 被执行了2次,因为我们定义的class,每个类被执行一次所以执行了2次)
============================= test session starts =============================
collecting ... collected 4 items test_fixture_scope.py::Test_fixture::test_set_project1
test_fixture_scope.py::Test_fixture::test_set_project2
test_fixture_scope.py::Test_fixture2::test_set_project3 验证是否前置的执行
PASSED [ 25%]第一个类id1 335
PASSED [ 50%]第一个类id2 332 test_fixture_scope.py::Test_fixture2::test_set_project4 ============================== 4 passed in 0.09s ============================== Process finished with exit code 0
验证是否前置的执行
PASSED [ 75%]第二个类id1 335
PASSED [100%]第二个类id2 332
重点来了
此时我们将class换成module
@pytest.fixture(scope='module')
返回结果(在整个py文件中,不论多个类调用,只被运行了一次)
============================= test session starts =============================
collecting ... collected 4 items test_fixture_scope.py::Test_fixture::test_set_project1
test_fixture_scope.py::Test_fixture::test_set_project2
test_fixture_scope.py::Test_fixture2::test_set_project3 验证是否前置的执行
PASSED [ 25%]第一个类id1 335
PASSED [ 50%]第一个类id2 332 test_fixture_scope.py::Test_fixture2::test_set_project4 ============================== 4 passed in 0.08s ============================== Process finished with exit code 0
PASSED [ 75%]第二个类id1 335
PASSED [100%]第二个类id2 332
四、session
一般我们这种fixture都卸载目录下的conftest.py文件下,如果有2个py文件都调用了conftest.py下的fixture函数,如果fixture是session形式,多个py可以用这一个函数返回的数据,但是不会重复调用。
新建conftest.py 文件,里面去放入我们的fixture函数
import pytest
@pytest.fixture(scope='module')
def getsql_project(): #在我们需要设置的fxture上方增加@pytest.fixture()装饰器
project_id = 335
project_id2 = 332
print('验证是否前置的执行')
return project_id,project_id2
然后多个py都同时调用getsql_project 实际只被调用一次
test_fixture_scope.py::Test_fixture::test_set_project1
test_fixture_scope.py::Test_fixture::test_set_project2
test_fixture_scope.py::Test_fixture2::test_set_project3 验证是否前置的执行
PASSED [ 25%]第一个类id1 335
PASSED [ 50%]第一个类id2 332 test_fixture_scope.py::Test_fixture2::test_set_project4 ============================== 4 passed in 0.08s ============================== Process finished with exit code 0
PASSED [ 75%]第二个类id1 335
PASSED [100%]第二个类id2 332
接口自动化 - pytest-fixture -scope作用范围的更多相关文章
- pytest 用 @pytest.mark.usefixtures("fixtureName")或@pytest.fixture(scope="function", autouse=True)装饰,实现类似setup和TearDown的功能
conftest.py import pytest @pytest.fixture(scope="class") def class_auto(): print("&qu ...
- requests接口自动化-pytest框架
pytest框架规则 测试文件以test_开头或者以_test结尾 测试类以Test开头,并且不能带有init方法 测试函数以test_开头 断言使用assert pytest框架运行用例 运行单个文 ...
- pytest:通过scope控制fixture的作用范围
一.fixture里面有个参数scope,通过scope可以控制fixture的作用范围,根据作用范围大小划分:session>module>class>function,具体作用范 ...
- 基于Python+Requests+Pytest+YAML+Allure实现接口自动化
本项目实现接口自动化的技术选型:Python+Requests+Pytest+YAML+Allure ,主要是针对之前开发的一个接口项目来进行学习,通过 Python+Requests 来发送和处理H ...
- Pytest学习(六) - conftest.py结合接口自动化的举例使用
一.conftest.py作用 可以理解成存放fixture的配置文件 二.conftest.py配置fixture注意事项 pytest会默认读取conftest.py里面的所有fixture co ...
- python+pytest接口自动化(13)-token关联登录
在PC端登录公司的后台管理系统或在手机上登录某个APP时,经常会发现登录成功后,返回参数中会包含token,它的值为一段较长的字符串,而后续去请求的请求头中都需要带上这个token作为参数,否则就提示 ...
- pytest fixture中scope试验,包含function、module、class、session、package
上图是试验的目录结构 conftest.py:存放pytest fixture的文件 import uuid import pytest @pytest.fixture(scope="mod ...
- python接口自动化12-pytest前后置与fixture
前言 我们都知道在自动化测试中都会用到前后置,pytest 相比 unittest 无论是前后置还是插件等都灵活了许多,还能自己用 fixture 来定义.(甩 unttest 半条街?) 首先了解一 ...
- 如何用tep完成增删改查接口自动化
tep的设计理念是让人人都可以用Python写自动化,本文就来介绍如何用tep完成增删改查接口自动化. 环境变量 编辑fixtures/fixture_admin.py: "qa" ...
随机推荐
- python刷题第三周
以下是本周有所收获的题目 第一题: 第4章-4 验证"哥德巴赫猜想" (20 分) 数学领域著名的"哥德巴赫猜想"的大致意思是:任何一个大于2的偶数总能表示为两 ...
- shell 一些常用命令
一般自己虚拟机新安装的centos才需要此配置 setenforce 是Linux的selinux防火墙配置命令 执行setenforce 0 表示关闭selinux防火墙. getenforce 查 ...
- iMAC_使用相关
MAC软件下载 https://www.macwk.com/ 这是网站是一个下载免费软件的网站,下载通过<天翼云盘>下载,这个天翼云盘下载的快 好用的软件推荐 腾讯柠檬(Tencent L ...
- P5363-[SDOI2019]移动金币【阶梯博弈,dp,组合数学】
正题 题目链接:https://www.luogu.com.cn/problem/P5363 题目大意 \(1\times n\)的网格上有\(m\)个硬币,两个人轮流向前移动一个硬币但是不能超过前一 ...
- Redis之品鉴之旅(二)
2)hash类型,上代码 using (RedisClient client = new RedisClient("127.0.0.1", 6379, "12345&qu ...
- 深入浅出WPF-06.Binding(绑定)03
MultiBinding(多路Binding) 当UI中的显示信息是由源Source中的多个数据来决定时,使用MultiBinding.他和Binding的区别是需要传递多个元数据,针对多个数据源需要 ...
- C#实例:datagridview单元格合并
这是替C#微信交流群群友做的一个小实例,目的就是在datagridview选择对应行以后,点击button后获取对应行的ip,并执行相应的操作,其实我觉得这样的话button没必要非放置到datagr ...
- T-SQL——数据透视和逆透视
目录 0. 测试数据集及说明 0.1 准备测试数据 0.2 对一维表和二维表理解 1. 透视转换 1.1 使用标准SQL进行数据透视 1.2 使用T-SQL中pivot函数进行数据透视 1.3 关于 ...
- Win32窗口框架
Win32窗口框架 WindowClass 单例,负责窗口初始化注册和取消注册: 负责提供静态方法: 放在Window类内部,方便初始化时,wndProc(HandleMsgSetup)的赋值: cl ...
- 微服务安全(二)OAuth 2.0
1. 概念 OAuth是一个开放的.安全的用户认证协议,允许用户让第三方应用访问该用户在某一网站上存储的私密的资源,而无须将用户名和登录口令提供给第三方应用.授权的第三方应用只能在特定的时段内访问特定 ...