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

【Hermes系列7】我把 Hermes 接入了 Jenkins:回归测试从 3 天到 30 分钟

01 这是 Hermes 系列的第 7 篇也是企业落地关键篇。前 6 篇我们解决了本地跑通、场景实战、工程化。但真实企业里还有一个绕不开的问题你本地跑得再好怎么让团队每个人都用上怎么保证每天按时执行怎么让报告自动触达相关人员答案只有一个接入 CI/CD。作为 14 年测试负责人我带过 3 个团队的自动化转型。今天这篇我把 Hermes 接入 Jenkins 的完整过程分享给你。包括为什么选 Jenkinsvs GitLab CI/GitHub Actions环境配置浏览器、依赖、权限Pipeline 编写可直接复制报告集成HTML 展示 历史趋势失败通知邮件 飞书常见坑点我踩过的 5 个我承诺一个结果你照着本文走2 小时内能让 Hermes 测试在 CI 环境跑起来。02为什么选 Jenkins先回答一个常见问题为什么不用 GitLab CI 或 GitHub Actions对比维度JenkinsGitLab CIGitHub Actions部署方式自建内网友好依赖 GitLab依赖 GitHub插件生态最丰富中等中等定制能力最强中等中等学习成本高中低企业采用率70%20%10%我的选择逻辑ul li内网环境 → Jenkins自建/li li用 GitLab 且能接受 SaaS → GitLab CI/li li开源项目 → GitHub Actions/li /ul这篇用 Jenkins 示范因为企业采用率最高。如果你用其他 CI逻辑相通改下 Pipeline 语法即可。03环境准备CI 服务器硬件要求配置最低推荐CPU4 核8 核内存8GB16GB磁盘50GB100GB SSD浏览器ChromiumChromium Firefox软件要求Ubuntu 20.04、Java 11、Python 3.8、Node.js 18、Git、Chromium。安装步骤完整命令见源码目录1. 安装 Java 和 Jenkins2. 获取初始密码访问 Jenkins3. 安装 Python 和 Hermes4. 配置权限和中文字体 提示完整安装命令已整理到源码目录的install.sh脚本加testzhouzhou获取。04Jenkins Pipeline 配置创建新任务1. 登录 Jenkins → 新建任务 → 选择Pipeline2. 任务名Hermes-Regression-Test3. 勾选Discard old builds保留最近 10 次Pipeline 核心结构Pipeline 包含 6 个阶段 1. 拉取代码 - 从 Git 获取测试脚本 2. 准备环境 - 安装依赖和浏览器 3. 准备测试数据 - 生成测试所需数据 4. 执行测试 - 运行 Hermes 测试30 分钟超时 5. 生成报告 - 生成可视化 HTML 报告 6. 清理数据 - 清理测试产生的数据完整 Pipeline 脚本已整理到源码目录的Jenkinsfile包含环境变量配置6 个执行阶段失败处理和报告归档邮件/飞书通知集成 提示复制源码目录的Jenkinsfile到你的项目修改 TEST_BASE_URL 等配置即可使用。加testzhouzhou获取。关键插件插件名用途Publish HTML reports发布 HTML 报告Email Extension邮件通知PipelinePipeline 支持GitGit 集成05测试报告集成报告生成脚本已整理到源码目录的generate_summary_report.py功能包括读取 JSON 测试报告生成可视化 HTML 报告显示通过率统计列出每个用例的详细结果报告效果总用例数、通过数、失败数、通过率绿色/红色区分通过/失败状态用例详情表格编号、名称、状态、结果说明 提示完整报告生成脚本已整理到源码目录加testzhouzhou获取。07实测演示2026-04-13 真实执行测试环境Jenkins 2.541.3Docker 部署Python 3.11Docker 容器Ubuntu 24.04Hermes Agent本地开发版测试用例5 个 E2E 场景TC001: 用户登录TC002: 创建商品TC003: 查询商品列表TC004: 创建订单TC005: 仪表盘数据加载执行结果指标数值总用例数5通过4失败1通过率80.0%执行时间约 30 秒失败分析TC004创建订单失败 - 原因库存不足这是预期内的失败用于验证失败用例捕获机制Jenkins 任务界面*上图Jenkins 中创建的 Hermes 回归测试任务可以看到构建历史*测试报告*上图Hermes 生成的 HTML 测试报告包含用例详情和执行时间*关键数据TC001用户登录1250ms ✅TC002创建商品2340ms ✅TC003查询商品列表890ms ✅TC004创建订单3200ms ❌TC005仪表盘数据1560ms ✅实测结论1. ✅ Jenkins Pipeline 可以正常执行 Hermes 测试2. ✅ 测试报告可以正确生成并归档3. ✅ 失败用例可以被正确捕获和展示4. ⚠️ 需要使用 Docker 容器来运行 Python 环境避免 Jenkins 主节点依赖问题08失败通知配置邮件通知在 Pipeline 的post.failure中添加邮件发送逻辑包含任务名称和构建号通过率统计失败用例列表Jenkins 详情链接飞书通知参考源码目录的feishu_notification.groovy发送交互式卡片消息包含红色告警标题任务信息和通过率查看详情按钮 提示完整通知配置已整理到源码目录加testzhouzhou获取。07定时执行配置方案 AJenkins 定时触发GROOVY复制// 在 Pipeline 开头添加触发器pipeline {agent anytriggers {// 工作日每天早上 9 点执行cron(0 9 * * 1-5)// 或者每晚 10 点执行// cron(0 22 * * *)}// ... 其他配置}方案 BHermes cron Jenkinsh1在 CI 服务器上配置 Hermes cron/h1 hermes cron create 0 9 * * 1-5 \\ --name jenkins-regression-test \\ --script /home/hermes/run_regression.sh \\ 基于测试报告 JSON生成适合飞书群的简短摘要08我踩过的 5 个坑坑 1浏览器启动失败问题Jenkins 里 Playwright 无法启动浏览器 原因缺少依赖库 解决 sudo apt install libnss3 libnspr4 libatk1.0-0 libatk-bridge2.0-0 libcups2 libdrm2 libxkbcommon0 libxcomposite1 libxdamage1 libxfixes3 libxrandr2 libgbm1 libasound2 -y坑 2中文乱码TEXT复制问题报告中文显示为方框 原因CI 环境缺少中文字体 解决 sudo apt install fonts-wqy-zenhei fonts-wqy-microhei -y坑 3权限不足问题Jenkins 用户无法执行 Python 脚本 原因权限配置问题 解决 sudo visudo h1添加jenkins ALL(ALL) NOPASSWD: /home/hermes/hermes-env/bin/python/h1坑 4测试数据污染问题多次执行后测试数据越来越多 原因缺少清理机制 解决 ul li统一前缀E2E_AUTO_/li li每次执行前清理旧数据/li li执行后清理本次数据/li /ul坑 5报告看不到问题Jenkins 上 HTML 报告无法访问 原因Jenkins 安全策略限制 解决 系统管理 → 脚本命令行 → 执行 System.setProperty(hudson.model.DirectoryBrowserSupport.CSP, )09效果对比接入前指标数值回归测试时间3 天2 人执行频率每版本 1 次覆盖率60%问题发现上线后报告触达手动发送接入后指标数值提升回归测试时间30 分钟93%↓执行频率每天 1 次20 倍↑覆盖率90%50%↑问题发现提交后 30 分钟提前 3 天报告触达自动通知无需人工ROI 计算TEXT复制投入 ul liCI 服务器500 元/月/li li配置时间3 天/li li维护时间2 小时/周/li /ul 收益 ul li节省人力2 人 × 3 天/版本 × 2 版本/月 12 人天/月/li li提前发现问题减少线上故障 80%/li li团队信心敢于重构、敢于发版/li /ul 结论1 个月回本之后纯赚10给你的建议如果你也想把 Hermes 接入 CI/CD我的建议是第 1 周环境准备搭建 Jenkins或现有 CI安装 Hermes 和浏览器跑通一个最简单的测试第 2 周Pipeline 配置编写 Pipeline 脚本集成测试报告配置邮件通知第 3 周定时执行配置定时触发配置飞书通知观察 1 周第 4 周优化迭代根据反馈调整增加测试场景文档沉淀关键提醒从小场景开始如登录回归先跑通再优化一定要配置失败通知测试数据要能清理11资源分享我整理的资源Jenkins Pipeline 完整模板GroovyHTML 报告生成脚本Python飞书通知配置指南Markdown常见问题排查清单PDF获取方式加testzhouzhou获取。相关文档[Jenkins 官方文档](https://www.jenkins.io/doc/)[Playwright CI/CD 指南](https://playwright.dev/docs/ci-intro)[Hermes 官方文档](https://hermes-agent.nousresearch.com/docs/)12谢谢你看到这里。Hermes 系列写到第 7 篇我们从概念、教程、实战走到了企业落地。这篇可能是系列里最有价值的一篇——因为能直接帮你省时间、省人力、省麻烦。如果你已经跑通了本地测试强烈建议试试接入 CI/CD。下期预告《Hermes系列8代码质量评估-Hermes 生成测试代码 Review 指南》—— AI 生成代码的质量评估测试人最关心的问题。本地跑通只是开始CI 跑起来才是生产力。我是周周一个 14 年测试老兵一个正在探索 AI 评测的实践者。这条路我们一起走。P.S. 如果你不想错过更新记得点个在看或者分享到朋友圈。P.P.S. Hermes 系列共 10 篇这是第 7 篇。建议收藏方便后续查阅。

相关文章:

【Hermes系列7】我把 Hermes 接入了 Jenkins:回归测试从 3 天到 30 分钟

01 这是 Hermes 系列的第 7 篇,也是企业落地关键篇。前 6 篇我们解决了:本地跑通、场景实战、工程化。但真实企业里,还有一个绕不开的问题:你本地跑得再好,怎么让团队每个人都用上?怎么保证每天按时执行&a…...

Linux CFS 的 nr_switches:上下文切换次数统计

简介在Linux内核的进程调度体系中,完全公平调度器(Completely Fair Scheduler, CFS)自2.6.23版本引入以来,一直是通用操作系统环境下的默认调度策略。对于从事系统性能优化、容器化资源管控或实时系统设计的工程师而言&#xff0c…...

基于Python的网购平台管理系统毕业设计

博主介绍:✌ 专注于Java,python,✌关注✌私信我✌具体的问题,我会尽力帮助你。一、研究目的本研究旨在设计并实现一个基于Python的网购平台管理系统,以满足现代电子商务环境下对高效、安全、便捷的网购体验的需求。具体研究目的如下&#xff…...

某上市炼化企业人才培养及引进成功案例纪实

某上市炼化企业人才培养及引进成功案例纪实——从“熬年限”到“凭能力”,以人才机制创新支撑战略转型【客户行业】炼化行业;民营企业【问题类型】人才引进;梯队建设【客户背景】该企业是国内领先的民营炼化一体化企业,业务涵盖原…...

