”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 使用早期 AI 生成单元测试

使用早期 AI 生成单元测试

发布于2024-11-08
浏览:120

加速单元测试生成并提高代码质量

最近,我有机会深入研究 Early,一个专为自动单元测试生成而设计的 AI 代理。作为经常使用 TypeScript 和 ExpressoTS Framework 的人,我很想知道 Early 如何简化我的工作流程。我决定测试他们在我正在开发的名为 @expressots/share 的新 NPM 库上构建的 vscode 扩展。

初步印象

Early 让我印象深刻的第一件事是它能够为我现有的代码库自动生成单元测试。我可以专注于改进生成的测试并提高代码的健壮性和可测试性,而不是从头开始编写测试。这种转变极大地加速了我的发展进程。我注意到的另一个有趣的方面是,我生成的 83% 的代码没有进行任何调整,它开箱即用,并增加了我的代码覆盖率。为我节省了很多时间。

节省时间并扩大覆盖范围

在短短 8.5 小时内,我设法:

  • 生成大约 3,000 行代码的单元测试。
  • 修复问题并增强代码可测试性。
  • 通过 96 次测试实现 88% 的总代码覆盖率。

我能在一天之内完成这一切,这一事实是了不起的。单元测试的理想场景是在实际开发功能时进行测试。我是在我已经有了一个库之后才这样做的,因此需要进行一些调整才能使代码可测试。

积极成果

自动生成边缘案例测试。例如,它为涉及空字符串的场景生成单元测试,即使需要参数:

export function printSuccess(message: string, component: string): void {
  stdout.write(chalk.green(`${message}:`, chalk.bold(chalk.white(`[${component}] ✔️\n`))));
}

最初,我不会在如此简单的函数中创建空字符串的测试。然而,Early 的方法促进了防御性编程实践,促使我处理我可能忽略的边缘情况。

检测潜在问题

在优化生成的测试时,我遇到了类型不匹配的问题:

问题:jest.fn() 返回 any,但 process.exit 从不返回,导致 TypeScript 中类型不匹配。
解决方案:修改mock以匹配process.exit签名,确保类型正确性。
这一发现促使我调整我的代码以获得更好的类型安全性,突出显示 Early 如何帮助识别否则可能会被忽视的微妙问题。

需要改进的地方

尽管总体体验积极,但我遇到了一些挑战,如果解决这些挑战,可以提高 Early 的可用性:

  • 库版本兼容性。在某些情况下,早期生成的测试使用已弃用的 Jest 方法,例如:

使用 Jest 29.7

expect(Compiler.loadConfig()).rejects.toThrowError("process.exit() was called with code 1");

//修正版本

expect(Compiler.loadConfig()).rejects.toThrow("process.exit() was called with code 1");
  • 测试生成的自定义选项 虽然为边缘情况生成测试是有益的,但在某些情况下,可能没有必要:

观察:为每个可能的输入(包括空字符串)生成测试有时可能有点过分。

建议:引入自定义测试生成级别的选项,允许开发人员根据需要选择防御性编程测试。

  • VSCODE 扩展中的用户界面增强功能 在 Early 和其他工具之间导航突出了一些 UI 限制:

测试结果可见性:我必须在 Early 和 Jest 之间切换才能查看哪些测试通过或失败。

文件树状态:从其他应用程序切换回来时,早期的项目层次结构会崩溃,需要我反复重新打开文件夹。
建议:改进 UI 以在 Early 中显示测试结果,反映 Jest 的结构。维护文件树的状态也将增强用户体验。

Unit Test Generation with Early AI

  • 模拟和类型安全 jest.fn() 返回 any 的问题表明需要更精确的模拟:

观察:在模拟中使用任何类型都可能导致类型不匹配并可能掩盖错误。
建议:改进模拟生成以使用准确的签名,促进更好的类型安全并减少手动更正的需要。

结论

总的来说,我在 Early 的经历非常积极。该工具显着加速了我的单元测试过程,使我能够专注于改进测试,而不是从头开始编写测试。它还鼓励我考虑边缘情况并提高代码的稳健性。

需要改进的领域相对较小,主要围绕增强可用性和定制化。解决这些问题将使该工具在软件开发中变得更加强大。

感谢早期团队的出色工作!我很高兴看到该工具如何发展,并很乐意继续提供反馈以帮助进一步完善它。

