Pytest框架实现一些前后置(固件,夹具)的处理,常见三种
一、setup/teardown,setup_class/teardown_class
为什么需要这些功能? 比如:web自动化执行用例之前,请问需要打开浏览器吗?用例执行后需要关闭浏览器?
import pytest
class aaaLogin:
# 这个在所有的用例之前只执行一次,作用域是类
def setup_class(self):
print('在每个类执行前的初始化工作:比如:创建日志对象,创建数据库的连接,创建接口的请求对象')
# 在每个用例之前执行一次,作用域是方法
def setup(self):
print("
在执行每个测试用例之前执行的代码:打开浏览器,加载网页")
# @pytest.mark.smoke
def test_aaa_1(self):
print("
aaa冒烟1")
def test_aaa_2(self):
print("
aaa冒烟2")
def test_aaa_3(self):
print("
aaa冒烟3")
def test_aaa_4(self):
print("
aaa冒烟4")
def teardown(self):
print("
在执行每个测试用例之后扫尾的代码:关闭浏览器")
# 这个在所有的用例之前只执行一次,作用域是类
def teardown_class(self):
print('在每个类执行后的扫尾工作:比如:销毁日志对象,销毁数据库的连接,销毁接口的请求对象')
# 注意:和unitest不一样,全是小写
二、使用@pytest.fixture()装饰器来实现部分用例的前后置
装饰器 @pytest.fixture(scope="",params="",autouse="",ids="",name="") 1)scope:表示的是被@pytest.fixture()标记的方法的作用域。function(默认),class,module,package/session.(函数、类、模块、包) 2)params:参数化(支持,列表[],元祖(),字典列表[{},{},{}],字典元祖({},{},{}))
params参数化例子:
import pytest
@pytest.fixture(scope="function",params=['成龙','甄子丹','蔡依林'])
def my_fixture(request):
print('这是前置')
# 使用yield返回参数化的param值,可以实现同一用例中实现参数化的同时满足前后置都正常,使用return会报错,return和yield同时使用实现不了
yield request.param # return和yield都表示返回的意思,但是return的后面不能有代码,yield返回后后面可以接代码。意思可以理解为return之后return所在方法的作用域结束;而yield返回之后,yield所在方法的作用域未结束
print('这是后置')
class aaaLogin1:
def test_aaa_1(self):
print("
aaa冒烟1")
def test_aaa_2(self):
print("
aaa冒烟2")
def test_aaa_3(self):
print("
aaa冒烟3")
def test_aaa_4(self,my_fixture):
print("
aaa冒烟4")
print("---------"+str(my_fixture))
# 注意:
# params=['成龙','甄子丹','蔡依林']这里params是参数名,有s
# request.param这里是属性名,是没有s的
3)autouse=Ture:自动执行,默认False 4)ids:当使用params参数化时,给每一个值设置一个变量名。意义不大
import pytest
@pytest.fixture(scope="function",params=['成龙','甄子丹','蔡依林'],ids=["cl","zzd","cyl"])
def my_fixture(request):
print('这是前置')
# 使用yield返回参数化的param值,可以实现同一用例中实现参数化的同时满足前后置都正常,使用return会报错,return和yield同时使用实现不了
yield request.param # return和yield都表示返回的意思,但是return的后面不能有代码,yield返回后后面可以接代码。意思可以理解为return之后return所在方法的作用域结束;而yield返回之后,yield所在方法的作用域未结束
print('这是后置')
class aaaLogin1:
def test_aaa_1(self):
print("
aaa冒烟1")
def test_aaa_2(self):
print("
aaa冒烟2")
def test_aaa_3(self):
print("
aaa冒烟3")
def test_aaa_4(self,my_fixture):
print("
aaa冒烟4")
print("---------"+str(my_fixture))
5)name:表示的是给被@pytest.fixture()标记的方法取一个别名
@pytest.fixture(scope="function",params=['成龙','甄子丹','蔡依林'],ids=["cl","zzd","cyl"],name='bbb')
def my_fixture(request):
print('这是前置')
yield request.param
print('这是后置')
class aaaLogin1:
def test_aaa_1(self):
print("
aaa冒烟1")
def test_aaa_2(self):
print("
aaa冒烟2")
def test_aaa_3(self):
print("
aaa冒烟3")
def test_aaa_4(self,bbb):
print("
aaa冒烟4")
print("---------"+str(bbb))
# 注意:当取了别名之后,那么原来的名称就用不了了
###########
下附源码地址: