npx skills add https://github.com/duongdev/ccpm --skill ccpm-debuggingSKILL.md
CCPM Debugging
Systematic debugging with Linear integration and structured troubleshooting workflow.
When to Use
This skill auto-activates when:
- User mentions: "error", "failing", "broken", "debug", "bug", "issue"
- Running
/ccpm:verifycommand - Tests failing during
/ccpm:verify - Build errors during implementation
- Runtime errors or exceptions
- Unexpected behavior
Core Debugging Philosophy
Defense-in-Depth Approach
Multiple layers of investigation:
- Symptoms - What's observable?
- Immediate cause - What directly caused the error?
- Root cause - Why did it happen?
- Systemic issues - Could this happen elsewhere?
- Prevention - How to prevent recurrence?
Systematic Process
Observe → Hypothesize → Test → Confirm → Fix → Verify → Document
Never skip steps. Each step builds on the previous.
Integration with CCPM
Use with /ccpm:verify
When verification fails, this skill provides structured debugging:
User: "/ccpm:verify AUTH-123"
Claude: [ccpm-debugging activates]
Starting systematic debugging for AUTH-123...
Step 1: GATHER SYMPTOMS
Running /ccpm:verify to collect error information...
Found failures:
- 3 failing tests
- 1 TypeScript compilation error
- 0 linting errors
Step 2: ANALYZE FAILURES
Test failures:
1. test/auth/login.test.ts:45
❌ "should handle invalid credentials"
Expected: 401 Unauthorized
Actual: 500 Internal Server Error
2. test/auth/jwt.test.ts:78
❌ "should refresh expired tokens"
Error: Cannot read property 'id' of undefined
3. test/api/protected.test.ts:23
❌ "should reject missing tokens"
Timeout: Request exceeded 5000ms
TypeScript error:
src/auth/jwt.ts:45:12
- error TS2345: Argument of type 'string | undefined' is not assignable to parameter of type 'string'
Step 3: FORM HYPOTHESES
Hypothesis 1: JWT token handling has type safety issue (TS error)
Hypothesis 2: Error handling missing (test 1 shows 500 instead of 401)
Hypothesis 3: Token refresh logic has null reference bug (test 2)
Hypothesis 4: Protected route timeout suggests authentication middleware hanging (test 3)
Step 4: TEST HYPOTHESES
[Proceeds with systematic testing...]
Step 5: UPDATE LINEAR
Adding debugging findings to AUTH-123...
Linear Integration
Automatic Linear updates during debugging:
// After each debugging step
Linear.addComment(taskId, {
title: "Debugging Progress",
content: `
## Symptoms
- 3 failing tests (login, jwt, protected routes)
- TypeScript type error in jwt.ts:45
## Root Cause
Missing null check before accessing user.id in token refresh
## Fix Applied
Added null guard and proper error handling
## Verification
Re-running tests...
`
});
Blocker Logging
When encountering blockers:
Claude: [ccpm-debugging detects blocker]
Found BLOCKER: Redis connection failing in staging
Adding blocker to Linear AUTH-123:
---
🚫 BLOCKER: Redis Connection Issue
Environment: Staging
Error: ECONNREFUSED 127.0.0.1:6379
Impact: Cannot test session management
Investigation:
- Redis service not running in staging
- Docker compose missing Redis container
- Connection string using localhost instead of service name
Temporary workaround:
- Skip Redis-dependent tests in staging
- Test locally with Docker
Resolution needed:
- Update staging docker-compose.yml
- Fix Redis service configuration
---
Blocker logged. Continuing with fixable issues...
Debugging Strategies
Strategy 1: Error Message Analysis
Read error messages carefully:
Error: Cannot read property 'id' of undefined
Analysis:
1. What's undefined? → Some object
2. What property? → 'id'
3. Where? → Line number in stack trace
4. When? → During what operation?
Investigation:
- Check stack trace for call site
- Identify which object is undefined
- Trace back to why it's undefined
- Find where it should be defined
Strategy 2: Reproduce Minimally
Create minimal reproduction:
Full test failing:
- 100 lines of setup
- Multiple database calls
- Complex state management
Minimal reproduction:
- 10 lines
- Mock database
- Isolated function call
Result: Easier to identify exact issue
Strategy 3: Binary Search
For intermittent or complex issues:
Problem: Feature works sometimes, fails other times
Binary search approach:
1. Identify working commit (git bisect start)
2. Test middle commit
3. Mark as good or bad
4. Repeat until culprit commit found
Result: Exact commit that introduced bug
Strategy 4: Rubber Duck Debugging
Explain the problem out loud:
User: "I don't understand why this is failing"
Claude: [ccpm-debugging activates]
Let's walk through this step by step:
1. What are you trying to do?
→ "Log in a user with JWT"
2. What do you expect to happen?
→ "Return 200 with token"
3. What actually happens?
→ "Returns 500 error"
4. What's different between expectation and reality?
→ "Erro
...
Repository
duongdev/ccpmParent repository
Repository Stats
Stars6
Forks1
LicenseMIT License