版本声明 本文转载于:https://dev.to/rsaz/unit-test-generation-with-early-ai-31co?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 哪种方法更有效地用于点 - 填点检测:射线跟踪或matplotlib \的路径contains_points?
    哪种方法更有效地用于点 - 填点检测:射线跟踪或matplotlib \的路径contains_points?
    在Python Matplotlib's path.contains_points FunctionMatplotlib's path.contains_points function employs a path object to represent the polygon.它...
    编程 发布于2025-07-13
  • 如何同步迭代并从PHP中的两个等级阵列打印值?
    如何同步迭代并从PHP中的两个等级阵列打印值?
    同步的迭代和打印值来自相同大小的两个数组使用两个数组相等大小的selectbox时,一个包含country代码的数组,另一个包含乡村代码,另一个包含其相应名称的数组,可能会因不当提供了exply for for for the uncore for the forsion for for ytry...
    编程 发布于2025-07-13
  • Python高效去除文本中HTML标签方法
    Python高效去除文本中HTML标签方法
    在Python中剥离HTML标签,以获取原始的文本表示 仅通过Python的MlStripper 来简化剥离过程,Python Standard库提供了一个专门的功能,MLSTREPERE,MLSTREPERIPLE,MLSTREPERE,MLSTREPERIPE,MLSTREPERCE,MLST...
    编程 发布于2025-07-13
  • 如何在Java字符串中有效替换多个子字符串?
    如何在Java字符串中有效替换多个子字符串?
    在java 中有效地替换多个substring,需要在需要替换一个字符串中的多个substring的情况下,很容易求助于重复应用字符串的刺激力量。 However, this can be inefficient for large strings or when working with nu...
    编程 发布于2025-07-13
  • PHP与C++函数重载处理的区别
    PHP与C++函数重载处理的区别
    作为经验丰富的C开发人员脱离谜题,您可能会遇到功能超载的概念。这个概念虽然在C中普遍,但在PHP中构成了独特的挑战。让我们深入研究PHP功能过载的复杂性,并探索其提供的可能性。在PHP中理解php的方法在PHP中,函数超载的概念(如C等语言)不存在。函数签名仅由其名称定义,而与他们的参数列表无关。...
    编程 发布于2025-07-13
  • 如何使用Python有效地以相反顺序读取大型文件?
    如何使用Python有效地以相反顺序读取大型文件?
    在python 反向行读取器生成器 == ord('\ n'): 缓冲区=缓冲区[:-1] 剩余_size- = buf_size lines = buffer.split('\ n'....
    编程 发布于2025-07-13
  • HTML格式标签
    HTML格式标签
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    编程 发布于2025-07-13
  • 如何有效地转换PHP中的时区?
    如何有效地转换PHP中的时区?
    在PHP 利用dateTime对象和functions DateTime对象及其相应的功能别名为时区转换提供方便的方法。例如: //定义用户的时区 date_default_timezone_set('欧洲/伦敦'); //创建DateTime对象 $ dateTime = ne...
    编程 发布于2025-07-13
  • 在Python中如何创建动态变量?
    在Python中如何创建动态变量?
    在Python 中,动态创建变量的功能可以是一种强大的工具,尤其是在使用复杂的数据结构或算法时,Dynamic Variable Creation的动态变量创建。 Python提供了几种创造性的方法来实现这一目标。利用dictionaries 一种有效的方法是利用字典。字典允许您动态创建密钥并分...
    编程 发布于2025-07-13
  • 如何在Chrome中居中选择框文本?
    如何在Chrome中居中选择框文本?
    选择框的文本对齐:局部chrome-inly-ly-ly-lyly solument 您可能希望将文本中心集中在选择框中,以获取优化的原因或提高可访问性。但是,在CSS中的选择元素中手动添加一个文本 - 对属性可能无法正常工作。初始尝试 state)</option> < op...
    编程 发布于2025-07-13
  • 如何为PostgreSQL中的每个唯一标识符有效地检索最后一行?
    如何为PostgreSQL中的每个唯一标识符有效地检索最后一行?
    postgresql:为每个唯一标识符提取最后一行,在Postgresql中,您可能需要遇到与在数据库中的每个不同标识相关的信息中提取信息的情况。考虑以下数据:[ 1 2014-02-01 kjkj 在数据集中的每个唯一ID中检索最后一行的信息,您可以在操作员上使用Postgres的有效效率: ...
    编程 发布于2025-07-13
  • 人脸检测失败原因及解决方案:Error -215
    人脸检测失败原因及解决方案:Error -215
    错误处理:解决“ error:((-215)!empty()in Function Multultiscale中的“ openCV 要解决此问题,必须确保提供给HAAR CASCADE XML文件的路径有效。在提供的代码片段中,级联分类器装有硬编码路径,这可能对您的系统不准确。相反,OPENCV提...
    编程 发布于2025-07-13
  • 反射动态实现Go接口用于RPC方法探索
    反射动态实现Go接口用于RPC方法探索
    在GO 使用反射来实现定义RPC式方法的界面。例如,考虑一个接口,例如:键入myService接口{ 登录(用户名,密码字符串)(sessionId int,错误错误) helloworld(sessionid int)(hi String,错误错误) } 替代方案而不是依靠反射...
    编程 发布于2025-07-13
  • 如何从Google API中检索最新的jQuery库?
    如何从Google API中检索最新的jQuery库?
    从Google APIS 问题中提供的jQuery URL是版本1.2.6。对于检索最新版本,以前有一种使用特定版本编号的替代方法,它是使用以下语法:获取最新版本:未压缩)While these legacy URLs still remain in use, it is recommended ...
    编程 发布于2025-07-13
  • 如何使用替换指令在GO MOD中解析模块路径差异?
    如何使用替换指令在GO MOD中解析模块路径差异?
    在使用GO MOD时,在GO MOD 中克服模块路径差异时,可能会遇到冲突,其中可能会遇到一个冲突,其中3派对软件包将另一个带有导入套件的path package the Imptioned package the Imptioned package the Imported tocted pac...
    编程 发布于2025-07-13

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3