首页
技术小册
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日志格式输出:日志发生的时间、文件、模块、行号等信息格式输出 在自动化测试领域,尤其是使用Selenium进行Web自动化测试时,日志记录(Logging)是一项至关重要的功能。它不仅帮助开发者和测试人员追踪程序的执行流程,还能在出现问题时迅速定位错误源头,提高调试效率。本章将深入探讨如何在Selenium自动化测试项目中设置和优化日志格式,确保日志中包含时间、文件、模块、行号等关键信息,从而构建一套高效、易读的日志系统。 #### 引言 日志记录是软件开发和测试过程中不可或缺的一部分。在Selenium自动化测试脚本中,日志不仅能够记录测试的执行情况,如测试用例的成功或失败,还能捕捉测试过程中的异常信息和系统状态,为后续的测试分析和优化提供宝贵的数据支持。然而,仅仅记录日志是不够的,合理的日志格式设计同样重要。一个结构清晰、信息丰富的日志,能够极大地提升日志的可读性和实用性。 #### Python的logging模块简介 在Python中,`logging`模块是标准库的一部分,提供了灵活的日志记录系统。它允许开发者为应用程序和库创建日志消息,并且可以控制日志信息的去向(控制台、文件、网络等),以及日志的详细程度(DEBUG、INFO、WARNING、ERROR、CRITICAL)。通过合理配置`logging`模块,我们可以轻松地实现包含时间、文件、模块、行号等信息的日志格式输出。 #### 日志格式定义 在`logging`模块中,日志的格式是通过`Formatter`类来定义的。`Formatter`类允许我们自定义日志消息的格式化字符串,该字符串可以使用特定的占位符来表示日志消息的不同部分,如时间戳、日志级别、日志消息本身、文件名、模块名、行号等。 以下是一个典型的日志格式定义示例,它包含了时间、日志级别、文件名、模块名、行号以及日志消息本身: ```python import logging # 定义日志格式 log_format = '%(asctime)s - %(levelname)s - %(filename)s - %(funcName)s - %(lineno)d - %(message)s' # 创建日志器 logger = logging.getLogger('SeleniumAutomation') logger.setLevel(logging.DEBUG) # 设置日志级别 # 创建日志处理器并设置格式 handler = logging.StreamHandler() # 控制台输出 formatter = logging.Formatter(log_format) handler.setFormatter(formatter) # 将处理器添加到日志器 logger.addHandler(handler) # 记录一条日志 logger.info('这是一条测试日志') ``` 在上述示例中,`log_format`字符串定义了日志的格式。各个占位符的含义如下: - `%(asctime)s`:日志事件发生的时间。默认格式为`2023-04-01 12:34:56,789`,但可以通过`datefmt`参数自定义。 - `%(levelname)s`:日志级别(DEBUG、INFO、WARNING、ERROR、CRITICAL)。 - `%(filename)s`:触发日志记录的文件名(不包含路径)。 - `%(funcName)s`:触发日志记录的函数名。如果日志消息是在代码的全局作用域中记录的,则此字段为空。 - `%(lineno)d`:触发日志记录的源代码行号。 - `%(message)s`:日志消息本身。 #### 日志文件配置 除了将日志输出到控制台外,我们还经常需要将日志保存到文件中,以便于后续的分析和存档。这可以通过为日志器添加`FileHandler`来实现。 ```python # 创建文件日志处理器 file_handler = logging.FileHandler('selenium_automation.log') file_handler.setFormatter(formatter) # 应用相同的格式 # 将文件处理器添加到日志器 logger.addHandler(file_handler) ``` 通过上述代码,我们创建了一个将日志保存到`selenium_automation.log`文件的处理器,并为其设置了与控制台输出相同的日志格式。 #### 日志级别的控制 在自动化测试项目中,合理控制日志级别同样重要。过低的日志级别(如DEBUG)可能会导致日志文件迅速膨胀,而过高的日志级别(如ERROR)则可能遗漏一些关键信息。因此,根据项目的实际需求,选择合适的日志级别进行记录是必要的。 在`logging`模块中,可以通过设置日志器的级别(如`logger.setLevel(logging.INFO)`)来控制输出的日志级别。只有大于等于该级别的日志消息才会被处理并输出。 #### 日志的滚动与分割 随着测试的进行,日志文件可能会变得非常大,难以管理。为了解决这个问题,我们可以使用`RotatingFileHandler`或`TimedRotatingFileHandler`等日志处理器来实现日志的滚动和分割。 - `RotatingFileHandler`:根据文件大小进行分割。当文件达到一定大小时,会自动将当前日志文件保存为另一个文件,并创建一个新的日志文件继续记录。 - `TimedRotatingFileHandler`:根据时间进行分割。例如,可以每天、每小时或每分钟创建一个新的日志文件。 #### 实际应用案例 在Selenium自动化测试项目中,我们可以将上述日志配置集成到测试框架中,确保在测试执行过程中能够实时记录关键信息。例如,在测试用例执行前后记录日志,包括测试用例的名称、执行时间、执行结果等信息。此外,还可以捕获并记录测试过程中发生的任何异常,以便于后续的故障排查。 #### 结论 通过合理配置Python的`logging`模块,我们可以在Selenium自动化测试项目中实现包含时间、文件、模块、行号等关键信息的日志格式输出。这不仅有助于我们更好地理解和追踪测试的执行过程,还能在出现问题时迅速定位并解决问题。因此,在自动化测试项目中,重视日志记录并合理设计日志格式是非常重要的。
上一篇:
logging模块简介:日志的作用、等级和常用函数
下一篇:
logging模块四大组件:Logger、Handler、Formatter、Filter的用法
该分类下的相关小册推荐:
Python合辑2-字符串常用方法
Python编程轻松进阶(五)
Python合辑14-面向对象编程案例(下)
Python与办公-玩转PDF
Python合辑13-面向对象编程案例(上)
Python合辑4-130个字符串操作示例
Python与办公-玩转PPT
Python3网络爬虫开发实战(下)
Python编程轻松进阶(四)
实战Python网络爬虫
剑指Python(万变不离其宗)
Python高性能编程与实战