返回技能列表

setup-putior-ci

pjt222
更新于 Yesterday
5 次查看
17
2
17
在 GitHub 上查看
设计automationdesign

关于

This Claude Skill automatically sets up GitHub Actions CI/CD to regenerate putior workflow diagrams on every push. It creates workflow YAML, R generation scripts with sentinel markers, auto-commits updated diagrams, and integrates markers into README for in-place updates. Use it when workflow diagrams must always reflect current code, multiple contributors modify workflow-affecting code, or to replace manual diagram regeneration with automated CI/CD.

快速安装

Claude Code

推荐
主要方式
npx skills add pjt222/agent-almanac -a claude-code
插件命令备选方式
/plugin add https://github.com/pjt222/agent-almanac
Git 克隆备选方式
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/setup-putior-ci

在 Claude Code 中复制并粘贴此命令以安装该技能

技能文档

Set Up putior CI/CD

Configurar GitHub Actions para regenerar automáticamente diagramas de flujo de trabajo cuando el código fuente cambia, manteniendo la documentación sincronizada con el código.

Cuándo Usar

  • Los diagramas de flujo de trabajo deben siempre reflejar el estado actual del código
  • El proyecto tiene CI/CD y desea actualizaciones automáticas de documentación
  • Múltiples contribuidores pueden cambiar código que afecta el flujo de trabajo
  • Reemplazar la regeneración manual de diagramas con un pipeline automatizado

Entradas

  • Requerido: Repositorio de GitHub con anotaciones putior en archivos fuente
  • Requerido: Archivo destino para la salida del diagrama (ej., README.md, docs/workflow.md)
  • Opcional: Tema de putior (por defecto: "github")
  • Opcional: Directorios fuente a escanear (por defecto: "./R/" o "./src/")
  • Opcional: Rama para activar (por defecto: main)

Procedimiento

Paso 1: Crear el Workflow de GitHub Actions

Crear el archivo YAML del workflow para generación automatizada de diagramas.

# .github/workflows/update-workflow-diagram.yml
name: Update Workflow Diagram

on:
  push:
    branches: [main]
    paths:
      - 'R/**'
      - 'src/**'
      - 'scripts/**'

permissions:
  contents: write

jobs:
  update-diagram:
    if: github.actor != 'github-actions[bot]'
    runs-on: ubuntu-latest

    steps:
      - uses: actions/checkout@v4

      - uses: r-lib/actions/setup-r@v2
        with:
          use-public-rspm: true

      - name: Install putior
        run: |
          install.packages("putior")
        shell: Rscript {0}

      - name: Generate workflow diagram
        run: |
          Rscript scripts/generate-workflow-diagram.R

      - name: Commit updated diagram
        run: |
          git config --local user.name "github-actions[bot]"
          git config --local user.email "github-actions[bot]@users.noreply.github.com"
          git add README.md docs/workflow.md  # Adjust to match your target files
          git diff --staged --quiet || git commit -m "docs: update workflow diagram [skip ci]"
          git push

Esperado: Archivo creado en .github/workflows/update-workflow-diagram.yml.

En caso de fallo: Asegurar que el directorio .github/workflows/ exista. Ajustar el filtro paths para coincidir con donde viven los archivos fuente anotados en el repositorio.

Paso 2: Escribir el Script de Generación

Crear el script R que genera el diagrama y actualiza los archivos destino usando marcadores centinela.

# scripts/generate-workflow-diagram.R
library(putior)

# Scan source files for annotations (exclude build scripts to avoid circular refs)
workflow <- put_merge("./R/", merge_strategy = "supplement",
  exclude = c("generate-workflow-diagram\\.R$"),
  log_level = NULL)  # Set to "DEBUG" to troubleshoot CI diagram generation

# Generate Mermaid code
mermaid_code <- put_diagram(workflow, output = "raw", theme = "github")

# Read target file (e.g., README.md)
readme <- readLines("README.md")

