skills/sprint/SKILL.md
Sprint Management — generic sprint capability for ANY bkit user. 16 sub-actions: init, start, status, watch, phase, iterate, qa, report, archive, list, feature, pause, resume, fork, help, master-plan. Triggers: sprint, sprint start, sprint init, sprint status, sprint list, 스프린트, 스프린트 시작, 스프린트 상태, スプリント, スプリント開始, スプリント状態, 冲刺, 冲刺开始, 冲刺状态, sprint, iniciar sprint, estado sprint, sprint, demarrer sprint, statut sprint, Sprint, Sprint starten, Sprint Status, sprint, avviare sprint, stato sprint, master plan, multi-sprint plan, sprint master plan, 마스터 플랜, 멀티 스프린트 계획, 스프린트 마스터 플랜, マスタープラン, マルチスプリント計画, スプリントマスタープラン, 主计划, 多冲刺计划, 冲刺主计划, plan maestro, plan multi-sprint, plan maestro sprint, plan maître, plan multi-sprint, plan maître sprint, Masterplan, Multi-Sprint-Plan, Sprint-Masterplan, piano principale, piano multi-sprint, piano principale sprint.
npx skillsauth add popup-studio-ai/bkit-claude-code sprintInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Sprint = meta-container above bkit's PDCA 9-phase. A sprint groups one or more features under a shared scope, budget, and timeline. Each sprint runs its own 8-phase lifecycle: prd -> plan -> design -> do -> iterate -> qa -> report -> archived.
/sprint init my-launch --name "Q2 Launch" --trust L3
/sprint start my-launch
The skill handler routes through <bkit-root>/scripts/sprint-handler.js
(bkit convention — handlers live at the bkit repo root scripts/ directory,
NOT inside skills/<name>/scripts/). The handler composes
Sprint 3 adapters (state-store + telemetry + doc-scanner + matrix-sync)
into Sprint 2 use cases (start / advance / iterate / qa / report / archive).
Sprint 1 entities (createSprint / SprintEvents / typedefs) are produced
and consumed transparently along the way.
Resolving
scripts/sprint-handler.jsin this document: throughout this SKILL.md, references toscripts/sprint-handler.jsmean<bkit-root>/scripts/sprint-handler.js(the canonical location). LLM dispatchers MUST NOT composeskills/sprint/scripts/sprint-handler.js— that path does not exist (Issue #107, fixed v2.1.19 S2 F2-1).
| Argument | Description | Example |
|----------|-------------|---------|
| init <id> | Create a sprint with default config | /sprint init my-launch |
| start <id> | Run auto-run loop bounded by Trust Level scope | /sprint start my-launch --trust L3 |
| status <id> | Show current sprint state from disk | /sprint status my-launch |
| list | Union of state-store entries and master-plan discoveries | /sprint list |
| phase <id> --to <phase> | Advance to a specific phase | /sprint phase my-launch --to qa |
| iterate <id> | Run matchRate-100 loop (max 5 cycles) | /sprint iterate my-launch |
| qa <id> --feature <name> | Run 7-Layer data-flow check on one feature | /sprint qa my-launch --feature auth |
| report <id> | Generate KPI + lessons + carry-items report | /sprint report my-launch |
| archive <id> | Move to terminal archived status | /sprint archive my-launch |
| pause <id> | Manually pause a running sprint | /sprint pause my-launch |
| resume <id> | Re-evaluate triggers and resume | /sprint resume my-launch |
| watch <id> | Live dashboard (Sprint 5 — current returns snapshot) | /sprint watch my-launch |
| feature <id> | Per-feature operations (Sprint 5) | /sprint feature my-launch --feature auth |
| fork <id> | Fork into a new sprint (Sprint 5) | /sprint fork my-launch --new my-launch-v2 |
| help | Print sub-action help | /sprint help |
| master-plan <project> | Generate multi-sprint Master Plan (agent isolated spawn) | /sprint master-plan q2-launch --name "Q2 Launch" --features auth,payment |
| measure <id> | Measure single gate / multi-gate / phase batch (v2.1.16 #94) | /sprint measure my-launch --gate M4 |
| Level | Stop after | Manual | Notes | |-------|------------|--------|-------| | L0 | prd | true | Each phase requires user approval | | L1 | prd | true (hint) | Hint mode but still manual | | L2 | design | false | Plan -> Design auto, Do requires approval | | L3 | report | false | Plan -> Report auto, Archive requires approval (default) | | L4 | archived | false | Full auto including archive (Trust >= 85 recommended) |
Four armed triggers can pause a running sprint:
QUALITY_GATE_FAIL — M3 > 0 OR S1 < 100ITERATION_EXHAUSTED — iter >= 5 AND matchRate < minAcceptableBUDGET_EXCEEDED — cumulativeTokens > config.budgetPHASE_TIMEOUT — phase elapsed > config.phaseTimeoutHoursPause writes an audit log entry and a SprintPaused event. Resume
re-evaluates the triggers and refuses if any are still firing.
USER COMMAND
v
skills/sprint/SKILL.md (this file — frontmatter triggers in 8 languages)
v
scripts/sprint-handler.js (English dispatcher)
v
Sprint 3: lib/infra/sprint -> { stateStore, eventEmitter, docScanner, matrixSync }
v
Sprint 2: lib/application/sprint-lifecycle -> startSprint / advancePhase / ...
v
Sprint 1: lib/domain/sprint -> createSprint / SprintEvents / typedefs
v
DISK: .bkit/state/sprints/<id>.json + .bkit/audit/<date>.jsonl
See:
examples/basic-sprint.mdexamples/multi-feature-sprint.mdexamples/archive-and-carry.mdbkit:pdca insteadbkit:pdca — single-feature PDCA cycle (foundation primitive)bkit:control — automation level (L0-L4) — surfaces SPRINT_AUTORUN_SCOPEbkit:sprint-orchestrator (agent) — full lifecycle coordinatorbkit:sprint-master-planner (agent) — plan/design generationbkit:sprint-qa-flow (agent) — 7-Layer dataFlowIntegrity verifierbkit:sprint-report-writer (agent) — KPI + lessons + carry itemsThis contract specifies how an LLM dispatcher should construct the args
object for each of the 16 sub-actions when invoking the underlying handler
via scripts/sprint-handler.js.
| Action | Required | Optional | Example call |
|--------|----------|----------|--------------|
| init | id, name | trust/trustLevel, phase, context, features | args = { id: "my-launch", name: "Q2 Launch", trust: "L3" } |
| start | id, name | trust/trustLevel, phase, context, features | args = { id: "my-launch", name: "Q2 Launch" } (resume preserves phase) |
| status | id | — | args = { id: "my-launch" } |
| list | — | — | args = {} |
| phase | id, to | approve (boolean), reason (string) | args = { id: "my-launch", to: "do", approve: true, reason: "Design review complete" } |
| iterate | id | — | args = { id: "my-launch" } |
| qa | id, featureName | — | args = { id: "my-launch", featureName: "auth" } |
| report | id | — | args = { id: "my-launch" } |
| archive | id | projectRoot | args = { id: "my-launch" } |
| pause | id | triggerId, severity, message | args = { id: "my-launch", triggerId: "USER_REQUEST" } |
| resume | id | — | args = { id: "my-launch" } |
| watch | id | — | args = { id: "my-launch" } |
| feature | id, action | featureName (required for add/remove) | args = { id: "my-launch", action: "list" } |
| fork | id, newId | — | args = { id: "my-launch", newId: "my-launch-v2" } |
| help | — | — | args = {} |
| master-plan | id (projectId), name (projectName) | features (CSV or array), trust/trustLevel, context, projectRoot, force (boolean), duration | args = { id: "q2-launch", name: "Q2 Launch", features: ["auth", "payment"] } |
| measure | id | one of: gate (string) / gates (CSV or array) / phase (string); plus trustLevel, source ('manual'|'auto'), agentTaskRunner (function in deps) | args = { id: "my-launch", gate: "M4" } |
measure action semantics (v2.1.16, Issue #94 F3)/sprint measure <id> is the user-invokable partial-gate measurement command
added in v2.1.16. It routes the requested gate(s) through
lib/application/quality-gates/measure-router.js (single SoT shared with
sprint-orchestrator self-assessment) and persists results into
sprint.qualityGates subject to Trust Level scope.
Three invocation modes (mutually exclusive precedence: gate > gates > phase):
/sprint measure my-launch --gate M4 # single gate
/sprint measure my-launch --gates M4,M8 # multi-gate (CSV)
/sprint measure my-launch --phase design # phase batch (ACTIVE_GATES_BY_PHASE[design])
Agent routing (Master Plan §11.3 AC4 — 7 gates × 4 agents):
| Gate | Agent | Source artifact | |------|--------------------|--------------------------------------------------| | M1 | gap-detector | Design §9 API Contract ↔ shipped implementation | | M2 | code-analyzer | lib/ + tests/ quality scan | | M3 | gap-detector | critical severity issue scan | | M4 | gap-detector | Design §9 API Contract ↔ module boundaries (#92) | | M7 | code-analyzer | style + naming convention scan | | M8 | sprint-orchestrator| design §14 self-assessment checklist | | S1 | sprint-qa-flow | 7-Layer hop traversal |
Gates outside this table (M5, M10, S2, S4) return
{ ok: false, reason: 'unsupported_gate' } — carried to v2.1.17.
Trust Level scope (Master Plan AC5):
L0 / L1: preview mode — measurement returned but
sprint.qualityGates NOT updated, no gate_measured audit entry.L2 / L3 / L4: record mode — qualityGates updated +
gate_measured audit entry emitted per gate.Audit emission (when in record mode):
{
"action": "gate_measured",
"category": "sprint",
"actor": "user",
"target": "<sprintId>",
"details": {
"sprintId": "...", "gateKey": "M4", "field": "M4_apiComplianceRate",
"agent": "gap-detector", "value": 100, "threshold": 95, "passed": true,
"source": "manual", "phase": "design", "trustLevel": "L3",
"previousValue": null
}
}
ENH-292 alignment: multi-gate / phase batch dispatches measurements sequentially (no Promise.all) to avoid #56293 sub-agent caching 10x.
Dispatcher requirement: the LLM dispatcher (main session) must inject
deps.agentTaskRunner: ({ subagent_type, prompt }) => Promise<{ output }>
wrapping Claude Code's Task tool. Without it the use case returns
reason: 'no_agent_runner' per gate (deterministic, not silent fail).
phase --approve semantics (v2.1.16, Issue #95)When a sprint is at Trust Level L2 (scope.stopAfter = "design") or any other
level whose scope.requireApproval blocks a forward transition, the user can
re-issue the phase action with --approve (and optional --reason) to
cross the scope boundary for this single call only:
/sprint phase my-launch --to do --approve --reason "Design review complete, M4/M8 gates pass"
Semantics (Master Plan §11.2 AC1-AC6):
sprint.autoRun.scope is NOT mutated. The next transition
faces the same scope check. To advance through multiple scope-blocking
transitions, re-issue --approve each time (or escalate Trust Level via
/bkit:control level <N>).sprint.autoRun.trustLevelAtStart and the global
automation level (/bkit:control) are unchanged. The approval is recorded
per-call.--approve boundary crossing emits an
audit-logger.writeAuditLog({ action: 'scope_boundary_approved', details: { sprintId, from, to, trustLevel, stopAfter, approvedBy, reason } }) entry.
The --reason "..." value is the recorded rationale (null when omitted).--approve the legacy deadlock behavior is preserved: handler
returns { ok: false, reason: 'requires_user_approval', stopAfter, hint }.Use this when you want to advance past the scope boundary for one specific transition (e.g., L2 design → do after design review) without permanently relaxing the trust level.
--approve does NOT bypass Quality Gate failures (v2.1.19 S1, CO-S0-6)Critical semantic clarification (added v2.1.19 S1 in response to S0 discovery of ambiguity — master plan carry-over CO-S0-6):
--approve is the Trust Level scope-boundary escape hatch ONLY.
It is NOT a Quality Gate override mechanism.
| Situation | --approve works? | Correct remediation |
|-----------|--------------------|---------------------|
| Trust scope blocks transition (requires_user_approval) | ✅ Yes — single-use cross | Re-issue with --approve --reason "..." |
| Quality Gate fails (gate_fail, e.g., M8=not_measured) | ❌ No — gate still blocks | Run /sprint measure <id> --gate <key> first, then re-issue phase |
| Both scope + gate fail | ❌ Gate wins | Measure gate, then --approve if scope still blocks |
Why this matters: in v2.1.19 S0 (master plan §23 step 0) we attempted
/sprint phase s0-sqm-baseline --to plan --approve and observed
{ ok: false, reason: 'gate_fail', ... } despite --approve. This is
expected behavior — --approve does not satisfy M8 designCompleteness.
Future work (deferred to v2.1.20+): --allowGateOverride flag may be
introduced as a gate override (with stronger audit + alarm trail than
--approve). Until then, gate failures must be resolved via /sprint measure.
/sprint trust <sprintId> --to <Level> [--reason "<text>"] [--force]
Mutate the stored sprint.autoRun.trustLevelAtStart for a specific
sprint. Unlike --approve (single-use scope boundary override, §10.1.2) or
--trustLevel L<N> (per-call volatile override), this command persists
the trust level across all subsequent operations on the sprint.
Use cases:
s1-foundation scenario).Example:
$ /sprint trust s1-foundation --to L3 --reason "P0 32/32 ready for measurement"
{
"ok": true,
"sprintId": "s1-foundation",
"from": "L1",
"to": "L3",
"reason": "P0 32/32 ready for measurement",
"actor": "user",
"forced": false,
"trustScoreAtMutation": null,
"blastRadius": "low",
"auditEntryId": "..."
}
$ /sprint measure s1-foundation --gate M1
{ "trustLevel": "L3", "mode": "record", "value": 92.3, ... } # ✦ now record mode
Downgrade Guardrail:
Major downgrades (≥2 levels, e.g. L4 → L2 or L3 → L1) require:
trustScore >= 80 (from .bkit/state/trust-profile.json trustScore field
— 6-component weighted sum: pdcaCompletionRate 0.25 / gatePassRate 0.2 /
rollbackFrequency 0.15 / destructiveBlockRate 0.15 / iterationEfficiency 0.15
/ userOverrideRate 0.1), OR--force flag (explicit override + forced: true audit + blastRadius: 'high'
for Defense Layer 6 alarm).Minor downgrades (1-level diff, e.g. L3 → L2) are not blocked.
Idempotent Path:
from === to (e.g. --to L3 when sprint already at L3) returns
{ ok: true, noop: true } and also emits audit with noop: true field
(CTO §C3 review: monitoring blind-spot prevention — surfaces automation
patterns hitting idempotent paths).
Actor Auto-Detection (CTO §E6 spoofing mitigation):
actor field is auto-detected:
args.actor (if 'user'|'agent'|'system'), elseprocess.env.CLAUDE_AGENT_ID set → 'agent', else'user'.Audit:
Every mutation (including no-op) emits an audit-logger entry:
{
"action": "sprint_trust_changed",
"category": "sprint",
"actor": "user",
"target": "s1-foundation",
"targetType": "feature",
"blastRadius": "low",
"details": {
"sprintId": "s1-foundation",
"from": "L1",
"to": "L3",
"reason": "...",
"trustScoreAtMutation": null,
"forced": false,
"noop": false,
"actor": "user",
"timestamp": "2026-05-21T..."
}
}
Comparison Table:
| Command | Scope | Persistence | Use When |
|---------|-------|------------|----------|
| /sprint phase --to ... --approve | Single transition | Single-use (state 무변경) | 1회 boundary 우회 (#95) |
| /sprint trust --to <L> ✦ | Sprint 전체 (this sprint only) | Persistent (sprint.autoRun.trustLevelAtStart) | 본 sprint 정책 영구 변경 |
| /bkit:control level <N> | Global (all sprints + PDCA) | Persistent (~/.bkit/state/control.json) | 전역 automation 정책 변경 |
| --trustLevel <L> (per-call) | Single call | Volatile (state 무변경) | 1회 debug override |
All actions that accept a Trust Level recognize three input forms (handled
by normalizeTrustLevel in scripts/sprint-handler.js):
args.trustLevel (preferred, explicit handler arg)args.trust (CLI --trust L3 natural mapping)args.trustLevelAtStart (stored property leak; defensive only)Precedence: trustLevel > trust > trustLevelAtStart. Defaults to L2
when none provided or value is invalid (case-insensitive match against L0-L4).
v2.1.19 S1 F1-4 default change: default lowered from L3 to L2 per
Safe Defaults principle (master plan §3.2 Controllable AI Principles). The
handler now aligns with lib/domain/sprint/entity.js createSprint which
already defaulted to L2 — eliminates the v2.1.16~v2.1.18 drift between
handler default (L3) and entity default (L2).
--trust L1 explicit warning: when the user explicitly requests L1 at
/sprint init, the handler emits a stderr warning + audit
sprint_trust_warning event re: preview-mode lockout risk
(v2.1.18 #101 follow-up). The warning is education-only — L1 sprint init
still succeeds.
When the user invokes the skill with mixed slash command + natural language
(e.g., /sprint start S1-UX Phase 1 PRD please proceed thoroughly), the
LLM dispatcher SHOULD:
/sprint → action./^[a-z][a-z0-9-]{1,62}[a-z0-9]$/). Lowercase if
needed. Example: S1-UX → s1-ux.start action on an existing sprint, the
name field can be resolved by handleStatus({ id }) first; otherwise
fall back to the id itself.User: /sprint start s1-ux
LLM dispatch:
1. action = "start", id = "s1-ux"
2. status = await handleSprintAction("status", { id: "s1-ux" })
3. name = status.sprint.name // "S1-UX P0/P1 Quick Fixes"
4. await handleSprintAction("start", { id: "s1-ux", name })
5. Handler invokes load-then-resume path (P0 fix) — phase preserved
User: /sprint start S1-UX Phase 1 PRD proceed thoroughly
LLM dispatch:
1. action = "start"
2. Candidates: ["s1-ux"] (kebab-case extracted from "S1-UX")
3. AskUserQuestion: "Did you mean to start sprint 's1-ux' and continue
with Phase 1 (PRD)?" → user confirms
4. await handleSprintAction("start", { id: "s1-ux", ... })
Handler returns { ok: false, error: <string>, ... } on failure. LLM
dispatcher SHOULD surface the error verbatim to the user and offer
remediation (e.g., for error: 'Sprint not found', suggest /sprint list).
The same handler is invokable as a standalone CLI when run as
node scripts/sprint-handler.js <action> [id] [--flags]. Useful for
headless tests, debugging, and CI integration. The CLI parser accepts
--key value and --key=value forms, with the first positional argument
after action treated as id if no --id flag is provided.
Exit codes: 0 (success), 1 (handler returned ok: false), 2
(exception thrown).
The master-plan action generates a multi-sprint roadmap via the
bkit:sprint-master-planner agent (isolated subagent spawn) and persists
both markdown documentation and state JSON.
USER: /sprint master-plan q2-launch --name "Q2 Launch" --features auth,payment
|
SKILL.md dispatches -> scripts/sprint-handler.js handleMasterPlan
|
handleMasterPlan calls lib/application/sprint-lifecycle/master-plan.usecase.js generateMasterPlan
|
generateMasterPlan validates input + loads existing state (idempotent check)
|
If deps.agentSpawner provided: spawn bkit:sprint-master-planner agent -> markdown
If not: dry-run via templates/sprint/master-plan.template.md substitution
|
Atomic write: .bkit/state/master-plans/<projectId>.json (state first)
|
File write: docs/01-plan/features/<projectId>.master-plan.md (markdown)
|
Audit: lib/audit/audit-logger.js writeAuditLog({ action: 'master_plan_created' })
|
Optional Task wiring: deps.taskCreator called N times for N sprint tasks
--force flag: overwrites both state JSON and markdown. Audit entry has
details.forceOverwrite: true.'master_plan_created' for both cases (PM-S2G).When the caller (LLM dispatcher at main session) does NOT inject
deps.agentSpawner, the use case generates a minimal valid markdown by
substituting variables in templates/sprint/master-plan.template.md. The
output is a skeleton — header, context anchor placeholders, empty features
table, empty sprints array. This dry-run mode is useful for unit tests and
when the user wants a starting template to fill manually.
When deps.agentSpawner is injected, the use case calls it with
{ subagent_type: 'bkit:sprint-master-planner', prompt: <built> } and uses
the returned output field as the markdown content.
The state JSON at .bkit/state/master-plans/<projectId>.json:
{
"schemaVersion": "1.0",
"projectId": "q2-launch",
"projectName": "Q2 Launch",
"features": ["auth", "payment", "reports"],
"sprints": [],
"dependencyGraph": {},
"trustLevel": "L3",
"context": { "WHY": "", "WHO": "", "RISK": "", "SUCCESS": "", "SCOPE": "" },
"generatedAt": "2026-05-12T20:00:00Z",
"updatedAt": "2026-05-12T20:00:00Z",
"masterPlanPath": "docs/01-plan/features/q2-launch.master-plan.md"
}
The sprints array is populated by the S3-UX context-sizer.js use case.
S2-UX leaves it as an empty stub.
When the caller injects deps.taskCreator, the use case iterates
plan.sprints sequentially (ENH-292 caching alignment) and calls
deps.taskCreator(...) once per planned sprint with addBlockedBy populated
from the previous sprint's task ID. This enables automatic Task list creation
for multi-sprint roadmaps.
When deps.taskCreator is undefined or plan.sprints.length === 0, Task
creation is silently skipped (no error).
tools
CC CLI version upgrade impact analysis — research changes, analyze bkit impact, generate report. Triggers: cc-version-analysis, CC upgrade, version analysis, CC 버전 분석, 버전 영향.
testing
Manage PDCA checkpoints and rollback — create, list, restore for safe recovery. Rollback events are recorded via lib/audit/audit-logger ACTION_TYPES.rollback_executed. For sprint-level recovery, individual feature rollbacks may be triggered from within sprint phases (sprint itself is forward-only — terminal state is `archived`, not rolled back; v2.1.13). Triggers: rollback, checkpoint, restore, undo, 롤백, 체크포인트, 복원.
testing
QA Phase execution — L1-L5 test planning, generation, execution, and reporting for a single feature. For sprint-level QA (7-Layer dataFlowIntegrity / S1 gate across multiple features) use /sprint qa <sprintId> which delegates to sprint-qa-flow agent (v2.1.13). Triggers: qa phase, QA test, qa run, QA 실행, QAフェーズ, QA阶段, fase QA, phase QA, QA-Phase, fase QA.
data-ai
PM Agent Team — automated product discovery, strategy, and PRD generation with 4 PM agents (for a single feature). For multi-feature initiatives with shared scope/budget/timeline, use /sprint master-plan which generates a sprint-level PRD via sprint-master-planner agent (v2.1.13). Triggers: pm, PRD, product discovery, PM 분석, 제품 기획, PM analysis.