1、特点:
1.1、文件名称不可修改
1.2、不需要其它文件导入,可直接使用
1.3、放在根目录下,可以被所有文件调用,放到某个package下,只对该目录生效,可配置多个conftest文件
1.4、文件内存放整个项目中所有的fixture
2、应用场景
2.1、用到的token
2.2、用到的测试数据
2.3、用到的配置信息
2.4、登录
3、使用方法
结合fixture使用
在函数前添加@pytest.fixture()装饰器
在测试用例的函数中传入fixture标识的函数名。
import pytest
import time
from selenium import webdriver
from config.conf import ConfigYaml
# 引用封装的点击元素操作
from ElmentOperate.DtpPortal.DtpPortalPlatform import DtpPortalPlatform as DTP
@pytest.fixture()
def getdriver(request): # request是Pytest中的一个关键字,固定写法。
# 创建驱动对象
options = webdriver.ChromeOptions()
options.add_argument('--allow-insecure-localhost') # 允许忽略localhost上的TLS/SSL错误(无插页式,不阻止请求
caps = options.to_capabilities()
caps['acceptInsecureCerts'] = True # 绕过或隐式信任浏览器中的证书服务不信任的 TLS 证书
driver = webdriver.Chrome(desired_capabilities=caps)
driver.maximize_window()
driver.implicitly_wait(30)
# 定义用例执行后要执行的代码,封装到一个函数内
def end():
driver.quit()
# 通过request关键字,结束上面的函数
request.addfinalizer(end)
# 返回驱动对象
return driver
# 注入cookie;每次运行实例前需要手动修改value
@pytest.fixture(autouse=True)
def add_cookie(getdriver):
cookie = eval(ConfigYaml().get_cookies()) # 字符串转字典
dtp = DTP(driver=getdriver, path='/home')
# oidc.send_click()
dtp.driver.add_cookie(cookie)
time.sleep(1)
dtp.driver.refresh()
time.sleep(1)