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

使用早期 AI 生成单元测试

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

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

最近,我有机会深入研究 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]删除
最新教程 更多>
  • 如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 识别今天生日的用户使用 MySQL 确定今天是否是用户的生日涉及查找生日匹配的所有行今天的日期。这可以通过一个简单的 MySQL 查询来实现,该查询将存储为 UNIX 时间戳的生日与今天的日期进行比较。以下 SQL 查询将获取今天有生日的所有用户: FROM USERS ...
    编程 发布于2025-01-07
  • 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-01-07
  • 除了“if”语句之外:还有什么地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有什么地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为的主要场景bool:语句:if、whi...
    编程 发布于2025-01-07
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSocke...
    编程 发布于2025-01-07
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2025-01-07
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1 和 $array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求...
    编程 发布于2025-01-07
  • 尽管代码有效,为什么 POST 请求无法捕获 PHP 中的输入?
    尽管代码有效,为什么 POST 请求无法捕获 PHP 中的输入?
    解决 PHP 中的 POST 请求故障在提供的代码片段中:action=''而不是:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"检查 $_POST数组:表单提交后使用 var_dump 检查 $_POST 数...
    编程 发布于2025-01-07
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2025-01-07
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2025-01-07
  • 插入数据时如何修复“常规错误:2006 MySQL 服务器已消失”?
    插入数据时如何修复“常规错误:2006 MySQL 服务器已消失”?
    插入记录时如何解决“一般错误:2006 MySQL 服务器已消失”介绍:将数据插入 MySQL 数据库有时会导致错误“一般错误:2006 MySQL 服务器已消失”。当与服务器的连接丢失时会出现此错误,通常是由于 MySQL 配置中的两个变量之一所致。解决方案:解决此错误的关键是调整wait_tim...
    编程 发布于2025-01-07
  • 如何正确声明Python源代码编码?
    如何正确声明Python源代码编码?
    正确声明 Python 源代码编码PEP 263 概述了声明 Python 源代码编码的标准实践。虽然典型约定涉及使用“# --编码: --”,但遇到使用“# --编码:--".那么,编码声明的正确形式是什么?根据Python文档, Python 脚本第一行或第二行中与以下正则表达式匹配的...
    编程 发布于2025-01-07
  • std::shared_ptr 真的是线程安全的吗?对指向的对象的并发修改又如何呢?
    std::shared_ptr 真的是线程安全的吗?对指向的对象的并发修改又如何呢?
    std::shared_ptr 的线程安全您从 MSDN 引用的有关 std::shared_ptr 线程安全的声明可能会被误解。这意味着虽然多个线程可以同时读写不同的shared_ptr对象,但这并不能保证修改shared_ptr对象本身的安全性。TL;DR: std::shared_ptr 的线...
    编程 发布于2025-01-07
  • 如何根据特定属性查找并替换 JavaScript 数组中的对象?
    如何根据特定属性查找并替换 JavaScript 数组中的对象?
    在对象数组中查找具有特定属性的对象在 Javascript 中,可以在未命名对象数组中搜索特定属性基于属性值匹配的对象。考虑以下数组:var array = [ { name:"string 1", value:"this", other: "...
    编程 发布于2025-01-06
  • 为什么我的 MySQL LOAD_FILE 函数无提示地失败?
    为什么我的 MySQL LOAD_FILE 函数无提示地失败?
    使用 LOAD_FILE 将文件导入 MySQL Blob - 故障排除LOAD_FILE 函数允许您读取文件并将其加载到 MySQL斑点。然而,用户在使用此功能时有时会遇到问题,尽管没有收到错误消息。根据 MySQL 文档,LOAD_FILE 必须满足某些条件才能正常运行:文件必须驻留在服务器主机...
    编程 发布于2025-01-06
  • 如何高效地从 JavaScript 对象中获取键数组?
    如何高效地从 JavaScript 对象中获取键数组?
    从对象中以数组形式检索键在 JavaScript 中,可以通过多种方法实现将对象的键提取到数组中。虽然提供的使用 for-in 循环的代码片段是有效的,但它可能不是最简洁或最有效的方法。使用 Object.keys()A更简洁、更现代的方法是利用内置的 Object.keys() 函数。该函数直接返...
    编程 发布于2025-01-06

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

Copyright© 2022 湘ICP备2022001581号-3