Test-Agent

Test-Agent

智能测试助理助力软件质量提升

Test-Agent是一个开源的智能测试助理项目,融合大模型与质量工程技术。它提供多语言测试用例生成和Assert补全功能,支持Java、Python和JavaScript。项目开源的TestGPT-7B模型在用例执行通过率和场景覆盖方面表现优异。Test-Agent支持本地部署,保障数据安全。未来将持续迭代,扩展更多测试应用场景和模型规模。

Test-AgentTestGPT-7B测试用例生成大模型质量技术Github开源项目

Test-Agent: 您的智能测试助手

<p align="center"> <img src="https://yellow-cdn.veclightyear.com/ab5030c0/9b1fabb2-c2af-4ec7-a8c2-41da5f1a9b3f.jpg" width="50%" /> </p> <p align="center"> <a href="https://github.com/codefuse-ai/Test-Agent"> <img alt="stars" src="https://img.shields.io/github/stars/codefuse-ai/Test-Agent?style=social" /> </a> <a href="https://github.com/codefuse-ai/Test-Agent"> <img alt="forks" src="https://img.shields.io/github/forks/codefuse-ai/Test-Agent?style=social" /> </a> <a href="https://github.com/codefuse-ai/Test-Agent/LICENCE"> <img alt="License: MIT" src="https://badgen.net/badge/license/apache2.0/blue" /> </a> <a href="https://github.com/codefuse-ai/Test-Agent/issues"> <img alt="Open Issues" src="https://img.shields.io/github/issues-raw/codefuse-ai/Test-Agent" /> </a> </p>

本地Mac M1体验效果

图片

魔搭体验效果

魔搭模型访问链接:ModelScope TestGPT-7B MS

什么是Test Agent?(简介)

Test Agent 旨在构建测试领域的"智能体",融合大模型和质量领域工程化技术,促进质量技术体系升级。我们期望与社区成员一起合作,打造创新的测试领域解决方案,构建24小时在线的测试助理服务,让测试如丝般顺滑。

本期特性

  • 模型 本期我们开源了测试领域模型TestGPT-7B。该模型以CodeLlama-7B为基础,进行了相关下游任务的微调:

    • 多语言测试用例生成(Java/Python/Javascript) 一直以来都是学术界和工业界非常关注的领域,近年来不断有新产品或工具孵化出来,如EvoSuite、Randoop、SmartUnit等。然而传统的用例生成存在其难以解决的痛点问题,基于大模型的测试用例生成在测试用例可读性、测试场景完整度、多语言支持方面都优于传统用例生成工具。本次重点支持了多语言测试用例生成,在我们本次开源的版本中首先包含了Java、Python、Javascript的测试用例生成能力,下一版本中将逐步开放Go、C++等语言。
    • 测试用例断言补全 在对当前测试用例现状进行分析与探查时,我们发现代码仓库中存在一定比例的存量测试用例中未包含断言。没有断言的测试用例虽然能够在回归过程中执行通过,却无法发现问题。因此我们拓展了测试用例断言自动补全这一场景。通过该模型能力,结合一定的工程化配套,可以实现对全库测试用例的批量自动补全,智能提升项目质量水平。
  • 工程框架 本地模型快速发布和体验工程化框架

    • ChatBot页面
    • 模型快速启动
    • 私有化部署,本地化的GPT大模型与您的数据和环境进行交互,无数据泄露风险,100%安全

后续我们会持续迭代模型和工程化能力:

  • 不断加入更多令人激动的测试领域应用场景,如领域知识问答、测试场景分析等
  • 支持面向测试场景的copilot工程框架开放,如测试领域知识智能嵌入、测试通用工具API体系、智能测试Agent等,敬请期待!
  • 以7B为基础,逐步扩展至13B、34B模型。欢迎关注!

性能最强的7B测试领域大模型

目前在TestAgent中,我们默认使用了TestGPT-7B模型。与当前已有开源模型相比,TestGPT-7B模型在用例执行通过率(pass@1)、用例场景覆盖(平均测试场景数)上都处于业界领先水平。 TestGPT-7B模型核心能力的评测结果如下:

  • 多语言测试用例生成 针对模型支持的三种语言:Java、Python、Javascript,Pass@1评测结果如下:
模型Java pass@1Java平均测试场景数Python pass@1Python平均测试场景数Javascript pass@1Javascript平均测试场景数
TestGPT-7B48.6%4.3735.67%3.5636%2.76
CodeLlama-13B-Instruct40.54%1.0830.57%1.6531.7%3.13
Qwen-14B-Chat10.81%2.7815.9%1.329.15%4.22
Baichuan2-13B-Chat13.5%2.2412.7%2.126.1%3.31
  • 测试用例断言补全 目前模型支持Java用例的断言补全,Pass@1评测结果如下:
模型pass@1强验证百分比
Codefuse-TestGPT-7B71.1%100%

工程架构

JG

大模型的号角已经吹响,测试领域大模型也在不断进化中。通过预训练过程中积累的丰富世界知识,在复杂交互环境中展现出了非凡的推理与决策能力。

尽管在测试领域中基础模型取得了显著的成果,但仍然存在一些局限性,特定领域的测试任务通常需要专业化的工具或领域知识来解决。例如,基础模型可以通过预训练知识完成单次测试代码生成和测试文本生成等任务,但处理复杂的集成用例生成、特定领域用例生成和测试流程pipeline交互等问题时,需要更专业的工具和领域知识。因此将专用工具与基础模型整合在一起,可以充分发挥它们各自的优势。专用工具可以解决模型时效性不足、增强专业知识、提高可解释性和鲁棒性的问题。而基础模型则具备类人的推理规划能力,可以理解复杂的数据和场景,并与现实世界进行交互。

在本期开放模型工程化部署和ChatBot基础上,我们将继续在测试开源领域深耕投入。协同社区志同道合的开发者们,一起打造测试领域最领先的工具工程体系、智能测试助理和测试开源工程!

快速使用

前置准备

模型下载

You can obtain detailed information about the model and download the model files from modelscope or huggingface.

Please note:

  1. If you download the model through modelscope, you can refer to: Download Instructions for the download method;
  2. If you download the model through huggingface, please ensure that you can access huggingface normally.

Environment Installation

  • python>=3.8
  • transformers==4.33.2
git clone https://github.com/codefuse-ai/Test-Agent cd Test-Agent pip install -r requirements.txt

Before running the TestGPT-7B model, please ensure that your execution environment has about 14GB of video memory.

Start the Service

The project provides the ability to quickly set up a UI on the web page to more intuitively demonstrate model interaction and effects. We can use a few simple commands to wake up the front-end page and call the model's capabilities in real-time. In the project directory, start the following services in order:

1.Start the controller controller python3 -m chat.server.controller

2.Start the model worker work python3 -m chat.server.model_worker --model-path models/TestGPT-7B --device mps

(models/TestGPT-7B is the actual model file path)

For the startup method, you can choose from the following configuration options as needed:

  • --device mps is used to enable GPU acceleration on Mac computers (Apple Silicon or AMD GPUs);
  • --device xpu is used to enable acceleration on Intel XPU (Intel Data Center and Arc A-Series GPUs);
  • --device npu is used to enable acceleration on Huawei AI processors;
    • Need to install Ascend PyTorch Adapter
    • Set CANN environment variables: source /usr/local/Ascend/ascend-toolkit/set_env.sh
  • --device cpu is the option to run using CPU alone, without GPU;
  • --num-gpus 2 specifies the option for concurrent GPU running.
  1. Start the web service python3 -m chat.server.gradio_testgpt web Once the service is ready, we can open the locally launched web service address http://0.0.0.0:7860 to see the complete front-end page. At the bottom of the page, there are two examples of "Unit Test Generation" and "Assert Completion". Clicking the button will automatically generate a sample text in the input box. Clicking the Send button will trigger the model to run, and after waiting patiently for a while (running time depends on the performance of your machine), you can see the complete answer. demo

🤗 Acknowledgments

This project is built based on FastChat. We deeply appreciate their open-source contributions!

Contact Us

testagent_wechat_3

编辑推荐精选

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具酷表ChatExcelAI智能客服AI营销产品使用教程
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

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

AI工具TraeAI IDE协作生产力转型热门
AIWritePaper论文写作

AIWritePaper论文写作

AI论文写作指导平台

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

AI辅助写作AI工具AI论文工具论文写作智能生成大纲数据安全AI助手热门
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

下拉加载更多