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

如何借助AI进行测试代码code review

成熟测试团队会产出大量自动化代码因测试人员的经验和习惯原因代码质量可能参差不齐通常需要依靠专家code review(CR)来确保产出的测试代码质量借助大模型进行CR已经成为一种趋势可以提高CR效率和有效性。大模型 CR优势自动化检查利用大模型对代码进行自动化检查可以快速识别出语法错误、代码风格问题、潜在安全漏洞等。这种自动化过程减少了人工审查的工作量使开发者能够更加专注于代码的逻辑和功能问题。减少重复工作传统的人工CR往往会耗费大量时间在识别低级错误上而大模型可以有效过滤这些错误从而让审查者能够关注更有价值的逻辑和设计问题。快速反馈结合Gitlab CI等工具大模型能够在代码提交后立即执行CR并提供即时反馈大大缩短了反馈周期。简单来讲可发起Merge RequestMR请求的时候使用Gitlab CI触发该任务借助中间平台调用大模型并给到反馈信息回到Gitlab。给到的提示词例如以下代码是GitLab代码补丁。请以测试专家的角度,从自动化测试 用例设计;代码的实现;可改进的领域;这几个角度,给出详细的例子进行解释尽量少离题和耍幽默。这种模式在CR具体场景内仍然会存在一些问题只针对表层问题无法深度分析拿UI自动化举例通用大模型无法识别公共方法和业务相关的方法这样给CR的深度会造成很大限制一致性检查代码风格命名测试数据的管理方式case写法有较多的个性化的内容因团队而异没有业界的统一标准这方面AI难免会有误判修复建议噪音高在review质量不够100%有效情况下放入MR 的comments会非常困难由谁去Resolve 提出的修改建议也是一个难题借助RAG加强CR改进思路通过构造合适的prompt将约束条件构建知识库系统来做规范管理提供更加丰富和标准的信息这里就要用到前序文章中对RAG的论述Review结果适合通过企信(钉钉)消息发出而不是直接在gitlab评论上CR建议只供参考具体的Comments动作和Resolve过程由实际的Review人员来进行现有业界的RAG支撑系统很多这里我们选择的是FastGPT的平台其他还有DifyQAnything等对CR场景没有太大区别这里以fastGPT作为举例说明如何形成CR思路搭建步骤初始化CR知识库这里非常重要个性化的信息主要通过有效的知识库 来实现测试基础方法的信息明确哪些是最佳方法以及语义对测试代码规范自定义信息不同业务线的要求例如给到最佳实践的代码模板新建FastGPT项目在界面和交互方面公司内针对FastGPT进行对应小范围改造但基本遵从FastGPT对应用的定义新建的项目要勾选之前的知识库配置好一个FastGPT应用后根据应用可提供API选取待CR的Repo从gitlab内筛选想要review的项目ID优化提示词测试代码的提示词可参考假设你是测试开发工程师现在你的任务是阅读GitLab代码变更使用中文给出修改建议。建议要求a.必须使用知识库给出建议生成的建议语句通顺b.指明具体位置使用例子进行解释只需要给出少量关键代码不要全部输出d.不要脱离给定的代码e.不要复述原代码f.不要给出重复建议g.评审建议不超过700字符下面是GitLab代码变更后面附上MR的变更代码触发Review调用GET:https://fastqa.xxxx.com/api/review/work?projectIdxxxxxmrIdxx 接口即可发起Review此处我们改造fastGPT代码去抓取Gitlab的MR信息和代码变更projectId:项目IDmrId:MR请求ID在Gitlab CI中添加以下内容curl --location https://fastqa.xxxxx.com/api/review/work?projectId$CI_MERGE_REQUEST_PROJECT_IDmrId$CI_MERGE_REQUEST_IID一键获取完整项目代码这样MR请求的时候就会触发Review任务结果触发企信机器人。结果查看Review结束的时候企业微信 (钉钉)会收到消息打开企业微信(钉钉)通知中的链接就可以查看结果高价值的CR信息具体review同学或者mgr可以补充到gitlab上进行修改使用平台人员标记Review结果是否有效便于后续优化实际内部CR实践摘取对公司内某一个真实自动化代码的一些建议从初步实践的情况看:确实可产出大量值得采纳的建议存在一些误报情况和AI目前返回数据的不确定性相关但可通过调优知识库进行优化本文引入了大模型进行测试代码Code Review的思路然后介绍了如何较低成本搭建基于FastGPT通用大模型的的CR系统我们相信机器审查代码是一个非常有价值的赛道随着AI的不断增强CR的能力有望变得更完善希望文本能给大家带来启发感兴趣的读者也可以留言参与讨论可以持续关注本公众号关于AI实践的文章。总结感谢每一个认真阅读我文章的人作为一位过来人也是希望大家少走一些弯路如果你不想再体验一次学习时找不到资料没人解答问题坚持几天便放弃的感受的话在这里我给大家分享一些自动化测试的学习资源希望能给你前进的路上带来帮助。软件测试 面试文档我们学习必然是为了找到高薪的工作下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料并且有字节大佬给出了权威的解答刷完这一套面试资料相信大家都能找到满意的工作。视频文档获取方式这份文档和视频资料对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库这个仓库也陪伴我走过了最艰难的路程希望也能帮助到你以上均可以分享点下方小卡片即可自行领取。

相关文章:

如何借助AI进行测试代码code review

成熟测试团队会产出大量自动化代码,因测试人员的经验和习惯原因,代码质量可能参差不齐,通常需要依靠专家code review(CR)来确保产出的测试代码质量,借助大模型进行CR已经成为一种趋势,可以提高CR效率和有效性。 大模型…...

从零开始玩转通义千问2.5-7B:环境配置、模型加载到Web Demo全流程

从零开始玩转通义千问2.5-7B:环境配置、模型加载到Web Demo全流程 1. 引言 通义千问2.5-7B-Instruct作为阿里云最新发布的中等规模大语言模型,凭借其70亿参数的"黄金体量",在性能和资源消耗之间找到了完美平衡点。对于想要快速上…...

显卡驱动清理终极指南:使用DDU彻底解决NVIDIA/AMD/Intel驱动残留问题

显卡驱动清理终极指南:使用DDU彻底解决NVIDIA/AMD/Intel驱动残留问题 【免费下载链接】display-drivers-uninstaller Display Driver Uninstaller (DDU) a driver removal utility / cleaner utility 项目地址: https://gitcode.com/gh_mirrors/di/display-driver…...

丢包率不高但吞吐就是上不去?一文讲透 TCP 零窗口(Zero Window)的识别、边界与排查方法

丢包率不高但吞吐就是上不去?一文讲透 TCP 零窗口(Zero Window)的识别、边界与排查方法 Topic:TCP 零窗口与接收端瓶颈排查 很多网络性能问题看起来像“链路抖动”或“出口带宽不足”,但真正的根因并不在网络中间&…...

Kotaemon镜像快速部署:5步搭建企业级RAG问答平台

Kotaemon镜像快速部署:5步搭建企业级RAG问答平台 1. 为什么选择Kotaemon搭建RAG系统? 在当今企业智能化转型的浪潮中,检索增强生成(RAG)技术已成为连接大语言模型与企业知识库的关键桥梁。然而,传统RAG方…...

别再只用滑动平均了!三种滤波算法(卡尔曼/滑动/异常剔除)在Arduino数据采集中的性能对比与选型指南

Arduino数据采集实战:三种滤波算法性能对比与选型指南 当你在Arduino项目中采集传感器数据时,是否经常遇到数值跳变的问题?光照强度突然飙升、土壤湿度读数异常波动、PM2.5数值毫无规律地跳动——这些噪声不仅影响数据质量,更可能…...

SpringBoot项目整合Minio存储,从配置到实战上传下载(附完整代码)

SpringBoot项目整合Minio存储:工程化实践与深度优化 在当今云原生应用开发中,对象存储已成为处理非结构化数据的标准方案。Minio作为一款高性能的开源对象存储服务,以其轻量级、兼容S3协议的特性,成为许多Java开发者替代商业云存储…...

FFmpeg QSV滤镜实战:解决`get_buffer() failed`报错的两种GPU内存访问方案

FFmpeg QSV滤镜实战:解决get_buffer() failed报错的两种GPU内存访问方案 在视频处理领域,Intel Quick Sync Video(QSV)硬件加速技术因其出色的性能表现而广受欢迎。然而,当开发者尝试在QSV环境下使用滤镜链时&#xf…...

SPSS小白也能搞定!用PROCESS插件5分钟完成中介效应分析(附保姆级操作截图)

零基础SPSS实战:5分钟用PROCESS插件完成中介效应分析 第一次接触中介效应分析时,我被那些晦涩的统计术语和复杂的操作步骤吓得不轻。直到发现了Andrew Hayes开发的PROCESS插件,才发现原来完成一篇论文所需的中介效应检验可以如此简单——不需…...

AraLingBench:首个阿拉伯语大语言模型评估基准解析

1. 项目背景与核心价值 阿拉伯语作为全球第四大语言,拥有超过4亿母语使用者,覆盖22个阿拉伯国家联盟成员国。然而在自然语言处理领域,阿拉伯语长期面临资源匮乏、方言复杂、形态学特殊等挑战。AraLingBench的诞生正是为了填补这一空白——它是…...

2026-04-28 全国各地响应最快的 BT Tracker 服务器(移动版)

数据来源:https://bt.me88.top 序号Tracker 服务器地域网络响应(毫秒)1http://211.75.205.188:6969/announce广东广州移动342http://211.75.205.187:80/announce广东佛山移动373http://211.75.210.221:6969/announce广东惠州移动374udp://107.189.7.165:6969/annou…...

【VS Code Dev Containers 2026权威优化指南】:20位一线云原生架构师联合验证的7大性能跃迁实践

更多请点击: https://intelliparadigm.com 第一章:Dev Containers 2026核心架构演进与性能瓶颈图谱 Dev Containers 2026 在容器化开发范式中实现了从声明式配置到语义感知运行时的跃迁。其核心架构已不再依赖单一 Docker Compose 抽象层,而…...

Python的__complex__与__float__数值转换协议在科学计算中的支持

Python的数值转换协议在科学计算中扮演着关键角色,尤其是__complex__与__float__这两个特殊方法,它们为自定义对象提供了与内置复数、浮点数无缝交互的能力。科学计算领域常涉及复数运算(如信号处理、量子力学)和高精度浮点计算&a…...

终极实战指南:如何利用开源光学数据库加速你的光学设计项目

终极实战指南:如何利用开源光学数据库加速你的光学设计项目 【免费下载链接】refractiveindex.info-database Database of optical constants 项目地址: https://gitcode.com/gh_mirrors/re/refractiveindex.info-database 在光学工程和材料科学领域&#xf…...

如何用本地化工具提升英雄联盟游戏体验:从手动操作到智能辅助的转变

如何用本地化工具提升英雄联盟游戏体验:从手动操作到智能辅助的转变 【免费下载链接】League-Toolkit An all-in-one toolkit for LeagueClient. Gathering power 🚀. 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit 在英雄联盟的对…...

CheatEngine-DMA插件完整教程:硬件级内存访问的终极解决方案

CheatEngine-DMA插件完整教程:硬件级内存访问的终极解决方案 【免费下载链接】CheatEngine-DMA Cheat Engine Plugin for DMA users 项目地址: https://gitcode.com/gh_mirrors/ch/CheatEngine-DMA 在游戏修改和内存分析领域,DMA技术正成为突破传…...

AI在线工具导航:精选免费资源与高效使用指南

1. 项目概述与核心价值 作为一个在互联网和AI工具领域摸爬滚打了十多年的老博主,我深知一个痛点:信息过载。每天都有新的AI工具、在线服务冒出来,但找到真正好用、免费且稳定的那个,往往需要花费大量时间去搜索、测试和筛选。最近…...

Rust的声明宏macro_rules!与过程宏在元编程能力上的根本差异

Rust作为一门现代系统编程语言,其元编程能力主要依赖于两种宏系统:声明宏macro_rules!和过程宏。它们在语法扩展和代码生成方面各具特色,但背后的设计理念和实现机制却存在根本性差异。理解这些差异不仅能帮助开发者选择合适的工具&#xff0…...

彻底搞懂秒杀产品支持加入购物车:干货合集

关于这个问题,很多商家都不太清楚。今天来详细解答。一、问题背景在实际运营小程序商城的过程中,不少商家会遇到:【20210526功能更新】秒杀产品支持加入购物车二、详细解答秒杀产品支持加入购物车用户参与秒杀活动,在产品详情页即…...

别再买现成模块了!手把手教你用FT232RL-REEL芯片,从零设计一个USB转串口调试器(附完整原理图)

从芯片到产品:基于FT232RL-REEL的工业级USB-UART转换器全流程开发指南 当市面上充斥着各种廉价USB转串口模块时,为什么我们还要从零开始设计?答案很简单——可靠性、定制化和真正的技术掌控。作为电子工程师,我曾在量产项目中遇到…...

保姆级教程:用PyTorch 1.7.1+cu110和SSD算法训练你自己的VOC格式数据集

基于PyTorch与SSD的实战目标检测:从数据准备到模型训练全流程解析 目标检测作为计算机视觉领域的核心任务之一,在工业质检、自动驾驶、安防监控等场景中发挥着重要作用。SSD(Single Shot MultiBox Detector)算法以其高效的检测速…...

告别公网IP烦恼:用VS Code Tunnel免费搭建你的远程开发环境(保姆级教程)

告别公网IP烦恼:用VS Code Tunnel免费搭建你的远程开发环境(保姆级教程) 远程开发环境搭建一直是开发者面临的痛点之一。想象一下这样的场景:你在办公室的台式机上开始了一个项目,下班后需要继续在家里的笔记本上工作…...

《作妖计》通天塔副本速通技巧:手把手教你配置如来、多宝幻化增伤流

《作妖计》通天塔&副本极限增伤流实战手册:从幻化配置到怒气微操 在《作妖计》的高阶PVE玩法中,通天塔和灭神殿副本一直是检验玩家阵容深度与策略理解的试金石。当常规的装备强化、武将升星已经无法突破当前瓶颈时,一套精准的增伤体系往往…...

从‘囚徒困境’到‘广告竞价’:聊聊博弈论里的占优策略在实际产品设计中的应用

从‘囚徒困境’到‘广告竞价’:博弈论在产品设计中的实战应用 当两个电商平台同时推出"满300减50"的促销活动时,这背后隐藏着怎样的策略博弈?社交软件中"已读不回"的功能设计,为何会引发用户间的心理博弈&am…...

从JTAG到AS:一文搞懂EP4CE10E22C8N的nCONFIG、nSTATUS、DATA0等配置引脚实战用法

从JTAG到AS:EP4CE10E22C8N配置引脚实战全解析 在嵌入式系统设计中,FPGA的配置流程往往是硬件工程师最容易忽视却又最关键的环节之一。EP4CE10E22C8N作为Cyclone IV系列中的经典型号,其灵活的配置选项和丰富的引脚功能,既带来了设计…...

全球领先制造企业(如汽车、航空航天)Windchill许可证管理最佳实践

风云突变!Windchill许可证一用就爆,怎地破?我刚从一个汽车零部件厂回来,那帮人开完会后集体抱怨:“又抢不折腾到Windchill许可了!”项目急着出图,偏偏授权全被占用。可也是,更让我惊…...

HyperWorks许可证使用时空间热力图分析

超过40%的软件许可在“沉睡”?你不单是一个人在项目紧急赶工的深夜,你突然收到系统提示:“许可证不足,劳驾等待”。可你明明知道,隔壁工位的工程师早就在午休时把软件关了,问题是资源池里根本没人释放。这种…...

LinkSwift:八大网盘直链解析工具,突破下载限制的智能解决方案

LinkSwift:八大网盘直链解析工具,突破下载限制的智能解决方案 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中…...

从内核panic到App闪退:一条Android Crash的‘全链路’排查指南(附QCOM平台实战)

从内核panic到App闪退:一条Android Crash的‘全链路’排查指南(附QCOM平台实战) 当用户点击App图标时,很少有人会想到这个简单的动作背后,隐藏着从应用层到芯片级的复杂技术栈。一次看似普通的闪退,可能是S…...

MDK调试进阶:除了打印信息,Event Recorder还能帮你精准测量代码执行时间

MDK调试进阶:Event Recorder代码执行时间测量实战指南 在嵌入式开发中,性能优化往往是一场与毫秒甚至微秒的较量。当你的代码需要在严格的时间约束下运行时,仅靠printf打印信息就像用沙漏测量短跑——精度远远不够。这就是为什么每个追求极致…...