前面讲 request 是pytest的一个内置 fixture ,作用是获取测试的上下文,可以通过request.config 获取配置对象。
pytestconfig 的作用跟 request.config 是一样的,都是获取配置对象
pytestconfig 是一个内置fixture,用于获取配置对象 pytestconfig 源码
pytestconfig 有2个常用的方法
- .getoption() 获取命令行参数
- .getini() 获取ini配置文件的参数
@fixture(scope="session")
def pytestconfig(request: FixtureRequest) -> Config:
"""Session-scoped fixture that returns the :class:`_pytest.config.Config` object.
Example::
def test_foo(pytestconfig):
if pytestconfig.getoption("verbose") > 0:
...
"""
return request.config
从上面的源码看出,实际返回的就是 request.config
使用示例
def test_foo(pytestconfig):
if pytestconfig.getoption("verbose") > 0:
...
getoption() 获取命令行参数
获取命令行参数的案例,在前面讲过很多次了,这个也是用的最广泛的
# content of conftest.py
# 作者-上海悠悠 QQ交流群:717225969
# blog地址 https://www.cnblogs.com/yoyoketang/
import pytest
def pytest_addoption(parser):
parser.addoption(
"--cmdopt", action="store", default="type1", help="my option: type1 or type2"
)
@pytest.fixture
def cmdopt(pytestconfig):
return pytestconfig.getoption("--cmdopt")
测试用例
# test_cmdopt.py
import pytest
# 作者-上海悠悠 QQ交流群:717225969
# blog地址 https://www.cnblogs.com/yoyoketang/
def test_answer_1(pytestconfig):
type = pytestconfig.getoption("--cmdopt")
print("获取到命令行参数:%s" % type)
def test_answer_2(cmdopt):
print("获取到命令行参数:%s" % cmdopt)
命令行运行用例的时候,可以用 --cmdopt 参数
>pytest -s test_cmdopt.py --cmdopt type2
================== test session starts =======
platform win32 -- Python 3.6.6, pytest-4.5.0, py-1.9.0, pluggy-0.13.1
rootdir: D:\wangyiyun\web\cases\module2
rerunfailures-9.1, xdist-2.1.0
collected 2 items
test_cmdopt.py 获取到命令行参数:type2
.获取到命令行参数:type2
.
================== 2 passed in 0.06 seconds ==========
getini() 从 pytest.ini 配置文件获取参数
在项目的根目录一般会放一个 pytest.ini 写一些配置参数
[pytest]
log_cli = 1
addopts = -v -x
我们想读取 pytest.ini 里面的配置信息,可以用 pytestconfig.getini() 来获取,使用示例
# conftest.py
# 作者-上海悠悠 QQ交流群:717225969
# blog地址 https://www.cnblogs.com/yoyoketang/
@pytest.fixture(autouse=True)
def get_ini(pytestconfig):
'''读取ini配置信息'''
# 读取 log_cli配置
log_cli = pytestconfig.getini('log_cli')
print("获取到markers :%s" % log_cli)
addopts = pytestconfig.getini('addopts')
print("获取到addopts的配置:%s " % addopts)
在命令行运行后,可以看到打印的内容
test_cmdopt.py::test_answer_1 获取到markers :True
获取到db的配置:['-v', '-x']
获取到命令行参数:type1
PASSED
addopts 参数可以更改默认命令行选项,这个当我们在 cmd 输入一堆指令去执行用例的时候,就可以用该参数代替了,省去重复性的敲命令工作
比如上面的配置, 命令行输入pytest运行的时候,会默认带上的参数,如 ‘pytest -v -x’
log_cli 是控制台实时输出日志,可以设置True 和 False,也可以设置1 和 0
log_cli 是控制台实时输出日志,可以设置True 和 False,也可以设置1 和 0,默认是关闭状态(False)
当 log_cli = 0 或默认的 False 状态时,命令行输入 pytest 运行用例,在控制台输出是按每个模块显示运行结果
collected 6 items
test_1.py .. [ 33%]
test_anothersmtp.py . [ 50%]
test_cmdopt.py .. [ 83%]
test_y.py . [100%]
============================== 6 passed in 1.80 seconds ==============================
当log_cli = 1后 运行 pytest 命令
collected 6 items
test_1.py::test_answer_1 PASSED [ 16%]
test_1.py::test_answer_2 PASSED [ 33%]
test_anothersmtp.py::test_showhelo PASSED [ 50%]
test_cmdopt.py::test_answer_1 PASSED [ 66%]
test_cmdopt.py::test_answer_2 PASSED [ 83%]
test_y.py::test_i PASSED [100%]
============================== 6 passed in 0.84 seconds ==============================
这时候报告会按每条用例显示结果