当前位置: 首页 > news >正文

CircleCI自动化_circleci-automation

以下为本文档的中文说明

这是一个通过 Rube MCP(Model Context Protocol)中间件来自动化 CircleCI CI/CD 操作的技能。它基于 Composio 平台的 CircleCI 工具集,通过 Rube MCP 桥接 AI 代理与 CircleCI API 的交互,使得用户可以通过自然语言指令完成复杂的 CI/CD 管理任务。使用场景包括:需要触发新的流水线运行(Trigger Pipeline)、监控管道和工作流状态(Monitor Pipelines and Workflows)、查看具体的 Job 执行详情(Inspect Job Details)、获取构建产物(Retrieve Build Artifacts)以及检查测试结果(Review Test Metadata)。核心操作流程遵循严格的先决条件检查:首先确认 Rube MCP 可用,然后通过 RUBE_MANAGE_CONNECTIONS 建立 CircleCI 连接,确认连接状态为 ACTIVE 后才开始执行工作流。该技能提供了完整的参数说明和陷阱提示,例如 project_slug 的格式必须是 {vcs}/{org}/{repo}(如 gh/myorg/myrepo),branch 和 tag 参数互斥不能同时使用,以及 Pipeline ID 和工作流 ID 是 UUID 格式而 Job Number 是整数格式。它还定义了 Pipeline → Workflow → Job 的三层调用层级关系,以及分页处理的规范。此外,该技能覆盖了常见的错误处理和速率限制应对策略,如指数退避(Exponential Backoff)和合理的轮询间隔(5-10 秒),适合在生产环境中使用。


CircleCI Automation via Rube MCP

Automate CircleCI CI/CD operations through Composio’s CircleCI toolkit via Rube MCP.

Prerequisites

  • Rube MCP must be connected (RUBE_SEARCH_TOOLS available)
  • Active CircleCI connection viaRUBE_MANAGE_CONNECTIONSwith toolkitcircleci
  • Always callRUBE_SEARCH_TOOLSfirst to get current tool schemas

Setup

Get Rube MCP: Addhttps://rube.app/mcpas an MCP server in your client configuration. No API keys needed — just add the endpoint and it works.

  1. Verify Rube MCP is available by confirmingRUBE_SEARCH_TOOLSresponds
  2. CallRUBE_MANAGE_CONNECTIONSwith toolkitcircleci
  3. If connection is not ACTIVE, follow the returned auth link to complete CircleCI authentication
  4. Confirm connection status shows ACTIVE before running any workflows

Core Workflows

1. Trigger a Pipeline

When to use: User wants to start a new CI/CD pipeline run

Tool sequence:

  1. CIRCLECI_TRIGGER_PIPELINE- Trigger a new pipeline on a project [Required]
  2. CIRCLECI_LIST_WORKFLOWS_BY_PIPELINE_ID- Monitor resulting workflows [Optional]

Key parameters:

  • project_slug: Project identifier in formatgh/org/repoorbb/org/repo
  • branch: Git branch to run the pipeline on
  • tag: Git tag to run the pipeline on (mutually exclusive with branch)
  • parameters: Pipeline parameter key-value pairs

Pitfalls:

  • project_slugformat is{vcs}/{org}/{repo}(e.g.,gh/myorg/myrepo)
  • branchandtagare mutually exclusive; providing both causes an error
  • Pipeline parameters must match those defined in.circleci/config.yml
  • Triggering returns a pipeline ID; workflows start asynchronously

2. Monitor Pipelines and Workflows

When to use: User wants to check the status of pipelines or workflows

Tool sequence:

  1. CIRCLECI_LIST_PIPELINES_FOR_PROJECT- List recent pipelines for a project [Required]
  2. CIRCLECI_LIST_WORKFLOWS_BY_PIPELINE_ID- List workflows within a pipeline [Required]
  3. CIRCLECI_GET_PIPELINE_CONFIG- View the pipeline configuration used [Optional]

Key parameters:

  • project_slug: Project identifier in{vcs}/{org}/{repo}format
  • pipeline_id: UUID of a specific pipeline
  • branch: Filter pipelines by branch name
  • page_token: Pagination cursor for next page of results

Pitfalls:

  • Pipeline IDs are UUIDs, not numeric IDs
  • Workflows inherit the pipeline ID; a single pipeline can have multiple workflows
  • Workflow states include: success, running, not_run, failed, error, failing, on_hold, canceled, unauthorized
  • page_tokenis returned in responses for pagination; continue until absent

3. Inspect Job Details

When to use: User wants to drill into a specific job’s execution details

Tool sequence:

  1. CIRCLECI_LIST_WORKFLOWS_BY_PIPELINE_ID- Find workflow containing the job [Prerequisite]
  2. CIRCLECI_GET_JOB_DETAILS- Get detailed job information [Required]

Key parameters:

  • project_slug: Project identifier
  • job_number: Numeric job number (not UUID)

Pitfalls:

  • Job numbers are integers, not UUIDs (unlike pipeline and workflow IDs)
  • Job details include executor type, parallelism, start/stop times, and status
  • Job statuses: success, running, not_run, failed, retried, timedout, infrastructure_fail, canceled

4. Retrieve Build Artifacts

When to use: User wants to download or list artifacts produced by a job

Tool sequence:

  1. CIRCLECI_GET_JOB_DETAILS- Confirm job completed successfully [Prerequisite]
  2. CIRCLECI_GET_JOB_ARTIFACTS- List all artifacts from the job [Required]

Key parameters:

  • project_slug: Project identifier
  • job_number: Numeric job number

Pitfalls:

  • Artifacts are only available after job completion
  • Each artifact has apathandurlfor download
  • Artifact URLs may require authentication headers to download
  • Large artifacts may have download size limits

5. Review Test Results

