自动化测试学习实现(二)-- 日志

基于python+pytest,是小白的学习之路,过程思路参考EVAN_HU的思路


再写其他模块的时候呢,我发现调试很重要,跑长流程的时候,输出日志是比较直观的方式,我个人认为


import logging
import logging.handlers
import os
from datetime import datetime
from common.read_path import LOGS_PATH

LOGS_FILE_PATH = LOGS_PATH + os.path.sep + datetime.now().strftime("%Y-%m-%d") + "AT_logs.log"
NAME = "root"


class Logger(object):
    def __init__(self):
        # 创建日志文件
        if os.path.exists(LOGS_PATH) is False:
            os.makedirs(LOGS_PATH)
        # 创建一个logger
        self.logger = logging.getLogger(NAME)
        self.logger.setLevel(level=logging.DEBUG)
        # 每次被调用后,清空已经存在handler
        self.logger.handlers.clear()
        # 日志格式
        self.matter = "%(asctime)s - %(name)s - %(levelname)s - %(message)s"

    def logs_file(self):
        # 创建一个handler,用于写入日志文件
        handle = logging.handlers.TimedRotatingFileHandler(LOGS_FILE_PATH, when='D', encoding='UTF-8')
        handle.setLevel(level=logging.DEBUG)
        # 生成并设置日志格式
        handle.setFormatter(logging.Formatter(self.matter))
        self.logger.addHandler(handle)
        return self.logger

    def logs_cmd(self):
        cmd_handle = logging.StreamHandler()
        cmd_handle.setLevel(level=logging.DEBUG)
        cmd_handle.setFormatter(logging.Formatter(self.matter))
        self.logger.addHandler(cmd_handle)
        return self.logger

# if __name__ == '__main__':
    # Logger().logs_file().debug("aaa")
    # Logger().logs_cmd().debug("aaa")
  •  生成的日志文件名称--->2021-08-30AT_logs.log
  •  NAME可以修改,修改成使用者,这样查看日志的时候很好区分
  •  handles.clear() 之前出现了,只执行一次流程,但是每个日志都打印了很多次的情况,所以加上这句话;但是还存在一个问题,就是第一句产生的日志还是重复出现,目前未解决;

       参考文件:https://juejin.cn/post/6844903692915703815   中表述创建了自定义的 Logger 对象,就不要在用 logging 中的日志输出方法了,这些方法使用的是默认配置的 Logger 对象,否则会输出的日志信息会重复


自动化所有的文件夹路径我都保存在一个文件中,方便调用


我很菜!请求大家的意见让我成长

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值