首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
聊聊Web自动化测试:黑盒、白盒、α测试、β测试、冒烟测试、回归测试
Selenium三剑客:WebDriver、IDE、Grid一网打尽
Selenium开发环境搭建
下载安装浏览器驱动:教你解决最麻烦的版本匹配问题
第一个Selenium测试:Selenium测试流程、源码分析
实现元素定位:掌握Selenium八大定位方法
通过打车生活案例,深入剖析WebDriver运行原理
掌握WebDriver核心方法和属性的使用
掌握WebElement核心方法和属性的使用
form表单:熟练掌握form表单操作步骤
掌握checkbox和radiobutton的定位技巧
下拉列表:熟练使用Select类,来实现下拉列表定位
弹框处理:掌握alert、confirm、prompt三种弹出的用法
Selenium三种等待方式:剖析原理、用法和应用场景
Selenium等待条件:掌握17种元素等待条件
掌握鼠标单击、双击、右击,键盘输入、键盘组合键的应用
熟练执行JavaScript的方法和技巧,掌握JavaScript操作滚动条
Selenium屏幕截图:实现屏幕截屏、按照日期时间格式保存图片
掌握frame、iframe定位,熟练frame的切入和切出
下载安装Selenium IDE:下载安装Chrome、Firefox插件IDE
熟练Selenium IDE菜单栏、工具类、命令窗口的使用
Selenium IDE实现录制和回放及脚本导出
项目环境搭建:安装JDK、MySQL、Tomcat和测试系统
需求分析和用例设计:深度挖掘需求,掌握测试用例设计范式
项目架构设计:掌握分层设计思想,合理设计目录和包结构
解决验证码问题-方案一:使用pytesseract和Pillow实现验证码识别
解决验证码问题-方案二:通过第三方AI库识别验证码
实现工具类:设计获得验证码、随机字符串生成、cookie操作工具类
完成用户注册测试用例:解决验证码、等待弹框等复杂内容
完成用户登录测试用例:实现登录成功和失败测试
完成管理员登录测试用例:完成验证码正确和错误测试用例
完成文章分类测试用例:解决测试用例依赖问题
完成添加、删除文章测试用例
unittest简介:测试用例、测试套件、测试运行器、测试加载器
unittest中的方法:掌握各种setup、teardown和断言方法
测试用例、测试套件和测试加载器:掌握加载测试用例的四种方法
使用unittest重构测试用例:掌握使用unittest模块的方法和技巧
为项目添加测试报告:使用第三方模块实现测试报告
pytest框架简介:pytest安装、用例编写规则、执行用例
pytest标记:查找测试策略、标记测试函数
pytest参数化处理:使用参数化装饰器、解析列表、元组、字典等数据
pytest Fixture:使用fixture实现用例之间的调用
pytest setup 和 teardown
pytest allure生成测试报告
使用pytest重构项目:实现用例依赖、测试报告、数据参数化
logging模块简介:日志的作用、等级和常用函数
logging日志格式输出:日志发生的时间、文件、模块、行号等信息格式输出
logging模块四大组件:Logger、Handler、Formatter、Filter的用法
为项目添加日志:将日志应用到项目
使用csv模块读取CSV文件,使用pytest参数化实现DDT
使用json模块读取json文件,使用pytest参数化实现DDT
使用xlrd模块读取excel文件,使用pytest参数化实现DDT
Selenium读取数据库数据:将数据保存到数据库,实现数据驱动的测试
Selenium DDT:使用DDT模块实现数据驱动的测试
使用DDT思想重构项目:使用数据库保存数据,将数据驱动思想应用到项目
POM设计模式简介:理解页面-对象-模型设计模式,实现代码的松耦合
设计BasePage类:设计基类,提高项目的代码重用性
设计项目页面对应的PO类:使用POM设计模式设计PO类
设计项目测试用例:将POM设计模式应用到项目
Selenium Grid下载安装:配置Java运行环境,下载安装Selenium Grid
Selenium注册node节点
使用Selenium执行远程测试
Jenkins环境搭建:下载安装Jenkins
在Jenkins中运行项目
邮件通知:实现邮件通知功能
定时运行项目,实现真正的自动化测试
当前位置:
首页>>
技术小册>>
Selenium自动化测试实战
小册名称:Selenium自动化测试实战
### 章节:Logging模块四大组件:Logger、Handler、Formatter、Filter的用法 在自动化测试领域,尤其是使用Selenium进行Web自动化测试时,日志记录是不可或缺的一环。它帮助开发者与测试人员跟踪程序运行时的详细信息、错误信息和调试信息,是问题排查和性能优化的重要工具。Python的`logging`模块提供了强大的日志记录功能,其核心在于其灵活且可扩展的架构,主要由四个关键组件构成:Logger、Handler、Formatter、Filter。本章节将详细探讨这四个组件的用法及其在Selenium自动化测试中的应用。 #### 一、Logger:日志的记录器 Logger是`logging`模块的核心,它提供了应用程序代码直接使用的接口。Logger对象负责记录日志信息,但它本身并不负责日志信息的显示或存储。相反,它通过将日志信息传递给与之关联的Handler来完成这一任务。每个Logger都有一个名称,这个名称用于标识和过滤日志消息。 **基本用法**: ```python import logging # 创建一个Logger实例,如果不指定name,则返回root logger logger = logging.getLogger('selenium_automation') logger.setLevel(logging.DEBUG) # 设置日志级别 # 记录一条日志 logger.debug('This is a debug message') logger.info('This is an info message') logger.warning('This is a warning message') logger.error('This is an error message') logger.critical('This is a critical message') ``` 在Selenium自动化测试中,你可以为每个测试用例或测试套件创建一个独立的Logger,以便于区分和管理日志信息。 #### 二、Handler:日志的处理器 Handler负责将日志信息发送到适当的目的地,比如文件、控制台、网络等。一个Logger可以配置多个Handler,以便同时向多个地方发送日志信息。 **常用Handler**: - `StreamHandler`:将日志输出到标准输出流(通常是控制台)。 - `FileHandler`:将日志写入到文件中。 - `RotatingFileHandler`:支持日志文件回滚,即当日志文件达到一定大小时自动创建新文件。 **示例代码**: ```python # 创建一个FileHandler,用于写入日志文件 file_handler = logging.FileHandler('selenium_test.log') file_handler.setLevel(logging.ERROR) # 设置Handler的日志级别 # 创建一个StreamHandler,用于输出到控制台 console_handler = logging.StreamHandler() console_handler.setLevel(logging.INFO) # 将Handler添加到Logger logger.addHandler(file_handler) logger.addHandler(console_handler) # 记录日志 logger.error('This error will be written to both console and file.') logger.info('This info will only be written to console.') ``` 在Selenium自动化测试中,可以根据需要配置不同的Handler,比如只在测试失败时记录详细日志到文件,而将所有日志输出到控制台以便实时监控。 #### 三、Formatter:日志的格式器 Formatter用于定义日志信息的格式。通过Formatter,可以控制日志信息的输出格式,包括时间戳、日志级别、日志信息、调用者信息等。 **基本用法**: ```python # 创建一个Formatter formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s') # 将Formatter设置到Handler file_handler.setFormatter(formatter) console_handler.setFormatter(formatter) ``` 在上面的示例中,`%(asctime)s`、`%(name)s`、`%(levelname)s`、`%(message)s`是日志消息格式化的占位符,分别代表时间戳、Logger名称、日志级别和日志消息本身。 在Selenium自动化测试中,通过自定义Formatter,可以确保日志信息清晰、易读,便于后续的分析和处理。 #### 四、Filter:日志的过滤器 Filter用于对日志信息进行过滤,决定是否将其传递给Handler。通过Filter,可以基于日志级别、Logger名称、日志消息内容等条件来过滤日志。 **自定义Filter示例**: ```python class MyFilter(logging.Filter): def filter(self, record): # 假设我们只希望记录包含特定关键字的错误日志 return 'critical error' in record.msg and record.levelno == logging.ERROR # 创建Filter实例并添加到Handler my_filter = MyFilter() file_handler.addFilter(my_filter) # 记录日志 logger.error('This is a critical error message.') # 将被记录 logger.error('This is just an error message.') # 将被忽略 ``` 在Selenium自动化测试中,Filter的使用可能相对较少,但在处理大量日志或需要精确控制日志输出时,Filter可以发挥重要作用。 #### 总结 `logging`模块的四大组件——Logger、Handler、Formatter、Filter,共同构成了Python日志系统的核心。通过灵活运用这些组件,可以在Selenium自动化测试中实现高效、灵活的日志记录。Logger作为日志记录的入口,Handler负责将日志发送到不同的目的地,Formatter定义了日志的格式,而Filter则用于过滤日志信息。在实际应用中,根据测试需求合理配置这些组件,可以大大提高测试的可维护性和可调试性。 通过本章节的学习,你应该能够掌握如何在Selenium自动化测试中使用`logging`模块的四大组件来记录和管理日志信息,从而为你的测试工作提供更加有力的支持。
上一篇:
logging日志格式输出:日志发生的时间、文件、模块、行号等信息格式输出
下一篇:
为项目添加日志:将日志应用到项目
该分类下的相关小册推荐:
Python与办公-玩转Excel
Python合辑2-字符串常用方法
Python机器学习实战
Python合辑5-格式化字符串
Python编程轻松进阶(三)
Python与办公-玩转Word
Python编程轻松进阶(五)
Python合辑11-闭包函数
Python面试指南
Python合辑12-面向对象
Python自动化办公实战
Python神经网络入门与实践