When to use: User wants to check test outcomes for a specific job

Tool sequence:

  1. CIRCLECI_GET_JOB_DETAILS- Verify job ran tests
    [Prerequisite]
  2. CIRCLECI_GET_TEST_METADATA- Retrieve test results and metadata [Required]

Key parameters:

  • project_slug: Project identifier
  • job_number: Numeric job number

Pitfalls:

  • Test metadata requires the job to have uploaded test results (JUnit XML format)
  • If no test results were uploaded, the response will be empty
  • Test metadata includes classname, name, result, message, and run_time fields
  • Failed tests include failure messages in themessagefield

Common Patterns

Project Slug Format

Format: {vcs_type}/{org_name}/{repo_name} - GitHub: gh/myorg/myrepo - Bitbucket: bb/myorg/myrepo

Pipeline -> Workflow -> Job Hierarchy

1. Call CIRCLECI_LIST_PIPELINES_FOR_PROJECT to get pipeline IDs 2. Call CIRCLECI_LIST_WORKFLOWS_BY_PIPELINE_ID with pipeline_id 3. Extract job numbers from workflow details 4. Call CIRCLECI_GET_JOB_DETAILS with job_number

Pagination

  • Check response fornext_page_tokenfield
  • Pass token aspage_tokenin next request
  • Continue untilnext_page_tokenis absent or null

Known Pitfalls

ID Formats:

  • Pipeline IDs: UUIDs (e.g.,5034460f-c7c4-4c43-9457-de07e2029e7b)
  • Workflow IDs: UUIDs
  • Job numbers: Integers (e.g.,123)
  • Do NOT mix up UUIDs and integers between different endpoints

Project Slugs:

  • Must include VCS prefix:gh/for GitHub,bb/for Bitbucket
  • Organization and repo names are case-sensitive
  • Incorrect slug format causes 404 errors

Rate Limits:

  • CircleCI API has per-endpoint rate limits
  • Implement exponential backoff on 429 responses
  • Avoid rapid polling; use reasonable intervals (5-10 seconds)

Quick Reference

TaskTool SlugKey Params
Trigger pipelineCIRCLECI_TRIGGER_PIPELINEproject_slug, branch, parameters
List pipelinesCIRCLECI_LIST_PIPELINES_FOR_PROJECTproject_slug, branch
List workflowsCIRCLECI_LIST_WORKFLOWS_BY_PIPELINE_IDpipeline_id
Get pipeline configCIRCLECI_GET_PIPELINE_CONFIGpipeline_id
Get job detailsCIRCLECI_GET_JOB_DETAILSproject_slug, job_number
Get job artifactsCIRCLECI_GET_JOB_ARTIFACTSproject_slug, job_number
Get test metadataCIRCLECI_GET_TEST_METADATAproject_slug, job_number

When to Use

This skill is applicable to execute the workflow or actions described in the overview.

Limitations

  • Use this skill only when the task clearly matches the scope described above.
  • Do not treat the output as a substitute for environment-specific validation, testing, or expert review.
  • Stop and ask for clarification if required inputs, permissions, safety boundaries, or success criteria are missing.
http://www.jsqmd.com/news/1072803/

相关文章:

  • 程序员跨境收支必备:查外汇网实战指南
  • 《Effective Python》读书笔记14: 附录 - 90条建议完整列表
  • 鸿蒙PC中使用ohos-sdk完成Rust适配,自动签名编译安装第三方库walkdir是 Rust 递归遍历目录的专用库
  • 第34章:自动化代码评审Agent——自动审查PR并给出建议
  • AI调试助手EAP谱试,连接周期从2天到3小时
  • 一篇文章带你入门漏洞靶场:从 0 到 1 玩转 bWAPP(附完整安装教程)
  • ChatGPT 转 pdf 怎么压缩但清晰,AI 导出鸭平衡体积与清晰度,告别文档臃肿问题
  • Codex CLI-03-AGENTS.md 编写指南:让 AI 理解你的项目
  • 屏幕截图文字识别工具帮你屏幕截图取字
  • 论文分享➲ arXiv2026 | H2HMem: A Multimodal Memory Benchmark for Agents in Human-Human Interactions
  • 鸿蒙PC适配llvm-gcc-compat编译安装第三方库convert_case,打造Rust 第三方字符串命名风格互相转换
  • 5分钟搞定OpenCode Go套餐无缝接入Claude Code,性价比直接起飞!
  • 鸿蒙 PC使用ohos-pip-autosign激活自动签名工具,安装第三方库arrow实现Python人性化时间处理库
  • 嵌入式linux学习记录十四、术语
  • 第二章 基本数据类型及其操作4
  • SoK: Taxonomy and Evaluation of Prompt Security in Large Language Models
  • 智谱清言能生成 word 吗?AI 导出鸭一站式搞定文档导出难题
  • 31. 完美转发:将参数原样传递
  • 在MacOS上如何安装配置工时通
  • 驱动更新工具
  • 第30章 「对称破缺」—— 悦儿篇
  • Agent 到底是什么?它不是会聊天的 AI,而是会执行任务的系统
  • 古籍版本流传信息目录页爬取实战:用 Python 抽取书名、版本、刊刻年代、藏馆与链接
  • 计算机毕业设计之高校社团管理网站
  • HoRain云--R循环实战:从语法到高效向量化技巧
  • 【C++】new/delete 还是 malloc/free?C++内存管理的“世纪抉择
  • 大型电网企业数字化转型全解析:从国网顶层战略到基层落地实践深度剖析(PPT)
  • 第31章:构建自定义Code Agent——打造专属的代码助手
  • 使用 Python 调用商品条形码查询API并解析商品信息
  • FAST-LIVO2 源码精读(九):VoxelMap 体素地图——哈希索引与八叉树平面拟合