pytest简易教程(26):pytest中日志配置
pytest简易教程汇总,详见:https://www.cnblogs.com/uncleyong/p/17982846
日志格式配置
pytest.ini,内容包含terminal和日志文件
[pytest] addopts = --capture=no ;日志开关 true/false、1/0 log_cli = 1 ;输出到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_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
说明:
1、日志文件以写入模式打开,每次运行测试都会覆盖上一次日志文件内容
2、日志输出的时候不要用print,要采用logger进行输出
使用
示例:
#!/usr/bin/env python # -*- coding: utf-8 -*- # @Author : 韧 # @wx :ren168632201 # @Blog :https://www.cnblogs.com/uncleyong/ import logging logger = logging.getLogger(__name__) def test_case(): logger.info("断言1==1") assert 1==1
结果:
生成了日志目录和文件
待解决:
如果使用loguru:from loguru import logger
日志没写入日志文件
动态生成log文件名
conftest.py中:
#!/usr/bin/env python # -*- coding: utf-8 -*- # @Author: 韧 # @wx: ren168632201 # @Blog: https://www.cnblogs.com/uncleyong/ import os from datetime import datetime # 动态生成log文件的名称,哪怕配置文件中配置了log_file = ./log/test.log也不会生效 def pytest_configure(config): time_now = datetime.now().strftime('%Y-%m-%d_%H-%M-%S') config.option.log_file = os.path.join(config.rootdir, 'log', f'{time_now}.log')
结果:
__EOF__
本文作者:持之以恒(韧)
关于博主:擅长性能、全链路、自动化、企业级自动化持续集成(DevTestOps)、测开等
面试必备:项目实战(性能、自动化)、简历笔试,https://www.cnblogs.com/uncleyong/p/15777706.html
测试提升:从测试小白到高级测试修炼之路,https://www.cnblogs.com/uncleyong/p/10530261.html
欢迎分享:如果您觉得文章对您有帮助,欢迎转载、分享,也可以点击文章右下角【推荐】一下!
关于博主:擅长性能、全链路、自动化、企业级自动化持续集成(DevTestOps)、测开等
面试必备:项目实战(性能、自动化)、简历笔试,https://www.cnblogs.com/uncleyong/p/15777706.html
测试提升:从测试小白到高级测试修炼之路,https://www.cnblogs.com/uncleyong/p/10530261.html
欢迎分享:如果您觉得文章对您有帮助,欢迎转载、分享,也可以点击文章右下角【推荐】一下!