# Find sentinel markers
start_marker <- "<!-- PUTIOR-WORKFLOW-START -->"
end_marker <- "<!-- PUTIOR-WORKFLOW-END -->"

start_idx <- which(readme == start_marker)
end_idx <- which(readme == end_marker)

if (length(start_idx) == 1 && length(end_idx) == 1 && end_idx > start_idx) {
  # Replace content between sentinels
  new_content <- c(
    readme[1:start_idx],
    "",
    "```mermaid",
    mermaid_code,
    "```",
    "",
    readme[end_idx:length(readme)]
  )
  writeLines(new_content, "README.md")
  cat("Updated README.md workflow diagram\n")
} else {
  warning("Sentinel markers not found in README.md. Add them manually:\n",
          start_marker, "\n", end_marker)
}

# Also write standalone diagram file
writeLines(
  c("# Workflow Diagram", "",
    "```mermaid", mermaid_code, "```"),
  "docs/workflow.md"
)
cat("Updated docs/workflow.md\n")

Esperado: Script en scripts/generate-workflow-diagram.R que lee anotaciones, genera código Mermaid y reemplaza contenido entre marcadores centinela.

En caso de fallo: Si put_merge() retorna vacío, verificar que las rutas fuente coincidan con la estructura del repositorio. Ajustar "./R/" al directorio fuente real.

Paso 3: Configurar Auto-Commit

El workflow debe evitar bucles infinitos donde un auto-commit re-activa el mismo workflow. Los pushes hechos con el GITHUB_TOKEN por defecto típicamente no activan nuevas ejecuciones del workflow, pero el workflow también incluye una guarda explícita if: en el job como red de seguridad.

Puntos clave de configuración:

  • permissions: contents: write otorga acceso de push
  • if: github.actor != 'github-actions[bot]' omite el job cuando el push proviene del bot mismo
  • git diff --staged --quiet || git commit solo hace commit si hay cambios
  • [skip ci] en el mensaje de commit es una convención que algunos sistemas CI honran (no está integrado en GitHub Actions, pero es útil como señal)
  • Identidad del bot usada para commits: github-actions[bot]

Esperado: El workflow solo hace commit cuando los diagramas realmente cambian. Sin commits vacíos, sin bucles infinitos.

En caso de fallo: Si el push falla con permiso denegado, verificar la configuración del repositorio: Settings > Actions > General > Workflow permissions debe estar configurado como "Read and write permissions".

Paso 4: Agregar Marcadores Centinela al README

Insertar marcadores centinela en el archivo destino donde el diagrama debe aparecer.

## Workflow

<!-- PUTIOR-WORKFLOW-START -->
<!-- This section is auto-generated by putior CI. Do not edit manually. -->

```mermaid
flowchart TD
  A["Placeholder — will be replaced on next CI run"]
<!-- PUTIOR-WORKFLOW-END -->

**Esperado:** Marcadores centinela en README.md (u otro archivo destino). El contenido entre ellos será reemplazado en cada ejecución de CI.

**En caso de fallo:** Asegurar que los marcadores estén en sus propias líneas sin espacios iniciales/finales. El script busca coincidencia exacta del contenido de la línea.

### Paso 5: Probar el Pipeline

Activar el workflow y verificar que el diagrama se actualice.

```bash
# Make a small change to trigger the workflow
echo "# test" >> R/some-file.R
git add R/some-file.R
git commit -m "test: trigger workflow diagram update"
git push

# Monitor the GitHub Actions run
gh run watch

# Verify the diagram was updated
git pull
cat README.md | grep -A 5 "PUTIOR-WORKFLOW-START"

Esperado: La ejecución de GitHub Actions se completa exitosamente. El diagrama entre marcadores centinela en README.md se actualiza con los datos de flujo de trabajo actuales.

En caso de fallo: Verificar el log de Actions para errores. Problemas comunes:

  • Paquete putior no disponible: agregar a Suggests en DESCRIPTION o instalar explícitamente en el workflow
  • Ruta fuente incorrecta: la ruta de put_merge() en el script R debe ser relativa a la raíz del repositorio
  • Sin marcadores centinela: el script avisa pero no falla; agregar marcadores al README.md

