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

RayRay
CodiumAICover Agent自动化测试生成单元测试生成式AIGithub开源项目

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的发展中来。这不仅有助于工具本身的进步,也为整个软件测试领域的发展注入了新的活力。

编辑推荐精选

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

下拉加载更多