pytest文档63-内置fixture之pytestconfig

前言

前面讲 request 是pytest的一个内置 fixture ,作用是获取测试的上下文,可以通过request.config 获取配置对象。
pytestconfig 的作用跟 request.config 是一样的,都是获取配置对象

pytestconfig 源码分析

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

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 ==============================

这时候报告会按每条用例显示结果

2020年第五期《python接口自动化+测试开发》课程,10月11号开学(火热报名中!)
本期上课时间:10月11号-1月3号,每周六、周日晚上20:30-22:30

(0)

相关推荐