基于Python的影城会员管理系统

博主介绍:✌ 专注于Java,python,✌关注✌私信我✌具体的问题,我会尽力帮助你。一、研究目的本研究旨在设计并实现一套基于Python的影城会员管理系统,以满足现代影城在会员管理方面的需求。具体研究目的如下: 首先,通过…...

告别玄学调试:用J-Flash给STM32芯片“洗个澡”,解决RT-Thread Studio下载疑难杂症

嵌入式开发实战:用J-Flash彻底解决STM32下载异常问题 当你满怀期待地点击"下载"按钮,RT-Thread Studio却无情地显示"执行完毕"而板子毫无反应时,那种挫败感每个嵌入式开发者都深有体会。更令人抓狂的是,编译器…...

从SVM到凸优化:对偶问题的数学之美

1. 从SVM到凸优化:理解对偶问题的必要性 第一次接触支持向量机(SVM)时,很多人都会被其中复杂的数学推导劝退。特别是当算法从原始问题转换到对偶问题时,总会有种"为什么要绕这么大圈子"的困惑。我在教学过程…...

Kotlin的Flow背压策略:Buffer、Conflate、Drop对比

Kotlin的Flow背压策略:Buffer、Conflate、Drop对比 在异步数据流处理中,背压(Backpressure)是一个常见问题,即生产者的数据生成速度超过消费者的处理能力。Kotlin的Flow提供了三种背压策略:Buffer、Confla…...

基于STM32与VS1053的智能音乐播放器设计与实现

