Notre avis
Fournit un workflow structuré pour implémenter des fonctionnalités en utilisant le développement piloté par les tests (TDD) et les principes SOLID dans le cadre du processus SDD.
Points forts
- Impose un cycle TDD rigoureux (Rouge-Vert-Refactor) pour un code fiable
- Favorise une architecture propre avec des exemples concrets pour chaque principe SOLID
- Intègre les processus SDD existants (vérifications de statut, documents de tâches)
- Fournit des exemples de code pour chaque principe SOLID
Limites
- Nécessite une configuration SDD préalable (spécifications, tâches, documents de conception), ce qui peut être lourd pour les petits projets
- L'invocation de commande (/sdd-implement) est spécifique à un environnement d'outil particulier (probablement Claude Code)
- Peut être trop normatif pour des équipes utilisant d'autres méthodologies
À utiliser lors de l'implémentation d'une nouvelle fonctionnalité dans un projet suivant déjà la méthodologie SDD et exigeant une adhésion stricte au TDD et aux principes SOLID.
À éviter pour les corrections rapides, le code expérimental ou les projets non structurés avec le flux de travail de spécification SDD.
Analyse de sécurité
SûrThe skill provides implementation guidelines, TDD and security best practices. It does not instruct the AI to perform any destructive or data-exfiltrating actions. No shell commands like curl|sh, rm -rf, or token leaks are included.
Aucun point d'attention détecté
Exemples
/sdd-implement user-authentication/sdd-implement payment-processingImplement the next task from the tasks.md for the user-profile feature following TDD and SOLID principles.name: sdd-implement description: Implementation guidelines for SDD workflow. Use when implementing features, applying TDD, checking security, or ensuring code quality. Invoked via /sdd-implement <feature-name>.
SDD Implementation Guidelines
Execute implementation following TDD methodology, SOLID principles, and security best practices.
Prerequisites
Before implementing:
- Tasks must be approved (use
sdd-statusto verify) - Review tasks in
.spec/specs/{feature}/tasks.md - Understand the design in
.spec/specs/{feature}/design.md
Implementation Workflow
Step 1: Load Context
- Use
sdd-statusMCP tool to verify all phases approved - Read the tasks document for current implementation
- Identify the next task to implement
Step 2: Execute TDD Cycle
For each task:
┌─────────────────────────────────────────────────────────────┐
│ 1. RED: Write Failing Test │
│ - Define expected behavior │
│ - Run test, confirm it FAILS │
│ │
│ 2. GREEN: Write Minimal Code │
│ - Just enough to pass the test │
│ - No extra features │
│ - Run test, confirm it PASSES │
│ │
│ 3. REFACTOR: Improve Code │
│ - Clean up without changing behavior │
│ - Run tests, confirm still PASSING │
│ │
│ REPEAT for each test case │
└─────────────────────────────────────────────────────────────┘
Step 3: Apply SOLID Principles
S - Single Responsibility Principle
// GOOD: One class, one job
class UserValidator {
validate(user: User): ValidationResult { ... }
}
class UserRepository {
save(user: User): Promise<void> { ... }
}
// BAD: Class doing too much
class UserManager {
validate(user: User) { ... }
save(user: User) { ... }
sendEmail(user: User) { ... }
generateReport() { ... }
}
O - Open/Closed Principle
// GOOD: Open for extension, closed for modification
interface PaymentProcessor {
process(amount: number): Promise<Result>;
}
class StripeProcessor implements PaymentProcessor { ... }
class PayPalProcessor implements PaymentProcessor { ... }
// BAD: Modifying existing code for new payment types
class PaymentService {
process(type: string, amount: number) {
if (type === 'stripe') { ... }
else if (type === 'paypal') { ... }
// Adding new type requires modifying this class
}
}
L - Liskov Substitution Principle
// GOOD: Subtypes are substitutable
class Bird {
move(): void { /* fly or walk */ }
}
class Sparrow extends Bird {
move(): void { this.fly(); }
}
class Penguin extends Bird {
move(): void { this.walk(); }
}
// BAD: Subtype breaks expected behavior
class Bird {
fly(): void { ... }
}
class Penguin extends Bird {
fly(): void { throw new Error("Can't fly!"); }
}
I - Interface Segregation Principle
// GOOD: Specific interfaces
interface Readable {
read(): Data;
}
interface Writable {
write(data: Data): void;
}
class FileHandler implements Readable, Writable { ... }
class ReadOnlyFile implements Readable { ... }
// BAD: Fat interface forcing unnecessary implementation
interface FileOperations {
read(): Data;
write(data: Data): void;
delete(): void;
execute(): void;
}
D - Dependency Inversion Principle
// GOOD: Depend on abstractions
interface IUserRepository {
findById(id: string): Promise<User>;
}
class UserService {
constructor(private repo: IUserRepository) {}
}
// BAD: Depend on concrete implementations
class UserService {
private repo = new PostgresUserRepository();
}
Step 4: Security Checklist (OWASP Top 10)
Before marking implementation complete, verify:
1. Broken Access Control
- [ ] Enforce access control on every request
- [ ] Deny by default
- [ ] Validate user owns the resource
2. Cryptographic Failures
- [ ] Use strong encryption (AES-256, RSA-2048+)
- [ ] Never store passwords in plain text (use bcrypt/argon2)
- [ ] Use HTTPS for all communications
3. Injection
- [ ] Use parameterized queries for database
- [ ] Validate and sanitize all user inputs
- [ ] Escape output in templates
4. Insecure Design
- [ ] Apply threat modeling
- [ ] Implement defense in depth
- [ ] Fail securely
5. Security Misconfiguration
- [ ] Remove default credentials
- [ ] Disable unnecessary features
- [ ] Keep dependencies updated
6. Vulnerable Components
- [ ] Use dependency audit tools (e.g.,
npm audit,pip-audit,cargo audit,snyk) - [ ] Update vulnerable packages
- [ ] Remove unused dependencies
7. Authentication Failures
- [ ] Implement proper session management
- [ ] Use MFA where appropriate
- [ ] Implement account lockout
8. Software Integrity
- [ ] Verify package integrity
- [ ] Use lockfiles (e.g.,
package-lock.json,Cargo.lock,poetry.lock,go.sum) - [ ] Sign commits if required
9. Logging & Monitoring
- [ ] Log security events
- [ ] Don't log sensitive data
- [ ] Implement alerting
10. SSRF (Server-Side Request Forgery)
- [ ] Validate and sanitize URLs
- [ ] Use allowlists for external calls
- [ ] Disable redirects or validate them
Step 5: Code Quality Standards
Naming
// GOOD
const userEmail = user.email;
function calculateTotalPrice(items: Item[]): number { ... }
// BAD
const e = user.email;
function calc(i: any): any { ... }
Comments
// GOOD: Explain WHY, not WHAT
// Use retry because the external API has rate limits
const result = await retryWithBackoff(fetchData);
// BAD: Obvious comments
// Get the user
const user = getUser(id);
Error Handling
// GOOD: Specific, informative errors
class UserNotFoundError extends Error {
constructor(userId: string) {
super(`User with ID ${userId} not found`);
this.name = 'UserNotFoundError';
}
}
// BAD: Generic errors
throw new Error('Error');
Step 6: Update Task Status
After implementing each task:
- Mark task as complete in tasks.md
- Verify test coverage >= 80%
- Run
sdd-quality-checkMCP tool on new code
MCP Tool Integration
| Tool | When to Use |
|------|-------------|
| sdd-status | Check all phases approved before implementing |
| sdd-spec-impl | Execute specific tasks with TDD |
| sdd-quality-check | Validate code quality after implementation |
Definition of Done
- [ ] All acceptance criteria met
- [ ] All tests pass
- [ ] Code coverage >= 80%
- [ ] No lint/type errors
- [ ] Security checklist verified
- [ ] SOLID principles applied
- [ ] Code self-documenting or commented where needed
Steering Document References
Apply these steering documents during implementation:
| Document | Purpose | Key Application |
|----------|---------|-----------------|
| .spec/steering/tdd-guideline.md | Test-Driven Development | Follow Red-Green-Refactor cycle for all code |
| .spec/steering/principles.md | SOLID, DRY, KISS, YAGNI | Apply SOLID principles, keep code simple and focused |
| .spec/steering/owasp-top10-check.md | Security checklist | Verify all OWASP Top 10 security requirements before completion |
Critical Implementation Rules:
- TDD First: Never write production code without a failing test
- SOLID Always: Apply all five principles (SRP, OCP, LSP, ISP, DIP)
- Security Required: Complete OWASP checklist before marking done
Common Anti-Patterns to Avoid
| Anti-Pattern | Problem | Solution | |--------------|---------|----------| | God Class | Class does too much | Split by responsibility | | Feature Envy | Method uses another class's data extensively | Move method to that class | | Primitive Obsession | Using primitives for domain concepts | Create value objects | | Magic Numbers | Unexplained numeric literals | Use named constants | | Deep Nesting | Multiple levels of if/loops | Extract methods, early returns | | Long Methods | Methods doing too much | Split into smaller methods |
Expert Next.js App Router
Developpement
Un skill qui transforme Claude en expert Next.js App Router.
Générateur de README
Developpement
Crée des README.md professionnels et complets pour vos projets.
Rédacteur de Documentation API
Developpement
Génère de la documentation API complète au format OpenAPI/Swagger.