semaphore-ci

star 8

Manage Semaphore CI/CD via sem-ai. Use when the user asks about CI status, pipeline failures, test results, deployments, secrets, notifications, scheduled tasks, deployment targets, project health, or anything related to their Semaphore pipelines and workflows — e.g. "CI status", "pipeline failed", "why did CI fail", "deploy to staging", "rerun the pipeline", "what's flaky", "check the build", "show me the logs", "promote to production", "validate yaml".

semaphoreio By semaphoreio schedule Updated 6/9/2026

name: semaphore-ci description: Manage Semaphore CI/CD via sem-ai. Use when the user asks about CI status, pipeline failures, test results, deployments, secrets, notifications, scheduled tasks, deployment targets, project health, or anything related to their Semaphore pipelines and workflows — e.g. "CI status", "pipeline failed", "why did CI fail", "deploy to staging", "rerun the pipeline", "what's flaky", "check the build", "show me the logs", "promote to production", "validate yaml". allowed-tools: Bash(sem-ai *)

Semaphore CI/CD — via sem-ai

sem-ai is a CLI that gives you full control over Semaphore CI/CD. Every command returns structured JSON. 77 commands covering projects, workflows, pipelines, jobs, tests, artifacts, secrets, deploys, and more.

Setup

# Connect (one-time). Get your token at https://me.semaphoreci.com/account
sem-ai connect <your-org>.semaphoreci.com <your-api-token>

# Verify
sem-ai context show

Self-orientation

sem-ai discover                  # Full capability map (77 commands + flags + examples)
sem-ai <any-command> --examples  # Usage examples for any command

Quick reference

Task Command
CI status sem-ai status (--project/--branch auto-detect; --pr N resolves a PR's workflow)
Did my push pass? / watch CI to green sem-ai status (or until sem-ai status --exit-code; do sleep 20; done); see watch-after-push
Why did CI fail? sem-ai diagnose <workflow-id>
Project health sem-ai health --project <p>
Job logs sem-ai job log <job-id>
Test results sem-ai test summary --pipeline <id>
Rerun workflow sem-ai workflow rerun <id>
Rebuild failed only sem-ai rerun-failed <pipeline-id>
Deploy to staging sem-ai pipeline promote <id> --target "Staging" --confirm
Deploy and wait sem-ai promote-and-wait <id> --target "Staging" --confirm
Validate YAML sem-ai yaml validate --file .semaphore/semaphore.yml
Server diagnostics sem-ai troubleshoot workflow <id>
List secrets sem-ai secret list
Flaky tests sem-ai test flaky (--project optional; auto-detects)
Test locally in CI env sem-ai testbox warmup (--project optional) then sem-ai testbox run --id <id> "cmd"
Watch CI after a push git push, then sem-ai watch <workflow-id> (see watch-after-push)

For the is-it-green check, prefer sem-ai status — it keeps the failure drill (sem-ai diagnose <workflow-id>) one tool away. Your git host's own checks (gh pr checks on GitHub, or the GitLab/Bitbucket equivalent) mirror the same Semaphore result and are a fine fallback when sem-ai isn't connected — Semaphore connects to any of those hosts.

Project detection

--project is optional on all repo-scoped commands (status, workflow list/run, pipeline list, deploy targets/create, task list/create, test flaky, diagnose, health, open, analytics) — it auto-detects from the origin git remote (ssh or https) when omitted, so there's no need to pass it inside a checkout. --branch likewise auto-detects from HEAD; sem-ai status pins the current HEAD commit ("matched_by":"commit_sha", falling back to "latest_on_branch"). Pass --project/--branch only to override.

Caveat: if the repo maps to multiple Semaphore projects, sem-ai status returns all of them ("multiple_projects": true) instead of guessing — pass --project <name> to pick one. (To target a specific run regardless, filter workflow list by commit_sha; see the watch-after-push skill.)

Sub-skills — load for deeper context

For detailed workflows with step-by-step examples, load the relevant sub-skill:

  • Debugging failures → load debug-pipeline — diagnosing, reading logs, fixing CI
  • Testing locally in CI → load testbox — run tests in real Semaphore env before pushing
  • Deploying → load deploy — promotions, deployment targets, deploy-and-wait
  • Test analysis → load test-intelligence — test results, flaky detection, frameworks
  • Infrastructure → load manage-infra — secrets, notifications, agents, tasks
  • Monitoring → load project-health — health checks, pass rates, trends
  • After a push → load watch-after-push — find the run for your commit and watch it to completion

Safety

  • pipeline promote requires --confirm to execute. Without it: dry-run preview only.
  • --override bypasses promotion conditions — use with caution.
  • Delete operations execute immediately.
  • All output is JSON. Use --format table for human display.

Output format

Success: JSON to stdout, exit 0. Error: {"error": true, "code": "not_found", "message": "...", "status": 404} to stderr, exit 1.

Install via CLI
npx skills add https://github.com/semaphoreio/sem-ai --skill semaphore-ci
Repository Details
star Stars 8
call_split Forks 1
navigation Branch main
article Path SKILL.md
More from Creator