pytest logging 收集日志

pytest.ini 文件配置日志级别,保存地址等内容。

  • 注意:
    windows系统 需要把中文 注释去掉。
[pytest]
;日志开关 true false
log_cli = true
;日志级别
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_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
4 个赞
@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))

网上查到这个可以动态生成log文件的名称,不过需要的pytest版本比较高

4 个赞

可以动态的生成这个路径,官网有介绍,可以替换自定义文件名

https://docs.pytest.org/en/6.2.x/logging.html?highlight=set_log_path

conftest也能实现

def pytest_configure(config):
    time_now = datetime.now().strftime('%Y-%m-%d_%H-%M-%S')
    config.option.log_file = os.path.join(config.rootdir, 'logs', f'{time_now}.log')
6 个赞

有看到这个,但是这个具体是什么意思?怎么使用呢?

你可以看下 "pytest配置文件"录播课,里面有讲怎么使用


老师,我这么写的, 然后test_demo.py执行完后,test.log里面没有内容,这是为啥?

明白了,不能出现中文