VOL 124
15
2020-05
今天距2021年230天
这是ITester软件测试小栈第124次推文
点击上方蓝字“ITester软件测试小栈“关注我,每周一、三、五早上 07:30准时推送。
微信公众号后台回复“资源”、“测试工具包”领取测试资源,回复“21天打卡”一起学习成长,打怪升级。
本文5035字,阅读约需14分钟
在上一篇Python接口自动化测试系列文章:Python接口自动化之logging日志,主要介绍日志相关概念及logging日志模块的操作流程。
而在此之前介绍过yaml封装,数据驱动、配置文件、日志文件等独立的功能,我们将这些串联起来,形成一个完整的接口测试流程。
以下主要介绍将logging常用配置放入yaml配置文件、logging日志封装及结合登录用例讲解日志如何在接口测试中运用。
一
yaml配置文件
将日志中的常用配置,比如日志器名称
、日志器等级
及格式化
放在配置文件中,在配置文件config.yaml中添加:
logger:
name: ITester
level: DEBUG
format: '%(filename)s-%(lineno)d-%(asctime)s-%(levelname)s-%(message)s'
封装logging类,读取yaml中的日志配置。
二
读取yaml
之前读写yaml配置文件的类已经封装好,愉快的拿来用即可,读取yaml配置文件中的日志配置。
yaml_handler.py
import yaml
class YamlHandler:
def __init__(self, file):
self.file = file
def read_yaml(self, encoding='utf-8'):
"""读取yaml数据"""
with open(self.file, encoding=encoding) as f:
return yaml.load(f.read(), Loader=yaml.FullLoader)
def write_yaml(self, data, encoding='utf-8'):
"""向yaml文件写入数据"""
with open(self.file, encoding=encoding, mode='w') as f:
return yaml.dump(data, stream=f, allow_unicode=True)
yaml_data = YamlHandler('../config/config.yaml').read_yaml()
三
封装logging类
在common目录下新建文件logger_handler.py,用于存放封装的logging类。
封装思路:
首先分析一下,logging中哪些数据可以作为参数?比如日志器名称、日志等级、日志文件路径、输出格式,可以将这些放到__init__方法里,作为参数。
其次,要判断日志文件是否存在,存在就将日志输出到日志文件中。
最后,logging模块已经封装好了Logger类,可以直接继承,减少代码量。
这里截取logging模块中Logger类的部分源码。