Validation des limites de contexte Phoenix

VérifiéSûr

Analyse les dépendances entre les contextes Phoenix avec mix xref pour détecter les violations de frontières, les dépendances circulaires et la contamination des couches. Calcule un score de santé (0-100) et suggère des refontes (split de contextes, extraction de sous-contextes). Utile lors des revues de PR, avant un refactoring ou pour évaluer l'architecture.

Spar Skills Guide Bot
DeveloppementIntermédiaire
10002/06/2026
Claude Code
#phoenix#elixir#context-boundaries#mix-xref#architecture

Recommandé pour

Notre avis

Analyse les dépendances entre les contextes Phoenix pour garantir une séparation propre et une architecture saine.

Points forts

  • Détecte automatiquement les violations de frontières entre contextes.
  • Fournit un score de santé contextuel basé sur plusieurs métriques.
  • Propose des correctifs concrets pour améliorer la structure.

Limites

  • Nécessite une configuration initiale du projet Phoenix.
  • Les suggestions de correction sont génériques et peuvent nécessiter adaptation.
  • Ne couvre pas l'analyse des dépendances au niveau des modules individuels.
Quand l'utiliser

Utilisez cette compétence lors de revues de code, avant des refontes majeures ou lorsque les contextes semblent désorganisés.

Quand l'éviter

Ne l'utilisez pas pour des projets non-Phoenix ou pour analyser des dépendances de bibliothèques externes.

Analyse de sécurité

Sûr
Score qualité92/100

The skill only uses safe read-only Bash commands (mix xref, find, grep) for static analysis. It does not execute destructive actions, download external content, or expose secrets.

Aucun point d'attention détecté

Exemples

Check context boundary violations
Run /phx:boundaries to check for violations in my Phoenix project.
Assess context health
Run /phx:boundaries --assess to score context health in my Phoenix app.
Fix boundary issues
Run /phx:boundaries --fix to suggest fixes for context boundary violations.

name: phx:boundaries description: Validate Phoenix context boundaries and dependencies using mix xref. Use when reviewing PRs, before major refactors, when contexts feel tangled, or when a module has too many cross-context dependencies. Also use when planning context splits or evaluating architecture health. argument-hint: [--assess|--fix] allowed-tools: Read, Grep, Glob, Bash

Phoenix Context Boundary Validation

Analyze module dependencies to ensure clean context separation and proper architectural boundaries.

Usage

/phx:boundaries              # Check for violations
/phx:boundaries --assess     # Score context health (0-100)
/phx:boundaries --fix        # Suggest fixes for violations

--assess Mode: Context Health Score

Evaluate overall boundary health with a quantified score.

Metrics Calculated

| Metric | Healthy Range | Red Flag | Weight | |--------|---------------|----------|--------| | Modules per context | 3-15 | >20 or <2 | 20% | | Public API surface | 5-30 funcs | >40 funcs | 15% | | Fan-out (contexts called) | 1-4 | >6 | 20% | | Fan-in (called by contexts) | 1-6 | >10 | 15% | | Circular dependencies | 0 | >0 | 15% | | Boundary violations | 0 | >0 | 15% |

Commands for Assessment

# Module count per context
for dir in lib/my_app/*/; do
  echo "$(basename $dir): $(find $dir -name '*.ex' | wc -l) modules"
done

# Public function count per context
for f in lib/my_app/*.ex; do
  echo "$(basename $f): $(grep -c '^  def ' $f 2>/dev/null || echo 0) public funcs"
done

# Dependency analysis
mix xref graph --format stats

# Circular dependencies
mix xref graph --format cycles

Output Format

## Context Health Assessment

### Overall Score: 82/100 (Good)

| Context | Modules | API | Fan-Out | Fan-In | Score |
|---------|---------|-----|---------|--------|-------|
| Accounts | 5 | 12 | 2 | 4 | 95 |
| Orders | 18 | 45 | 8 | 3 | 62 |
| Shared | 2 | 8 | 0 | 12 | 78 |

### Issues Found

1. **Orders** - Too large (18 modules, 45 funcs)
   - Consider: Extract Fulfillment, Invoicing sub-contexts

2. **Orders** - High fan-out (8 contexts)
   - Consider: Review if all dependencies necessary

### Recommendations

- Split Orders into Orders + Fulfillment
- Review Accounts ← Billing dependency

Iron Laws - Never Violate These

  1. Controllers call only contexts - No direct Repo access from web layer
  2. Schemas are pure data - No side effects, no Repo calls in schema modules
  3. Contexts own their schemas - Don't import schemas from other contexts
  4. Explicit dependencies only - Cross-context calls must be intentional

Dependency Rules

| Layer | Can Call | Cannot Call | |-------|----------|-------------| | Controllers | Contexts, Plug, Conn | Repo, Schemas directly | | LiveViews | Contexts, Components, PubSub | Repo, Schemas directly | | Contexts | Own schemas, Repo, other contexts | Web layer modules | | Schemas | Ecto types, validations | Contexts, Repo |

Analysis Commands

Check Compile Dependencies

mix xref graph --label compile-connected

Find What Depends on a Context

mix xref graph --sink MyApp.Accounts --label compile

Find What a Module Calls

mix xref callers MyApp.Accounts.get_user!/1

Check for Circular Dependencies

mix xref graph --format cycles

Red Flags to Detect

| Issue | Detection Command | Fix | |-------|------------------|-----| | Repo in web layer | grep -r "Repo\." lib/my_app_web/ | Move to context | | Schema with queries | grep -r "import Ecto.Query" lib/my_app/**/schemas/ | Move queries to context | | Cross-context schema import | grep -r "alias MyApp.Other.Schema" lib/my_app/ctx/ | Call context API | | Business logic in LiveView | grep -r "Repo\.\|Ecto\.Multi" lib/my_app_web/live/ | Extract to context |

Boundary Verification Process

  1. Run mix xref graph --label compile-connected for overview
  2. Check for context cross-contamination
  3. Verify no direct Repo calls from web layer
  4. Ensure schemas have no side effects
  5. Validate explicit cross-context dependencies

Next Steps

Always end with actionable follow-up — findings without a plan get lost:

- `/phx:plan` — Create a plan to fix violations (recommended for 3+ issues)
- `/phx:quick` — Fix a single boundary violation directly
- `/phx:review` — Review specific modules for deeper issues

References

For detailed patterns, see:

  • references/context-design.md - Context design principles
  • references/refactoring-boundaries.md - Fixing boundary violations
Skills similaires