acc-bug-fix-knowledge
1
总安装量
1
周安装量
#50456
全站排名
安装命令
npx skills add https://github.com/dykyi-roman/awesome-claude-code --skill acc-bug-fix-knowledge
Agent 安装分布
opencode
1
claude-code
1
Skill 文档
Bug Fix Knowledge Base
Comprehensive knowledge for diagnosing and fixing bugs in PHP applications following DDD, CQRS, and Clean Architecture patterns.
Bug Categories and Symptoms
1. Logic Errors
Symptoms:
- Incorrect output for valid input
- Wrong branch taken in conditionals
- Inverted boolean logic
- Off-by-one errors in loops
- Missing edge case handling
Common Causes:
>instead of>=,&&instead of||- Negation errors (
!$conditionvs$condition) - Loop boundary mistakes (
< countvs<= count) - Missing
breakin switch statements
Fix Pattern:
// Before: Logic error
if ($amount > $limit) { // Should be >=
throw new LimitExceededException();
}
// After: Fixed
if ($amount >= $limit) {
throw new LimitExceededException();
}
2. Null Pointer Issues
Symptoms:
- “Call to a member function on null”
- “Cannot access property on null”
- Unexpected null returns
- Missing null checks after optional operations
Common Causes:
- Repository returning null for non-existent entity
- Optional relationships not checked
- Nullable parameters not validated
- Method chaining on potentially null objects
Fix Pattern:
// Before: Null pointer risk
$user = $this->userRepository->find($id);
$email = $user->getEmail(); // Crashes if user is null
// After: Safe with null check
$user = $this->userRepository->find($id);
if ($user === null) {
throw new UserNotFoundException($id);
}
$email = $user->getEmail();
// Alternative: Null coalescing
$email = $user?->getEmail() ?? throw new UserNotFoundException($id);
3. Boundary Issues
Symptoms:
- Array index out of bounds
- Empty collection access
- String index errors
- Numeric overflow/underflow
Common Causes:
- Accessing first/last element without checking emptiness
- Loop index exceeding array size
- Integer overflow in calculations
- Missing bounds validation
Fix Pattern:
// Before: Boundary issue
$firstItem = $items[0]; // Crashes if empty
// After: Safe boundary check
if ($items === []) {
throw new EmptyCollectionException('items');
}
$firstItem = $items[0];
// Alternative: Using first() with default
$firstItem = $items[0] ?? throw new EmptyCollectionException('items');
4. Race Conditions
Symptoms:
- Intermittent failures
- Data corruption under load
- Lost updates
- Duplicate records
Common Causes:
- Check-then-act without locking
- Shared mutable state
- Missing database transactions
- Concurrent file access
Fix Pattern:
// Before: Race condition
if (!$this->repository->exists($id)) {
$this->repository->save($entity); // Another process might insert between check and save
}
// After: Atomic operation with locking
$this->lockManager->acquire("entity:$id");
try {
if (!$this->repository->exists($id)) {
$this->repository->save($entity);
}
} finally {
$this->lockManager->release("entity:$id");
}
// Alternative: Database-level uniqueness
// Use UNIQUE constraint + INSERT ... ON DUPLICATE KEY
5. Resource Leaks
Symptoms:
- Memory exhaustion over time
- “Too many open files”
- Database connection pool exhaustion
- Slow performance degradation
Common Causes:
- Unclosed file handles
- Missing database connection release
- Event listeners not removed
- Circular references preventing GC
Fix Pattern:
// Before: Resource leak
$handle = fopen($path, 'r');
$content = fread($handle, filesize($path));
// Missing fclose()
// After: Proper resource management
$handle = fopen($path, 'r');
try {
$content = fread($handle, filesize($path));
} finally {
fclose($handle);
}
// Better: Use high-level functions
$content = file_get_contents($path);
6. Exception Handling Issues
Symptoms:
- Silent failures
- Generic error messages
- Lost exception context
- Swallowed exceptions
Common Causes:
- Empty catch blocks
- Catching too broad exception types
- Not re-throwing after logging
- Missing exception chaining
Fix Pattern:
// Before: Swallowed exception
try {
$this->service->process($data);
} catch (Exception $e) {
// Silent failure - bug hidden
}
// After: Proper exception handling
try {
$this->service->process($data);
} catch (ValidationException $e) {
throw new ProcessingFailedException(
"Failed to process data: {$e->getMessage()}",
previous: $e
);
}
7. Type Issues
Symptoms:
- “Type error: Argument must be of type X, Y given”
- Unexpected type coercion
- String/int confusion
- Array/object mismatch
Common Causes:
- Missing strict_types declaration
- Implicit type casting
- Mixed types from external sources
- Legacy code without type hints
Fix Pattern:
// Before: Type issue
function calculate($amount) { // No type hint
return $amount * 1.1; // Fails if string passed
}
// After: Strict typing
declare(strict_types=1);
function calculate(float $amount): float {
return $amount * 1.1;
}
8. SQL Injection
Symptoms:
- Security vulnerabilities
- Unexpected query results
- Data corruption
- Authentication bypass
Common Causes:
- String concatenation in queries
- Missing parameter binding
- Unvalidated user input in queries
- Dynamic table/column names
Fix Pattern:
// Before: SQL injection vulnerability
$query = "SELECT * FROM users WHERE email = '$email'";
// After: Parameterized query
$query = "SELECT * FROM users WHERE email = :email";
$stmt = $pdo->prepare($query);
$stmt->execute(['email' => $email]);
9. Infinite Loops
Symptoms:
- Application hangs
- 100% CPU usage
- Request timeouts
- Memory exhaustion
Common Causes:
- Missing or unreachable exit condition
- Iterator not advancing
- Recursive call without base case
- Circular dependencies in processing
Fix Pattern:
// Before: Potential infinite loop
while ($item = $queue->pop()) {
$this->process($item);
// If process() adds items back to queue, infinite loop
}
// After: Safe with limit
$maxIterations = 10000;
$iterations = 0;
while ($item = $queue->pop()) {
if (++$iterations > $maxIterations) {
throw new MaxIterationsExceededException($maxIterations);
}
$this->process($item);
}
Minimal Intervention Principles
1. Single Responsibility Fix
- Fix ONLY the bug, nothing else
- No refactoring while fixing
- No “while I’m here” improvements
- Keep the diff minimal
2. Preserve Behavior
- Existing tests must pass
- API contracts must not change
- Side effects must be preserved (if intentional)
- Error messages format should match
3. Backward Compatibility
- Public method signatures unchanged
- Return types unchanged
- Exception types unchanged
- Event payloads unchanged
4. Test First
- Write failing test that reproduces bug
- Fix should make test pass
- No fix without reproduction test
Fix Validation Checklist
Before applying a fix, verify:
-
Reproduction Test Exists
- Test fails without fix
- Test passes with fix
- Test covers edge cases
-
Minimal Change
- Only affected code changed
- No unrelated refactoring
- No formatting changes
-
No Regressions
- All existing tests pass
- No new warnings
- Performance not degraded
-
Code Quality
- No new code smells
- SOLID principles respected
- DDD patterns maintained
-
Documentation
- PHPDoc updated if needed
- CHANGELOG entry added
- Issue linked in commit
DDD-Specific Bug Patterns
Domain Layer Bugs
- Value Object validation bypass
- Entity invariant violation
- Aggregate boundary crossing
- Domain Event lost
Application Layer Bugs
- Use Case not transactional
- Command/Query mixing
- Missing authorization check
- Event handler not idempotent
Infrastructure Layer Bugs
- Repository returning detached entity
- Cache invalidation missing
- Message not acknowledged
- Connection not released
Quick Reference: Fix by Error Message
| Error Message | Likely Bug | Quick Fix |
|---|---|---|
| “Call to member function on null” | Null pointer | Add null check |
| “Undefined array key” | Boundary issue | Check array_key_exists |
| “Type error: Argument X” | Type issue | Add type validation |
| “Maximum execution time” | Infinite loop | Add iteration limit |
| “Allowed memory exhausted” | Resource leak | Close resources in finally |
| “Integrity constraint violation” | Race condition | Add locking/transaction |
| “Cannot modify readonly property” | Immutability violation | Create new instance |