前言
request 是 pytest 的内置 fixture , "为请求对象提供对请求测试上下文的访问权,并且在fixture被间接参数化的情况下具有可选的“param”属性。"这是官方文档对request的描述,可参考的文档不多。
一、FixtureRequest
FixtureRequest 是来自 fixture 或者 测试用例的请求,它有访问测试上下文的权限, FixtureRequest_pytest.fixtures pytest documentation。
class FixtureRequest[源代码](https://docs.pytest.org/en/latest/_modules/_pytest/fixtures.html#FixtureRequest) 请求对象提供对请求的测试上下文的访问,并且具有可选的 param 属性,以防设备被间接参数化。 fixturename 正在为其执行此请求的 fixture 名称。 scope 作用域字符串,“function”、“class”、“module”、“session”之一。 fixturenames 此请求中所有活动状态的 fixture 的名称。 node 基础集合节点(取决于当前请求范围)。 config 与此请求关联的 pytest 配置对象。 function 如果请求具有每个函数范围,则测试函数对象。 cls 类(可以是None),其中收集了测试函数。 instance 在其上收集测试函数的实例(可以是None)。 module 收集测试函数的Python模块对象。 fspath 收集此测试的测试模块的文件系统路径。 keywords 基础节点的关键字/标记词典。 session Pytest会话对象。 addfinalizer(finalizer: Callable[], object]) → None[源代码] 添加finalizer/teardown函数,以便在请求的测试上下文中的最后一个测试完成执行后调用。 applymarker(marker) → None[源代码] 对单个测试函数调用应用标记。 如果不希望在所有函数调用上都有关键字/标记,则此方法非常有用。 参数 marker -- A _pytest.mark.MarkDecorator 调用创建的对象 pytest.mark.NAME(...) . raiseerror(msg: Optional[str]) → NoReturn[源代码] 使用给定的消息引发FixtureLookupError。 getfixturevalue(argname: str) → Any[源代码] 动态运行命名的fixture函数。 如果可能,建议通过函数参数声明fixtures。但是,如果您只能在测试设置时决定是否使用另一个fixture,那么您可以使用此函数在fixture或测试函数体中检索它。 引发 pytest.FixtureLookupError -- 如果找不到给定的固定装置。 折叠二、request.param
前面讲fixture参数化的时候,有接触到 "request.param" 用于获取测试的请求参数,以下示例
''' import pytest # 测试数据 test_data = ["user1", "user2"] @pytest.fixture(params=test_data) def register_users(request): # 获取当前的测试数据 user = request.param print("\n拿着这个账号去注册:%s"%user) result = "success" return user, result def test_register(register_users): user, result = register_users print("在测试用例里面里面获取到当前测试数据:%s"%user) print(result) assert result == "success"
此案例里面我们可以在fixture参数化的时候,通过request.param获取到测试的请求参数,但是在用例里面用 request.param 却不能获取到测试的请求参数
def test_register_x(register_users, request): print(request.param)
这样运行,会抛异常:'FixtureRequest' object has no attribute 'param'
拿着这个账号去注册:user1 F register_users = ('user1', 'success') request =关注打赏