IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> 自动化测试学习实现(二)-- 日志 -> 正文阅读

[开发测试]自动化测试学习实现(二)-- 日志

基于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 对象,否则会输出的日志信息会重复


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


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

  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2021-09-02 11:40:46  更:2021-09-02 11:42:13 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/12 17:06:35-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码