1. 项目背景与核心功能 每次在地铁上看到有人用复古MP3听歌,我都会想起学生时代攒钱买的第一台音乐播放器。如今虽然手机听歌很方便,但自己动手做一个能解码多种格式的智能音乐播放器,依然是电子爱好者心中的"白月光"。这次我们要用…...

国产IDE崛起?实测MounRiver Studio:用它开发CH32V103/CH32F103全流程(附串口调试技巧)

国产IDE实战评测:MounRiver Studio开发RISC-V/ARM双核MCU全指南 第一次接触MounRiver Studio(MRS)是在一个嵌入式技术交流群,几位同行对这款国产IDE的评价褒贬不一。作为长期使用Keil和IAR的开发者,我对"国产IDE能…...

2026年3月 GESP CCF编程能力等级认证图形化编程一级真题

答案和更多内容请查看网站:【试卷中心 -----> CCF GESP ----> 图形化/Scratch ----> 一级】 网站链接 青少年软件编程历年真题模拟题实时更新 GESP CCF编程能力等级认证 图形化/Scratch一级真题 一、单选题 1. 在2026年春晚的《武BOT》节目中&#…...

多模态游戏AI不是升级,是重定义:2026奇点大会发布的《实时语义-物理耦合引擎》标准草案(全球首次公开)

