Adr Fundamentals
ADR Fundamentals
Section titled “ADR Fundamentals”Architectural Decision Records (ADRs) capture important architectural decisions along with their context and consequences. This skill provides foundational knowledge for creating, managing, and maintaining ADRs effectively.
When to Create an ADR
Section titled “When to Create an ADR”Create an ADR when making decisions that:
- Have significant impact - Affect system structure, behavior, or quality attributes
- Are hard to reverse - Would require substantial effort to change later
- Have multiple viable options - Alternatives were seriously considered
- Affect multiple components - Cross-cutting concerns or system-wide patterns
- Set precedent - Establish patterns others will follow
- Involve trade-offs - Balance competing concerns or constraints
Common ADR-Worthy Decisions
Section titled “Common ADR-Worthy Decisions”| Category | Examples |
|---|---|
| Technology Selection | Programming language, framework, database, cloud provider |
| Architecture Patterns | Microservices vs monolith, event-driven, CQRS |
| API Design | REST vs GraphQL, versioning strategy, authentication |
| Data Management | Storage strategy, caching, replication, backup |
| Security | Authentication method, encryption, access control |
| Integration | Third-party services, messaging patterns, protocols |
| Infrastructure | Container orchestration, deployment strategy, scaling |
When NOT to Create an ADR
Section titled “When NOT to Create an ADR”Skip ADRs for:
- Routine implementation choices
- Decisions with obvious answers
- Temporary or experimental changes
- Minor configuration tweaks
- Decisions that can be easily reversed
ADR Lifecycle
Section titled “ADR Lifecycle”Status Workflow
Section titled “Status Workflow”proposed → accepted → [deprecated] → superseded ↓ rejected| Status | Meaning |
|---|---|
| proposed | Under consideration, open for discussion |
| accepted | Approved and active, guides current development |
| rejected | Considered but not adopted (document why) |
| deprecated | No longer recommended, pending replacement |
| superseded | Replaced by a newer ADR (link to successor) |
Status Transitions
Section titled “Status Transitions”proposed → accepted: Decision reviewed and approved by stakeholders proposed → rejected: Decision not adopted after review accepted → deprecated: Circumstances changed, better alternatives exist accepted/deprecated → superseded: New ADR replaces this one
Writing Effective ADRs
Section titled “Writing Effective ADRs”Title Guidelines
Section titled “Title Guidelines”Use clear, action-oriented titles:
- Good: “Use PostgreSQL for primary data storage”
- Good: “Adopt event-driven architecture for order processing”
- Bad: “Database decision”
- Bad: “Architecture stuff”
Context Best Practices
Section titled “Context Best Practices”Provide sufficient background:
- Current state of the system
- Problem being solved
- Constraints and requirements
- Relevant stakeholders
Decision Drivers
Section titled “Decision Drivers”List forces influencing the decision:
- Technical requirements (performance, scalability, reliability)
- Business requirements (cost, time-to-market, compliance)
- Team factors (expertise, capacity, preferences)
- Organizational constraints (existing systems, standards)
Documenting Options
Section titled “Documenting Options”For each option considered:
- Brief description
- Pros and cons
- Key trade-offs
- Why selected or rejected
Consequences
Section titled “Consequences”Document both positive and negative outcomes:
- Expected benefits
- Known trade-offs accepted
- Risks and mitigations
- Future implications
ADR Naming Convention
Section titled “ADR Naming Convention”Standard pattern: {NUMBER}-{slug}.md
Examples:
0001-use-postgresql-for-primary-storage.md0002-adopt-event-driven-architecture.md0003-implement-oauth2-authentication.md
Number Format Options
Section titled “Number Format Options”| Format | Example | Use Case |
|---|---|---|
| 4-digit | 0001, 0042 | Default, supports 9999 ADRs |
| 3-digit | 001, 042 | Smaller projects |
| Date-based | 20250115 | Chronological emphasis |
ADR Directory Structure
Section titled “ADR Directory Structure”Standard structure:
docs/adr/├── README.md # Index and guidelines├── 0001-first-adr.md├── 0002-second-adr.md└── templates/ # Optional: custom templatesFor large projects, consider module-level ADRs:
src/├── module-a/│ └── docs/adr/├── module-b/│ └── docs/adr/└── docs/adr/ # Project-wide ADRsADR Linking
Section titled “ADR Linking”Link Types
Section titled “Link Types”| Relationship | Meaning |
|---|---|
| supersedes | This ADR replaces ADR-XXX |
| superseded-by | ADR-XXX replaces this one |
| relates-to | Related decision, not a replacement |
| amends | Modifies without fully replacing |
Linking Best Practices
Section titled “Linking Best Practices”- Always link both directions (supersedes/superseded-by)
- Include reason for supersession
- Keep superseded ADRs for historical context
- Use relates-to for decisions that inform each other
Common Mistakes
Section titled “Common Mistakes”Avoid These Patterns
Section titled “Avoid These Patterns”- Missing context - Decisions without background are hard to understand later
- Vague options - “Option A vs Option B” without specifics
- Missing trade-offs - Every decision has downsides; document them
- Orphaned ADRs - Not linking superseded decisions
- Status neglect - Forgetting to update status as decisions evolve
- Too much detail - ADRs are summaries, not full specifications
Integration with Development
Section titled “Integration with Development”Pull Request Workflow
Section titled “Pull Request Workflow”- Create ADR in proposed status
- Open PR for team review
- Discuss and refine
- Update status to accepted when merged
- Reference ADR in related implementation PRs
Documentation Links
Section titled “Documentation Links”Cross-reference ADRs from:
- Architecture documentation
- README files
- Code comments (for non-obvious patterns)
- Wiki or knowledge base
Configuration
Section titled “Configuration”Read project configuration from .claude/adr.local.md for:
- ADR directory location(s)
- Numbering format
- Status workflow
- Template preferences
Additional Resources
Section titled “Additional Resources”Reference Files
Section titled “Reference Files”For detailed guidance on specific topics:
references/decision-criteria.md- Comprehensive criteria for ADR-worthy decisionsreferences/review-checklist.md- ADR quality review checklist
Related Skills
Section titled “Related Skills”- adr-format-madr - MADR template format details (default format)
- adr-format-nygard - Classic Nygard format
- adr-decision-drivers - Identifying and documenting decision drivers
- adr-quality - Quality criteria and review process
- adr-compliance - Auditing code against ADRs
- adr-integration - CI/CD and tooling integration