jdd-sprint-kit
v0.7.3
Published
Judgment-Driven Development toolkit for BMad Method
Maintainers
Readme
JDD Sprint Kit
Enables product experts to turn customer knowledge into software outcomes. Users decide, judge, and redirect — AI handles everything else. Execution extension for Claude Code + BMad Method.
User inputs (meeting notes, references, existing system context) raise AI's first-generation quality, and human time is spent only at customer-lens judgment points (JP1, JP2).
Design philosophy: Judgment-Driven Development Conceptual foundation: Delta-Driven Design Full architecture and Sprint walkthrough: Blueprint
Overall Flow
flowchart TD
A["1. Provide Brief & Materials"] --> B["2. Analyze Existing System\n(Brownfield Scan)"]
B --> C["3. AI Generates PRD & Design\n(Auto-Pipeline)"]
C --> D["4. Generate Specs"]
D --> JP1{{"JP1\nIs this the right\nproduct?"}}
JP1 -->|Approve| E["5. Generate Prototype\n(Deliverables)"]
JP1 -->|Revise| C
E --> JP2{{"JP2\nIs this the right\nexperience?"}}
JP2 -->|Start Crystallize| CR["6b. Translate & Compute Delta\n(Crystallize)"]
JP2 -->|Revise| E
JP2 -.->|Re-examine requirements| JP1
CR --> F["7. Build\n(Parallel Implementation)"]
F --> G["8. Quality Check\n(Validate)"]
G -->|Pass| H["Done"]
G -->|Repeated failure| CB["Course Correction\n(Circuit Breaker)"]
CB --> C
style JP1 fill:#FFD700,stroke:#333
style JP2 fill:#FFD700,stroke:#333
style CR fill:#87CEEB,stroke:#333
style CB fill:#FF6B6B,stroke:#333Human involvement happens at exactly 2 points (JP1, JP2) — everything else runs autonomously. If JP2 reveals issues with the requirements themselves, it loops back to JP1 — this is not a failure, but a normal discovery prompted by concrete deliverables. After JP2 approval, selecting [S] Start Crystallize translates the prototype into development specs and computes the delta. After Crystallize completes, you choose whether to proceed to Build.
What Gets Generated
A single Sprint run auto-generates the following artifacts:
- 3 spec documents — requirements.md, design.md, tasks.md
- OpenAPI 3.1 YAML — API specification + MSW Mock + Specmatic contract tests
- DBML schema — Database design (viewable as ERD on dbdiagram.io)
- BDD/Gherkin scenarios — Given-When-Then acceptance tests
- React + MSW prototype — Clickable prototype via
npm run dev
Quick Start
Prerequisites
- Claude Code CLI
- Node.js 18+
- Git, GitHub CLI (
gh) - BMad Method (
npx bmad-method install)
Installation
npx jdd-sprint-kit initAn interactive wizard detects your environment and installs Sprint Kit files.
(Optional) Connect Existing Service Data
Sprint Kit can analyze your existing service code to avoid duplicate APIs and breaking changes. Three access methods exist, from simplest to most flexible:
Method 1: GitHub URL in brief.md (simplest — no setup needed)
Declare GitHub repo URLs in the ## Reference Sources section of brief.md. Sprint auto-downloads a read-only snapshot via gh api tarball/HEAD.
Method 2: --add-dir (for local clones)
Add local repo directories when launching Claude Code:
claude --add-dir /path/to/backend-repo --add-dir /path/to/client-repoMethod 3: Figma MCP (for live design data)
claude mcp add --transport http figma https://mcp.figma.com/mcpMethods 1 and 2 were introduced in v0.4.0, replacing MCP filesystem servers which were restricted by Claude Code's MCP security to the project root directory only. Figma remains MCP because its data exists only on Figma's servers and cannot be downloaded as files.
First Sprint Run
# In Claude Code — start a new feature (creates template if folder doesn't exist)
/sprint my-feature-name
# Or start immediately with an inline Brief
/sprint "Describe the feature you want to build"Tutorial
To experience the full Sprint Kit pipeline, use the included example project:
# In Claude Code
/sprint test-tutor-exclThis is a scenario for adding a "tutor exclusion" feature to a fictional EduTalk service. 4 meeting notes are prepared in specs/test-tutor-excl/inputs/, and brownfield-context.md is pre-written to substitute for external data source scan results. No external data setup required.
Route Selection
3 routes are available based on your input readiness. All routes converge into the same pipeline.
[Input + Brownfield + BMad] → [Specs] → JP1 → [Deliverables] → JP2 → [Crystallize] → [Execute]
Sprint: |←──────────────── Fully Auto ───────────────────────→|
Guided: |←── BMad Dialog ──→|←────────── Auto ───────────────→|
Direct: |←── Auto ──────────────────────→|| Route | Entry Point | Best When |
|-------|-------------|-----------|
| Sprint | /sprint "Brief" or /sprint feature-name | You have materials (meeting notes, references) — AI builds, you judge |
| Guided | BMad 12-step → /specs → /preview | Exploration needed — discover and define with AI |
| Direct | /specs → /preview | Planning is complete — execute immediately |
After JP2 approval, Crystallize translates the prototype into development specs and computes the delta. Also available standalone via /crystallize feature-name.
For small tasks, use BMad Quick Flow:
/quick-spec→/dev-story→/code-review
Routes are not fixed. If you have materials but need deep exploration, use Guided with materials as reference input. After completing BMad 12-step, /specs auto-detects the artifacts — same as Direct.
Details: Blueprint §4.3 Route Selection
Brownfield — Existing System Integration
AI must understand the existing service structure to avoid creating duplicate APIs or breaking existing screen flows. Brownfield data is cumulatively collected from 4 sources:
- document-project — Structured docs generated by BMad
/document-projectworkflow scanning the existing codebase - External repos — Existing service code accessed via
--add-dir(local clones) or tarball snapshot (GitHub URLs) - Figma — Live design data accessed via MCP (OAuth)
- Local codebase — Direct scan of source code in the current project
Brownfield Context Generation
Auto-Generation (Sprint Route)
/sprint automatically generates brownfield-context.md:
- Phase 0 — Topology detection: detect document-project presence, external data sources (
--add-dirpaths, GitHub repo URLs, Figma MCP), build tools → determine project type (standalone/co-located/msa/monorepo) - Pass 1 (Broad Scan) — Collect domain concepts (L1) and behavior patterns (L2) based on Brief keywords
- Pass 2 (Targeted Scan) — After Architecture/Epics, collect integration points (L3) and code-level details (L4)
Results are recorded in specs/{feature}/planning-artifacts/brownfield-context.md as L1~L4 layers.
Pre-Sprint Preparation: document-project (Recommended)
Running BMad /document-project before Sprint improves scan quality:
# In Claude Code
/document-projectThis analyzes the existing codebase and generates structured docs under _bmad-output/ (project-overview.md, api-contracts.md, data-models.md, etc.). Sprint's Brownfield Scanner uses these as seed data to narrow scan scope.
External Data Sources
External service data can be provided through 3 methods (see Quick Start for setup):
| Source Type | Access Method | When to Use |
|-------------|---------------|-------------|
| External repos (backend, client, service-map) | --add-dir (local clone) or tarball snapshot (GitHub URL in brief.md) | When existing service code needs analysis |
| Figma | MCP (OAuth) | When live design data needs analysis |
The 4 roles external data can fill:
| Role | Provided Information | |------|---------------------| | backend-docs | API specs, domain policies, business rules, data models | | client-docs | Component structure, state management patterns, screen flows | | svc-map | Customer journeys, screen screenshots, flow graphs | | figma | Wireframes, design tokens, component specs |
Manual Preparation (Without External Sources)
You can manually write brownfield-context.md and provide it to Sprint without any external data:
# Place directly in the feature directory
specs/{feature}/brownfield-context.md
# or
specs/{feature}/planning-artifacts/brownfield-context.mdSprint detects existing files and uses them instead of re-scanning those levels. See _bmad/docs/brownfield-context-format.md for the format. A manually written brownfield-context.md sample is included in the tutorial example (specs/test-tutor-excl/).
Greenfield Projects
For Greenfield projects with no existing system, Sprint works normally without Brownfield data. Auto-detected in Phase 0 — no configuration needed.
Details: Blueprint §4.1 System Components
Project Structure
{project-root}/
├── CLAUDE.md # Project-specific rules (user-maintained)
├── .mcp.json # MCP server config (.gitignored)
├── .claude/
│ ├── agents/ # Sprint agents (8)
│ ├── commands/ # Sprint commands + BMad agents/workflows
│ ├── rules/ # Sprint rules (bmad-*.md)
│ ├── hooks/ # Hook scripts (notification, protection, recovery)
│ └── settings.json # Hook settings
├── _bmad/ # BMad Method (runtime reference)
│ └── docs/ # Format guides
├── preview-template/ # Prototype scaffold (Vite + React + MSW)
├── specs/ # Per-feature Sprint artifacts
│ └── {feature}/
│ ├── inputs/ # User Brief + reference materials
│ ├── planning-artifacts/ # BMad artifacts (PRD, Architecture, Epics)
│ ├── requirements.md # Requirements
│ ├── design.md # Design
│ ├── tasks.md # Tasks (Entropy + File Ownership)
│ ├── brownfield-context.md # Existing system context
│ ├── api-spec.yaml # OpenAPI 3.1
│ ├── schema.dbml # DB schema
│ ├── bdd-scenarios/ # Gherkin acceptance tests
│ ├── preview/ # React + MSW prototype
│ └── reconciled/ # Crystallize output (prototype-reconciled artifacts)
└── docs/ # Framework documentationSprint Kit files (
.claude/agents/,.claude/commands/,.claude/rules/bmad-*,_bmad/) should not be modified directly. Update vianpx jdd-sprint-kit update.
Multi-IDE Support
Sprint Kit's canonical definition files live in .claude/. Other AI IDEs beyond Claude Code are also supported.
Claude Code — Default IDE. No additional setup required.
Codex CLI — Use the --ide option during installation to generate Codex files:
npx jdd-sprint-kit init --ide claude-code,codexIn Codex, run Sprint commands via $sprint, $specs, $preview, $parallel, $validate.
Gemini Code Assist — TOML wrappers are auto-generated in .gemini/commands/.
When the canonical files (
.claude/) are modified,npx jdd-sprint-kit updatealso refreshes the converted files.
Documentation
| Document | Contents | |----------|----------| | Blueprint | Full product picture — 8-Section (Problem → Thesis → User Model → Value Chain → Judgment → Constraints → Risk → Current State) | | Judgment-Driven Development | Design philosophy + definition and discussion of design judgments | | BMad Method | AI role-play framework (external) |
License
MIT