Validación

  • .github/workflows/update-workflow-diagram.yml existe y es YAML válido
  • scripts/generate-workflow-diagram.R se ejecuta sin errores localmente
  • README.md contiene centinelas <!-- PUTIOR-WORKFLOW-START --> y <!-- PUTIOR-WORKFLOW-END -->
  • El workflow de GitHub Actions se activa con push a la rama y rutas correctas
  • El contenido del diagrama entre centinelas se actualiza después de una ejecución del workflow
  • La guarda if: a nivel de job previene bucles infinitos de commits del bot
  • Sin cambios = sin commit (idempotente)

Errores Comunes

  • Bucles infinitos de CI: Los pushes con el GITHUB_TOKEN por defecto típicamente no activan nuevas ejecuciones, pero siempre agregar una guarda explícita if: github.actor != 'github-actions[bot]' en el job. La etiqueta [skip ci] en el mensaje de commit es una convención útil pero no es un mecanismo integrado de GitHub Actions.
  • Permiso denegado en push: GitHub Actions necesita permiso de escritura. Configurar permissions: contents: write en el archivo de workflow, o configurarlo en la configuración del repositorio.
  • Desajuste de marcadores centinela: Si los marcadores tienen espacios finales, tabulaciones iniciales o están en la misma línea que otro contenido, el script no los encontrará. Mantener los marcadores en sus propias líneas limpias.
  • Desajuste de ruta fuente: El script R se ejecuta desde la raíz del repositorio. Rutas como "./R/" o "./src/" deben coincidir con la estructura de directorios real.
  • Instalación de paquetes en CI: Si el proyecto usa renv, el workflow de CI necesita renv::restore() antes de que putior esté disponible. Alternativamente, instalar putior explícitamente en el workflow.
  • Repos grandes ralentizando CI: Para repos con muchos archivos fuente, limitar el filtro de activación paths a directorios que contengan anotaciones PUT, no el repositorio completo.

Habilidades Relacionadas

  • generate-workflow-diagram — la versión manual de lo que este CI automatiza
  • setup-github-actions-ci — configuración general de GitHub Actions CI/CD para paquetes R
  • build-ci-cd-pipeline — diseño más amplio de pipelines CI/CD
  • annotate-source-files — las anotaciones deben existir antes de que CI pueda generar diagramas
  • commit-changes — entender patrones de auto-commit

GitHub 仓库

pjt222/agent-almanac
路径: i18n/es/skills/setup-putior-ci
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

相关推荐技能

executing-plans

设计

该Skill用于当开发者提供完整实施计划时,以受控批次方式执行代码实现。它会先审阅计划并提出疑问,然后分批次执行任务(默认每批3个任务),并在批次间暂停等待审查。关键特性包括分批次执行、内置检查点和架构师审查机制,确保复杂系统实现的可控性。

查看技能

requesting-code-review

设计

该Skill可在完成任务、实现主要功能或合并代码前自动调度代码审查子代理,确保实现符合需求和计划。它支持通过指定git SHA范围进行精准的代码变更审查,帮助开发者在关键节点及时发现潜在问题。核心原则是"早审查、勤审查",适用于开发流程的各个关键阶段。

查看技能

connect-mcp-server

设计

这个Skill指导开发者如何将MCP服务器连接到Claude Code,支持HTTP、stdio和SSE三种传输协议。它涵盖了从安装配置到认证安全的完整流程,适用于集成GitHub、Notion、数据库等外部服务。当开发者需要添加集成、配置外部工具或提及MCP相关功能时,这个Skill能提供实用的操作指南。

查看技能

web-cli-teleport

设计

该Skill帮助开发者根据任务特性选择Claude Code的Web或CLI界面,并指导如何在两种环境间无缝迁移会话。它能分析任务复杂度、迭代需求等要素,推荐最优工作界面和工作流。关键特性包括会话状态管理、环境切换指导和上下文优化建议。

查看技能