gh-fix-ci
Original:🇺🇸 English
Not Translated
Inspect GitHub PR checks with gh, pull failing GitHub Actions logs, summarize failure context, then create a fix plan and implement after user approval. Use when a user asks to debug or fix failing PR CI/CD checks on GitHub Actions and wants a plan + code changes; for external checks (e.g., Buildkite), only report the details URL and mark them out of scope.
1installs
Added on
NPX Install
npx skill4agent add davila7/claude-code-templates gh-fix-ciSKILL.md Content
Gh Pr Checks Plan Fix
Overview
Use gh to locate failing PR checks, fetch GitHub Actions logs for actionable failures, summarize the failure snippet, then propose a fix plan and implement after explicit approval.
- Depends on the skill for drafting and approving the fix plan.
plan
Prereq: ensure is authenticated (for example, run once), then run with escalated permissions (include workflow/repo scopes) so commands succeed. If sandboxing blocks , rerun it with .
ghgh auth logingh auth statusghgh auth statussandbox_permissions=require_escalatedInputs
- : path inside the repo (default
repo). - : PR number or URL (optional; defaults to current branch PR)
pr - authentication for the repo host
gh
Quick start
python "<path-to-skill>/scripts/inspect_pr_checks.py" --repo "." --pr "<number-or-url>"- Add if you want machine-friendly output for summarization.
--json
Workflow
- Verify gh authentication.
- Run in the repo with escalated scopes (workflow/repo) after running
gh auth status.gh auth login - If sandboxed auth status fails, rerun the command with to allow network/keyring access.
sandbox_permissions=require_escalated - If unauthenticated, ask the user to log in before proceeding.
- Run
- Resolve the PR.
- Prefer the current branch PR: .
gh pr view --json number,url - If the user provides a PR number or URL, use that directly.
- Prefer the current branch PR:
- Inspect failing checks (GitHub Actions only).
- Preferred: run the bundled script (handles gh field drift and job-log fallbacks):
python "<path-to-skill>/scripts/inspect_pr_checks.py" --repo "." --pr "<number-or-url>"- Add for machine-friendly output.
--json
- Manual fallback:
gh pr checks <pr> --json name,state,bucket,link,startedAt,completedAt,workflow- If a field is rejected, rerun with the available fields reported by .
gh
- If a field is rejected, rerun with the available fields reported by
- For each failing check, extract the run id from and run:
detailsUrlgh run view <run_id> --json name,workflowName,conclusion,status,url,event,headBranch,headShagh run view <run_id> --log
- If the run log says it is still in progress, fetch job logs directly:
gh api "/repos/<owner>/<repo>/actions/jobs/<job_id>/logs" > "<path>"
- Preferred: run the bundled script (handles gh field drift and job-log fallbacks):
- Scope non-GitHub Actions checks.
- If is not a GitHub Actions run, label it as external and only report the URL.
detailsUrl - Do not attempt Buildkite or other providers; keep the workflow lean.
- If
- Summarize failures for the user.
- Provide the failing check name, run URL (if any), and a concise log snippet.
- Call out missing logs explicitly.
- Create a plan.
- Use the skill to draft a concise plan and request approval.
plan
- Use the
- Implement after approval.
- Apply the approved plan, summarize diffs/tests, and ask about opening a PR.
- Recheck status.
- After changes, suggest re-running the relevant tests and to confirm.
gh pr checks
- After changes, suggest re-running the relevant tests and
Bundled Resources
scripts/inspect_pr_checks.py
Fetch failing PR checks, pull GitHub Actions logs, and extract a failure snippet. Exits non-zero when failures remain so it can be used in automation.
Usage examples:
python "<path-to-skill>/scripts/inspect_pr_checks.py" --repo "." --pr "123"python "<path-to-skill>/scripts/inspect_pr_checks.py" --repo "." --pr "https://github.com/org/repo/pull/123" --jsonpython "<path-to-skill>/scripts/inspect_pr_checks.py" --repo "." --max-lines 200 --context 40