Ferrum v0.17 版本发布:浏览器自动化工具的重要升级
Ferrum 是一个基于 Chrome DevTools Protocol (CDP) 的高性能 Ruby 浏览器自动化工具,它提供了简洁的 API 来控制无头浏览器。与 Selenium 等传统工具相比,Ferrum 更加轻量级且直接与浏览器通信,特别适合现代 Web 应用测试和爬虫开发。
核心功能增强
网络请求追踪能力提升
新版本在网络请求追踪方面做了多项改进:
-
Blob 请求识别:新增的
blob?方法可以判断网络交换是否为 blob 类型请求,解决了之前版本中无法识别这类特殊请求的问题。 -
请求头信息增强:通过整合
Network.requestWillBeSentExtraInfo事件,现在可以获取更完整的请求头信息,这对于需要精确追踪 HTTP 请求的场景特别有用。 -
未知状态处理:新增
unknown方法用于识别处于未知状态的网络交换,配合改进后的finished?方法,能更准确地判断请求是否完成,特别是在页面跳转后。
浏览器控制功能扩展
-
事件订阅管理:新增
Page#off方法提供了取消订阅 CDP 事件的能力,完善了事件管理机制。 -
滚动操作增强:除了现有的
scroll_to方法,新增的scroll_by提供了相对滚动的能力,使页面滚动控制更加灵活。 -
无痕模式控制:现在可以通过
incognito: false参数选择是否创建无痕浏览会话,为不同测试场景提供了更多选择。
开发者工具集成
新版本引入了 Browser#debug 方法,可以直接在浏览器开发者工具中打开无头会话,这大大简化了调试过程。开发者可以像调试普通网页一样查看和调试自动化测试中的页面状态。
框架与元素操作改进
-
框架关系查询:新增的
Frame#parent和Frame#frame_element方法可以查询 iframe 的父子关系和嵌入元素,为处理复杂页面结构提供了便利。 -
屏幕录制功能:通过
start_screencast和stop_screencast方法,现在可以录制浏览器操作过程,这对于创建演示或记录测试过程非常有用。
兼容性与稳定性优化
-
移除过时的 headless 模式:随着 Chrome 的更新,"new" headless 模式已成为默认选项,因此移除了这一冗余配置。
-
鼠标事件修复:修正了鼠标事件按钮属性的设置问题,使模拟点击操作更加准确。
-
迭代安全增强:修复了在哈希迭代过程中添加新键可能导致的错误,提高了代码稳定性。
-
空页面处理:优化了在空页面情况下调用 DOM 方法的健壮性,避免了潜在错误。
总结
Ferrum v0.17 版本在网络追踪、浏览器控制、框架操作等方面都有显著提升,特别是对开发者调试体验的改善和对复杂网络请求的处理能力。这些改进使得 Ferrum 在浏览器自动化测试和网页爬虫开发领域更具竞争力,为 Ruby 开发者提供了更强大、更稳定的工具选择。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00