Logo

Cover-Agent: CodiumAI的AI驱动自动化测试生成工具

cover-agent

Cover-Agent:CodiumAI的AI驱动自动化测试生成工具

在软件开发过程中,单元测试的编写往往是一项繁琐而耗时的工作。为了解决这一痛点,CodiumAI推出了一款创新型工具——Cover-Agent。这款工具利用先进的生成式AI技术,自动化测试生成过程,旨在提高代码覆盖率并简化测试流程。本文将全面介绍Cover-Agent的功能特性、安装使用方法以及未来发展规划。

Cover-Agent简介

Cover-Agent是CodiumAI开发的一个专注项目,利用生成式AI来自动化和增强测试(目前主要是单元测试)的生成,旨在简化开发工作流程。Cover-Agent可以通过终端运行,并计划将其集成到流行的CI平台中。

Cover-Agent演示

CodiumAI邀请社区成员共同合作,帮助扩展Cover Agent的功能,继续将其发展成为自动化单元测试生成领域的前沿解决方案。他们也希望能够激励研究人员利用这个开源工具探索新的测试生成技术。

系统概述

Cover-Agent是一套旨在自动化软件项目单元测试创建的工具套件的一部分。它利用先进的生成式AI模型,简化并加速测试过程,确保高质量的软件开发。该系统包括以下几个主要组件:

  1. 测试运行器(Test Runner): 执行命令或脚本来运行测试套件并生成代码覆盖率报告。
  2. 覆盖率解析器(Coverage Parser): 验证随着测试的添加,代码覆盖率是否增加,确保新测试对整体测试效果有所贡献。
  3. 提示构建器(Prompt Builder): 从代码库收集必要数据,构建传递给大型语言模型(LLM)的提示。
  4. AI调用器(AI Caller): 与LLM交互,根据提供的提示生成测试。

安装和使用

安装要求

在开始之前,请确保您具备以下条件:

  • 在环境变量中设置OPENAI_API_KEY,这是调用OpenAI API所必需的。
  • 代码覆盖工具:该工具需要Cobertura XML代码覆盖报告才能正常运行。
    • 例如,在Python中可以使用pytest-cov。运行Pytest时添加--cov-report=xml选项。
  • 如果直接从存储库运行,还需要:
    • 系统上安装了Python。
    • 安装了Poetry用于管理Python包依赖。

安装方法

Cover Agent可以作为Python Pip包安装或作为独立可执行文件运行。

  1. 通过Python Pip安装:

    pip install git+https://github.com/Codium-ai/cover-agent.git
    
  2. 二进制文件: 可以在不安装Python环境的情况下运行二进制文件。您可以通过导航到项目的发布页面下载适合您系统的版本。

运行Cover-Agent

下载可执行文件或安装Pip包后,您可以运行Cover Agent来生成和验证单元测试。从命令行使用以下命令执行:

cover-agent \
  --source-file-path "<源文件路径>" \
  --test-file-path "<测试文件路径>" \
  --code-coverage-report-path "<覆盖率报告路径>" \
  --test-command "<要运行的测试命令>" \
  --test-command-dir "<运行测试命令的目录>" \
  --coverage-type "<覆盖率报告类型>" \
  --desired-coverage <期望的覆盖率(0到100之间)> \
  --max-iterations <最大LLM迭代次数> \
  --included-files "<可选的要包含的文件列表>"

输出结果

Cover-Agent会在本地存储库中输出几个调试文件(这些文件是.gitignore的一部分):

  • run.log: 记录器的副本,会被转储到您的stdout
  • test_results.html: 结果表,包含每个生成测试的以下信息:
    • 测试状态
    • 失败原因(如果适用)
    • 退出代码
    • stderr
    • stdout
    • 生成的测试

使用其他LLM模型

Cover-Agent使用LiteLLM与OpenAI和其他托管的LLM进行通信(目前支持100多个LLM)。要使用OpenAI默认以外的其他模型,您需要:

  1. 按照LiteLLM说明导出受支持LLM所需的任何环境变量。
  2. 在调用Cover Agent时使用--model选项指定模型名称。

例如:

export VERTEX_PROJECT="hardy-project"
export VERTEX_LOCATION="us-west"

cover-agent \
  ... \
  --model "vertex_ai/gemini-pro"

未来发展规划

Cover-Agent的未来发展规划包括以下几个方面:

  1. 自动为软件项目生成单元测试,利用先进的AI模型确保全面的测试覆盖和质量保证。

    • 能够为不同的编程语言生成测试
    • 能够处理各种测试场景
    • 为被测代码生成行为分析,并据此生成测试
    • 检查测试的不稳定性,例如按TestGen-LLM的建议运行5次
  2. 覆盖更多测试生成痛点

    • 生成专注于PR变更集的新测试
    • 在整个存储库/代码库上运行,并尝试增强所有现有的测试套件
  3. 提高可用性

    • 为GitHub Actions、Jenkins、CircleCI、Travis CI等提供连接器
    • 集成到数据库、API、OpenTelemetry和其他数据源,以提取与测试生成相关的输入/输出
    • 添加设置文件

结语

Cover-Agent作为CodiumAI推出的创新型AI驱动自动化测试生成工具,为开发者提供了一种高效、智能的方式来提高代码覆盖率并简化测试流程。通过利用先进的生成式AI技术,Cover-Agent不仅能够自动生成高质量的单元测试,还能够适应不同的编程语言和测试场景。

随着Cover-Agent的不断发展和完善,我们可以期待它在未来为软件开发领域带来更多革新。无论是提高测试效率,还是增强代码质量,Cover-Agent都将成为开发团队不可或缺的得力助手。

对于那些希望提高测试覆盖率、简化测试流程或探索AI在软件测试中应用的开发者和团队来说,Cover-Agent无疑是一个值得关注和尝试的工具。随着更多功能的加入和与流行CI平台的集成,Cover-Agent有望在软件开发生态系统中发挥越来越重要的作用。

最后,作为一个开源项目,Cover-Agent也为社区协作和创新提供了平台。开发者可以通过贡献代码、提出建议或探索新的测试生成技术来参与到Cover-Agent的发展中来。这不仅有助于工具本身的进步,也为整个软件测试领域的发展注入了新的活力。

最新项目

Project Cover
豆包MarsCode
豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。
Project Cover
AI写歌
Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。
Project Cover
商汤小浣熊
小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。
Project Cover
有言AI
有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。
Project Cover
Kimi
Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。
Project Cover
吐司
探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。
Project Cover
SubCat字幕猫
SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。
Project Cover
AIWritePaper论文写作
AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。
Project Cover
稿定AI
稿定设计 是一个多功能的在线设计和创意平台,提供广泛的设计工具和资源,以满足不同用户的需求。从专业的图形设计师到普通用户,无论是进行图片处理、智能抠图、H5页面制作还是视频剪辑,稿定设计都能提供简单、高效的解决方案。该平台以其用户友好的界面和强大的功能集合,帮助用户轻松实现创意设计。
投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号