“conftest.py” 是 pytest 测试框架中的一个特殊的配置文件,它能够为整个测试环境提供一些共享的配置。
假设我们有三个业务模块,分别为商品模块、订单模块、用户模块。它们都有各自的测试用例,其中订单和用户模块需要拿到登录成功返回的 token 才能进行测试。
import pytest
@pytest.fixture(scope="session")
def login():
print("### 登录系统! ###")
name = "jan"
token = "111"
yield name, token
print("### 退出系统! ###")
@pytest.fixture(autouse=True)
def get_token(login):
name, token = login
print(f"===(全局 conftest.py),每个测试函数执行前都自动调用 get_token fixture===")
import pytest
if __name__ == '__main__':
pytest.main(["-s", "../test-demo/"])
def test_case1():
print(">>>无需登录的商品模块:执行商品查询测试>>>")
import pytest
@pytest.fixture(scope="module")
def open_order_management_system(login):
name, token = login
print(f"===(order 目录下的 conftest.py),得到token{token},用户{name}打开订单管理系统. ===")
def test_case1(open_order_management_system):
print(">>>进入订单管理:执行创建订单测试>>>")
def test_case2(open_order_management_system):
print(">>>进入订单管理:执行查询订单测试>>>")
def test_case1(login):
name, token = login
print(f">>>(全局 conftest.py)得到token:{token},进入用户管理:执行创建用户测试>>>")
import pytest
if __name__ == '__main__':
pytest.main(["-s", "../test-demo/"])
# ### 登录系统! ###
#
# ===(全局 conftest.py),每个测试函数执行前都自动调用 get_token fixture===
# >>>无需登录的商品模块:执行商品查询测试>>>
#
# ===(order 目录下的 conftest.py),得到token111,用户jan打开订单管理系统. ===
# ===(全局 conftest.py),每个测试函数执行前都自动调用 get_token fixture===
# >>>进入订单管理:执行创建订单测试>>>
#
# ===(全局 conftest.py),每个测试函数执行前都自动调用 get_token fixture===
# >>>进入订单管理:执行查询订单测试>>>
#
# ===(全局 conftest.py),每个测试函数执行前都自动调用 get_token fixture===
# >>>(全局 conftest.py)得到token:111,进入用户管理:执行创建用户测试>>>
#
# ### 退出系统! ###
import
conftest.py,pytest 会自动查找。“-------怕什么真理无穷,进一寸有一寸的欢喜。”
微信公众号搜索:饺子泡牛奶。