Added: - guide/third-party-tools.md: External Orchestration Frameworks section (Ruflo + Athena Flow) with architectural distinction from multi-instance tools - examples/skills/pr-triage/: 3-phase PR backlog management skill (audit, deep review via parallel agents, validated comment posting) - examples/github-actions/: claude-code-review.yml + .coderabbit.yaml + prompts/code-review.md — AI-powered PR review GitHub Actions workflow - docs/resource-evaluations/073-athena-flow-workflow-runtime.md (2/5 Watch) - docs/resource-evaluations/074-ruflo-multi-agent-orchestration.md (3/5 Pertinent) Updated: - examples/README.md + examples/github-actions/README.md: new templates indexed - machine-readable/reference.yaml: new entries for github-actions + pr-triage Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com> |
||
|---|---|---|
| .. | ||
| prompts | ||
| .coderabbit.yaml | ||
| claude-code-review.yml | ||
| claude-issue-triage.yml | ||
| claude-pr-auto-review.yml | ||
| claude-security-review.yml | ||
| README.md | ||
| title | description | tags | ||||
|---|---|---|---|---|---|---|
| GitHub Actions Workflows for Claude Code | Ready-to-use CI/CD workflows integrating Claude Code into GitHub Actions |
|
GitHub Actions Workflows for Claude Code
Ready-to-use GitHub Actions workflows that integrate Claude Code into your CI/CD pipeline.
Prerequisites
- Install the Claude GitHub App on your org/repo (required for Actions to comment on PRs/issues)
- Add API Key Secret: In your repo, go to Settings → Secrets and variables → Actions → New repository secret
- Name:
ANTHROPIC_API_KEY - Value: Your Anthropic API key from console.anthropic.com
- Name:
- Copy Workflows: Place these
.ymlfiles in.github/workflows/directory - Test: Open a test PR or issue to see them run
Available Workflows
1. Code Review — Prompt-Based (claude-code-review.yml) ⭐ Recommended
Robust pattern with externalized prompt, anti-hallucination protocol, and /claude-review on-demand trigger.
The review logic lives in .github/prompts/code-review.md, so you can iterate on criteria without touching the workflow YAML. The prompt enforces a verification step before every finding — Claude must confirm an issue with Read/Grep before reporting it.
Features:
- Triggers on PR open/sync/ready and
/claude-reviewcomment - Externalized prompt: edit
code-review.mdto tune criteria for your stack - Anti-hallucination protocol: no invented line numbers or unverified claims
- Structured output:
🔴 MUST FIX/🟡 SHOULD FIX/🟢 CAN SKIPtable + inline comments - Read-only
allowed_tools(no write access to repo) - OAuth token support (no API key needed if Claude GitHub App is installed)
Setup:
# Copy both files into your repo
cp examples/github-actions/claude-code-review.yml .github/workflows/
mkdir -p .github/prompts
cp examples/github-actions/prompts/code-review.md .github/prompts/
# Add secret: CLAUDE_CODE_OAUTH_TOKEN (or ANTHROPIC_API_KEY)
# Install Claude GitHub App: https://github.com/apps/claude
Customization:
Edit .github/prompts/code-review.md to add your stack conventions:
## Stack Context
- TypeScript strict mode, no `any`
- React Server Components — no `useEffect` for data fetching
- All DB writes must go through the repository layer
- New API routes require integration tests
2. Auto PR Review (claude-pr-auto-review.yml)
Enhanced version with comprehensive review criteria and smart filtering.
Creates a structured review with inline comments as soon as a PR opens or updates.
Features:
- Automatic code review on PR open/update
- 8 focus areas: Correctness, Security, Performance, Readability, Maintainability, Testing, Best Practices, Breaking Changes
- Priority-based feedback: 🔴 Critical, 🟡 Important, 🟢 Suggestion, 💡 Tip
- Smart file filtering (skips build artifacts, lock files)
- Skips draft PRs to save costs
- Summary review with risk assessment
- Error handling and fallback notifications
- Inline comments on specific lines
Usage:
# Copy the workflow file
cp examples/github-actions/claude-pr-auto-review.yml .github/workflows/
# Open a PR - Claude will automatically review it
Customization:
Add project-specific context by uncommenting the append_system_prompt section:
append_system_prompt: |
Project conventions:
- Use TypeScript strict mode
- Follow functional programming patterns
- All functions must have JSDoc comments
- Test coverage must be >80%
2. Security Review (claude-security-review.yml)
Runs a focused security scan and comments findings directly on the PR.
Features:
- Security-focused analysis on every PR
- Identifies potential vulnerabilities
- OWASP Top 10 considerations
- Posts findings as PR comments
Configuration:
# Optional parameters in the workflow file:
exclude-directories: "docs,examples" # Skip certain directories
claudecode-timeout: "20" # Timeout in minutes
claude-model: "claude-3-5-sonnet-20240620" # Model to use
Usage:
# Copy the workflow file
cp examples/github-actions/claude-security-review.yml .github/workflows/
# Every PR will be automatically scanned for security issues
3. Issue Triage (claude-issue-triage.yml)
When a new issue opens, Claude proposes labels/severity and posts a tidy triage comment.
Features:
- Automatic issue classification
- Label suggestions
- Severity assessment (low, medium, high, critical)
- Duplicate detection
- Markdown triage comment
Auto-apply Labels (Optional): To automatically apply suggested labels, edit the workflow file and change:
- name: Apply labels (optional)
if: ${{ false }} # Change to true to auto-apply labels
Usage:
# Copy the workflow file
cp examples/github-actions/claude-issue-triage.yml .github/workflows/
# Open a new issue - Claude will automatically triage it
Multi-Model Review Setup
Running Claude alongside other automated reviewers (Gemini, Greptile, CodeRabbit) surfaces issues that any single model misses. The pattern: each service reviews independently, then Claude synthesizes the consensus.
Why multi-model? Each model has blind spots. Points raised by 2+ independent reviewers are high-signal; unique catches from each model add coverage you'd otherwise miss.
Recommended stack ($30/month flat)
| Service | Cost | Strength |
|---|---|---|
| Claude Code Review (this workflow) | Included in Anthropic plan | Deep reasoning, codebase-aware |
| Gemini Code Assist | $0 (included in Google Workspace) | Independent LLM, different training data |
| Greptile | ~$30/month flat | Cross-file context, dependency graphs |
Alternative: CodeRabbit Pro ($15/dev/month) adds interactive Q&A and sequence diagrams.
Setup
Step 1: Install Gemini Code Assist
- GitHub Marketplace → search "Gemini Code Assist"
- Install and authorize on your repo
- Gemini will automatically review new PRs (posts as
gemini-code-assist[bot]) - Optional config via
.gemini/config.yaml:code_review: comment_severity_threshold: MEDIUM max_comments_per_review: 20
Step 2: Install Greptile
- greptile.com → connect GitHub account
- Select your repo — Greptile indexes the codebase (~5 min)
- Configure in dashboard: target branches, focus paths
- Reviews post as
greptile[bot]comments on PRs
Step 3: Enable synthesis job
In claude-code-review.yml, remove false && from the synthesis job condition:
# Before (disabled):
if: |
false &&
(github.event_name == 'pull_request' ...
# After (enabled):
if: |
(github.event_name == 'pull_request' ...
Step 4: Configure CodeRabbit (optional)
Copy .coderabbit.yaml from this directory to your repo root. Edit path_instructions to match your stack.
How the synthesis works
The multi-reviewer-synthesis job in claude-code-review.yml:
- Waits 5 minutes after the Claude review (external bots post within 2-3 min)
- Collects all reviews and comments via GitHub API
- Skips silently if fewer than 2 reviewers have posted
- Claude identifies consensus (same finding flagged by 2+ reviewers) vs. unique catches
- Posts a structured synthesis comment on the PR
Files in this directory
examples/github-actions/
├── README.md # This file
├── claude-code-review.yml # Main review + optional synthesis job
├── .coderabbit.yaml # CodeRabbit config (copy to repo root)
├── claude-pr-auto-review.yml # Inline prompt auto-review (alternative)
├── claude-security-review.yml # Security-focused scan
├── claude-issue-triage.yml # Issue triage workflow
└── prompts/
└── code-review.md # Externalized review prompt (copy to .github/prompts/)
Customization
Model Selection
Set CLAUDE_MODEL or claude-model parameter in workflows:
env:
CLAUDE_MODEL: claude-3-5-sonnet-20240620
Permissions
Each workflow declares minimal required permissions:
pull-requests: writefor PR reviewsissues: writefor issue triagecontents: readfor reading repository content
Adjust only if your organization requires stricter policies.
Scope Filtering
Use paths: filters to limit when workflows run:
on:
pull_request:
paths:
- 'src/**'
- '!docs/**'
Troubleshooting
No comments appear on PRs:
- Verify the Claude GitHub App is installed
- Check workflow has
pull-requests: writepermission
403 when applying labels:
- Ensure the job has
issues: writepermission - Verify
GITHUB_TOKENhas access to this repo
Anthropic API errors:
- Confirm
ANTHROPIC_API_KEYis set at repository level - Check the key is not expired
YAML syntax errors:
- Validate spacing: two spaces per nesting level, no tabs
- Use a YAML validator: yamllint.com
Advanced Usage
Combining Workflows
Run multiple workflows together for comprehensive automation:
- PR Review + Security Review on every PR
- Issue Triage + Auto-labeling for new issues
Custom Prompts
Edit the direct_prompt section in workflows to customize Claude's focus:
direct_prompt: |
Review this PR focusing on:
1. TypeScript type safety
2. React performance patterns
3. Accessibility compliance
4. Test coverage
Integration with Other Actions
Combine with existing workflows:
jobs:
tests:
runs-on: ubuntu-latest
steps:
- name: Run tests
run: npm test
claude-review:
needs: tests # Run after tests pass
runs-on: ubuntu-latest
steps:
- uses: anthropics/claude-code-action@main
# ...
Cost Considerations
These workflows consume Anthropic API credits:
- PR Review: ~$0.10-$0.50 per review (depending on diff size)
- Security Review: ~$0.20-$0.80 per scan
- Issue Triage: ~$0.05-$0.20 per issue
Tips to reduce costs:
- Use
paths:filters to skip docs/config changes - Set conditions:
if: github.event.pull_request.draft == false - Review logs and adjust model selection
Examples in This Directory
examples/github-actions/
├── README.md # This file
├── claude-code-review.yml # Prompt-based review + optional synthesis job
├── .coderabbit.yaml # CodeRabbit config (copy to repo root)
├── claude-pr-auto-review.yml # Inline prompt auto-review (alternative)
├── claude-security-review.yml # Security scanning workflow
├── claude-issue-triage.yml # Issue triage workflow
└── prompts/
└── code-review.md # Externalized review prompt (copy to .github/prompts/)
Resources
- Claude Code Documentation
- GitHub Actions Documentation
- Anthropic API Documentation
- Claude GitHub App
License
These workflows are provided as examples. Adapt them to your needs.