From tend-ci-runner
Triages new GitHub issues — classifies, reproduces bugs, attempts conservative fixes, and comments. Use when a new issue is opened and needs automated triage.
npx claudepluginhub max-sixty/tend --plugin tend-ci-runnerThis skill uses the workspace's default tool permissions.
Triage a newly opened GitHub issue.
Investigates GitHub issues/PRs: pulls open items via gh CLI, classifies, searches codebase for root causes, reviews contributed code, proposes fixes with file:line references, optionally implements. For GitHub issue/PR triage only.
Fixes GitHub issues end-to-end with GitHub CLI: views issue, researches context, plans fix, creates branch, implements/tests changes, submits PR.
Resolves GitHub issues through triage, root cause analysis, TDD, branch management, testing, and CI/CD-compliant pull requests. Ideal for team workflows on bugs and features.
Share bugs, ideas, or general feedback.
Triage a newly opened GitHub issue.
Issue to triage: $ARGUMENTS
Load /tend-ci-runner:running-in-ci first (CI environment rules, security).
It will also prompt you to load any repo-specific skills (e.g.,
running-tend) — do so before proceeding.
Follow the AD FONTES principle throughout: reproduce before fixing, evidence before speculation, test before committing.
gh issue view $ARGUMENTS --json title,body,labels,author
Classify into one of:
Skip for questions and other.
# Search open issues for similar problems
gh issue list --state open --json number,title,labels --limit 50
# Check for existing fix branches and PRs
git branch -r --list 'origin/fix/*'
gh pr list --state open --json number,title,headRefName --limit 50
If a duplicate or existing fix is found, note it for the comment in step 7. Don't create a duplicate fix.
Feature requests only.
Search the codebase to check whether the requested feature already exists.
Record what you found (or didn't find) for use in step 7.
Bug reports only.
If the test passes (bug may already be fixed), note this for the comment.
If you cannot reproduce the bug (unclear steps, environment-specific, etc.), note what you tried and skip to step 7. Do NOT proceed to Step 6 without a failing test — a fix without reproduction evidence is not a conservative fix.
Bug reports only.
CRITICAL — gate check before proceeding:
You MUST have a failing test from Step 5 before writing any fix. If you skipped the test (couldn't write one, environment-specific bug, etc.), do NOT attempt a fix — go directly to Step 7 and use the "Reproduction test only" or "Could not reproduce" comment template.
Only attempt a fix if ALL of these conditions are met:
When the bug is about bot behavior (e.g., "bot didn't use links", "bot posted wrong format"), the root cause is often a skill/prompt compliance issue, not missing code. Before adding guidance to a skill:
git checkout -b fix/issue-$ARGUMENTS
git add -A
git commit -m "fix: <description>
Closes #$ARGUMENTS
Co-Authored-By: Claude <noreply@anthropic.com>"
git push -u origin fix/issue-$ARGUMENTS
gh pr create --title "fix: <description>" --body "## Problem
[What the issue reported and the root cause]
## Solution
[What was fixed and why]
## Testing
[How the fix was verified — mention the reproduction test]
---
Closes #<issue-number> — automated triage"
Commit just the failing test on a reproduction branch and open a PR:
git checkout -b repro/issue-$ARGUMENTS
git add -A
git commit -m "test: add reproduction for #$ARGUMENTS
Co-Authored-By: Claude <noreply@anthropic.com>"
git push -u origin repro/issue-$ARGUMENTS
gh pr create --title "test: reproduction for #$ARGUMENTS" --body "## Context
Adds a failing test that reproduces #$ARGUMENTS. The fix is not yet included — this PR captures the reproduction so a maintainer can investigate.
---
Automated triage for #<issue-number>"
Note the PR number for the comment.
Recheck before posting. Triage can take several minutes. Before posting, re-fetch the conversation to check for new comments:
gh issue view $ARGUMENTS --json comments --jq '.comments | length'
If new comments appeared since you first read the issue, read them and adjust your response — someone may have answered, provided more context, or closed the issue. If your comment is now redundant, skip it.
Always comment via gh issue comment. Keep it brief, polite, and specific. A
maintainer will always review — never claim the issue is fully resolved by
automation alone.
Stay within what you verified. State facts you found in the codebase — don't characterize something as "known" unless you find prior issues or documentation about it. Don't speculate beyond the code you read.
Use the heredoc pattern from /tend-ci-runner:running-in-ci for --body arguments to avoid shell
quoting issues.
Choose the appropriate template:
Thanks for reporting this! I was able to reproduce the issue and identified the root cause: [one-sentence explanation].
I've opened #PR_NUMBER with a fix. A maintainer will review it shortly.
Thanks for reporting this! I was able to reproduce the issue — #PR_NUMBER adds a failing test that demonstrates the bug.
Root cause appears to be [brief explanation if known, or "still under investigation"]. A maintainer will take a closer look.
Thanks for reporting this! I tried to reproduce this but wasn't able to with the information provided.
Could you share [specific information needed — exact command, config file, OS, shell, etc.]? That would help narrow it down.
A maintainer will also take a look.
Thanks for reporting this! I looked into this and it appears the behavior described may already be fixed on the default branch (the relevant test passes).
Could you confirm which version you're running? If you're on an older release, updating should resolve this. A maintainer will confirm.
Thanks for the suggestion! It's possible that [existing feature — specific behavior, config/flag] already does what you're looking for: [brief description of how it works].
If that's not quite what you had in mind, could you clarify what additional behavior you're looking for? A maintainer will take a look either way.
Thanks for the suggestion! I searched the codebase and didn't find an existing implementation of this. [Optionally: the closest related functionality is X, which does Y.]
I'll leave it for a maintainer to evaluate and prioritize.
Thanks for reaching out! This looks like a usage question rather than a bug report.
[Brief answer if obvious from the codebase, or pointer to relevant docs/help text.]
A maintainer can provide more detail if needed.
Thanks for reporting this! This appears to be related to #EXISTING_ISSUE [and/or PR #EXISTING_PR]. I'll leave it to a maintainer to confirm and link them.