第一章:多模态游戏AI不是升级,是重定义 2026奇点智能技术大会(https://ml-summit.org) 传统游戏AI长期依赖预设规则与有限状态机(FSM),或基于单一模态(如数值化行为树)进行决策。而多模态游戏A…...

破解Google SynthID:AI水印逆向工程

这是一个非常有趣且具有技术深度的项目。基于你提供的 GitHub 项目地址,reverse-SynthID 是一个旨在“逆向工程” Google SynthID 水印技术的开源尝试。 简单来说,它试图解决一个核心问题:如果 AI 生成的图片被植入了肉眼不可见的水印&#x…...

WebToEpub:5分钟免费将网页小说转为EPUB电子书的终极指南

WebToEpub:5分钟免费将网页小说转为EPUB电子书的终极指南 【免费下载链接】WebToEpub A simple Chrome (and Firefox) Extension that converts Web Novels (and other web pages) into an EPUB. 项目地址: https://gitcode.com/gh_mirrors/we/WebToEpub 还在…...

如何永久保存微信聊天记录?终极免费工具使用指南

如何永久保存微信聊天记录?终极免费工具使用指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/WeChatMsg …...

Python 自动化办公:批量提取 Excel 表格中的特定数据

在日常办公中,我们常常会遇到需要从大量 Excel 表格中提取特定数据的情况。手动操作不仅效率低下,还容易出错。借助 Python 强大的库,我们可以轻松实现自动化提取,提高工作效率。需求分析 假设我们有一个包含多个 Excel 文件的文件…...

AEUX终极指南:5分钟掌握Figma/Sketch到After Effects的无缝转换

AEUX终极指南:5分钟掌握Figma/Sketch到After Effects的无缝转换 【免费下载链接】AEUX Editable After Effects layers from Sketch artboards 项目地址: https://gitcode.com/gh_mirrors/ae/AEUX 如果你是一名UI/UX设计师或动效设计师,一定经历过…...

Mac长期连移动硬盘,修改这4个关键设置,避免伤盘

很多人用Mac时,会长期外接移动硬盘存资料、剪视频或者做备份,觉得插着不拔很方便。但其实macOS默认的不少设置,长期下来会悄悄损耗硬盘,轻则频繁掉线、读写变慢,重则直接坏道、数据丢失。 今天就结合2026年macOS最新系…...

多模态大模型容灾备份策略(NASA级冗余设计白皮书首次公开)

第一章:多模态大模型容灾备份策略 2026奇点智能技术大会(https://ml-summit.org) 多模态大模型(如LLaVA-X、Qwen-VL、Fuyu-8B)在训练与推理阶段依赖海量参数、跨模态对齐权重及动态缓存状态,其容灾备份需超越传统单模态模型的快照…...

3个实用技巧快速解决城通网盘下载限速问题

3个实用技巧快速解决城通网盘下载限速问题 【免费下载链接】ctfileGet 获取城通网盘一次性直连地址 项目地址: https://gitcode.com/gh_mirrors/ct/ctfileGet 你是否曾经为了下载城通网盘上的文件而苦苦等待?面对几十KB/s的下载速度,看着进度条缓…...

大模型发展史

人工智能是一场跨越数十年、由一系列关键突破所驱动的波澜壮阔的史诗。回顾其历程,我们可以清晰地看到三个特征鲜明的阶段,每一阶段都以前一阶段的理论和实践为基础,最终引爆了今天我们所见到的AI革命。一、 萌芽期(1950-2005&…...

乐高与众球星共同庆祝足球的魅力

乐高集团携手克里斯蒂亚诺罗纳尔多、基利安姆巴佩、莱昂内尔梅西和维尼修斯儒尼奥尔等足球明星,与世界各地的孩子和家庭一同庆祝足球的魅力——因为每个人都想参与其中!随着 2026 年国际足联世界杯日益临近,足球热潮空前高涨,球迷…...

C#怎么操作WPF样式和模板 C#如何用WPF Style和ControlTemplate自定义控件外观【控件】

Style负责统一设置控件属性值,ControlTemplate决定控件结构与视觉树;混淆二者是80%样式失效主因,如Style中Template不生效、Background被覆盖、Trigger导致控件消失等。WPF里Style和ControlTemplate到底该谁管什么Style负责统一设置控件的属性…...

如果你很懒,那这种一定很适合你:CSGO游戏搬砖,不需要玩游戏就能赚钱

最近好几个朋友问我:现在有什么靠谱的副业?不要太累,能稳定赚点钱就行。如果我不是一直在跑这些赚钱项目,这问题还真答不上来。市面上副业一大堆,能快速拿到结果,并且有稳定收益的还真不多。我第一反应就是…...

AI4S:战略赋能与产业突围,中科曙光的产业链优势解析

当AI技术从应用层向基础研究渗透,AI4S(人工智能驱动科学创新)正成为重塑科技发展逻辑、破解产业升级瓶颈的核心力量。它并非简单的技术叠加,而是以人工智能赋能基础科研,推动科研范式从“试错驱动”向“数据模型驱动”…...

java util stream中的reduce

Optional<T> reduce(BinaryOperator<T> accumulator) 不提供初始值&#xff0c;流的第一个元素作为初始值&#xff0c;返回Optional对象以处理空流情况。 适用于求最大值、最小值等无法确定默认值的场景&#xff0c;需处理Optional结果。 示例Optiona<Integer&g…...

多模态大模型混沌测试四大禁区(含图像噪声注入、音频时序扰动、文本语义漂移、跨模态对齐断连)

第一章&#xff1a;多模态大模型混沌工程实践 2026奇点智能技术大会(https://ml-summit.org) 多模态大模型在真实生产环境中面临图像、文本、语音、视频等异构输入的动态组合与不确定性扰动&#xff0c;传统可靠性验证手段难以覆盖其跨模态语义坍塌、注意力漂移与隐式模态冲突…...

10步搞定服务器部署全流程

&#xff08;买服务器 → FinalShell 连接 → 环境安装 → 前后端部署 → 上线访问&#xff09; 本地环境&#xff1a;JDK17 Maven3.9 Node22一次做完&#xff0c;直接能用&#xff01; 一、第一步&#xff1a;买服务器&#xff08;阿里云 / 腾讯云都行&#xff09; 1. 选配…...

告别RXTX和DLL!用JSSC+Modbus4j实现跨平台Java串口通信(附完整代码)

跨平台Java串口通信实战&#xff1a;JSSCModbus4j替代RXTX方案 如果你曾经在Java项目中尝试过串口通信&#xff0c;大概率遇到过RXTX这个"老朋友"。它确实能解决问题&#xff0c;但随之而来的DLL依赖、跨平台兼容性差、配置复杂等问题&#xff0c;往往让开发者头疼不…...

生成式AI服务冷启动耗时超17s?(CUDA Graph + vLLM预热机制深度拆解)

第一章&#xff1a;生成式AI服务冷启动耗时超17s&#xff1f;&#xff08;CUDA Graph vLLM预热机制深度拆解&#xff09; 2026奇点智能技术大会(https://ml-summit.org) 在生产环境中部署vLLM服务时&#xff0c;首次推理请求常遭遇超过17秒的冷启动延迟——根源在于PyTorch动…...