相当于self对象,因为调试的时候测试用例是类似沙箱的单步运行,所以self对象的属性被阻挡在沙箱外边。

request.cls 是pytest中的一个属性,它允许您在测试类中共享数据或属性。当您使用pytest编写测试类时,request 夹具允许您在测试方法之间传递数据或设置属性。

具体来说,以下是 request.cls 的用法:

在测试类中设置属性:您可以在一个测试方法中使用 request.cls 来设置属性,然后在同一个测试类中的其他测试方法中访问这些属性。这使得在整个测试类中共享数据变得容易。

继承测试夹具:通过使用 @pytest.mark.usefixtures(“request”) 装饰器,您可以将 request 夹具应用于整个测试类,以使 request.cls 在整个测试类中可用。

下面是一个示例,展示了如何在pytest测试类中使用 request.cls:

import pytest

class TestSample:
    def test_example1(self, request):
        # 在这个测试方法中,使用request夹具来写入属性到self对象中
        request.cls.shared_data = "Data from test_example1"
        assert 1 == 1

    def test_example2(self, request):
        # 在这个测试方法中,获取先前设置的属性
        shared_data = request.cls.shared_data
        assert shared_data == "Data from test_example1"

@pytest.mark.usefixtures("request")
class TestSampleFixture:
    pass

运行结果

============================= test session starts =============================
collecting ... collected 2 items

test.py::TestSample::test_example1 PASSED                                [ 50%]
test.py::TestSample::test_example2 PASSED                                [100%]

============================== 2 passed in 0.02s ==============================

在上述示例中,request.cls 用于在 test_example1 中设置属性 shared_data,然后在 test_example2 中获取该属性。通过使用 @pytest.mark.usefixtures(“request”) 装饰器,我们确保 request 夹具在整个 TestSampleFixture 测试类中可用。

请注意,使用 request.cls 应该小心谨慎,确保不会引入测试之间的状态污染,因为pytest默认情况下会运行测试方法的时候不会重用测试类的实例。

10-25 20:44