Back to Workflow & Productivity

code-review-excellence

code reviewsoftware qualitydevelopment workflowteam collaborationfeedbackbest practicesmentoringdevops
⭐ 36.8kπŸ“„ MITπŸ•’ 2026-06-16Source β†—

Install this skill

npx skills add wshobson/agents

Works across Claude Code, Cursor, Codex, Copilot & Antigravity

The code-review-excellence skill shifts the focus of pull request evaluations from surface-level gatekeeping to a collaborative, educational process. Instead of treating reviews as mere error-spotting, this skill guides you through a structured, multi-phase assessment. You begin by gathering context, move into high-level architectural evaluation, and conclude with specific, actionable feedback that avoids subjective nitpicking. By employing questioning techniques rather than dictatorial commands, this skill helps improve overall code maintainability, security, and performance. It emphasizes identifying logic gaps and architectural flaws while delegating trivial formatting tasks to automated tools. This methodical approach fosters a culture of technical growth, ensuring that every review cycle serves as an opportunity for team knowledge sharing and long-term codebase health rather than simply a barrier to merging new features.

When to Use This Skill

  • β€’Onboarding junior developers through detailed, educational feedback cycles
  • β€’Standardizing PR expectations across distributed engineering squads
  • β€’Performing deep-dive architectural assessments on large feature branches
  • β€’Reducing the feedback loop duration by prioritizing high-impact logic flaws

How to Invoke This Skill

Example prompts that trigger this skill in Claude Code, Cursor, or Antigravity:

  • β€œReview this pull request and provide constructive feedback
  • β€œHelp me audit this code for security vulnerabilities
  • β€œCritique my implementation approach for architectural consistency
  • β€œDraft a set of review comments that prioritize learning
  • β€œHow can I suggest improvements without sounding judgmental?
  • β€œCheck this branch against our performance and security standards

Pro Tips

  • πŸ’‘**Prioritize Feedback**: Focus on critical issues (bugs, security, architecture) first, addressing minor suggestions or style preferences afterwards or via automated tools.
  • πŸ’‘**Frame Feedback as Questions**: Instead of declarative statements like 'This is wrong,' ask 'Have you considered X?' or 'What happens if Y occurs?' to encourage critical thinking and learning.
  • πŸ’‘**Balance Praise and Critique**: Always acknowledge good solutions, well-written sections, or effective problem-solving to maintain morale and reinforce positive coding habits.

What this skill does

  • β€’Conducts structured multi-phase PR analysis covering architecture, security, and performance
  • β€’Translates subjective feedback into objective, actionable questions
  • β€’Categorizes issues into critical blockers versus optional, non-blocking suggestions
  • β€’Enforces separation between automated linting concerns and manual logic verification
  • β€’Provides templates for evaluating security vulnerabilities and test coverage

When not to use it

  • βœ•When immediate, high-priority hotfixes require bypassing standard peer review
  • βœ•For projects lacking automated linters or CI/CD pipelines where manual formatting checks are still necessary

Example workflow

  1. Review the linked issue and PR description for context
  2. Assess if the PR size is manageable; request splitting if it exceeds 400 lines
  3. Perform a high-level scan of the architectural design and file organization
  4. Analyze code logic line-by-line for edge cases and security risks
  5. Generate a summary response using collaborative, inquiry-based language
  6. Apply appropriate status labels like Approved or Request Changes

Prerequisites

  • –Active pull request or branch to review
  • –Existing automated linter (Prettier/Black) in the repository
  • –Defined team coding standards

Pitfalls & limitations

  • !Over-commenting on trivial formatting that should be handled by automation
  • !Focusing on developer style preferences rather than functional correctness
  • !Providing overly vague feedback like 'this looks wrong' without justification

FAQ

Should I manually check for code style issues?
No, manual review time is best spent on logic, security, and architecture. Use automated linters for formatting and import ordering.
What is the best way to request a change without causing friction?
Use the question approach. Instead of demanding a change, ask how the code should handle a specific edge case or performance scenario.
When is a PR too large to review effectively?
PRs exceeding 400 lines often indicate a lack of focus. It is best to ask the author to break these into smaller, logical chunks.
How do I balance praise with critique?
Always highlight what works well before addressing issues. Balanced feedback ensures the author remains receptive to learning rather than feeling discouraged.

How it compares

Generic prompts often focus on basic error hunting; this skill structures the review process into a professional, growth-oriented workflow that treats the reviewer as a mentor.

Source & trust

⭐ 37k starsπŸ“„ MITπŸ•’ Updated 2026-06-16
πŸ“„ Full skill instructions β€” original source: wshobson/agents
# Code Review Excellence

Transform code reviews from gatekeeping to knowledge sharing through constructive feedback, systematic analysis, and collaborative improvement.

## When to Use This Skill

