一、固件(Fixture)是一些函数,pytest 会在执行测试函数之前(或之后)加载运行它们。我们可以利用固件做任何事情,其中最常见的可能就是数据库的初始连接和最后关闭操作。
①场景一:使用@pytest.fixture,并在要使用方法前传入函数名称
导入Pytest,在登陆函数前加上@pytest.fixture,在使用的方法前传入(登陆函数名称),就先登陆;不传入就不登陆,直接执行测试方法
import pytest
@pytest.fixture()
def login():
print('\n输入用户名密码登陆')
def test_cart(login):
print('用例1,登陆后执行购物车功能')
def test_check():
print('用例2,不登陆直接查询')
def test_pay(login):
print('用例3,登陆后执行支付操作')
if __name__ == '__main__':
pytest.main(["-s","test.py"])
②场景二:conftest.py文件,实现共享数据。
在工程目录下,新建一个conftest.py文件,并将前置函数,放在此文件中。
③场景三:yield测试方法之后的动作,先执行前置动作,然后执行测试方法,最后执行yield。
#conftest.py
import pytest
@pytest.fixture()
def login():
print('\n输入用户名密码登陆')
yield
print('\n退出登陆')
④场景四:使用fixture进行参数传递,固件在定义时使用?params ?参数进行参数化,固件参数化依赖于内置固件?request ?及其属性?param。
import pytest
#固定写法,利用内置固件 request 及其属性 param
@pytest.fixture(params=['1','2','abc'])
def params_data(request):
return request.params
#将函数params_data作为参数传入
def test_params(params_data):
print(params_data)
if __name__ == '__main__':
pytest.main(["-s","param.py"])
⑤场景五:多个fixture(固件)一起使用。
import pytest
#将固件browser作为传参
@pytest.fixture()
def login(browser):
print('\n输入用户名密码登陆')
yield
print('\n退出登陆')
@pytest.fixture()
def browser():
print('\n打开浏览器')
def test_cart(login):
print('用例1,登陆后执行购物车功能')
def test_check(browser):
print('用例2,不登陆直接查询')
def test_pay(login):
print('用例3,登陆后执行支付操作')
if __name__ == '__main__':
pytest.main(["-s","test2.py"])
?⑥场景六:@pytest.fixture(autouse=True)表示该函数是否所有的测试用例都默认调用,True表示自动均调用,False表示不自动调用。
?⑦场景七:@pytest.mark.usefixtures('login'),在测试用例前加上使用某方法,则会调用。
#加载固件login
@pytest.mark.usefixtures('login')
def test_pay():
print('用例3,登陆后执行支付操作')
?
|