当前位置: 首页 > article >正文

Python-Selenium报错截图

报错截图设计方案:

​ 功能:截图层主要用来存放selenium运行时的报错截图信息

1. 截图路径管理

  • 分层存储:在项目根目录下创建 screenshots 文件夹,并按日期进一步分类(如 20250601)。
  • 命名规范:截图文件名包含错误类型和精确时间戳(如 error_el_message_20250601_143022.png),便于快速定位问题。
  • 自动创建目录:使用 os.makedirs(exist_ok=True) 确保目录存在,避免手动创建。

2. 多类型错误检测

  • 多样化定位策略:支持 XPath、ID、ClassName、CSS 选择器等多种定位方式,覆盖不同框架的错误组件(如 Element UI、Ant Design)。
  • 关键词扫描:若未找到特定错误组件,扫描页面源码中的错误关键词(如 error错误异常)。
  • 自定义错误类型:为不同定位方式设置专属错误类型标签(如 el_messageant_message),便于后续分析。

3. 智能错误捕获

  • 显式等待机制:使用 WebDriverWait 等待错误元素出现,避免因页面加载延迟导致的误判。

  • 异常处理

    • 捕获 TimeoutExceptionNoSuchElementException 以跳过不存在的定位器。
    • 处理页面源码扫描时的异常,并记录为 page_source_error
  • 多轮检测:先检查特定错误组件,再扫描页面源码,确保全面覆盖。

4. 信息完整性

  • 错误信息记录:截图时保存错误文本内容(如 用户名不存在/密码错误),便于后续分析。
  • 操作反馈:通过打印日志提示截图路径和错误详情,支持自定义消息。

5. 扩展性设计

  • 可配置定位器:错误定位器以元组形式存储在列表中,便于添加新的定位方式。
  • 错误类型分类:支持自定义错误类型标签,方便后续统计和筛选。

6. 异常安全保障

  • 多层异常捕获:在不同层级捕获异常,确保即使某个检测环节失败,仍能生成通用错误截图。
  • 健壮的路径生成:使用 os.path 模块处理路径,确保跨平台兼容性。

示例代码:

class ErrorChecker:def __init__(self, driver):self.driver = driverdef get_screenshot_path(self, error_type="unknown"):"""获取截图保存路径"""# 获取项目根目录project_root = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))# 在项目根目录下创建screenshots文件夹screenshot_dir = os.path.join(project_root, "screenshots")# 创建截图目录(如果不存在)os.makedirs(screenshot_dir, exist_ok=True)# 获取当前日期作为子文件夹名date_folder = time.strftime("%Y%m%d")screenshot_path_dir = os.path.join(screenshot_dir, date_folder)# 创建日期子目录(如果不存在)os.makedirs(screenshot_path_dir, exist_ok=True)# 生成带完整日期时间的截图文件名timestamp = time.strftime("%Y%m%d_%H%M%S")return os.path.join(screenshot_path_dir, f"error_{error_type}_{timestamp}.png")def save_screenshot(self, error_type="unknown", message=""):"""保存截图并打印消息"""screenshot_path = self.get_screenshot_path(error_type)self.driver.save_screenshot(screenshot_path)if message:print(message)print(f"📸 错误截图已保存至: {screenshot_path}")return Truedef check_and_capture_error(self):"""检查页面是否存在错误提示,并在发现时截图"""# 定义多种定位方式的错误提示元素error_locators = [# XPath定位(By.XPATH, "//div[contains(@class, 'el-message--error')]//p", "el_message"),(By.XPATH, "//div[contains(@class, 'ant-message-error')]", "ant_message"),(By.XPATH, "//div[contains(@class, 'error-text')]", "error_text"),(By.XPATH, "//div[contains(@class, 'toast-error')]", "toast_error"),# ID定位(By.ID, "errorMessage", "error_message_id"),(By.ID, "error-container", "error_container_id"),# Class Name定位(By.CLASS_NAME, "error-message", "error_message_class"),(By.CLASS_NAME, "alert-danger", "alert_danger_class"),# CSS选择器定位(By.CSS_SELECTOR, ".error-box .message", "error_box_css"),(By.CSS_SELECTOR, "#errorContent", "error_content_css"),# Name属性定位(By.NAME, "error-display", "error_display_name"),(By.NAME, "errorInfo", "error_info_name")]try:# 遍历所有可能的错误提示元素for locator_type, locator_value, error_type in error_locators:try:error_element = WebDriverWait(self.driver, 1).until(EC.visibility_of_element_located((locator_type, locator_value)))error_text = error_element.textreturn self.save_screenshot(error_type, f"⚠️ 捕获到错误: {error_text}")except (TimeoutException, NoSuchElementException):continue# 如果没有找到自定义错误提示,则检查页面是否存在其他错误try:# 获取页面源码page_source = self.driver.page_source# 如果页面中包含常见的错误关键词,则进行截图error_keywords = ['error', 'exception', 'failed', '错误', '异常', '失败']for keyword in error_keywords:if keyword.lower() in page_source.lower():return self.save_screenshot(f"keyword_{keyword}", f"⚠️ 捕获到错误关键词: {keyword}")print("✅ 未发现任何错误")return Falseexcept Exception as e:return self.save_screenshot("page_source_error", f"❌ 检查错误时发生异常: {str(e)}")except Exception as e:return self.save_screenshot("general_error", f"❌ 检查错误时发生异常: {str(e)}")
http://www.lryc.cn/news/2395435.html

相关文章:

  • 数论——质数和合数及求质数
  • nc 命令示例
  • 乾元通渠道商中标青海省自然灾害应急能力提升工程基层防灾项目
  • Ubuntu取消开机用户自动登录
  • 用 Spring Boot 静态资源映射 vs 用 Nginx 提供静态文件服务总结
  • openssl-aes-ctr使用openmp加速
  • PHP+MySQL开发语言 在线下单订水送水小程序源码及搭建指南
  • 计算机网络第1章(上):网络组成与三种交换方式全解析
  • Android studio进阶开发(七)---做一个完整的登录系统(前后端连接)
  • 计算机网络第1章(下):网络性能指标与分层模型全面解析
  • 恶意软件清理工具,让Mac电脑安全更简单
  • HackMyVM-Jabita
  • 112 Gbps 及以上串行链路的有效链路均衡
  • Mac 版不能连接华为 GaussDB 吗?我看 Windows 版可以连接?
  • Python-13(永久存储)
  • 《关于有序推动绿电直连发展有关事项的通知》核心内容
  • 数据结构-排序(1)
  • 记录一次session安装应用recyclerview更新数据的bug
  • 大数据-274 Spark MLib - 基础介绍 机器学习算法 剪枝 后剪枝 ID3 C4.5 CART
  • 力扣面试150题--二叉树的锯齿形层序遍历
  • 如何在 CentOS / RHEL 上修改 MySQL 默认数据目录 ?
  • 网页前端开发(基础进阶2)
  • 简历制作要精而不简
  • SPA-RL:通过Stepwise Progress Attribution训练LLM智能体
  • 【深度学习】9. CNN性能提升-轻量化模型专辑:SqueezeNet / MobileNet / ShuffleNet / EfficientNet
  • Relational Algebra(数据库关系代数)
  • 【C/C++】面试常考题目
  • Chorme如何对于youtube视频进行画中画背景播放?
  • 017搜索之深度优先搜索——算法备赛
  • 从单机到集群,再到分布式,再到微服务