- Reviewing pull requests and code changes
- Establishing code review standards for teams
- Mentoring junior developers through reviews
- Conducting architecture reviews
- Creating review checklists and guidelines
- Improving team collaboration
- Reducing code review cycle time
- Maintaining code quality standards

## Core Principles

### 1. The Review Mindset

**Goals of Code Review:**

- Catch bugs and edge cases
- Ensure code maintainability
- Share knowledge across team
- Enforce coding standards
- Improve design and architecture
- Build team culture

**Not the Goals:**

- Show off knowledge
- Nitpick formatting (use linters)
- Block progress unnecessarily
- Rewrite to your preference

### 2. Effective Feedback

**Good Feedback is:**

- Specific and actionable
- Educational, not judgmental
- Focused on the code, not the person
- Balanced (praise good work too)
- Prioritized (critical vs nice-to-have)

❌ Bad: "This is wrong."
βœ… Good: "This could cause a race condition when multiple users
access simultaneously. Consider using a mutex here."

❌ Bad: "Why didn't you use X pattern?"
βœ… Good: "Have you considered the Repository pattern? It would
make this easier to test. Here's an example: [link]"

❌ Bad: "Rename this variable."
βœ… Good: "[nit] Consider userCount instead of uc for
clarity. Not blocking if you prefer to keep it."


### 3. Review Scope

**What to Review:**

- Logic correctness and edge cases
- Security vulnerabilities
- Performance implications
- Test coverage and quality
- Error handling
- Documentation and comments
- API design and naming
- Architectural fit

**What Not to Review Manually:**

- Code formatting (use Prettier, Black, etc.)
- Import organization
- Linting violations
- Simple typos

## Review Process

### Phase 1: Context Gathering (2-3 minutes)

Before diving into code, understand:

1. Read PR description and linked issue
2. Check PR size (>400 lines? Ask to split)
3. Review CI/CD status (tests passing?)
4. Understand the business requirement
5. Note any relevant architectural decisions


### Phase 2: High-Level Review (5-10 minutes)

1. **Architecture & Design**
- Does the solution fit the problem?
- Are there simpler approaches?
- Is it consistent with existing patterns?
- Will it scale?

2. **File Organization**
- Are new files in the right places?
- Is code grouped logically?
- Are there duplicate files?

3. **Testing Strategy**
- Are there tests?
- Do tests cover edge cases?
- Are tests readable?


### Phase 3: Line-by-Line Review (10-20 minutes)

For each file:

1. **Logic & Correctness**
- Edge cases handled?
- Off-by-one errors?
- Null/undefined checks?
- Race conditions?

2. **Security**
- Input validation?
- SQL injection risks?
- XSS vulnerabilities?
- Sensitive data exposure?

3. **Performance**
- N+1 queries?
- Unnecessary loops?
- Memory leaks?
- Blocking operations?

4. **Maintainability**
- Clear variable names?
- Functions doing one thing?
- Complex code commented?
- Magic numbers extracted?


### Phase 4: Summary & Decision (2-3 minutes)

1. Summarize key concerns
2. Highlight what you liked
3. Make clear decision:
- βœ… Approve
- πŸ’¬ Comment (minor suggestions)
- πŸ”„ Request Changes (must address)
4. Offer to pair if complex


## Review Techniques

### Technique 1: The Checklist Method

## Security Checklist

- [ ] User input validated and sanitized
- [ ] SQL queries use parameterization
- [ ] Authentication/authorization checked
- [ ] Secrets not hardcoded
- [ ] Error messages don't leak info

## Performance Checklist

- [ ] No N+1 queries
- [ ] Database queries indexed
- [ ] Large lists paginated
- [ ] Expensive operations cached
- [ ] No blocking I/O in hot paths

## Testing Checklist

- [ ] Happy path tested
- [ ] Edge cases covered
- [ ] Error cases tested
- [ ] Test names are descriptive
- [ ] Tests are deterministic


### Technique 2: The Question Approach

Instead of stating problems, ask questions to encourage thinking:

❌ "This will fail if the list is empty."
βœ… "What happens if items is an empty array?"

❌ "You need error handling here."
βœ… "How should this behave if the API call fails?"

❌ "This is inefficient."
βœ… "I see this loops through all users. Have we considered
the performance impact with 100k users?"


### Technique 3: Suggest, Don't Command

## Use Collaborative Language

❌ "You must change this to use async/await"
βœ… "Suggestion: async/await might make this more readable:
typescript
async function fetchUser(id: string) {
const user = await db.query('SELECT * FROM users WHERE id = ?', id);
return user;
}

What do you think?"

❌ "Extract this into a function"
βœ… "This logic appears in 3 places. Would it make sense to
extract it into a shared utility function?"


### Technique 4: Differentiate Severity

Use labels to indicate priority:

