软件测试/测试开发丨Pytest配置文件pytest.ini

发布时间:2023年12月29日

pytest.ini 配置

pytest.ini 是什么

  • pytest.ini 是 pytest 的配置文件
  • 可以修改 pytest 的默认行为
  • 不能使用任何中文符号,包括汉字、空格、引号、冒号等等

pytest.ini

  • 修改用例的命名规则
  • 配置日志格式,比代码配置更方便
  • 添加标签,防止运行过程报警告错误
  • 指定执行目录
  • 排除搜索目录

pytest 配置- 改变运行规则

# 执行check_开头和 test_开头的所有的文件,后面一定要加*
python_files = check_* test_*
# 执行所有的以Test和Check开头的类
python_classes = Test*  Check*
# 执行所有以test_和check_开头的方法
python_functions= test_* check_*

image

pytest 配置- 添加默认参数

addopts = -v -s --alluredir=./results

image

添加默认参数后,输入pytest后,相当于下面这样直接输入一行,更方便

pytest 配置- 指定/忽略执行目录

# 设置执行的路径
testpaths = bilibili baidu
# 忽略某些文件夹/目录
norecursedirs = result logs datas test_demo*

pytest 配置- 日志

配置参考链接:pytest logging 收集日志
pytest.ini 文件配置日志级别,保存地址等内容。

  • 注意:
    windows系统 需要把中文 注释去掉。
[pytest]
# 日志开关 true false
log_cli = true

# 输出到terminal
# 日志级别
log_cli_level = info
# 打印详细日志,相当于命令行加 -vs
addopts = --capture=no
# 日志格式
log_cli_format = %(asctime)s [%(levelname)s] %(message)s (%(filename)s:%(lineno)s)
# 日志时间格式
log_cli_date_format = %Y-%m-%d %H:%M:%S

# 输出到文件,log文件需要手动创建
# 日志文件位置
log_file = ./log/test.log
# 日志文件等级
log_file_level = info
# 日志文件格式
log_file_format = %(asctime)s [%(levelname)s] %(message)s (%(filename)s:%(lineno)s)
# 日志文件日期格式
log_file_date_format = %Y-%m-%d %H:%M:%S
# 可以动态生成log文件的名称,不过需要的pytest版本比较高
@pytest.fixture(scope="session", autouse=True)
def manage_logs(request):
    """Set log file name same as test name"""
    now = time.strftime("%Y-%m-%d %H-%M-%S")
    log_name = 'output/log/' + now + '.logs'

    request.config.pluginmanager.get_plugin("logging-plugin") \
        .set_log_path(return_path(log_name))

总结 pytest.ini

  • 修改用例的命名规则
  • 配置日志格式,比代码配置更方便
  • 指定执行目录
  • 排除搜索目录
  • 添加标签,防止运行过程报警告错误
  • 添加默认参数

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!?

文章来源:https://blog.csdn.net/nhb687095/article/details/135290772
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。