Files
pm-claude-skills/skills/architecture-decision-record/SKILL.md
T
mohitagw15856 01c10eb625 Content quality improvements to remaining 5 engineering skills
Completes the quality pass across all 10 skills:
- incident-postmortem: fix opening paragraph (blameless framing emphasis),
  add root cause circular check + action item specificity quality checks
- pr-description-writer: add title format quality check, fix
  risk-appropriate reviewer guidance quality check
- system-design-interview: rewrite architecture diagram instruction
  (system-specific not generic template), fix capacity estimates to show
  arithmetic, add trade-offs non-empty check
- api-docs-writer: add API Version + Rate Limits inputs, clarify output
  format options, add error codes completeness check, fix code examples check
- architecture-decision-record: add ADR Number + Team Context inputs,
  fix Implementation Notes + Review Date guidance, fix quality checks for
  context specificity and rejected option reasoning

Both skills/ and plugins/pm-engineering/skills/ copies updated.

https://claude.ai/code/session_01C3HwChrccJd145vJ6Z7ajF
2026-05-20 12:06:26 +00:00

4.5 KiB
Raw Blame History

name, description
name description
architecture-decision-record Create an Architecture Decision Record (ADR) for any technical decision. Use when asked to document a technical decision, write an ADR, record an architecture choice, or capture why a technology or approach was selected. Produces a structured ADR with context, decision, consequences, and tradeoffs.

Architecture Decision Record (ADR) Skill

This skill produces a complete Architecture Decision Record (ADR) following the Nygard format — the most widely adopted standard. ADRs document the reasoning behind significant technical decisions so future team members understand not just what was decided, but why.

Required Inputs

Ask the user for these if not provided:

  • ADR number (sequential number in your ADR registry — e.g. 012; or "next available" if unknown)
  • Decision title (brief, e.g. "Use PostgreSQL as primary datastore")
  • Context (what situation led to this decision needing to be made?)
  • Options considered (at least 2; if only 1 is given, prompt for alternatives that were considered or ruled out)
  • Decision made (which option was chosen)
  • Reason for choice
  • Status (Proposed / Accepted / Deprecated / Superseded)
  • Author and date
  • Team context (optional — team size, relevant experience, org constraints; helps calibrate formality and depth of the Context section)

Output Format


ADR-[NNN]: [Decision Title]

Date: [YYYY-MM-DD] Status: [Proposed / Accepted / Deprecated / Superseded by ADR-NNN] Author(s): [Name(s)] Deciders: [Who had final say — individual or team]


Context

[36 sentences. Describe the situation, constraints, and forces at play that made this decision necessary. Include: the problem being solved, relevant system state, team constraints, timeline pressures, or non-negotiable requirements. Write as if explaining to someone joining the team 18 months from now who has no prior context.]

Key constraints:

  • [Constraint 1: e.g. "Must be deployable on-premise for enterprise customers"]
  • [Constraint 2: e.g. "Team has no prior Go experience"]
  • [Add as many as are relevant]

Options Considered

For each option, produce:

Option [N]: [Name]

Description: [What this option is — 13 sentences]

Pros:

  • [Pro 1]
  • [Pro 2]

Cons:

  • [Con 1]
  • [Con 2]

Why this was ruled out (if not chosen): [Honest reason]


Decision

We will [chosen option].

[24 sentences explaining the decision in plain language. This should be readable in isolation — someone should understand the decision from this paragraph alone without reading the full document.]


Consequences

Positive Consequences

  • [What this decision enables or improves]
  • [What risk it mitigates]

Negative Consequences / Accepted Tradeoffs

  • [What we're giving up or taking on as a result of this decision]
  • [Technical debt or limitations introduced]
  • [What must now be true for this decision to remain valid]

Risks

  • [What could cause this decision to be wrong in hindsight]
  • [What would trigger us to revisit this decision]

Implementation Notes

[Include if the decision has non-obvious implementation gotchas, or if there are related tickets/RFCs implementers will need. Skip only if the decision is purely tooling selection with no implementation ambiguity.]


Review Date

[Include unless the decision is permanent or self-evidently final. State a specific trigger condition — e.g. "Review if team grows beyond 20 engineers or traffic exceeds 10M requests/day" — not just "should be reviewed periodically".]


Quality Checks

  • Context explains the why — not just the what
  • At least 2 options are documented (including the rejected ones)
  • Rejected options include honest reasons for rejection
  • Consequences include negative consequences — no decision is consequence-free
  • Decision is stated in plain language in the Decision section
  • Risks section identifies what would invalidate this decision
  • Context section states the problem explicitly in its first 12 sentences (does not assume the reader knows what problem the team was solving)
  • Each rejected option's "Why ruled out" explanation names a specific constraint or trade-off (not a circular statement like "didn't meet our requirements")

Usage Examples

  • "Write an ADR for using [technology]"
  • "Document our decision to [architectural choice]"
  • "Create an architecture decision record for [topic]"
  • "Help me write up why we chose [option] over [alternative]"