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

使用早期 AI 生成单元测试

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

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

最近,我有机会深入研究 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]删除
最新教程 更多>
  • CSS强类型语言解析
    CSS强类型语言解析
    您可以通过其强度或弱输入的方式对编程语言进行分类的方式之一。在这里,“键入”意味着是否在编译时已知变量。一个例子是一个场景,将整数(1)添加到包含整数(“ 1”)的字符串: result = 1 "1";包含整数的字符串可能是由带有许多运动部件的复杂逻辑套件无意间生成的。它也可以是故意从单个真理...
    编程 发布于2025-05-05
  • 如何在Chrome中居中选择框文本?
    如何在Chrome中居中选择框文本?
    选择框的文本对齐:局部chrome-inly-ly-ly-lyly solument 您可能希望将文本中心集中在选择框中,以获取优化的原因或提高可访问性。但是,在CSS中的选择元素中手动添加一个文本 - 对属性可能无法正常工作。初始尝试 state)</option> < op...
    编程 发布于2025-05-05
  • 在Oracle SQL中如何提取下划线前的子字符串?
    在Oracle SQL中如何提取下划线前的子字符串?
    [ 在oracle sql 解决方案: Explanation:SUBSTR function extracts a substring starting from the specified position (0) and continuing for a specified length.IN...
    编程 发布于2025-05-05
  • Java中如何使用观察者模式实现自定义事件?
    Java中如何使用观察者模式实现自定义事件?
    在Java 中创建自定义事件的自定义事件在许多编程场景中都是无关紧要的,使组件能够基于特定的触发器相互通信。本文旨在解决以下内容:问题语句我们如何在Java中实现自定义事件以促进基于特定事件的对象之间的交互,定义了管理订阅者的类界面。以下代码片段演示了如何使用观察者模式创建自定义事件: args)...
    编程 发布于2025-05-05
  • 如何在php中使用卷发发送原始帖子请求?
    如何在php中使用卷发发送原始帖子请求?
    如何使用php 创建请求来发送原始帖子请求,开始使用curl_init()开始初始化curl session。然后,配置以下选项: curlopt_url:请求 [要发送的原始数据指定内容类型,为原始的帖子请求指定身体的内容类型很重要。在这种情况下,它是文本/平原。要执行此操作,请使用包含以下标头...
    编程 发布于2025-05-05
  • 如何将多种用户类型(学生,老师和管理员)重定向到Firebase应用中的各自活动?
    如何将多种用户类型(学生,老师和管理员)重定向到Firebase应用中的各自活动?
    Red: How to Redirect Multiple User Types to Respective ActivitiesUnderstanding the ProblemIn a Firebase-based voting app with three distinct user type...
    编程 发布于2025-05-05
  • 如何在其容器中为DIV创建平滑的左右CSS动画?
    如何在其容器中为DIV创建平滑的左右CSS动画?
    通用CSS动画,用于左右运动 ,我们将探索创建一个通用的CSS动画,以向左和右移动DIV,从而到达其容器的边缘。该动画可以应用于具有绝对定位的任何div,无论其未知长度如何。问题:使用左直接导致瞬时消失 更加流畅的解决方案:混合转换和左 [并实现平稳的,线性的运动,我们介绍了线性的转换。这...
    编程 发布于2025-05-05
  • 如何高效地在一个事务中插入数据到多个MySQL表?
    如何高效地在一个事务中插入数据到多个MySQL表?
    mySQL插入到多个表中,该数据可能会产生意外的结果。虽然似乎有多个查询可以解决问题,但将从用户表的自动信息ID与配置文件表的手动用户ID相关联提出了挑战。使用Transactions和last_insert_id() 插入用户(用户名,密码)值('test','test...
    编程 发布于2025-05-05
  • 如何检查对象是否具有Python中的特定属性?
    如何检查对象是否具有Python中的特定属性?
    方法来确定对象属性存在寻求一种方法来验证对象中特定属性的存在。考虑以下示例,其中尝试访问不确定属性会引起错误: >>> a = someClass() >>> A.property Trackback(最近的最新电话): 文件“ ”,第1行, AttributeError: SomeClass...
    编程 发布于2025-05-05
  • 左连接为何在右表WHERE子句过滤时像内连接?
    左连接为何在右表WHERE子句过滤时像内连接?
    左JOIN CONUNDRUM:WITCHING小时在数据库Wizard的领域中变成内在的加入很有趣,当将c.foobar条件放置在上面的Where子句中时,据说左联接似乎会转换为内部连接。仅当满足A.Foo和C.Foobar标准时,才会返回结果。为什么要变形?关键在于其中的子句。当左联接的右侧值...
    编程 发布于2025-05-05
  • 如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    从python import codecs import codecs import codecs 导入 text = codecs.decode('这狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#带有...
    编程 发布于2025-05-05
  • 如何在Java的全屏独家模式下处理用户输入?
    如何在Java的全屏独家模式下处理用户输入?
    Handling User Input in Full Screen Exclusive Mode in JavaIntroductionWhen running a Java application in full screen exclusive mode, the usual event ha...
    编程 发布于2025-05-05
  • 如何在Java中正确显示“ DD/MM/YYYY HH:MM:SS.SS”格式的当前日期和时间?
    如何在Java中正确显示“ DD/MM/YYYY HH:MM:SS.SS”格式的当前日期和时间?
    如何在“ dd/mm/yyyy hh:mm:mm:ss.ss”格式“ gormat 解决方案:的,请访问量很大,并应为procectiquiestate的,并在整个代码上正确格式不多: java.text.simpledateformat; 导入java.util.calendar; 导入java...
    编程 发布于2025-05-05
  • Java开发者如何保护数据库凭证免受反编译?
    Java开发者如何保护数据库凭证免受反编译?
    在java 在单独的配置文件保护数据库凭证的最有效方法中存储凭据是将它们存储在单独的配置文件中。该文件可以在运行时加载,从而使登录数据从编译的二进制文件中远离。使用prevereness class import java.util.prefs.preferences; 公共类示例{ 首选项...
    编程 发布于2025-05-05
  • 为什么我在Silverlight Linq查询中获得“无法找到查询模式的实现”错误?
    为什么我在Silverlight Linq查询中获得“无法找到查询模式的实现”错误?
    查询模式实现缺失:解决“无法找到”错误在Silverlight应用程序中,尝试使用LINQ建立LINQ连接以错误而实现的数据库”,无法找到查询模式的实现。”当省略LINQ名称空间或查询类型缺少IEnumerable 实现时,通常会发生此错误。 解决问题来验证该类型的质量是至关重要的。在此特定实例中...
    编程 发布于2025-05-05

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

Copyright© 2022 湘ICP备2022001581号-3