πŸ”΄ [blocking] - Must fix before merge
🟑 [important] - Should fix, discuss if disagree
🟒 [nit] - Nice to have, not blocking
πŸ’‘ [suggestion] - Alternative approach to consider
πŸ“š [learning] - Educational comment, no action needed
πŸŽ‰ [praise] - Good work, keep it up!

Example:
"πŸ”΄ [blocking] This SQL query is vulnerable to injection.
Please use parameterized queries."

"🟒 [nit] Consider renaming data to userData for clarity."

"πŸŽ‰ [praise] Excellent test coverage! This will catch edge cases."


## Language-Specific Patterns

### Python Code Review

# Check for Python-specific issues

# ❌ Mutable default arguments
def add_item(item, items=[]): # Bug! Shared across calls
items.append(item)
return items

# βœ… Use None as default
def add_item(item, items=None):
if items is None:
items = []
items.append(item)
return items

# ❌ Catching too broad
try:
result = risky_operation()
except: # Catches everything, even KeyboardInterrupt!
pass

# βœ… Catch specific exceptions
try:
result = risky_operation()
except ValueError as e:
logger.error(f"Invalid value: {e}")
raise

# ❌ Using mutable class attributes
class User:
permissions = [] # Shared across all instances!

# βœ… Initialize in __init__
class User:
def __init__(self):
self.permissions = []


### TypeScript/JavaScript Code Review

// Check for TypeScript-specific issues

// ❌ Using any defeats type safety
function processData(data: any) { // Avoid any
return data.value;
}

// βœ… Use proper types
interface DataPayload {
value: string;
}
function processData(data: DataPayload) {
return data.value;
}

// ❌ Not handling async errors
async function fetchUser(id: string) {
const response = await fetch(/api/users/${id});
return response.json(); // What if network fails?
}

// βœ… Handle errors properly
async function fetchUser(id: string): Promise<User> {
try {
const response = await fetch(/api/users/${id});
if (!response.ok) {
throw new Error(HTTP ${response.status});
}
return await response.json();
} catch (error) {
console.error('Failed to fetch user:', error);
throw error;
}
}

// ❌ Mutation of props
function UserProfile({ user }: Props) {
user.lastViewed = new Date(); // Mutating prop!
return <div>{user.name}</div>;
}

// βœ… Don't mutate props
function UserProfile({ user, onView }: Props) {
useEffect(() => {
onView(user.id); // Notify parent to update
}, [user.id]);
return <div>{user.name}</div>;
}


## Advanced Review Patterns

### Pattern 1: Architectural Review

When reviewing significant changes:

1. **Design Document First**
- For large features, request design doc before code
- Review design with team before implementation
- Agree on approach to avoid rework

2. **Review in Stages**
- First PR: Core abstractions and interfaces
- Second PR: Implementation
- Third PR: Integration and tests
- Easier to review, faster to iterate

3. **Consider Alternatives**
- "Have we considered using [pattern/library]?"
- "What's the tradeoff vs. the simpler approach?"
- "How will this evolve as requirements change?"


### Pattern 2: Test Quality Review

// ❌ Poor test: Implementation detail testing
test('increments counter variable', () => {
const component = render(<Counter />);
const button = component.getByRole('button');
fireEvent.click(button);
expect(component.state.counter).toBe(1); // Testing internal state
});

// βœ… Good test: Behavior testing
test('displays incremented count when clicked', () => {
render(<Counter />);
const button = screen.getByRole('button', { name: /increment/i });
fireEvent.click(button);
expect(screen.getByText('Count: 1')).toBeInTheDocument();
});

// Review questions for tests:
// - Do tests describe behavior, not implementation?
// - Are test names clear and descriptive?
// - Do tests cover edge cases?
// - Are tests independent (no shared state)?
// - Can tests run in any order?


### Pattern 3: Security Review

## Security Review Checklist

### Authentication & Authorization

- [ ] Is authentication required where needed?
- [ ] Are authorization checks before every action?
- [ ] Is JWT validation proper (signature, expiry)?
- [ ] Are API keys/secrets properly secured?

### Input Validation

- [ ] All user inputs validated?
- [ ] File uploads restricted (size, type)?
- [ ] SQL queries parameterized?
- [ ] XSS protection (escape output)?

### Data Protection

- [ ] Passwords hashed (bcrypt/argon2)?
- [ ] Sensitive data encrypted at rest?
- [ ] HTTPS enforced for sensitive data?
- [ ] PII handled according to regulations?

### Common Vulnerabilities

- [ ] No eval() or similar dynamic execution?
- [ ] No hardcoded secrets?
- [ ] CSRF protection for state-changing operations?
- [ ] Rate limiting on public endpoints?


## Giving Difficult Feedback

### Pattern: The Sandwich Method (Modified)

Traditional: Praise + Criticism + Praise (feels fake)

Better: Context + Specific Issue + Helpful Solution

