-
Notifications
You must be signed in to change notification settings - Fork 1.4k
Add Claude Code GitHub Workflow #636
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change | ||||||||
|---|---|---|---|---|---|---|---|---|---|---|
| @@ -0,0 +1,57 @@ | ||||||||||
| name: Claude Code Review | ||||||||||
|
|
||||||||||
| on: | ||||||||||
| pull_request: | ||||||||||
| types: [opened, synchronize] | ||||||||||
| # Optional: Only run on specific file changes | ||||||||||
| # paths: | ||||||||||
| # - "src/**/*.ts" | ||||||||||
| # - "src/**/*.tsx" | ||||||||||
| # - "src/**/*.js" | ||||||||||
| # - "src/**/*.jsx" | ||||||||||
|
|
||||||||||
| jobs: | ||||||||||
| claude-review: | ||||||||||
| # Optional: Filter by PR author | ||||||||||
| # if: | | ||||||||||
| # github.event.pull_request.user.login == 'external-contributor' || | ||||||||||
| # github.event.pull_request.user.login == 'new-developer' || | ||||||||||
| # github.event.pull_request.author_association == 'FIRST_TIME_CONTRIBUTOR' | ||||||||||
|
|
||||||||||
| runs-on: ubuntu-latest | ||||||||||
| permissions: | ||||||||||
| contents: read | ||||||||||
| pull-requests: read | ||||||||||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Important: The prompt instructs Claude to use While this may work if the action uses the Claude GitHub App token, it could fail with confusing errors if it uses the workflow token. Consider either:
|
||||||||||
| issues: read | ||||||||||
| id-token: write | ||||||||||
|
|
||||||||||
| steps: | ||||||||||
| - name: Checkout repository | ||||||||||
| uses: actions/checkout@v4 | ||||||||||
| with: | ||||||||||
| fetch-depth: 1 | ||||||||||
|
|
||||||||||
| - name: Run Claude Code Review | ||||||||||
| id: claude-review | ||||||||||
| uses: anthropics/claude-code-action@v1 | ||||||||||
| with: | ||||||||||
| anthropic_api_key: ${{ secrets.ANTHROPIC_API_KEY }} | ||||||||||
| prompt: | | ||||||||||
| REPO: ${{ github.repository }} | ||||||||||
| PR NUMBER: ${{ github.event.pull_request.number }} | ||||||||||
|
|
||||||||||
| Please review this pull request and provide feedback on: | ||||||||||
| - Code quality and best practices | ||||||||||
| - Potential bugs or issues | ||||||||||
| - Performance considerations | ||||||||||
| - Security concerns | ||||||||||
| - Test coverage | ||||||||||
|
|
||||||||||
| Use the repository's CLAUDE.md for guidance on style and conventions. Be constructive and helpful in your feedback. | ||||||||||
|
|
||||||||||
| Use `gh pr comment` with your Bash tool to leave your review as a comment on the PR. | ||||||||||
|
|
||||||||||
| # See https://github.com/anthropics/claude-code-action/blob/main/docs/usage.md | ||||||||||
| # or https://docs.claude.com/en/docs/claude-code/cli-reference for available options | ||||||||||
|
Comment on lines
+54
to
+55
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Consider updating the documentation references to point to action-specific docs first:
Suggested change
The current link to docs.claude.com may be less specific for GitHub Action usage. |
||||||||||
| claude_args: '--allowed-tools "Bash(gh issue view:*),Bash(gh search:*),Bash(gh issue list:*),Bash(gh pr comment:*),Bash(gh pr diff:*),Bash(gh pr view:*),Bash(gh pr list:*)"' | ||||||||||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Critical: The flag name is incorrect. Should be This will cause the tool restrictions to be ignored, potentially allowing Claude to use unintended tools or preventing it from using necessary ones.
Suggested change
See docs/usage.md and docs/configuration.md for correct syntax. |
||||||||||
|
|
||||||||||
| Original file line number | Diff line number | Diff line change | ||||
|---|---|---|---|---|---|---|
|
|
@@ -23,9 +23,10 @@ jobs: | |||||
| pull-requests: read | ||||||
| issues: read | ||||||
| id-token: write | ||||||
| actions: read # Required for Claude to read CI results on PRs | ||||||
| steps: | ||||||
| - name: Checkout repository | ||||||
| uses: actions/checkout@v5 | ||||||
| uses: actions/checkout@v4 | ||||||
| with: | ||||||
| fetch-depth: 1 | ||||||
|
|
||||||
|
|
@@ -34,6 +35,16 @@ jobs: | |||||
| uses: anthropics/claude-code-action@v1 | ||||||
| with: | ||||||
| anthropic_api_key: ${{ secrets.ANTHROPIC_API_KEY }} | ||||||
| claude_args: | | ||||||
| --allowedTools "Bash(bun install),Bash(bun test:*),Bash(bun run format),Bash(bun typecheck)" | ||||||
| --model "claude-opus-4-1-20250805" | ||||||
|
|
||||||
| # This is an optional setting that allows Claude to read CI results on PRs | ||||||
| additional_permissions: | | ||||||
| actions: read | ||||||
|
|
||||||
| # Optional: Give a custom prompt to Claude. If this is not specified, Claude will perform the instructions specified in the comment that tagged it. | ||||||
| # prompt: 'Update the pull request description to include a summary of changes.' | ||||||
|
|
||||||
| # Optional: Add claude_args to customize behavior and configuration | ||||||
| # See https://github.com/anthropics/claude-code-action/blob/main/docs/usage.md | ||||||
| # or https://docs.claude.com/en/docs/claude-code/cli-reference for available options | ||||||
| # claude_args: '--allowed-tools Bash(gh pr:*)' | ||||||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Consistency issue: The example uses the same incorrect flag name (
Suggested change
This ensures developers copying this example use the correct syntax. |
||||||
|
|
||||||
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Performance concern: This workflow runs unconditionally on every PR opened/updated, which could result in high costs in active repositories.
Consider adding path filters or conditional logic:
Or add a job-level condition:
Also consider adding concurrency controls to cancel older runs: