Skip to content

Adr Compliance

This skill provides guidance on auditing code and system compliance with accepted Architectural Decision Records. Compliance checking ensures that architectural decisions are actually implemented and followed.

ADR Compliance verifies that:

  • Implementation matches documented decisions
  • New code follows accepted patterns
  • Deviations are intentional and documented
  • Technical debt from violations is tracked

Not all ADRs require compliance checking:

ADR TypeEnforcement
Technology choiceCheck for usage/imports
Pattern adoptionCheck for structure/patterns
ConstraintCheck for violations
Process decisionManual review
OrganizationalManual audit

For each enforceable ADR, define:

  • What code patterns indicate compliance
  • What patterns indicate violations
  • Where to look (file patterns, modules)
  • How to verify (automated vs manual)

Methods for checking:

  • Code analysis (grep, AST)
  • Architecture tests (ArchUnit, etc.)
  • Manual code review
  • Runtime verification

Document findings:

  • List violations found
  • Assess severity
  • Recommend remediation
  • Track resolution

Search for patterns that should/shouldn’t exist:

Terminal window
# Check for prohibited imports (ADR says don't use library X)
grep -r "import libraryX" src/
# Check for required patterns (ADR says use factory pattern)
grep -r "Factory.create" src/

Use architecture test frameworks:

Java (ArchUnit):

@ArchTest
static final ArchRule servicesShouldNotAccessRepositories =
noClasses().that().resideInAPackage("..service..")
.should().accessClassesThat().resideInAPackage("..repository..");

TypeScript:

// Custom architecture rules
describe('Architecture compliance', () => {
it('services should not import from UI layer', () => {
// Check import patterns
});
});

For ADRs requiring manual review:

  • Implementation matches decision
  • No unauthorized deviations
  • Documentation updated
  • Tests reflect architecture

“Use PostgreSQL for primary storage”

Compliance checks:

  • Database connections use PostgreSQL
  • No other databases for primary data
  • Configuration points to PostgreSQL

“Adopt event-driven architecture”

Compliance checks:

  • Components communicate via events
  • Direct calls minimized
  • Event schemas defined
  • Event handlers implemented

“All external APIs must use authentication”

Compliance checks:

  • No unauthenticated endpoints
  • Auth middleware applied
  • Token validation present

“Use service X for notifications”

Compliance checks:

  • Service X client used
  • No alternative notification services
  • Configuration for service X present
## ADR Compliance Report
**Date**: {date}
**Scope**: {files/modules checked}
### Summary
| Status | Count |
|--------|-------|
| Compliant | X |
| Violations | Y |
| Undetermined | Z |
### Violations Found
#### ADR-001: Use PostgreSQL
**Severity**: High
**Location**: `src/legacy/data.js:45`
**Issue**: Direct MySQL connection found
**Recommendation**: Migrate to PostgreSQL adapter
#### ADR-007: Event-Driven Architecture
**Severity**: Medium
**Location**: `src/services/order.ts:123`
**Issue**: Synchronous call to payment service
**Recommendation**: Emit PaymentRequired event
LevelCriteriaAction
CriticalSecurity or data riskImmediate fix
HighArchitectural violationFix in next sprint
MediumPattern deviationPlan remediation
LowMinor inconsistencyTrack for cleanup

Add compliance checks to pipeline:

  1. Run architecture tests
  2. Execute pattern checks
  3. Generate compliance report
  4. Fail/warn on violations

Schedule regular compliance audits:

  • Weekly: Automated checks
  • Monthly: New ADR verification
  • Quarterly: Full architecture audit

Maintain violation backlog:

  • Tag violations with ADR reference
  • Track remediation status
  • Monitor violation trends
  • Celebrate compliance improvements

Configure in .claude/adr.local.md:

compliance:
enabled: true
check_all_accepted: true
file_patterns:
- "**/*.ts"
- "**/*.py"
ignore_patterns:
- "**/test/**"
- "**/node_modules/**"
  • references/compliance-patterns.md - Common compliance check patterns
  • references/automation.md - Automation strategies
  • adr-integration - CI/CD integration patterns
  • adr-quality - ADR quality for compliance