Example:
"I noticed the payment processing logic is inline in the
controller. This makes it harder to test and reuse.

[Specific Issue]
The calculateTotal() function mixes tax calculation,
discount logic, and database queries, making it difficult
to unit test and reason about.

[Helpful Solution]
Could we extract this into a PaymentService class? That
would make it testable and reusable. I can pair with you
on this if helpful."


### Handling Disagreements

When author disagrees with your feedback:

1. **Seek to Understand**
"Help me understand your approach. What led you to
choose this pattern?"

2. **Acknowledge Valid Points**
"That's a good point about X. I hadn't considered that."

3. **Provide Data**
"I'm concerned about performance. Can we add a benchmark
to validate the approach?"

4. **Escalate if Needed**
"Let's get [architect/senior dev] to weigh in on this."

5. **Know When to Let Go**
If it's working and not a critical issue, approve it.
Perfection is the enemy of progress.


## Best Practices

1. **Review Promptly**: Within 24 hours, ideally same day
2. **Limit PR Size**: 200-400 lines max for effective review
3. **Review in Time Blocks**: 60 minutes max, take breaks
4. **Use Review Tools**: GitHub, GitLab, or dedicated tools
5. **Automate What You Can**: Linters, formatters, security scans
6. **Build Rapport**: Emoji, praise, and empathy matter
7. **Be Available**: Offer to pair on complex issues
8. **Learn from Others**: Review others' review comments

## Common Pitfalls

- **Perfectionism**: Blocking PRs for minor style preferences
- **Scope Creep**: "While you're at it, can you also..."
- **Inconsistency**: Different standards for different people
- **Delayed Reviews**: Letting PRs sit for days
- **Ghosting**: Requesting changes then disappearing
- **Rubber Stamping**: Approving without actually reviewing
- **Bike Shedding**: Debating trivial details extensively

## Templates

### PR Review Comment Template

## Summary

[Brief overview of what was reviewed]

## Strengths

- [What was done well]
- [Good patterns or approaches]

## Required Changes

πŸ”΄ [Blocking issue 1]
πŸ”΄ [Blocking issue 2]

## Suggestions

πŸ’‘ [Improvement 1]
πŸ’‘ [Improvement 2]

## Questions

❓ [Clarification needed on X]
❓ [Alternative approach consideration]

## Verdict

βœ… Approve after addressing required changes


## Resources

- **references/code-review-best-practices.md**: Comprehensive review guidelines
- **references/common-bugs-checklist.md**: Language-specific bugs to watch for
- **references/security-review-guide.md**: Security-focused review checklist
- **assets/pr-review-template.md**: Standard review comment template
- **assets/review-checklist.md**: Quick reference checklist
- **scripts/pr-analyzer.py**: Analyze PR complexity and suggest reviewers

How to Use This Skill Unit

Option A: Project-Specific (Recommended)

  1. Click "Download" above
  2. In your project, create the directory: .agent/skills/code-review-excellence/
  3. Save the file as SKILL.md
  4. The agent will automatically discover the skill based on its description.

Option B: Global Installation (All Agents)

Save the file to these locations to make it available across all projects:

  • Claude Code: ~/.claude/skills/wshobson/agents/code-review-excellence/SKILL.md
  • Cursor: ~/.cursor/skills/wshobson/agents/code-review-excellence/SKILL.md
  • Antigravity: ~/.gemini/antigravity/skills/wshobson/agents/code-review-excellence/SKILL.md

πŸš€ Install with CLI:
npx skills add wshobson/agents

Read the Master Guide: Mastering Agent Skills β†’

Recommended Rules

View more rules β†’

Recommended Workflows

View more workflows β†’

Recommended MCP Servers

View more MCP servers β†’

Take It Further

Maximize your productivity with these powerful resources

πŸ“‹

Define Your Standards

Set up coding standards to ensure this workflow produces consistent, high-quality results.

Browse Rules Library
πŸ“–

Master Workflows

Learn how to create custom workflows, use Turbo Mode, and build your automation library.

Complete Guide

How to use this Skill in Claude Code & Cursor

For Claude Code (CLI)

To use this skill in Claude Code, copy the rule content into your project's custom instructions or follow our Add-Skill CLI guide. This ensures Claude follows your standards during every code generation.

For Cursor & Windsurf

For Cursor or Windsurf, individual skills are best used in the "Rules for AI" section. This specific unit helps the agent avoid workflow & productivity issues, leading to cleaner, more efficient code.

Why the skill format matters: the standardized Agent Skills format lets your AI agent load detailed instructions only when they are relevant, keeping your prompt clean while improving results.

Source & attribution

This skill is categorized under Workflow & Productivity and is published by W. Shobson, maintained in wshobson/agents.

← Browse All Agent Skills
Sponsored AI assistant. Recommendations may be paid.