cover-agent

cover-agent

自动生成测试,提高代码覆盖率的工具

CodiumAI Cover Agent 通过自动生成测试来增强现有测试套件,有效提升代码覆盖率。使用先进的生成式AI模型,Cover Agent 简化并自动化了单元测试创建,确保软件开发质量。支持多种LLM模型,并可集成到流行的CI平台,适用于终端或CI环境。该工具还提供详细日志记录和示例代码,帮助用户快速上手。

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

Cover-Agent: 自动化测试生成的革新工具

Cover-Agent 是一个由 CodiumAI 开发的创新项目,旨在通过生成式人工智能技术来自动化和增强测试生成过程,特别是单元测试。这个工具的主要目标是提高代码覆盖率,同时简化开发人员的工作流程。Cover-Agent 不仅可以通过终端运行,未来还计划集成到流行的 CI 平台中,为开发团队提供更加便捷的测试解决方案。

核心功能

Cover-Agent 由几个关键组件构成,共同协作以实现高效的测试生成:

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

安装与使用

要使用 Cover-Agent,用户需要满足以下前提条件:

  • 设置 OPENAI_API_KEY 环境变量,用于调用 OpenAI API。
  • 安装代码覆盖率工具,生成 Cobertura XML 格式的代码覆盖率报告。

Cover-Agent 提供了多种安装和运行方式:

  1. 通过 pip 安装 Python 包:

    pip install git+https://github.com/Codium-ai/cover-agent.git
    
  2. 下载独立可执行文件:从项目的 release 页面下载适合您系统的二进制文件。

  3. 从源代码运行:克隆仓库后,使用 Poetry 安装依赖:

    poetry install
    

使用 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 会生成以下输出文件:

  • run.log:包含输出到 stdout 的日志副本。
  • test_results.html:结果表格,包含每个生成测试的状态、失败原因(如果适用)、退出代码、stderr、stdout 和生成的测试内容。

此外,如果设置了 WANDB_API_KEY 环境变量,还可以将提示、响应和其他信息记录到 Weights and Biases 平台。

支持多种 LLM

Cover-Agent 使用 LiteLLM 与 OpenAI 和其他托管的 LLM 通信,支持超过 100 种 LLM。用户可以通过设置相应的环境变量并使用 --model 选项来指定不同的模型。

开发和贡献

Cover-Agent 是一个开源项目,欢迎社区成员参与开发和贡献。开发者可以通过运行测试、构建二进制文件等方式参与项目。项目的路线图包括增强测试生成能力、支持更多测试场景、改进可用性等方面。

结语

Cover-Agent 代表了自动化测试生成领域的一个重要进展。通过利用先进的 AI 技术,它为开发团队提供了一个强大的工具,帮助他们更高效地生成高质量的测试用例,从而提高软件的整体质量和可靠性。随着项目的不断发展和社区的贡献,Cover-Agent 有望成为软件开发流程中不可或缺的一部分。

编辑推荐精选

GPT Plus|Pro充值

GPT Plus|Pro充值

GPT充值

支持 ChatGPT Plus / Pro 充值服务,支付便捷,自动发货,售后可查。

GPT Image 2中文站

GPT Image 2中文站

AI 图片生成平台

GPT Image 2 是面向用户的 AI 图片生成平台,支持文生图、图生图及多模型创意工作流。

Vecbase

Vecbase

你的AI Agent团队

Vecbase 是专为 AI 团队打造的智能工作空间,将数据管理、模型协作与知识沉淀整合于一处。算法、产品与业务在同一平台无缝协同,让从数据到 AI 应用的落地更快一步。

音述AI

音述AI

全球首个AI音乐社区

音述AI是全球首个AI音乐社区,致力让每个人都能用音乐表达自我。音述AI提供零门槛AI创作工具,独创GETI法则帮助用户精准定义音乐风格,AI润色功能支持自动优化作品质感。音述AI支持交流讨论、二次创作与价值变现。针对中文用户的语言习惯与文化背景进行专门优化,支持国风融合、C-pop等本土音乐标签,让技术更好地承载人文表达。

QoderWork

QoderWork

阿里Qoder团队推出的桌面端AI智能体

QoderWork 是阿里推出的本地优先桌面 AI 智能体,适配 macOS14+/Windows10+,以自然语言交互实现文件管理、数据分析、AI 视觉生成、浏览器自动化等办公任务,自主拆解执行复杂工作流,数据本地运行零上传,技能市场可无限扩展,是高效的 Agentic 生产力办公助手。

lynote.ai

lynote.ai

一站式搞定所有学习需求

不再被海量信息淹没,开始真正理解知识。Lynote 可摘要 YouTube 视频、PDF、文章等内容。即时创建笔记,检测 AI 内容并下载资料,将您的学习效率提升 10 倍。

AniShort

AniShort

为AI短剧协作而生

专为AI短剧协作而生的AniShort正式发布,深度重构AI短剧全流程生产模式,整合创意策划、制作执行、实时协作、在线审片、资产复用等全链路功能,独创无限画布、双轨并行工业化工作流与Ani智能体助手,集成多款主流AI大模型,破解素材零散、版本混乱、沟通低效等行业痛点,助力3人团队效率提升800%,打造标准化、可追溯的AI短剧量产体系,是AI短剧团队协同创作、提升制作效率的核心工具。

seedancetwo2.0

seedancetwo2.0

能听懂你表达的视频模型

Seedance two是基于seedance2.0的中国大模型,支持图像、视频、音频、文本四种模态输入,表达方式更丰富,生成也更可控。

nano-banana纳米香蕉中文站

nano-banana纳米香蕉中文站

国内直接访问,限时3折

输入简单文字,生成想要的图片,纳米香蕉中文站基于 Google 模型的 AI 图片生成网站,支持文字生图、图生图。官网价格限时3折活动

扣子-AI办公

扣子-AI办公

职场AI,就用扣子

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

下拉加载更多