Selenide v7.7.0 版本发布:新增 Moon 浏览器支持与滚动控制功能
项目简介
Selenide 是一个基于 Selenium WebDriver 的轻量级测试框架,它简化了 Web 应用程序的自动化测试流程。Selenide 提供了简洁的 API 和强大的内置功能,如自动等待机制、简单的断言方法和简洁的选择器语法,使得编写稳定可靠的 UI 测试变得更加容易。
版本亮点
1. 新增 Moon 浏览器自动化解决方案支持
Selenide v7.7.0 版本正式加入了对 Moon 浏览器自动化解决方案的支持。Moon 是一个基于 Kubernetes 的浏览器自动化平台,特别适合在云环境中运行大规模的浏览器测试。通过这一集成,Selenide 用户现在可以轻松地将他们的测试扩展到 Moon 平台上运行,享受云浏览器测试带来的便利和扩展性。
2. 增强的滚动控制功能
新版本引入了 $.scroll() 方法,提供了更精细的页面滚动控制能力。与之前版本相比,这个新方法允许开发者指定滚动的方向和距离,使得测试脚本能够更精确地控制页面滚动行为。这在测试现代单页应用(SPA)或具有复杂滚动行为的页面时尤为有用。
方法签名类似于:
$(selector).scroll(Direction.UP, 100); // 向上滚动100像素
$(selector).scroll(Direction.DOWN, 50); // 向下滚动50像素
3. 调试日志增强
为了帮助开发者更好地理解和调试测试执行过程,v7.7.0 增加了关于添加和移除事件监听器的详细调试日志。这些日志信息可以帮助开发者追踪 Selenide 内部的事件处理机制,特别是在处理复杂交互或调试测试失败时非常有用。
4. 安全更新与依赖升级
本次版本包含了对 BrowserUpProxy 相关证书的更新,确保代理功能的安全性。同时,项目也更新了多个关键依赖:
- Netty 升级至 4.1.116.Final 版本
- LittleProxy 升级至 2.4.0 版本
- Commons Text 升级至 1.13.0 版本
- Guava 升级至 33.4.0-jre 版本
这些依赖更新不仅带来了性能改进,还修复了已知的问题,提高了整个框架的稳定性和安全性。
技术深度解析
Moon 浏览器集成背后的技术
Moon 的集成意味着 Selenide 现在支持又一种云浏览器解决方案。在实现上,这涉及到对 Selenium RemoteWebDriver 的扩展,以及对 Moon 特定配置参数的支持。开发者现在可以通过 Selenide 的标准配置方式指定 Moon 作为目标浏览器,而无需编写额外的适配代码。
滚动控制的实现原理
新的 $.scroll() 方法底层利用了 JavaScript 执行能力,通过注入脚本来精确控制页面滚动。这种方法比传统的基于动作链的滚动方式更加可靠,因为它直接操作 DOM 而不是模拟用户行为,减少了因浏览器差异或渲染延迟导致的问题。
升级建议
对于现有用户,升级到 v7.7.0 版本是推荐的,特别是:
- 计划使用云浏览器测试解决方案的团队
- 需要精确控制页面滚动的项目
- 关注依赖安全性的组织
升级过程通常只需更新 Maven 或 Gradle 依赖版本号即可,大多数现有测试应该无需修改即可继续工作。不过,建议在全面升级前先在测试环境中验证关键测试用例。
结语
Selenide v7.7.0 通过新增 Moon 支持和增强的滚动控制功能,进一步巩固了其作为现代化 Web 测试框架的地位。这些改进不仅扩展了框架的应用场景,也为开发者提供了更多工具来编写可靠、可维护的自动化测试。随着云测试环境的普及和 Web 应用复杂度的增加,这些新特性将帮助团队更高效地应对现代 Web 测试挑战。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0191
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0117
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
omega-aiOmega-AI:基于java打造的深度学习框架,帮助你快速搭建神经网络,实现模型推理与训练,引擎支持自动求导,多线程与GPU运算,GPU支持CUDA,CUDNN。Java04
llm-universe本项目是一个面向小白开发者的大模型应用开发教程,在线阅读地址:https://datawhalechina.github.io/llm-universe/Jupyter Notebook08