agentic-orchestrator 0.1.28 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/settings.local.json +46 -1
- package/.cortexrc +28 -0
- package/.github/agents/copilot-instructions.md +29 -0
- package/.github/copilot-instructions.md +93 -0
- package/.vscode/settings.json +13 -0
- package/.vscode/tms.code-snippets +223 -0
- package/AGENTS.md +72 -1
- package/Agentic-Orchestrator.iml +12 -11
- package/CLAUDE.md +72 -1
- package/CONSTITUTION.md +504 -0
- package/FUTURE-ENHANCEMENTS.md +85 -0
- package/NEXT-TASKS.md +25 -0
- package/PROMPTS.md +161 -0
- package/README.md +126 -29
- package/agentic/orchestrator/agents.yaml +4 -3
- package/agentic/orchestrator/defaults/policy.defaults.yaml +39 -3
- package/agentic/orchestrator/gates.yaml +15 -3
- package/agentic/orchestrator/policy.yaml +47 -3
- package/agentic/orchestrator/prompts/builder.system.md +69 -20
- package/agentic/orchestrator/prompts/planner-intake.system.md +149 -0
- package/agentic/orchestrator/prompts/planner.system.md +113 -40
- package/agentic/orchestrator/prompts/qa.system.md +73 -18
- package/agentic/orchestrator/prompts/reconciler.system.md +119 -0
- package/agentic/orchestrator/schemas/agents.schema.json +89 -1
- package/agentic/orchestrator/schemas/execution-control.schema.json +242 -0
- package/agentic/orchestrator/schemas/index.schema.json +234 -0
- package/agentic/orchestrator/schemas/intake.review.schema.json +82 -0
- package/agentic/orchestrator/schemas/organizer-ordering-artifact.schema.json +75 -0
- package/agentic/orchestrator/schemas/plan.schema.json +44 -0
- package/agentic/orchestrator/schemas/policy.schema.json +238 -9
- package/agentic/orchestrator/schemas/policy.user.schema.json +129 -1
- package/agentic/orchestrator/schemas/spec.manifest.bootstrap.schema.json +101 -0
- package/agentic/orchestrator/schemas/spec.manifest.verified.schema.json +80 -0
- package/agentic/orchestrator/schemas/state.schema.json +298 -3
- package/agentic/orchestrator/tools/catalog.json +145 -15
- package/agentic/orchestrator/tools/schemas/input/doctor.run.input.schema.json +18 -0
- package/agentic/orchestrator/tools/schemas/input/evidence.latest.input.schema.json +4 -0
- package/agentic/orchestrator/tools/schemas/input/evidence.verify_chain.input.schema.json +13 -0
- package/agentic/orchestrator/tools/schemas/input/feature.intake_submit.input.schema.json +11 -0
- package/agentic/orchestrator/tools/schemas/input/feature.question_answer.input.schema.json +15 -0
- package/agentic/orchestrator/tools/schemas/input/feature.question_create.input.schema.json +21 -0
- package/agentic/orchestrator/tools/schemas/input/feature.question_list.input.schema.json +13 -0
- package/agentic/orchestrator/tools/schemas/input/feature.ready_to_merge.input.schema.json +5 -0
- package/agentic/orchestrator/tools/schemas/input/feature.send_message.input.schema.json +1 -1
- package/agentic/orchestrator/tools/schemas/input/replay.timeline_get.input.schema.json +32 -0
- package/agentic/orchestrator/tools/schemas/input/repo.conflict_abort.input.schema.json +16 -0
- package/agentic/orchestrator/tools/schemas/input/repo.conflict_files.input.schema.json +16 -0
- package/agentic/orchestrator/tools/schemas/input/repo.reconcile_mainline.input.schema.json +37 -0
- package/agentic/orchestrator/tools/schemas/input/repo.resolve_conflict.input.schema.json +40 -0
- package/agentic/orchestrator/tools/schemas/input/runtime.execution_request_list.input.schema.json +7 -0
- package/agentic/orchestrator/tools/schemas/input/runtime.execution_request_submit.input.schema.json +25 -0
- package/agentic/orchestrator/tools/schemas/output/doctor.run.output.schema.json +34 -0
- package/agentic/orchestrator/tools/schemas/output/evidence.verify_chain.output.schema.json +23 -0
- package/agentic/orchestrator/tools/schemas/output/feature.get_context.output.schema.json +62 -2
- package/agentic/orchestrator/tools/schemas/output/feature.intake_submit.output.schema.json +24 -0
- package/agentic/orchestrator/tools/schemas/output/feature.question_answer.output.schema.json +21 -0
- package/agentic/orchestrator/tools/schemas/output/feature.question_create.output.schema.json +12 -0
- package/agentic/orchestrator/tools/schemas/output/feature.question_list.output.schema.json +14 -0
- package/agentic/orchestrator/tools/schemas/output/feature.ready_to_merge.output.schema.json +31 -0
- package/agentic/orchestrator/tools/schemas/output/feature.send_message.output.schema.json +8 -18
- package/agentic/orchestrator/tools/schemas/output/replay.timeline_get.output.schema.json +64 -0
- package/agentic/orchestrator/tools/schemas/output/repo.conflict_abort.output.schema.json +16 -0
- package/agentic/orchestrator/tools/schemas/output/repo.conflict_files.output.schema.json +22 -0
- package/agentic/orchestrator/tools/schemas/output/repo.reconcile_mainline.output.schema.json +61 -0
- package/agentic/orchestrator/tools/schemas/output/repo.resolve_conflict.output.schema.json +19 -0
- package/agentic/orchestrator/tools/schemas/output/report.dashboard.output.schema.json +26 -0
- package/agentic/orchestrator/tools/schemas/output/runtime.execution_request_list.output.schema.json +17 -0
- package/agentic/orchestrator/tools/schemas/output/runtime.execution_request_submit.output.schema.json +24 -0
- package/agentic/orchestrator/tools.md +13 -0
- package/apps/control-plane/scripts/validate-mcp-contracts.ts +1 -1
- package/apps/control-plane/src/application/kernel-tool-wiring.ts +140 -2
- package/apps/control-plane/src/application/services/activity-monitor-service.ts +44 -1
- package/apps/control-plane/src/application/services/bootstrap-manifest-generator-service.ts +251 -0
- package/apps/control-plane/src/application/services/checkpoint-service.ts +87 -27
- package/apps/control-plane/src/application/services/collision-override-service.ts +906 -0
- package/apps/control-plane/src/application/services/collision-queue-service.ts +129 -38
- package/apps/control-plane/src/application/services/cost-tracking-service.ts +94 -0
- package/apps/control-plane/src/application/services/execution-control-service.ts +599 -0
- package/apps/control-plane/src/application/services/feature-deletion-service.ts +37 -1
- package/apps/control-plane/src/application/services/feature-lifecycle-service.ts +182 -4
- package/apps/control-plane/src/application/services/feature-send-message-service.ts +17 -8
- package/apps/control-plane/src/application/services/feature-state-service.ts +191 -6
- package/apps/control-plane/src/application/services/gate-service.ts +121 -2
- package/apps/control-plane/src/application/services/git-reconciliation-service.ts +1591 -0
- package/apps/control-plane/src/application/services/intake-service.ts +1468 -0
- package/apps/control-plane/src/application/services/merge-service.ts +308 -17
- package/apps/control-plane/src/application/services/notifier-service.ts +3 -1
- package/apps/control-plane/src/application/services/performance-analytics-service.ts +75 -0
- package/apps/control-plane/src/application/services/plan-service.ts +336 -20
- package/apps/control-plane/src/application/services/question-service.ts +693 -0
- package/apps/control-plane/src/application/services/reactions-service.ts +73 -17
- package/apps/control-plane/src/application/services/replay-timeline-service.ts +295 -0
- package/apps/control-plane/src/application/services/reporting-service.ts +194 -10
- package/apps/control-plane/src/application/services/run-lease-service.ts +121 -5
- package/apps/control-plane/src/application/services/worktree-watchdog-service.ts +95 -8
- package/apps/control-plane/src/application/tools/tool-metadata.ts +7 -0
- package/apps/control-plane/src/application/usage-types.ts +138 -0
- package/apps/control-plane/src/cli/add-command-handler.ts +162 -0
- package/apps/control-plane/src/cli/answer-command-handler.ts +113 -0
- package/apps/control-plane/src/cli/attach-command-handler.ts +12 -3
- package/apps/control-plane/src/cli/cli-argument-parser.ts +133 -11
- package/apps/control-plane/src/cli/collision-command-handler.ts +113 -0
- package/apps/control-plane/src/cli/command-catalog.ts +479 -0
- package/apps/control-plane/src/cli/complete-command-handler.ts +23 -0
- package/apps/control-plane/src/cli/completion-command-handler.ts +25 -0
- package/apps/control-plane/src/cli/completion-resolver.ts +319 -0
- package/apps/control-plane/src/cli/completion-shell-renderer.ts +58 -0
- package/apps/control-plane/src/cli/dashboard-command-handler.ts +110 -1
- package/apps/control-plane/src/cli/dashboard-runtime-runner.ts +1036 -0
- package/apps/control-plane/src/cli/dashboard-runtime.ts +31 -0
- package/apps/control-plane/src/cli/help-command-handler.ts +17 -185
- package/apps/control-plane/src/cli/init-command-handler.ts +51 -6
- package/apps/control-plane/src/cli/merge-command-handler.ts +200 -0
- package/apps/control-plane/src/cli/questions-command-handler.ts +70 -0
- package/apps/control-plane/src/cli/replay-command-handler.ts +98 -0
- package/apps/control-plane/src/cli/resume-command-handler.ts +231 -16
- package/apps/control-plane/src/cli/retry-command-handler.ts +229 -17
- package/apps/control-plane/src/cli/retry-resume-decision.ts +75 -0
- package/apps/control-plane/src/cli/rollback-command-handler.ts +4 -2
- package/apps/control-plane/src/cli/run-command-handler.ts +35 -1
- package/apps/control-plane/src/cli/spec-ingestion-service.ts +45 -55
- package/apps/control-plane/src/cli/spec-preparation.ts +114 -0
- package/apps/control-plane/src/cli/spec-utils.ts +90 -11
- package/apps/control-plane/src/cli/status-command-handler.ts +122 -0
- package/apps/control-plane/src/cli/types.ts +41 -3
- package/apps/control-plane/src/core/collisions.ts +150 -31
- package/apps/control-plane/src/core/constants.ts +18 -1
- package/apps/control-plane/src/core/error-codes.ts +39 -0
- package/apps/control-plane/src/core/execution-control.ts +56 -0
- package/apps/control-plane/src/core/feature-resume-phase.ts +118 -0
- package/apps/control-plane/src/core/gate-freshness.ts +359 -0
- package/apps/control-plane/src/core/gate-log-extractor.ts +97 -0
- package/apps/control-plane/src/core/gates.ts +90 -1
- package/apps/control-plane/src/core/intake-artifacts.ts +295 -0
- package/apps/control-plane/src/core/kernel-types.ts +11 -0
- package/apps/control-plane/src/core/kernel.ts +604 -16
- package/apps/control-plane/src/core/mainline-conflict.ts +22 -0
- package/apps/control-plane/src/core/merge-repair.ts +149 -0
- package/apps/control-plane/src/core/path-layout.ts +46 -2
- package/apps/control-plane/src/core/path-rules.ts +11 -3
- package/apps/control-plane/src/core/plan-submit-recovery.ts +130 -0
- package/apps/control-plane/src/core/questions.ts +49 -0
- package/apps/control-plane/src/core/runtime-sessions.ts +4 -0
- package/apps/control-plane/src/core/schemas.ts +40 -1
- package/apps/control-plane/src/core/tool-caller.ts +25 -1
- package/apps/control-plane/src/core/utils/index-normalizer.ts +25 -4
- package/apps/control-plane/src/core/worktree-diff.ts +66 -0
- package/apps/control-plane/src/index.ts +29 -1
- package/apps/control-plane/src/interfaces/cli/bootstrap.ts +300 -6
- package/apps/control-plane/src/mcp/kernel-tool-executor.ts +17 -0
- package/apps/control-plane/src/mcp/tool-runtime.ts +63 -4
- package/apps/control-plane/src/providers/api-worker-provider.ts +62 -15
- package/apps/control-plane/src/providers/cli-worker-provider.ts +1037 -61
- package/apps/control-plane/src/providers/output-parsers/generic-output-parser.ts +99 -1
- package/apps/control-plane/src/providers/output-parsers/types.ts +2 -0
- package/apps/control-plane/src/providers/provider-defaults.ts +116 -7
- package/apps/control-plane/src/providers/providers.ts +225 -21
- package/apps/control-plane/src/providers/worker-provider-factory.ts +26 -2
- package/apps/control-plane/src/supervisor/artifact-stager.ts +52 -0
- package/apps/control-plane/src/supervisor/build-wave-executor.ts +477 -166
- package/apps/control-plane/src/supervisor/execution-enrollment-service.ts +408 -0
- package/apps/control-plane/src/supervisor/organizer-enrollment-scheduler.ts +117 -0
- package/apps/control-plane/src/supervisor/organizer-sidecar-service.ts +394 -0
- package/apps/control-plane/src/supervisor/plan-conformance-scorer.ts +2 -5
- package/apps/control-plane/src/supervisor/planner-phase.ts +85 -0
- package/apps/control-plane/src/supervisor/planning-wave-executor.ts +993 -64
- package/apps/control-plane/src/supervisor/prompt-bundle-loader.ts +20 -1
- package/apps/control-plane/src/supervisor/qa-wave-executor.ts +384 -177
- package/apps/control-plane/src/supervisor/run-coordinator.ts +723 -20
- package/apps/control-plane/src/supervisor/runtime.ts +485 -9
- package/apps/control-plane/src/supervisor/session-orchestrator.ts +220 -1
- package/apps/control-plane/src/supervisor/types.ts +152 -1
- package/apps/control-plane/src/supervisor/worker-decision-loop.ts +1030 -92
- package/apps/control-plane/test/activity-monitor.spec.ts +76 -0
- package/apps/control-plane/test/add-command-handler.spec.ts +189 -0
- package/apps/control-plane/test/application/services/feature-state-service.spec.ts +208 -0
- package/apps/control-plane/test/artifact-stager.spec.ts +93 -0
- package/apps/control-plane/test/batch-operations.spec.ts +58 -0
- package/apps/control-plane/test/bootstrap-edge-cases.spec.ts +50 -2
- package/apps/control-plane/test/bootstrap-manifest-generator-service.spec.ts +99 -0
- package/apps/control-plane/test/bootstrap.spec.ts +177 -4
- package/apps/control-plane/test/checkpoint-service.spec.ts +977 -29
- package/apps/control-plane/test/cli-argument-parser.spec.ts +119 -0
- package/apps/control-plane/test/cli-helpers.spec.ts +1202 -12
- package/apps/control-plane/test/cli.unit.spec.ts +797 -16
- package/apps/control-plane/test/collision-command-handler.spec.ts +182 -0
- package/apps/control-plane/test/collision-override-service.spec.ts +878 -0
- package/apps/control-plane/test/collision-queue.spec.ts +430 -2
- package/apps/control-plane/test/collisions.spec.ts +209 -1
- package/apps/control-plane/test/core-utils.spec.ts +61 -0
- package/apps/control-plane/test/cost-tracking.spec.ts +224 -0
- package/apps/control-plane/test/dashboard-api.integration.spec.ts +185 -5
- package/apps/control-plane/test/dashboard-client.spec.ts +948 -0
- package/apps/control-plane/test/dashboard-command.spec.ts +138 -6
- package/apps/control-plane/test/dashboard-runtime-runner.spec.ts +1550 -0
- package/apps/control-plane/test/dashboard-runtime.spec.ts +138 -0
- package/apps/control-plane/test/dashboard-ui-utils.spec.ts +56 -12
- package/apps/control-plane/test/dependency-scheduler.spec.ts +7 -1
- package/apps/control-plane/test/env-file.spec.ts +76 -0
- package/apps/control-plane/test/execution-control-service.spec.ts +535 -0
- package/apps/control-plane/test/execution-enrollment-service.spec.ts +648 -0
- package/apps/control-plane/test/feature-lifecycle.spec.ts +126 -0
- package/apps/control-plane/test/feature-resume-phase.spec.ts +164 -0
- package/apps/control-plane/test/feature-send-message-service.spec.ts +161 -0
- package/apps/control-plane/test/feature-state-service.spec.ts +295 -0
- package/apps/control-plane/test/fs.spec.ts +80 -0
- package/apps/control-plane/test/gate-freshness.spec.ts +590 -0
- package/apps/control-plane/test/gate-log-extractor.spec.ts +170 -0
- package/apps/control-plane/test/gates.spec.ts +108 -0
- package/apps/control-plane/test/git-reconciliation-service.spec.ts +2307 -0
- package/apps/control-plane/test/helpers.ts +65 -0
- package/apps/control-plane/test/incremental-gates.spec.ts +271 -0
- package/apps/control-plane/test/index-normalizer.spec.ts +98 -0
- package/apps/control-plane/test/init-wizard.spec.ts +17 -0
- package/apps/control-plane/test/intake-artifacts.spec.ts +203 -0
- package/apps/control-plane/test/intake-service.spec.ts +3176 -0
- package/apps/control-plane/test/kernel-collision-replay.spec.ts +3 -2
- package/apps/control-plane/test/kernel-tool-executor.spec.ts +77 -0
- package/apps/control-plane/test/kernel-tool-wiring.spec.ts +279 -0
- package/apps/control-plane/test/kernel.branches.spec.ts +15 -2
- package/apps/control-plane/test/kernel.coverage.spec.ts +7 -3
- package/apps/control-plane/test/kernel.coverage2.spec.ts +731 -2
- package/apps/control-plane/test/kernel.spec.ts +464 -2
- package/apps/control-plane/test/mainline-conflict.spec.ts +66 -0
- package/apps/control-plane/test/mcp-helpers.spec.ts +79 -0
- package/apps/control-plane/test/mcp.spec.ts +177 -13
- package/apps/control-plane/test/merge-command-handler.spec.ts +531 -0
- package/apps/control-plane/test/merge-service.spec.ts +570 -4
- package/apps/control-plane/test/notifier-service.spec.ts +26 -0
- package/apps/control-plane/test/organizer-enrollment-scheduler.spec.ts +340 -0
- package/apps/control-plane/test/organizer-ordering-artifact.spec.ts +95 -0
- package/apps/control-plane/test/organizer-sidecar-service.spec.ts +468 -0
- package/apps/control-plane/test/output-loop-detector.spec.ts +6 -0
- package/apps/control-plane/test/path-layout.spec.ts +70 -0
- package/apps/control-plane/test/performance-analytics.spec.ts +124 -0
- package/apps/control-plane/test/plan-conformance-scorer.spec.ts +53 -0
- package/apps/control-plane/test/plan-service.spec.ts +686 -4
- package/apps/control-plane/test/planning-wave-executor.spec.ts +3272 -86
- package/apps/control-plane/test/policy-loader-service.spec.ts +5 -0
- package/apps/control-plane/test/prompt-overlay.spec.ts +65 -0
- package/apps/control-plane/test/provider-command-runner-epipe.spec.ts +64 -0
- package/apps/control-plane/test/providers/api-worker-provider.spec.ts +129 -0
- package/apps/control-plane/test/providers/cli-worker-provider.spec.ts +148 -0
- package/apps/control-plane/test/providers/usage-types.spec.ts +98 -0
- package/apps/control-plane/test/providers.spec.ts +293 -16
- package/apps/control-plane/test/question-command-handlers.spec.ts +156 -0
- package/apps/control-plane/test/question-service.spec.ts +1119 -0
- package/apps/control-plane/test/reactions.spec.ts +114 -0
- package/apps/control-plane/test/replay-command-handler.spec.ts +144 -0
- package/apps/control-plane/test/replay-timeline-service.spec.ts +459 -0
- package/apps/control-plane/test/response.spec.ts +31 -0
- package/apps/control-plane/test/resume-command.spec.ts +757 -9
- package/apps/control-plane/test/retry-resume-decision.spec.ts +133 -0
- package/apps/control-plane/test/rollback-command-handler.spec.ts +334 -0
- package/apps/control-plane/test/rollback-command.spec.ts +120 -0
- package/apps/control-plane/test/run-coordinator.spec.ts +3062 -404
- package/apps/control-plane/test/schemas/state.schema.spec.ts +71 -0
- package/apps/control-plane/test/service-retry-paths.spec.ts +112 -0
- package/apps/control-plane/test/services.spec.ts +472 -2
- package/apps/control-plane/test/session-management.spec.ts +346 -1
- package/apps/control-plane/test/spec-ingestion.spec.ts +102 -28
- package/apps/control-plane/test/spec-preparation.spec.ts +182 -0
- package/apps/control-plane/test/supervisor-collaborators.spec.ts +191 -3
- package/apps/control-plane/test/supervisor.calltool.spec.ts +198 -0
- package/apps/control-plane/test/supervisor.spec.ts +95 -16
- package/apps/control-plane/test/supervisor.unit.spec.ts +385 -18
- package/apps/control-plane/test/tool-runtime.spec.ts +122 -0
- package/apps/control-plane/test/worker-decision-loop.spec.ts +3479 -476
- package/apps/control-plane/test/worker-execution-policy.spec.ts +1416 -6
- package/apps/control-plane/test/worker-provider-adapters.spec.ts +1894 -37
- package/apps/control-plane/test/worker-provider-factory.spec.ts +81 -0
- package/apps/control-plane/test/worktree-watchdog-service.spec.ts +125 -0
- package/apps/control-plane/vitest.config.ts +5 -0
- package/config/agentic/orchestrator/agents.yaml +22 -1
- package/config/agentic/orchestrator/gates.yaml +24 -7
- package/config/agentic/orchestrator/policy.yaml +23 -1
- package/config/agentic/orchestrator/prompts/builder.system.md +69 -20
- package/config/agentic/orchestrator/prompts/organizer.system.md +85 -0
- package/config/agentic/orchestrator/prompts/overrides/builder.claude.md +28 -0
- package/config/agentic/orchestrator/prompts/overrides/builder.codex.md +28 -0
- package/config/agentic/orchestrator/prompts/overrides/planner.claude.md +20 -0
- package/config/agentic/orchestrator/prompts/overrides/planner.codex.md +20 -0
- package/config/agentic/orchestrator/prompts/planner-intake.system.md +149 -0
- package/config/agentic/orchestrator/prompts/planner.system.md +113 -40
- package/config/agentic/orchestrator/prompts/qa.system.md +75 -18
- package/config/agentic/orchestrator/prompts/reconciler.system.md +119 -0
- package/dist/apps/control-plane/application/kernel-tool-wiring.d.ts +26 -2
- package/dist/apps/control-plane/application/kernel-tool-wiring.js +40 -2
- package/dist/apps/control-plane/application/kernel-tool-wiring.js.map +1 -1
- package/dist/apps/control-plane/application/services/activity-monitor-service.js +37 -1
- package/dist/apps/control-plane/application/services/activity-monitor-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/bootstrap-manifest-generator-service.d.ts +4 -0
- package/dist/apps/control-plane/application/services/bootstrap-manifest-generator-service.js +188 -0
- package/dist/apps/control-plane/application/services/bootstrap-manifest-generator-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/checkpoint-service.d.ts +5 -0
- package/dist/apps/control-plane/application/services/checkpoint-service.js +69 -24
- package/dist/apps/control-plane/application/services/checkpoint-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/collision-override-service.d.ts +139 -0
- package/dist/apps/control-plane/application/services/collision-override-service.js +568 -0
- package/dist/apps/control-plane/application/services/collision-override-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/collision-queue-service.d.ts +15 -0
- package/dist/apps/control-plane/application/services/collision-queue-service.js +92 -33
- package/dist/apps/control-plane/application/services/collision-queue-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/cost-tracking-service.d.ts +11 -0
- package/dist/apps/control-plane/application/services/cost-tracking-service.js +75 -0
- package/dist/apps/control-plane/application/services/cost-tracking-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/execution-control-service.d.ts +75 -0
- package/dist/apps/control-plane/application/services/execution-control-service.js +421 -0
- package/dist/apps/control-plane/application/services/execution-control-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/feature-deletion-service.d.ts +1 -0
- package/dist/apps/control-plane/application/services/feature-deletion-service.js +23 -1
- package/dist/apps/control-plane/application/services/feature-deletion-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/feature-lifecycle-service.d.ts +24 -1
- package/dist/apps/control-plane/application/services/feature-lifecycle-service.js +132 -3
- package/dist/apps/control-plane/application/services/feature-lifecycle-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/feature-send-message-service.js +16 -8
- package/dist/apps/control-plane/application/services/feature-send-message-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/feature-state-service.d.ts +36 -0
- package/dist/apps/control-plane/application/services/feature-state-service.js +163 -6
- package/dist/apps/control-plane/application/services/feature-state-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/gate-service.d.ts +2 -1
- package/dist/apps/control-plane/application/services/gate-service.js +95 -5
- package/dist/apps/control-plane/application/services/gate-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/git-reconciliation-service.d.ts +92 -0
- package/dist/apps/control-plane/application/services/git-reconciliation-service.js +1097 -0
- package/dist/apps/control-plane/application/services/git-reconciliation-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/intake-service.d.ts +63 -0
- package/dist/apps/control-plane/application/services/intake-service.js +1050 -0
- package/dist/apps/control-plane/application/services/intake-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/merge-service.d.ts +5 -1
- package/dist/apps/control-plane/application/services/merge-service.js +233 -18
- package/dist/apps/control-plane/application/services/merge-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/notifier-service.d.ts +1 -1
- package/dist/apps/control-plane/application/services/notifier-service.js +1 -0
- package/dist/apps/control-plane/application/services/notifier-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/performance-analytics-service.d.ts +11 -0
- package/dist/apps/control-plane/application/services/performance-analytics-service.js +59 -0
- package/dist/apps/control-plane/application/services/performance-analytics-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/plan-service.d.ts +5 -0
- package/dist/apps/control-plane/application/services/plan-service.js +254 -15
- package/dist/apps/control-plane/application/services/plan-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/question-service.d.ts +72 -0
- package/dist/apps/control-plane/application/services/question-service.js +507 -0
- package/dist/apps/control-plane/application/services/question-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/reactions-service.d.ts +2 -0
- package/dist/apps/control-plane/application/services/reactions-service.js +60 -17
- package/dist/apps/control-plane/application/services/reactions-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/replay-timeline-service.d.ts +39 -0
- package/dist/apps/control-plane/application/services/replay-timeline-service.js +205 -0
- package/dist/apps/control-plane/application/services/replay-timeline-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/reporting-service.d.ts +59 -0
- package/dist/apps/control-plane/application/services/reporting-service.js +121 -9
- package/dist/apps/control-plane/application/services/reporting-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/run-lease-service.d.ts +20 -0
- package/dist/apps/control-plane/application/services/run-lease-service.js +81 -4
- package/dist/apps/control-plane/application/services/run-lease-service.js.map +1 -1
- package/dist/apps/control-plane/application/services/worktree-watchdog-service.d.ts +10 -0
- package/dist/apps/control-plane/application/services/worktree-watchdog-service.js +65 -8
- package/dist/apps/control-plane/application/services/worktree-watchdog-service.js.map +1 -1
- package/dist/apps/control-plane/application/tools/tool-metadata.js +7 -0
- package/dist/apps/control-plane/application/tools/tool-metadata.js.map +1 -1
- package/dist/apps/control-plane/application/usage-types.d.ts +65 -0
- package/dist/apps/control-plane/application/usage-types.js +75 -0
- package/dist/apps/control-plane/application/usage-types.js.map +1 -0
- package/dist/apps/control-plane/cli/add-command-handler.d.ts +18 -0
- package/dist/apps/control-plane/cli/add-command-handler.js +110 -0
- package/dist/apps/control-plane/cli/add-command-handler.js.map +1 -0
- package/dist/apps/control-plane/cli/answer-command-handler.d.ts +8 -0
- package/dist/apps/control-plane/cli/answer-command-handler.js +96 -0
- package/dist/apps/control-plane/cli/answer-command-handler.js.map +1 -0
- package/dist/apps/control-plane/cli/attach-command-handler.js +8 -3
- package/dist/apps/control-plane/cli/attach-command-handler.js.map +1 -1
- package/dist/apps/control-plane/cli/cli-argument-parser.js +131 -11
- package/dist/apps/control-plane/cli/cli-argument-parser.js.map +1 -1
- package/dist/apps/control-plane/cli/collision-command-handler.d.ts +8 -0
- package/dist/apps/control-plane/cli/collision-command-handler.js +90 -0
- package/dist/apps/control-plane/cli/collision-command-handler.js.map +1 -0
- package/dist/apps/control-plane/cli/command-catalog.d.ts +21 -0
- package/dist/apps/control-plane/cli/command-catalog.js +416 -0
- package/dist/apps/control-plane/cli/command-catalog.js.map +1 -0
- package/dist/apps/control-plane/cli/complete-command-handler.d.ts +15 -0
- package/dist/apps/control-plane/cli/complete-command-handler.js +26 -0
- package/dist/apps/control-plane/cli/complete-command-handler.js.map +1 -0
- package/dist/apps/control-plane/cli/completion-command-handler.d.ts +8 -0
- package/dist/apps/control-plane/cli/completion-command-handler.js +20 -0
- package/dist/apps/control-plane/cli/completion-command-handler.js.map +1 -0
- package/dist/apps/control-plane/cli/completion-resolver.d.ts +1 -0
- package/dist/apps/control-plane/cli/completion-resolver.js +250 -0
- package/dist/apps/control-plane/cli/completion-resolver.js.map +1 -0
- package/dist/apps/control-plane/cli/completion-shell-renderer.d.ts +3 -0
- package/dist/apps/control-plane/cli/completion-shell-renderer.js +53 -0
- package/dist/apps/control-plane/cli/completion-shell-renderer.js.map +1 -0
- package/dist/apps/control-plane/cli/dashboard-command-handler.d.ts +1 -0
- package/dist/apps/control-plane/cli/dashboard-command-handler.js +83 -1
- package/dist/apps/control-plane/cli/dashboard-command-handler.js.map +1 -1
- package/dist/apps/control-plane/cli/dashboard-runtime-runner.d.ts +81 -0
- package/dist/apps/control-plane/cli/dashboard-runtime-runner.js +724 -0
- package/dist/apps/control-plane/cli/dashboard-runtime-runner.js.map +1 -0
- package/dist/apps/control-plane/cli/dashboard-runtime.d.ts +1 -0
- package/dist/apps/control-plane/cli/dashboard-runtime.js +26 -0
- package/dist/apps/control-plane/cli/dashboard-runtime.js.map +1 -0
- package/dist/apps/control-plane/cli/help-command-handler.js +13 -172
- package/dist/apps/control-plane/cli/help-command-handler.js.map +1 -1
- package/dist/apps/control-plane/cli/init-command-handler.js +51 -6
- package/dist/apps/control-plane/cli/init-command-handler.js.map +1 -1
- package/dist/apps/control-plane/cli/merge-command-handler.d.ts +8 -0
- package/dist/apps/control-plane/cli/merge-command-handler.js +139 -0
- package/dist/apps/control-plane/cli/merge-command-handler.js.map +1 -0
- package/dist/apps/control-plane/cli/questions-command-handler.d.ts +8 -0
- package/dist/apps/control-plane/cli/questions-command-handler.js +59 -0
- package/dist/apps/control-plane/cli/questions-command-handler.js.map +1 -0
- package/dist/apps/control-plane/cli/replay-command-handler.d.ts +15 -0
- package/dist/apps/control-plane/cli/replay-command-handler.js +55 -0
- package/dist/apps/control-plane/cli/replay-command-handler.js.map +1 -0
- package/dist/apps/control-plane/cli/resume-command-handler.d.ts +2 -0
- package/dist/apps/control-plane/cli/resume-command-handler.js +180 -17
- package/dist/apps/control-plane/cli/resume-command-handler.js.map +1 -1
- package/dist/apps/control-plane/cli/retry-command-handler.js +202 -16
- package/dist/apps/control-plane/cli/retry-command-handler.js.map +1 -1
- package/dist/apps/control-plane/cli/retry-resume-decision.d.ts +26 -0
- package/dist/apps/control-plane/cli/retry-resume-decision.js +61 -0
- package/dist/apps/control-plane/cli/retry-resume-decision.js.map +1 -0
- package/dist/apps/control-plane/cli/rollback-command-handler.js +3 -2
- package/dist/apps/control-plane/cli/rollback-command-handler.js.map +1 -1
- package/dist/apps/control-plane/cli/run-command-handler.js +26 -2
- package/dist/apps/control-plane/cli/run-command-handler.js.map +1 -1
- package/dist/apps/control-plane/cli/spec-ingestion-service.d.ts +2 -0
- package/dist/apps/control-plane/cli/spec-ingestion-service.js +37 -48
- package/dist/apps/control-plane/cli/spec-ingestion-service.js.map +1 -1
- package/dist/apps/control-plane/cli/spec-preparation.d.ts +14 -0
- package/dist/apps/control-plane/cli/spec-preparation.js +81 -0
- package/dist/apps/control-plane/cli/spec-preparation.js.map +1 -0
- package/dist/apps/control-plane/cli/spec-utils.d.ts +4 -0
- package/dist/apps/control-plane/cli/spec-utils.js +70 -11
- package/dist/apps/control-plane/cli/spec-utils.js.map +1 -1
- package/dist/apps/control-plane/cli/status-command-handler.js +69 -0
- package/dist/apps/control-plane/cli/status-command-handler.js.map +1 -1
- package/dist/apps/control-plane/cli/types.d.ts +41 -4
- package/dist/apps/control-plane/cli/types.js +9 -1
- package/dist/apps/control-plane/cli/types.js.map +1 -1
- package/dist/apps/control-plane/core/collisions.d.ts +37 -19
- package/dist/apps/control-plane/core/collisions.js +87 -12
- package/dist/apps/control-plane/core/collisions.js.map +1 -1
- package/dist/apps/control-plane/core/constants.d.ts +17 -1
- package/dist/apps/control-plane/core/constants.js +18 -1
- package/dist/apps/control-plane/core/constants.js.map +1 -1
- package/dist/apps/control-plane/core/error-codes.d.ts +39 -0
- package/dist/apps/control-plane/core/error-codes.js +39 -0
- package/dist/apps/control-plane/core/error-codes.js.map +1 -1
- package/dist/apps/control-plane/core/execution-control.d.ts +45 -0
- package/dist/apps/control-plane/core/execution-control.js +2 -0
- package/dist/apps/control-plane/core/execution-control.js.map +1 -0
- package/dist/apps/control-plane/core/feature-resume-phase.d.ts +3 -0
- package/dist/apps/control-plane/core/feature-resume-phase.js +88 -0
- package/dist/apps/control-plane/core/feature-resume-phase.js.map +1 -0
- package/dist/apps/control-plane/core/gate-freshness.d.ts +48 -0
- package/dist/apps/control-plane/core/gate-freshness.js +267 -0
- package/dist/apps/control-plane/core/gate-freshness.js.map +1 -0
- package/dist/apps/control-plane/core/gate-log-extractor.d.ts +22 -0
- package/dist/apps/control-plane/core/gate-log-extractor.js +66 -0
- package/dist/apps/control-plane/core/gate-log-extractor.js.map +1 -0
- package/dist/apps/control-plane/core/gates.d.ts +11 -2
- package/dist/apps/control-plane/core/gates.js +67 -3
- package/dist/apps/control-plane/core/gates.js.map +1 -1
- package/dist/apps/control-plane/core/intake-artifacts.d.ts +109 -0
- package/dist/apps/control-plane/core/intake-artifacts.js +143 -0
- package/dist/apps/control-plane/core/intake-artifacts.js.map +1 -0
- package/dist/apps/control-plane/core/kernel-types.d.ts +8 -0
- package/dist/apps/control-plane/core/kernel.d.ts +256 -8
- package/dist/apps/control-plane/core/kernel.js +400 -14
- package/dist/apps/control-plane/core/kernel.js.map +1 -1
- package/dist/apps/control-plane/core/mainline-conflict.d.ts +7 -0
- package/dist/apps/control-plane/core/mainline-conflict.js +20 -0
- package/dist/apps/control-plane/core/mainline-conflict.js.map +1 -0
- package/dist/apps/control-plane/core/merge-repair.d.ts +35 -0
- package/dist/apps/control-plane/core/merge-repair.js +99 -0
- package/dist/apps/control-plane/core/merge-repair.js.map +1 -0
- package/dist/apps/control-plane/core/path-layout.d.ts +10 -0
- package/dist/apps/control-plane/core/path-layout.js +32 -2
- package/dist/apps/control-plane/core/path-layout.js.map +1 -1
- package/dist/apps/control-plane/core/path-rules.js +9 -3
- package/dist/apps/control-plane/core/path-rules.js.map +1 -1
- package/dist/apps/control-plane/core/plan-submit-recovery.d.ts +22 -0
- package/dist/apps/control-plane/core/plan-submit-recovery.js +78 -0
- package/dist/apps/control-plane/core/plan-submit-recovery.js.map +1 -0
- package/dist/apps/control-plane/core/questions.d.ts +40 -0
- package/dist/apps/control-plane/core/questions.js +2 -0
- package/dist/apps/control-plane/core/questions.js.map +1 -0
- package/dist/apps/control-plane/core/runtime-sessions.d.ts +4 -0
- package/dist/apps/control-plane/core/schemas.d.ts +2 -0
- package/dist/apps/control-plane/core/schemas.js +31 -1
- package/dist/apps/control-plane/core/schemas.js.map +1 -1
- package/dist/apps/control-plane/core/tool-caller.d.ts +18 -1
- package/dist/apps/control-plane/core/utils/index-normalizer.js +17 -4
- package/dist/apps/control-plane/core/utils/index-normalizer.js.map +1 -1
- package/dist/apps/control-plane/core/worktree-diff.d.ts +4 -0
- package/dist/apps/control-plane/core/worktree-diff.js +52 -0
- package/dist/apps/control-plane/core/worktree-diff.js.map +1 -0
- package/dist/apps/control-plane/index.d.ts +10 -2
- package/dist/apps/control-plane/index.js +9 -2
- package/dist/apps/control-plane/index.js.map +1 -1
- package/dist/apps/control-plane/interfaces/cli/bootstrap.js +236 -6
- package/dist/apps/control-plane/interfaces/cli/bootstrap.js.map +1 -1
- package/dist/apps/control-plane/mcp/kernel-tool-executor.js +16 -0
- package/dist/apps/control-plane/mcp/kernel-tool-executor.js.map +1 -1
- package/dist/apps/control-plane/mcp/tool-runtime.d.ts +5 -0
- package/dist/apps/control-plane/mcp/tool-runtime.js +40 -5
- package/dist/apps/control-plane/mcp/tool-runtime.js.map +1 -1
- package/dist/apps/control-plane/providers/api-worker-provider.d.ts +2 -2
- package/dist/apps/control-plane/providers/api-worker-provider.js +40 -9
- package/dist/apps/control-plane/providers/api-worker-provider.js.map +1 -1
- package/dist/apps/control-plane/providers/cli-worker-provider.d.ts +59 -3
- package/dist/apps/control-plane/providers/cli-worker-provider.js +758 -46
- package/dist/apps/control-plane/providers/cli-worker-provider.js.map +1 -1
- package/dist/apps/control-plane/providers/output-parsers/generic-output-parser.js +91 -1
- package/dist/apps/control-plane/providers/output-parsers/generic-output-parser.js.map +1 -1
- package/dist/apps/control-plane/providers/output-parsers/types.d.ts +2 -0
- package/dist/apps/control-plane/providers/provider-defaults.d.ts +12 -0
- package/dist/apps/control-plane/providers/provider-defaults.js +103 -7
- package/dist/apps/control-plane/providers/provider-defaults.js.map +1 -1
- package/dist/apps/control-plane/providers/providers.d.ts +50 -4
- package/dist/apps/control-plane/providers/providers.js +145 -14
- package/dist/apps/control-plane/providers/providers.js.map +1 -1
- package/dist/apps/control-plane/providers/worker-provider-factory.d.ts +2 -0
- package/dist/apps/control-plane/providers/worker-provider-factory.js +8 -1
- package/dist/apps/control-plane/providers/worker-provider-factory.js.map +1 -1
- package/dist/apps/control-plane/supervisor/artifact-stager.d.ts +5 -0
- package/dist/apps/control-plane/supervisor/artifact-stager.js +45 -0
- package/dist/apps/control-plane/supervisor/artifact-stager.js.map +1 -0
- package/dist/apps/control-plane/supervisor/build-wave-executor.d.ts +24 -1
- package/dist/apps/control-plane/supervisor/build-wave-executor.js +362 -150
- package/dist/apps/control-plane/supervisor/build-wave-executor.js.map +1 -1
- package/dist/apps/control-plane/supervisor/execution-enrollment-service.d.ts +41 -0
- package/dist/apps/control-plane/supervisor/execution-enrollment-service.js +311 -0
- package/dist/apps/control-plane/supervisor/execution-enrollment-service.js.map +1 -0
- package/dist/apps/control-plane/supervisor/organizer-enrollment-scheduler.d.ts +15 -0
- package/dist/apps/control-plane/supervisor/organizer-enrollment-scheduler.js +93 -0
- package/dist/apps/control-plane/supervisor/organizer-enrollment-scheduler.js.map +1 -0
- package/dist/apps/control-plane/supervisor/organizer-sidecar-service.d.ts +44 -0
- package/dist/apps/control-plane/supervisor/organizer-sidecar-service.js +311 -0
- package/dist/apps/control-plane/supervisor/organizer-sidecar-service.js.map +1 -0
- package/dist/apps/control-plane/supervisor/plan-conformance-scorer.js +2 -5
- package/dist/apps/control-plane/supervisor/plan-conformance-scorer.js.map +1 -1
- package/dist/apps/control-plane/supervisor/planner-phase.d.ts +3 -0
- package/dist/apps/control-plane/supervisor/planner-phase.js +70 -0
- package/dist/apps/control-plane/supervisor/planner-phase.js.map +1 -0
- package/dist/apps/control-plane/supervisor/planning-wave-executor.d.ts +42 -0
- package/dist/apps/control-plane/supervisor/planning-wave-executor.js +753 -55
- package/dist/apps/control-plane/supervisor/planning-wave-executor.js.map +1 -1
- package/dist/apps/control-plane/supervisor/prompt-bundle-loader.js +19 -1
- package/dist/apps/control-plane/supervisor/prompt-bundle-loader.js.map +1 -1
- package/dist/apps/control-plane/supervisor/qa-wave-executor.d.ts +21 -0
- package/dist/apps/control-plane/supervisor/qa-wave-executor.js +287 -156
- package/dist/apps/control-plane/supervisor/qa-wave-executor.js.map +1 -1
- package/dist/apps/control-plane/supervisor/run-coordinator.d.ts +30 -1
- package/dist/apps/control-plane/supervisor/run-coordinator.js +561 -17
- package/dist/apps/control-plane/supervisor/run-coordinator.js.map +1 -1
- package/dist/apps/control-plane/supervisor/runtime.d.ts +84 -0
- package/dist/apps/control-plane/supervisor/runtime.js +393 -3
- package/dist/apps/control-plane/supervisor/runtime.js.map +1 -1
- package/dist/apps/control-plane/supervisor/session-orchestrator.d.ts +54 -0
- package/dist/apps/control-plane/supervisor/session-orchestrator.js +176 -1
- package/dist/apps/control-plane/supervisor/session-orchestrator.js.map +1 -1
- package/dist/apps/control-plane/supervisor/types.d.ts +142 -1
- package/dist/apps/control-plane/supervisor/types.js.map +1 -1
- package/dist/apps/control-plane/supervisor/worker-decision-loop.d.ts +68 -2
- package/dist/apps/control-plane/supervisor/worker-decision-loop.js +723 -89
- package/dist/apps/control-plane/supervisor/worker-decision-loop.js.map +1 -1
- package/docs/core/ARCHITECTURE.md +227 -0
- package/docs/core/DECISIONS.md +94 -0
- package/docs/core/DOMAIN-LOGIC.md +60 -0
- package/docs/core/PATTERNS.md +201 -0
- package/docs/core/TROUBLESHOOTING.md +347 -0
- package/docs/core/intentgraph-dependencies.json +39860 -0
- package/docs/core/intentgraph.index.json +46580 -0
- package/docs/plans/2026-03-10-gate-failure-targeted-repair-design.md +224 -0
- package/docs/plans/2026-03-10-gate-failure-targeted-repair.md +1032 -0
- package/docs/superpowers/plans/2026-03-16-provider-cli-config.md +743 -0
- package/docs/superpowers/plans/2026-03-23-reconcile-divergence-fix.md +777 -0
- package/docs/superpowers/plans/2026-03-28-ordering-agent-implementation.md +1754 -0
- package/docs/superpowers/plans/2026-03-29-drop-zone-and-provider-optimization.md +1108 -0
- package/docs/superpowers/plans/2026-03-29-merge-target-feature-branch.md +685 -0
- package/docs/superpowers/plans/2026-03-29-organizer-sidecar-runtime-loop.md +1289 -0
- package/docs/superpowers/specs/2026-03-23-reconcile-divergence-fix-design.md +118 -0
- package/docs/superpowers/specs/2026-03-28-ordering-agent-spec-audit-design.md +50 -0
- package/docs/superpowers/specs/2026-03-29-drop-zone-and-provider-optimization-design.md +254 -0
- package/docs/superpowers/specs/2026-03-29-merge-target-feature-branch-design.md +152 -0
- package/docs/superpowers/specs/2026-03-29-organizer-sidecar-runtime-loop-design.md +225 -0
- package/package.json +3 -2
- package/packages/web-dashboard/package.json +2 -1
- package/packages/web-dashboard/src/app/analytics/page.tsx +36 -2
- package/packages/web-dashboard/src/app/api/actions/route.ts +274 -63
- package/packages/web-dashboard/src/app/api/actions/status/route.ts +35 -0
- package/packages/web-dashboard/src/app/api/analytics/provider/route.ts +18 -0
- package/packages/web-dashboard/src/app/api/collisions/approve/route.ts +58 -0
- package/packages/web-dashboard/src/app/api/features/[id]/checkpoint-diff/route.ts +36 -0
- package/packages/web-dashboard/src/app/api/features/[id]/checkpoints/route.ts +29 -0
- package/packages/web-dashboard/src/app/api/features/[id]/conflicts/abort/route.ts +29 -0
- package/packages/web-dashboard/src/app/api/features/[id]/conflicts/files/route.ts +30 -0
- package/packages/web-dashboard/src/app/api/features/[id]/conflicts/resolve/route.ts +51 -0
- package/packages/web-dashboard/src/app/api/features/[id]/conflicts/route.ts +75 -0
- package/packages/web-dashboard/src/app/api/features/[id]/diff/route.ts +16 -2
- package/packages/web-dashboard/src/app/api/features/[id]/files/route.ts +26 -0
- package/packages/web-dashboard/src/app/api/features/[id]/gate-history/route.ts +27 -0
- package/packages/web-dashboard/src/app/api/features/[id]/genealogy/route.ts +26 -0
- package/packages/web-dashboard/src/app/api/features/[id]/history/run/[runId]/route.ts +20 -0
- package/packages/web-dashboard/src/app/api/features/[id]/history/runs/route.ts +34 -0
- package/packages/web-dashboard/src/app/api/features/[id]/intake-workspace/route.ts +20 -0
- package/packages/web-dashboard/src/app/api/features/[id]/live-output/route.ts +74 -0
- package/packages/web-dashboard/src/app/api/features/[id]/plan/amend/route.ts +21 -0
- package/packages/web-dashboard/src/app/api/features/[id]/plan-progress/route.ts +20 -0
- package/packages/web-dashboard/src/app/api/features/[id]/planner-artifacts/[artifact]/route.ts +78 -0
- package/packages/web-dashboard/src/app/api/features/[id]/planner-lifecycle/route.ts +20 -0
- package/packages/web-dashboard/src/app/api/features/[id]/planning-workspace/route.ts +20 -0
- package/packages/web-dashboard/src/app/api/features/[id]/questions/[questionId]/answer/route.ts +27 -0
- package/packages/web-dashboard/src/app/api/features/[id]/questions/route.ts +18 -0
- package/packages/web-dashboard/src/app/api/features/[id]/review/route.ts +14 -7
- package/packages/web-dashboard/src/app/api/features/[id]/route.ts +57 -2
- package/packages/web-dashboard/src/app/api/features/[id]/spec/route.ts +30 -0
- package/packages/web-dashboard/src/app/api/features/[id]/triage/route.ts +83 -0
- package/packages/web-dashboard/src/app/api/features/[id]/worker-events/route.ts +40 -0
- package/packages/web-dashboard/src/app/api/launch/preview/route.ts +86 -0
- package/packages/web-dashboard/src/app/api/launch/submit/route.ts +180 -0
- package/packages/web-dashboard/src/app/api/mainline/status/route.ts +74 -0
- package/packages/web-dashboard/src/app/api/merge-queue/route.ts +13 -0
- package/packages/web-dashboard/src/app/api/policy/budget/route.ts +14 -0
- package/packages/web-dashboard/src/app/api/projects/route.ts +11 -7
- package/packages/web-dashboard/src/app/api/reconciler/queue/route.ts +47 -0
- package/packages/web-dashboard/src/app/api/run/route.ts +26 -2
- package/packages/web-dashboard/src/app/api/runtime/events/route.ts +227 -0
- package/packages/web-dashboard/src/app/api/runtime/operations/route.ts +269 -0
- package/packages/web-dashboard/src/app/api/runtime/questions/route.ts +11 -0
- package/packages/web-dashboard/src/app/api/runtime/runs/route.ts +80 -0
- package/packages/web-dashboard/src/app/api/status/route.ts +4 -2
- package/packages/web-dashboard/src/app/feature/[id]/page.tsx +32 -42
- package/packages/web-dashboard/src/app/globals.css +34 -3
- package/packages/web-dashboard/src/app/launch/page.tsx +357 -0
- package/packages/web-dashboard/src/app/layout.tsx +23 -1
- package/packages/web-dashboard/src/app/page.tsx +263 -272
- package/packages/web-dashboard/src/components/dashboard/attention-strip.tsx +52 -0
- package/packages/web-dashboard/src/components/dashboard/collision-approval-drawer.tsx +185 -0
- package/packages/web-dashboard/src/components/dashboard/command-center-header.tsx +102 -0
- package/packages/web-dashboard/src/components/dashboard/mainline-status-banner.tsx +84 -0
- package/packages/web-dashboard/src/components/dashboard/merged-archive.tsx +36 -0
- package/packages/web-dashboard/src/components/dashboard/prioritized-queues.tsx +98 -0
- package/packages/web-dashboard/src/components/dashboard/reconciler-queue-card.tsx +115 -0
- package/packages/web-dashboard/src/components/dashboard/secondary-diagnostics-rail.tsx +48 -0
- package/packages/web-dashboard/src/components/dashboard/task-filter-bar.tsx +74 -0
- package/packages/web-dashboard/src/components/dashboard/triage-drawer.tsx +455 -0
- package/packages/web-dashboard/src/components/diff-viewer.tsx +19 -3
- package/packages/web-dashboard/src/components/evidence-viewer.tsx +65 -51
- package/packages/web-dashboard/src/components/feature-card.tsx +90 -7
- package/packages/web-dashboard/src/components/feature-cost-panel.tsx +112 -11
- package/packages/web-dashboard/src/components/feature-list-view.tsx +25 -4
- package/packages/web-dashboard/src/components/features/runtime-inspector/EventsTimelineView.tsx +260 -0
- package/packages/web-dashboard/src/components/features/runtime-inspector/OperationsListView.tsx +172 -0
- package/packages/web-dashboard/src/components/features/runtime-inspector/RuntimeInspectorPanel.tsx +896 -0
- package/packages/web-dashboard/src/components/filter-bar.tsx +7 -39
- package/packages/web-dashboard/src/components/focus/ActionableRiskList.tsx +46 -0
- package/packages/web-dashboard/src/components/focus/AgentRolePerformanceCard.tsx +200 -0
- package/packages/web-dashboard/src/components/focus/BlockedGuidanceBanner.tsx +149 -0
- package/packages/web-dashboard/src/components/focus/CheckpointInspector.tsx +123 -0
- package/packages/web-dashboard/src/components/focus/CheckpointRail.tsx +118 -0
- package/packages/web-dashboard/src/components/focus/CheckpointScrubber.tsx +249 -0
- package/packages/web-dashboard/src/components/focus/CollisionApprovalBanner.tsx +192 -0
- package/packages/web-dashboard/src/components/focus/CollisionRadar.tsx +136 -0
- package/packages/web-dashboard/src/components/focus/ConflictStatusCard.tsx +52 -0
- package/packages/web-dashboard/src/components/focus/ContextSidebar.tsx +108 -0
- package/packages/web-dashboard/src/components/focus/DiagnosisPanel.tsx +68 -0
- package/packages/web-dashboard/src/components/focus/FeatureDecisionBanner.tsx +68 -0
- package/packages/web-dashboard/src/components/focus/FeatureQuestionAnswerPanel.tsx +167 -0
- package/packages/web-dashboard/src/components/focus/FocusHeader.tsx +54 -0
- package/packages/web-dashboard/src/components/focus/FocusLayout.tsx +283 -0
- package/packages/web-dashboard/src/components/focus/GateFlakinessSummary.tsx +144 -0
- package/packages/web-dashboard/src/components/focus/GenealogyTree.tsx +34 -0
- package/packages/web-dashboard/src/components/focus/HeroBlock.tsx +67 -0
- package/packages/web-dashboard/src/components/focus/LiveAgentConsole.tsx +277 -0
- package/packages/web-dashboard/src/components/focus/MergeQueueCard.tsx +78 -0
- package/packages/web-dashboard/src/components/focus/OperationalSummaryCard.tsx +227 -0
- package/packages/web-dashboard/src/components/focus/PinnedActions.tsx +96 -0
- package/packages/web-dashboard/src/components/focus/PlanAmendmentPanel.tsx +250 -0
- package/packages/web-dashboard/src/components/focus/PlanProgressPanel.tsx +133 -0
- package/packages/web-dashboard/src/components/focus/PlannerArtifactViewer.tsx +158 -0
- package/packages/web-dashboard/src/components/focus/PlannerLifecycleHeader.tsx +141 -0
- package/packages/web-dashboard/src/components/focus/ProgressSnapshotCard.tsx +113 -0
- package/packages/web-dashboard/src/components/focus/RecentMaterialChanges.tsx +69 -0
- package/packages/web-dashboard/src/components/focus/RoleLogViewer.tsx +436 -0
- package/packages/web-dashboard/src/components/focus/RunHistoryBrowser.tsx +62 -0
- package/packages/web-dashboard/src/components/focus/SpecViewer.tsx +172 -0
- package/packages/web-dashboard/src/components/focus/TabBar.tsx +33 -0
- package/packages/web-dashboard/src/components/focus/UsageBurnChart.tsx +212 -0
- package/packages/web-dashboard/src/components/focus/VerificationSummaryCard.tsx +122 -0
- package/packages/web-dashboard/src/components/focus/tabs/ChangesTab.tsx +325 -0
- package/packages/web-dashboard/src/components/focus/tabs/ConflictsTab.tsx +395 -0
- package/packages/web-dashboard/src/components/focus/tabs/GatesQaTab.tsx +38 -0
- package/packages/web-dashboard/src/components/focus/tabs/HistoryTab.tsx +213 -0
- package/packages/web-dashboard/src/components/focus/tabs/IntakeTab.tsx +429 -0
- package/packages/web-dashboard/src/components/focus/tabs/OverviewTab.tsx +217 -0
- package/packages/web-dashboard/src/components/focus/tabs/PlanningTab.tsx +390 -0
- package/packages/web-dashboard/src/components/focus/tabs/ReviewTab.tsx +497 -0
- package/packages/web-dashboard/src/components/focus/tabs/RuntimeTab.tsx +213 -0
- package/packages/web-dashboard/src/components/focus/tabs/TranscriptTab.tsx +315 -0
- package/packages/web-dashboard/src/components/gate-results.tsx +2 -2
- package/packages/web-dashboard/src/components/human-input-panel.tsx +33 -57
- package/packages/web-dashboard/src/components/kanban-board.tsx +4 -0
- package/packages/web-dashboard/src/components/launch/launch-draft-card.tsx +131 -0
- package/packages/web-dashboard/src/components/plan-viewer.tsx +147 -69
- package/packages/web-dashboard/src/components/quick-launch-panel.tsx +20 -47
- package/packages/web-dashboard/src/components/summary-bar.tsx +30 -76
- package/packages/web-dashboard/src/lib/aop-client.ts +2484 -36
- package/packages/web-dashboard/src/lib/blocked-state-guidance.ts +475 -0
- package/packages/web-dashboard/src/lib/collision-radar.ts +136 -0
- package/packages/web-dashboard/src/lib/dashboard-action-states.ts +204 -0
- package/packages/web-dashboard/src/lib/dashboard-runtime-client.ts +439 -0
- package/packages/web-dashboard/src/lib/dashboard-utils.ts +179 -18
- package/packages/web-dashboard/src/lib/drop-zone-utils.ts +92 -0
- package/packages/web-dashboard/src/lib/focus-detail-derivations.ts +958 -0
- package/packages/web-dashboard/src/lib/focus-view.ts +300 -0
- package/packages/web-dashboard/src/lib/health-diagnosis.ts +356 -0
- package/packages/web-dashboard/src/lib/launch-contracts.ts +77 -0
- package/packages/web-dashboard/src/lib/launch-markdown.ts +107 -0
- package/packages/web-dashboard/src/lib/launch-page-preview.ts +89 -0
- package/packages/web-dashboard/src/lib/live-feed.ts +1 -1
- package/packages/web-dashboard/src/lib/multi-project-config.ts +33 -0
- package/packages/web-dashboard/src/lib/orchestrator-tools.ts +845 -59
- package/packages/web-dashboard/src/lib/planner-workspace.ts +1285 -0
- package/packages/web-dashboard/src/lib/review-contracts.ts +5 -3
- package/packages/web-dashboard/src/lib/runtime-files.ts +285 -0
- package/packages/web-dashboard/src/lib/tool-catalog.ts +51 -0
- package/packages/web-dashboard/src/lib/types.ts +731 -3
- package/packages/web-dashboard/src/lib/usage-burn.ts +175 -0
- package/packages/web-dashboard/src/lib/worktree-diff.ts +128 -0
- package/packages/web-dashboard/src/styles/dashboard.module.css +1742 -459
- package/packages/web-dashboard/test/api/actions/route.spec.ts +675 -0
- package/packages/web-dashboard/test/api/features/diff.route.spec.ts +57 -0
- package/packages/web-dashboard/test/api/features/feature.route.spec.ts +99 -0
- package/packages/web-dashboard/test/api/features/live-output.route.spec.ts +123 -0
- package/packages/web-dashboard/test/api/features/plan-amend.route.spec.ts +95 -0
- package/packages/web-dashboard/test/api/features/planner-workspaces.route.spec.ts +162 -0
- package/packages/web-dashboard/test/api/features/question-answer.route.spec.ts +99 -0
- package/packages/web-dashboard/test/api/features/triage.route.spec.ts +195 -0
- package/packages/web-dashboard/test/api/launch/preview.route.spec.ts +149 -0
- package/packages/web-dashboard/test/api/launch/submit.route.spec.ts +382 -0
- package/packages/web-dashboard/test/api/runtime/events/route.spec.ts +164 -0
- package/packages/web-dashboard/test/api/runtime/operations/route.spec.ts +156 -0
- package/packages/web-dashboard/test/api/runtime/runs/route.spec.ts +112 -0
- package/packages/web-dashboard/test/components/changes-tab.spec.tsx +76 -0
- package/packages/web-dashboard/test/components/command-center-root.spec.tsx +87 -0
- package/packages/web-dashboard/test/components/diagnosis-panel.spec.tsx +59 -0
- package/packages/web-dashboard/test/components/feature-card.spec.tsx +45 -0
- package/packages/web-dashboard/test/components/focus-layout.spec.tsx +299 -0
- package/packages/web-dashboard/test/components/gate-results.spec.tsx +39 -0
- package/packages/web-dashboard/test/components/gates-qa-tab.spec.tsx +118 -0
- package/packages/web-dashboard/test/components/human-input-panel.spec.tsx +54 -0
- package/packages/web-dashboard/test/components/intake-tab.spec.tsx +210 -0
- package/packages/web-dashboard/test/components/kanban-board.spec.tsx +35 -0
- package/packages/web-dashboard/test/components/launch-draft-card.spec.tsx +54 -0
- package/packages/web-dashboard/test/components/launch-page.spec.tsx +79 -0
- package/packages/web-dashboard/test/components/overview-tab.spec.tsx +236 -0
- package/packages/web-dashboard/test/components/planning-tab.spec.tsx +202 -0
- package/packages/web-dashboard/test/components/review-tab.spec.tsx +169 -0
- package/packages/web-dashboard/test/components/role-log-viewer.spec.ts +42 -0
- package/packages/web-dashboard/test/components/runtime-inspector.spec.tsx +22 -0
- package/packages/web-dashboard/test/components/runtime-tab.spec.tsx +133 -0
- package/packages/web-dashboard/test/components/transcript-tab.spec.tsx +46 -0
- package/packages/web-dashboard/test/components/triage-drawer.spec.tsx +159 -0
- package/packages/web-dashboard/test/lib/aop-client.spec.ts +235 -0
- package/packages/web-dashboard/test/lib/dashboard-runtime-client.spec.ts +144 -0
- package/packages/web-dashboard/test/lib/focus-detail-derivations.spec.ts +314 -0
- package/packages/web-dashboard/test/lib/focus-view.spec.ts +248 -0
- package/packages/web-dashboard/test/lib/health-diagnosis.spec.ts +277 -0
- package/packages/web-dashboard/test/lib/launch-markdown.spec.ts +36 -0
- package/packages/web-dashboard/test/lib/multi-project-config.spec.ts +54 -0
- package/packages/web-dashboard/test/lib/orchestrator-tools.spec.ts +352 -0
- package/packages/web-dashboard/test/lib/planner-workspace.spec.ts +289 -0
- package/packages/web-dashboard/test/lib/worktree-diff.spec.ts +119 -0
- package/packages/web-dashboard/vitest.config.ts +2 -0
- package/spec-files/completed/agentic_orchestrator_add_feature_to_active_execution_spec.md +557 -0
- package/spec-files/completed/agentic_orchestrator_dashboard_command_center_redesign_spec.md +1147 -0
- package/spec-files/completed/agentic_orchestrator_execution_mode_spec.md +18 -16
- package/spec-files/completed/agentic_orchestrator_feature_focus_view_track_a_spec.md +672 -0
- package/spec-files/completed/agentic_orchestrator_feature_focus_view_track_b_spec.md +794 -0
- package/spec-files/completed/agentic_orchestrator_feature_focus_view_track_c_decision_centric_remediation_spec.md +1037 -0
- package/spec-files/completed/agentic_orchestrator_feature_focus_view_ux_redesign_spec.md +1432 -0
- package/spec-files/completed/agentic_orchestrator_focus_plan_tab_intake_planning_workspace_spec.md +921 -0
- package/spec-files/completed/agentic_orchestrator_intentional_collision_override_spec.md +584 -0
- package/spec-files/completed/agentic_orchestrator_interactive_planning_intake_and_requirements_verification_spec.md +1185 -0
- package/spec-files/completed/agentic_orchestrator_reactive_execution_enrollment_spec.md +864 -0
- package/spec-files/{outstanding → completed}/agentic_orchestrator_runtime_inspection_spec.md +92 -19
- package/spec-files/completed/agentic_orchestrator_scope_aware_run_lease_spec.md +408 -0
- package/spec-files/completed/git-reconciliation-engine.md +827 -0
- package/spec-files/outstanding/agentic_orchestrator_dashboard_quick_launch_and_control_surface_spec.md +331 -0
- package/spec-files/outstanding/agentic_orchestrator_enterprise_governance_dashboard_spec.md +16 -6
- package/spec-files/outstanding/agentic_orchestrator_evidence_integrity_doctor_spec.md +60 -9
- package/spec-files/outstanding/agentic_orchestrator_focus_plan_tab_execution_contract_workspace_spec.md +616 -0
- package/spec-files/outstanding/agentic_orchestrator_headless_standby_dashboard_runtime_spec.md +310 -0
- package/spec-files/outstanding/agentic_orchestrator_human_input_interaction_protocol_spec.md +175 -72
- package/spec-files/outstanding/agentic_orchestrator_interactive_rename_cleanup_spec.md +197 -0
- package/spec-files/outstanding/agentic_orchestrator_interactive_resume_and_reconciliation_disposition_spec.md +412 -0
- package/spec-files/outstanding/agentic_orchestrator_knowledge_canary_spec.md +166 -137
- package/spec-files/outstanding/agentic_orchestrator_observability_replay_spec.md +3 -3
- package/spec-files/outstanding/agentic_orchestrator_phase_specific_agent_profiles_and_token_telemetry_spec.md +303 -0
- package/spec-files/outstanding/agentic_orchestrator_planning_review_quality_spec.md +18 -5
- package/spec-files/outstanding/agentic_orchestrator_policy_stratification_spec.md +225 -0
- package/spec-files/outstanding/agentic_orchestrator_quality_adoption_execution_spec.md +77 -50
- package/spec-files/outstanding/agentic_orchestrator_ready_to_merge_branch_handoff_spec.md +724 -0
- package/spec-files/outstanding/agentic_orchestrator_remove_deterministic_mode_spec.md +263 -0
- package/spec-files/outstanding/agentic_orchestrator_request_more_context_and_dashboard_human_input_spec.md +456 -0
- package/spec-files/outstanding/agentic_orchestrator_spec_coverage_and_reconciliation_enforcement_spec.md +1411 -0
- package/spec-files/outstanding/agentic_orchestrator_spec_ordering_agent_spec.md +370 -0
- package/spec-files/outstanding/shadow_workspace_implementation_spec.md +1 -1
- package/spec-files/progress.md +2026 -120
- package/specs/001-runtime-inspection/checklists/requirements.md +35 -0
- package/specs/001-runtime-inspection/design.md +338 -0
- package/specs/001-runtime-inspection/spec.md +95 -0
- package/specs/002-scope-aware-lease/checklists/requirements.md +35 -0
- package/specs/002-scope-aware-lease/contracts/lease-registry.schema.json +101 -0
- package/specs/002-scope-aware-lease/data-model.md +236 -0
- package/specs/002-scope-aware-lease/plan.md +766 -0
- package/specs/002-scope-aware-lease/quickstart.md +150 -0
- package/specs/002-scope-aware-lease/research.md +135 -0
- package/specs/002-scope-aware-lease/spec.md +128 -0
- package/specs/002-scope-aware-lease/tasks.md +767 -0
- package/tsconfig.json +1 -1
- package/vitest.config.ts +28 -0
- package/ARCHITECTURE_ADHERENCE_ANALYSIS.md +0 -871
- package/packages/web-dashboard/next-env.d.ts +0 -6
- package/packages/web-dashboard/src/components/detail-panel.tsx +0 -1124
- package/packages/web-dashboard/src/components/review-workspace.tsx +0 -1162
- /package/spec-files/{outstanding → completed}/agentic_orchestrator_artifact_database_publishing_spec.md +0 -0
- /package/spec-files/{outstanding → completed}/agentic_orchestrator_cli_shell_tab_completion_spec.md +0 -0
- /package/spec-files/{outstanding → completed}/agentic_orchestrator_dashboard_diff_and_agent_console_spec.md +0 -0
- /package/spec-files/{outstanding → completed}/agentic_orchestrator_performance_improvements_spec.md +0 -0
- /package/spec-files/{outstanding → completed}/agentic_orchestrator_persistent_worker_runtime_spec.md +0 -0
- /package/spec-files/{outstanding → completed}/agentic_orchestrator_provider_auth_bootstrap_spec.md +0 -0
- /package/spec-files/{outstanding → completed}/agentic_orchestrator_real_worker_provider_execution_spec.md +0 -0
|
@@ -0,0 +1,864 @@
|
|
|
1
|
+
# Feature Spec: Reactive Execution Enrollment and Scheduling (AOP)
|
|
2
|
+
|
|
3
|
+
> **Purpose of this document**: Define the architecture and implementation plan for near-real-time `aop add` enrollment into an already-running supervisor, using a dedicated enrollment component and a pluggable scheduling policy that will later support an organizer agent outside the feature cluster.
|
|
4
|
+
|
|
5
|
+
**Version:** 1.0
|
|
6
|
+
**Date:** 2026-03-15
|
|
7
|
+
**Status:** Draft
|
|
8
|
+
**Roadmap Mapping:** M50
|
|
9
|
+
|
|
10
|
+
---
|
|
11
|
+
|
|
12
|
+
## 0. Standards and Dependencies
|
|
13
|
+
|
|
14
|
+
### 0.1 Required Standards
|
|
15
|
+
|
|
16
|
+
All implementation MUST preserve:
|
|
17
|
+
|
|
18
|
+
- single active run ownership per repository
|
|
19
|
+
- deterministic error envelopes and artifact writes
|
|
20
|
+
- atomic state mutation through existing kernel/application service paths
|
|
21
|
+
- one global orchestrator session and one shared reconciler lane per active run
|
|
22
|
+
- existing feature lifecycle invariants and terminal-state rules
|
|
23
|
+
- MCP/in-process parity for runtime control requests
|
|
24
|
+
- `operation_id` idempotency for mutating tool calls
|
|
25
|
+
- coverage thresholds: Lines >=90%, Branches >=90%, Functions >=90%, Statements >=90%
|
|
26
|
+
|
|
27
|
+
### 0.2 Required Inputs
|
|
28
|
+
|
|
29
|
+
Implementing agents MUST read:
|
|
30
|
+
|
|
31
|
+
- `apps/control-plane/src/supervisor/runtime.ts`
|
|
32
|
+
- `apps/control-plane/src/supervisor/run-coordinator.ts`
|
|
33
|
+
- `apps/control-plane/src/supervisor/session-orchestrator.ts`
|
|
34
|
+
- `apps/control-plane/src/supervisor/planning-wave-executor.ts`
|
|
35
|
+
- `apps/control-plane/src/supervisor/build-wave-executor.ts`
|
|
36
|
+
- `apps/control-plane/src/supervisor/qa-wave-executor.ts`
|
|
37
|
+
- `apps/control-plane/src/supervisor/types.ts`
|
|
38
|
+
- `apps/control-plane/src/application/services/execution-control-service.ts`
|
|
39
|
+
- `apps/control-plane/src/application/services/run-lease-service.ts`
|
|
40
|
+
- `apps/control-plane/src/core/kernel.ts`
|
|
41
|
+
- `apps/control-plane/src/core/execution-control.ts`
|
|
42
|
+
- `apps/control-plane/src/core/runtime-sessions.ts`
|
|
43
|
+
- `apps/control-plane/src/core/path-layout.ts`
|
|
44
|
+
- `apps/control-plane/src/cli/add-command-handler.ts`
|
|
45
|
+
- `apps/control-plane/src/cli/status-command-handler.ts`
|
|
46
|
+
- `apps/control-plane/test/execution-control-service.spec.ts`
|
|
47
|
+
- `apps/control-plane/test/run-coordinator.spec.ts`
|
|
48
|
+
- `apps/control-plane/test/supervisor.spec.ts`
|
|
49
|
+
- `spec-files/outstanding/agentic_orchestrator_add_feature_to_active_execution_spec.md`
|
|
50
|
+
|
|
51
|
+
### 0.3 Scope
|
|
52
|
+
|
|
53
|
+
This spec implements:
|
|
54
|
+
|
|
55
|
+
- reactive polling of pending execution requests during a live run
|
|
56
|
+
- a dedicated enrollment component outside `SupervisorRuntime` core orchestration logic
|
|
57
|
+
- a pluggable scheduling interface for deciding whether newly submitted features should run now, wait, or be deferred
|
|
58
|
+
- near-real-time visibility for accepted add requests
|
|
59
|
+
- safe integration points for a future organizer agent that determines feature ordering and dependencies
|
|
60
|
+
|
|
61
|
+
Out of scope:
|
|
62
|
+
|
|
63
|
+
- multiple active runs in the same repository
|
|
64
|
+
- mid-flight provider/model/execution-mode overrides for added features
|
|
65
|
+
- a separate long-lived daemon process outside the current supervisor
|
|
66
|
+
- direct cluster creation from background threads without coordinator mediation
|
|
67
|
+
- dependency graph implementation for the organizer agent itself
|
|
68
|
+
|
|
69
|
+
### 0.4 Design Guardrails
|
|
70
|
+
|
|
71
|
+
Implementation MUST follow:
|
|
72
|
+
|
|
73
|
+
- **KISS**: do not redesign run lease semantics or feature cluster ownership
|
|
74
|
+
- **SRP**: polling, scheduling policy, and queue mutation MUST be separate concerns
|
|
75
|
+
- **SOLID**:
|
|
76
|
+
- open/closed for future request types and future scheduling policies
|
|
77
|
+
- interface segregation between polling and scheduling contracts
|
|
78
|
+
- dependency inversion so coordinator depends on an enrollment contract, not timer or file details
|
|
79
|
+
- **Hexagonal architecture**: runtime control artifact access stays behind services/kernel ports
|
|
80
|
+
- **Composition over inheritance**: compose a new enrollment service into supervisor startup/shutdown
|
|
81
|
+
- **Single-writer runtime state**: only the coordinator may mutate the live run queue and cluster assignments
|
|
82
|
+
|
|
83
|
+
---
|
|
84
|
+
|
|
85
|
+
## 1. Problem Statement
|
|
86
|
+
|
|
87
|
+
### 1.1 Current Defect
|
|
88
|
+
|
|
89
|
+
`aop add` now durably writes pending requests into `.aop/runtime/<instanceId>/execution-control.json`, but the live supervisor only checks for pending requests at coarse boundaries in the main coordinator loop.
|
|
90
|
+
|
|
91
|
+
As a result:
|
|
92
|
+
|
|
93
|
+
1. a request may remain `pending` for minutes while a long planning/build/QA operation is running
|
|
94
|
+
2. the run lease may continue heartbeating, which makes the run appear healthy even though enrollment is not reactive
|
|
95
|
+
3. users do not get the expected behavior of “add work to the active execution if there is room”
|
|
96
|
+
|
|
97
|
+
### 1.2 Architectural Constraint
|
|
98
|
+
|
|
99
|
+
The solution must not hard-code feature ordering into the polling mechanism because a future organizer agent will exist outside the feature cluster and will decide:
|
|
100
|
+
|
|
101
|
+
- which enrolled features can start immediately
|
|
102
|
+
- which features must wait on other features
|
|
103
|
+
- which features should be deprioritized or deferred
|
|
104
|
+
|
|
105
|
+
That future system must be able to plug into the same enrollment pipeline without replacing the transport or state plumbing.
|
|
106
|
+
|
|
107
|
+
---
|
|
108
|
+
|
|
109
|
+
## 2. Design Decision
|
|
110
|
+
|
|
111
|
+
### 2.1 Chosen Approach
|
|
112
|
+
|
|
113
|
+
Introduce a dedicated supervisor-side enrollment component, composed into `SupervisorRuntime` but implemented as its own class, with the following responsibilities:
|
|
114
|
+
|
|
115
|
+
1. poll for pending execution requests on a short interval
|
|
116
|
+
2. optionally react to a lightweight wake/signal channel for lower-latency detection
|
|
117
|
+
3. normalize them into enrollment candidates
|
|
118
|
+
4. pass those candidates through a scheduling policy
|
|
119
|
+
5. hand the resulting decisions to `RunCoordinator`, which remains the only mutator of queue and cluster state
|
|
120
|
+
|
|
121
|
+
### 2.2 Explicit Non-Decision
|
|
122
|
+
|
|
123
|
+
The new component MUST NOT:
|
|
124
|
+
|
|
125
|
+
- directly initialize feature clusters
|
|
126
|
+
- directly mutate `state.queue`
|
|
127
|
+
- directly mark requests applied or rejected
|
|
128
|
+
- directly reorder the queue using internal heuristics beyond what the scheduler returns
|
|
129
|
+
|
|
130
|
+
Those responsibilities remain in `RunCoordinator`.
|
|
131
|
+
|
|
132
|
+
### 2.3 Why This Design
|
|
133
|
+
|
|
134
|
+
This approach:
|
|
135
|
+
|
|
136
|
+
- fixes the current latency defect
|
|
137
|
+
- avoids pushing more logic into `SupervisorRuntime`
|
|
138
|
+
- preserves a clean seam for a future organizer agent
|
|
139
|
+
- keeps runtime state mutation serialized in one place
|
|
140
|
+
- preserves durable correctness even if reactive signaling is lost
|
|
141
|
+
- avoids making ephemeral pub/sub the sole source of truth
|
|
142
|
+
|
|
143
|
+
### 2.4 Detection vs Admission
|
|
144
|
+
|
|
145
|
+
This spec separates two concerns:
|
|
146
|
+
|
|
147
|
+
- **Detection**: noticing that a new execution request exists
|
|
148
|
+
- **Admission**: safely incorporating that request into the active execution
|
|
149
|
+
|
|
150
|
+
Reactive signaling improves detection latency.
|
|
151
|
+
|
|
152
|
+
It does **not** eliminate the need for coordinator-controlled admission, because new work may arrive while:
|
|
153
|
+
|
|
154
|
+
- a build wave is running
|
|
155
|
+
- a QA repair loop is in progress
|
|
156
|
+
- a feature cluster mutation is in progress
|
|
157
|
+
|
|
158
|
+
Therefore:
|
|
159
|
+
|
|
160
|
+
- detection may be event-driven or interval-driven
|
|
161
|
+
- admission must remain coordinator-serialized
|
|
162
|
+
|
|
163
|
+
---
|
|
164
|
+
|
|
165
|
+
## 3. Architecture Overview
|
|
166
|
+
|
|
167
|
+
### 3.1 New Components
|
|
168
|
+
|
|
169
|
+
Add the following supervisor-layer abstractions:
|
|
170
|
+
|
|
171
|
+
#### A. `ExecutionEnrollmentService`
|
|
172
|
+
|
|
173
|
+
Primary runtime-owned service responsible for:
|
|
174
|
+
|
|
175
|
+
- interval-based polling
|
|
176
|
+
- optional wake-signal subscription
|
|
177
|
+
- request detection
|
|
178
|
+
- buffering or signaling newly available enrollment work
|
|
179
|
+
- invoking the scheduler
|
|
180
|
+
- exposing a safe `drainReadyDecisions()` API to the coordinator
|
|
181
|
+
|
|
182
|
+
This is the main new class required by this spec.
|
|
183
|
+
|
|
184
|
+
#### B. `EnrollmentScheduler` interface
|
|
185
|
+
|
|
186
|
+
Policy interface responsible for classifying enrollment candidates.
|
|
187
|
+
|
|
188
|
+
Initial implementation:
|
|
189
|
+
|
|
190
|
+
- `CapacityAwareEnrollmentScheduler`
|
|
191
|
+
|
|
192
|
+
Future implementation:
|
|
193
|
+
|
|
194
|
+
- `OrganizerAgentEnrollmentScheduler`
|
|
195
|
+
|
|
196
|
+
#### C. `EnrollmentDecision`
|
|
197
|
+
|
|
198
|
+
Value type describing what should happen to each requested feature.
|
|
199
|
+
|
|
200
|
+
Allowed decisions:
|
|
201
|
+
|
|
202
|
+
- `queue_now`
|
|
203
|
+
- `defer`
|
|
204
|
+
- `reject`
|
|
205
|
+
|
|
206
|
+
### 3.2 Existing Components That Remain Authoritative
|
|
207
|
+
|
|
208
|
+
#### `SupervisorRuntime`
|
|
209
|
+
|
|
210
|
+
Remains the composition root only:
|
|
211
|
+
|
|
212
|
+
- creates and starts `ExecutionEnrollmentService`
|
|
213
|
+
- stops it during runtime shutdown
|
|
214
|
+
- injects the scheduler implementation
|
|
215
|
+
- does not absorb enrollment logic into itself
|
|
216
|
+
|
|
217
|
+
#### `RunCoordinator`
|
|
218
|
+
|
|
219
|
+
Remains the execution authority:
|
|
220
|
+
|
|
221
|
+
- drains ready enrollment decisions
|
|
222
|
+
- mutates queue state
|
|
223
|
+
- initializes clusters through existing session orchestrator flows
|
|
224
|
+
- marks execution requests applied or rejected
|
|
225
|
+
|
|
226
|
+
#### `ExecutionControlService`
|
|
227
|
+
|
|
228
|
+
Remains the durable artifact service:
|
|
229
|
+
|
|
230
|
+
- submit request
|
|
231
|
+
- list request
|
|
232
|
+
- drain pending request snapshots
|
|
233
|
+
- mark processed
|
|
234
|
+
|
|
235
|
+
This spec does not move file persistence into the supervisor.
|
|
236
|
+
|
|
237
|
+
---
|
|
238
|
+
|
|
239
|
+
## 4. New Contracts
|
|
240
|
+
|
|
241
|
+
### 4.1 `ExecutionEnrollmentService` Contract
|
|
242
|
+
|
|
243
|
+
The new class should expose methods along these lines:
|
|
244
|
+
|
|
245
|
+
```ts
|
|
246
|
+
interface ExecutionEnrollmentService {
|
|
247
|
+
start(): Promise<void>;
|
|
248
|
+
stop(): Promise<void>;
|
|
249
|
+
notifyNewRequestHint(): Promise<void>;
|
|
250
|
+
noteSafeCheckpoint(): Promise<void>;
|
|
251
|
+
drainReadyDecisions(): Promise<EnrollmentDecisionBatch[]>;
|
|
252
|
+
hasPendingWork(): boolean;
|
|
253
|
+
}
|
|
254
|
+
```
|
|
255
|
+
|
|
256
|
+
Required behavior:
|
|
257
|
+
|
|
258
|
+
- `start()` begins polling on a configured interval
|
|
259
|
+
- `stop()` stops the timer and flushes in-flight polling work
|
|
260
|
+
- `notifyNewRequestHint()` is a best-effort wake signal; it hints that the service should reconcile immediately, but correctness must not depend on it
|
|
261
|
+
- `noteSafeCheckpoint()` allows the coordinator to request immediate reconciliation after a feature-level atomic step completes
|
|
262
|
+
- `drainReadyDecisions()` returns scheduler-produced decisions that are ready for coordinator application
|
|
263
|
+
- `hasPendingWork()` allows fast-path checks without forcing a file read
|
|
264
|
+
|
|
265
|
+
### 4.2 `EnrollmentScheduler` Contract
|
|
266
|
+
|
|
267
|
+
```ts
|
|
268
|
+
interface EnrollmentScheduler {
|
|
269
|
+
schedule(input: EnrollmentSchedulingInput): Promise<EnrollmentSchedulingResult>;
|
|
270
|
+
}
|
|
271
|
+
```
|
|
272
|
+
|
|
273
|
+
`EnrollmentSchedulingInput` MUST include:
|
|
274
|
+
|
|
275
|
+
- active feature ids
|
|
276
|
+
- queued feature ids
|
|
277
|
+
- assigned feature ids from runtime sessions
|
|
278
|
+
- current `max_active_features`
|
|
279
|
+
- request items and requested features
|
|
280
|
+
- optional feature metadata needed for future dependency checks
|
|
281
|
+
|
|
282
|
+
`EnrollmentSchedulingResult` MUST return per-feature decisions with a machine-readable reason.
|
|
283
|
+
|
|
284
|
+
### 4.3 `EnrollmentDecision` Shape
|
|
285
|
+
|
|
286
|
+
```ts
|
|
287
|
+
type EnrollmentDecisionDisposition = 'queue_now' | 'defer' | 'reject';
|
|
288
|
+
|
|
289
|
+
interface EnrollmentDecision {
|
|
290
|
+
request_id: string;
|
|
291
|
+
feature_id: string;
|
|
292
|
+
disposition: EnrollmentDecisionDisposition;
|
|
293
|
+
reason: string;
|
|
294
|
+
}
|
|
295
|
+
```
|
|
296
|
+
|
|
297
|
+
Reason values for the initial scheduler MUST be deterministic and finite. At minimum:
|
|
298
|
+
|
|
299
|
+
- `capacity_available`
|
|
300
|
+
- `capacity_full`
|
|
301
|
+
- `already_active`
|
|
302
|
+
- `already_queued`
|
|
303
|
+
- `already_assigned_cluster`
|
|
304
|
+
- `terminal_status`
|
|
305
|
+
- `dependency_blocked`
|
|
306
|
+
- `scheduler_rejected`
|
|
307
|
+
|
|
308
|
+
`dependency_blocked` is reserved for the future organizer scheduler and SHOULD NOT be emitted by the initial capacity-aware scheduler unless a dependency-aware source is already present.
|
|
309
|
+
|
|
310
|
+
---
|
|
311
|
+
|
|
312
|
+
## 5. Execution Lifecycle
|
|
313
|
+
|
|
314
|
+
### 5.1 Submission
|
|
315
|
+
|
|
316
|
+
Unchanged from the current `aop add` design:
|
|
317
|
+
|
|
318
|
+
1. `aop add` resolves or resumes the target feature
|
|
319
|
+
2. CLI submits a durable `runtime.execution_request_submit`
|
|
320
|
+
3. request is written as `pending`
|
|
321
|
+
|
|
322
|
+
### 5.2 Detection
|
|
323
|
+
|
|
324
|
+
The new enrollment service uses a hybrid detection model.
|
|
325
|
+
|
|
326
|
+
Required baseline:
|
|
327
|
+
|
|
328
|
+
- `execution_enrollment_poll_interval_ms = 2000`
|
|
329
|
+
|
|
330
|
+
Polling MUST:
|
|
331
|
+
|
|
332
|
+
- read only the active run’s request set
|
|
333
|
+
- ignore non-pending requests
|
|
334
|
+
- debounce duplicate reads of the same pending request set
|
|
335
|
+
- avoid marking requests applied or rejected directly
|
|
336
|
+
|
|
337
|
+
Optional improvement:
|
|
338
|
+
|
|
339
|
+
- a lightweight in-process or artifact-backed wake signal may call `notifyNewRequestHint()` so the active supervisor does not need to wait for the next interval to notice newly submitted work
|
|
340
|
+
|
|
341
|
+
Critical rule:
|
|
342
|
+
|
|
343
|
+
- the durable execution-control artifact remains canonical
|
|
344
|
+
- wake signaling is only an optimization
|
|
345
|
+
- lost wake signals must not lose requests
|
|
346
|
+
|
|
347
|
+
### 5.3 Scheduling
|
|
348
|
+
|
|
349
|
+
For each pending request batch:
|
|
350
|
+
|
|
351
|
+
1. service gathers current runtime state snapshot
|
|
352
|
+
2. service calls the scheduler
|
|
353
|
+
3. scheduler returns one decision per requested feature
|
|
354
|
+
4. service stores those decisions in an in-memory ready queue for the coordinator
|
|
355
|
+
|
|
356
|
+
### 5.4 Application
|
|
357
|
+
|
|
358
|
+
At the next safe coordinator checkpoint:
|
|
359
|
+
|
|
360
|
+
1. `RunCoordinator` drains ready decisions
|
|
361
|
+
2. for `queue_now`:
|
|
362
|
+
- call existing feature initialization path if needed
|
|
363
|
+
- append feature to the run queue
|
|
364
|
+
- rebalance immediately if active capacity exists
|
|
365
|
+
3. for `defer`:
|
|
366
|
+
- keep the execution request `pending`
|
|
367
|
+
- do not lose the decision context
|
|
368
|
+
4. for `reject`:
|
|
369
|
+
- mark the feature rejected in the request outcome
|
|
370
|
+
|
|
371
|
+
### 5.5 Wave Routing After Enrollment
|
|
372
|
+
|
|
373
|
+
Enrollment does not imply “start planning.”
|
|
374
|
+
|
|
375
|
+
Once a feature has been admitted and promoted to active, the coordinator MUST route it by its persisted feature status, using the existing wave executors as the source of truth.
|
|
376
|
+
|
|
377
|
+
Required behavior:
|
|
378
|
+
|
|
379
|
+
- a feature in `planning` enters the planning wave
|
|
380
|
+
- a feature in `building` enters the build wave
|
|
381
|
+
- a feature in `qa` enters the QA wave
|
|
382
|
+
- a feature in `ready_to_merge` does not re-enter planning/build/QA and should follow existing post-QA/merge handling
|
|
383
|
+
- a feature in `blocked` does not automatically enter a worker wave unless existing blocked-feature recovery logic transitions it back to an executable phase
|
|
384
|
+
|
|
385
|
+
This means the scheduler never decides which wave to run. It only decides whether the feature can be admitted into the active execution. The wave executor selection remains status-driven inside the coordinator loop.
|
|
386
|
+
|
|
387
|
+
### 5.6 Checkpoint Mini-Pass Dispatch
|
|
388
|
+
|
|
389
|
+
The coordinator MUST NOT wait for a full top-level iteration boundary if newly admitted work targets an earlier wave than the wave currently in progress.
|
|
390
|
+
|
|
391
|
+
Example:
|
|
392
|
+
|
|
393
|
+
- current execution is in `buildWaveExecutor`
|
|
394
|
+
- a newly admitted feature has persisted status `planning`
|
|
395
|
+
|
|
396
|
+
Correct behavior:
|
|
397
|
+
|
|
398
|
+
1. detect the new request immediately or on the next poll
|
|
399
|
+
2. wait for the next safe checkpoint in the current build work
|
|
400
|
+
3. admit/promote the feature through the coordinator
|
|
401
|
+
4. schedule a planning mini-pass before that feature is ever considered for build
|
|
402
|
+
|
|
403
|
+
Required rule:
|
|
404
|
+
|
|
405
|
+
- if admitted work targets a phase earlier than the current phase cursor, the coordinator should run a checkpoint mini-pass for the earlier applicable wave at the next safe boundary
|
|
406
|
+
|
|
407
|
+
This avoids unnecessary full-loop latency while preserving deterministic wave ordering.
|
|
408
|
+
|
|
409
|
+
Mini-pass constraints:
|
|
410
|
+
|
|
411
|
+
- mini-passes must operate on the current active feature set
|
|
412
|
+
- mini-passes must remain status-driven
|
|
413
|
+
- mini-passes must not interrupt an in-flight worker/provider operation
|
|
414
|
+
- mini-passes must be coordinator-invoked only
|
|
415
|
+
|
|
416
|
+
### 5.7 Completion
|
|
417
|
+
|
|
418
|
+
An execution request may only be marked:
|
|
419
|
+
|
|
420
|
+
- `applied` when every requested feature has either been queued or deterministically skipped for a stable reason
|
|
421
|
+
- `rejected` when the entire request fails for a request-level error
|
|
422
|
+
|
|
423
|
+
If any requested feature remains deferred because of scheduling policy, the request MUST remain `pending`.
|
|
424
|
+
|
|
425
|
+
This is important for future organizer-agent compatibility: a feature blocked on another feature should remain visible as outstanding work, not disappear into a processed tombstone.
|
|
426
|
+
|
|
427
|
+
### 5.8 Retry Semantics
|
|
428
|
+
|
|
429
|
+
This spec MUST explicitly preserve two distinct retry mechanisms.
|
|
430
|
+
|
|
431
|
+
#### A. Inline gate-repair retries during active execution
|
|
432
|
+
|
|
433
|
+
Existing build/QA retry behavior remains unchanged:
|
|
434
|
+
|
|
435
|
+
- build-wave gate retries continue to execute inside `BuildWaveExecutor`
|
|
436
|
+
- QA-wave gate retries continue to execute inside `QaWaveExecutor`
|
|
437
|
+
- these retries do not go through the enrollment service
|
|
438
|
+
|
|
439
|
+
Reason:
|
|
440
|
+
|
|
441
|
+
- they are part of a feature already active in the current run
|
|
442
|
+
- they are local repair loops, not admission of new work into the run
|
|
443
|
+
|
|
444
|
+
#### B. Explicit `aop retry` for non-active or blocked features
|
|
445
|
+
|
|
446
|
+
Explicit retry must become compatible with the single-active-execution model.
|
|
447
|
+
|
|
448
|
+
Required behavior:
|
|
449
|
+
|
|
450
|
+
1. `aop retry` may still reset retry counters and patch feature status exactly as it does today.
|
|
451
|
+
2. If there is no active run, retry may continue to use the existing resume path.
|
|
452
|
+
3. If there is an active run for the repository, retry MUST NOT try to start a second supervisor.
|
|
453
|
+
4. Instead, after the retry state mutation/gate action completes, the feature MUST be re-enrolled through the same execution-enrollment pipeline used by `aop add --resume`.
|
|
454
|
+
|
|
455
|
+
Wave re-entry after retry MUST remain status-driven:
|
|
456
|
+
|
|
457
|
+
- forced or recovered retry targeting `building` re-enters the build wave
|
|
458
|
+
- forced or recovered retry targeting `qa` re-enters the QA wave
|
|
459
|
+
- retry that leaves the feature `blocked` does not re-enter a worker wave until blocked recovery or a subsequent explicit action changes its state
|
|
460
|
+
|
|
461
|
+
This ensures retry is a state-transition concern first and an enrollment concern second.
|
|
462
|
+
|
|
463
|
+
The enrollment service must not invent special retry-only execution paths.
|
|
464
|
+
|
|
465
|
+
---
|
|
466
|
+
|
|
467
|
+
## 6. Safe-Checkpoint Model
|
|
468
|
+
|
|
469
|
+
### 6.1 Required Checkpoints
|
|
470
|
+
|
|
471
|
+
The coordinator MUST call into the enrollment service at these safe points:
|
|
472
|
+
|
|
473
|
+
- before the initial rebalance
|
|
474
|
+
- after each feature cluster close
|
|
475
|
+
- after each per-feature planner decision
|
|
476
|
+
- after each per-feature builder decision
|
|
477
|
+
- after each per-feature QA decision
|
|
478
|
+
- after each gate run
|
|
479
|
+
- after each top-level planning/build/QA wave
|
|
480
|
+
- before runtime shutdown
|
|
481
|
+
|
|
482
|
+
These checkpoints are also the only legal places to trigger a checkpoint mini-pass.
|
|
483
|
+
|
|
484
|
+
### 6.2 Safety Rule
|
|
485
|
+
|
|
486
|
+
“Safe checkpoint” means:
|
|
487
|
+
|
|
488
|
+
- no queue mutation is currently in progress
|
|
489
|
+
- no cluster assignment mutation is currently in progress
|
|
490
|
+
- a single feature-level unit of work has just completed
|
|
491
|
+
|
|
492
|
+
The implementation MUST NOT preempt or cancel an in-flight worker operation solely to apply enrollment.
|
|
493
|
+
|
|
494
|
+
### 6.3 Responsiveness Target
|
|
495
|
+
|
|
496
|
+
This spec does not guarantee cluster creation in the middle of a long provider call.
|
|
497
|
+
|
|
498
|
+
It does require:
|
|
499
|
+
|
|
500
|
+
- request detection within one poll interval, or faster if a wake hint is delivered
|
|
501
|
+
- request visibility in logs/status immediately after detection
|
|
502
|
+
- queue application at the next safe checkpoint
|
|
503
|
+
- wave dispatch at the next safe checkpoint, including a mini-pass when newly admitted work targets an earlier phase than the current phase cursor
|
|
504
|
+
|
|
505
|
+
This is the correct consistency/performance tradeoff for the current architecture.
|
|
506
|
+
|
|
507
|
+
---
|
|
508
|
+
|
|
509
|
+
## 7. Default Scheduling Policy
|
|
510
|
+
|
|
511
|
+
### 7.1 Initial Scheduler: `CapacityAwareEnrollmentScheduler`
|
|
512
|
+
|
|
513
|
+
The first scheduler implementation MUST be intentionally simple:
|
|
514
|
+
|
|
515
|
+
- if feature is already active: `reject` with `already_active`
|
|
516
|
+
- if feature is already queued: `reject` with `already_queued`
|
|
517
|
+
- if feature is already assigned in runtime sessions: `reject` with `already_assigned_cluster`
|
|
518
|
+
- if feature is terminal: `reject` with `terminal_status`
|
|
519
|
+
- otherwise:
|
|
520
|
+
- if active capacity is available or the queue is allowed to grow: `queue_now`
|
|
521
|
+
- if policy explicitly wants deferred behavior when queue growth should be organizer-controlled: `defer` with `capacity_full`
|
|
522
|
+
|
|
523
|
+
Recommended initial behavior:
|
|
524
|
+
|
|
525
|
+
- allow queue growth under capacity pressure
|
|
526
|
+
- use `defer` only when future organizer behavior is explicitly enabled or when dependency metadata blocks it
|
|
527
|
+
|
|
528
|
+
### 7.2 Organizer-Agent Compatibility
|
|
529
|
+
|
|
530
|
+
The future organizer agent should plug in by implementing `EnrollmentScheduler`.
|
|
531
|
+
|
|
532
|
+
That scheduler may:
|
|
533
|
+
|
|
534
|
+
- inspect dependency metadata
|
|
535
|
+
- rank features
|
|
536
|
+
- declare a feature blocked until another feature reaches a required state
|
|
537
|
+
- allow only certain features to enter the queue
|
|
538
|
+
|
|
539
|
+
The poller and coordinator MUST NOT need redesign for that future swap.
|
|
540
|
+
|
|
541
|
+
### 7.3 Policy Separation
|
|
542
|
+
|
|
543
|
+
Do not encode organizer behavior into:
|
|
544
|
+
|
|
545
|
+
- `ExecutionEnrollmentService`
|
|
546
|
+
- `SupervisorRuntime`
|
|
547
|
+
- `ExecutionControlService`
|
|
548
|
+
|
|
549
|
+
Only the scheduler should decide ordering/dependency outcomes.
|
|
550
|
+
|
|
551
|
+
### 7.4 Retry Is Not Scheduling Policy
|
|
552
|
+
|
|
553
|
+
Retry eligibility, gate retry counters, and blocked-feature recovery MUST remain outside the scheduler abstraction.
|
|
554
|
+
|
|
555
|
+
The scheduler may observe feature status and decide whether a feature can be admitted, but it MUST NOT:
|
|
556
|
+
|
|
557
|
+
- increment or reset `gate_retry_count`
|
|
558
|
+
- infer repair prompts
|
|
559
|
+
- run gates directly
|
|
560
|
+
- replace blocked-feature recovery
|
|
561
|
+
|
|
562
|
+
Those remain existing execution concerns owned by the CLI retry flow, run coordinator, and wave executors.
|
|
563
|
+
|
|
564
|
+
---
|
|
565
|
+
|
|
566
|
+
## 8. Runtime Artifacts and Status Projection
|
|
567
|
+
|
|
568
|
+
### 8.1 Execution Request Artifact
|
|
569
|
+
|
|
570
|
+
The existing `.aop/runtime/<instanceId>/execution-control.json` artifact remains canonical.
|
|
571
|
+
|
|
572
|
+
This spec adds meaning to `pending`:
|
|
573
|
+
|
|
574
|
+
- `pending` may now mean “not yet detected” or “detected but deferred by scheduler”
|
|
575
|
+
|
|
576
|
+
### 8.2 Optional In-Memory Only State
|
|
577
|
+
|
|
578
|
+
The enrollment service may keep transient in-memory state such as:
|
|
579
|
+
|
|
580
|
+
- last observed pending request fingerprint
|
|
581
|
+
- ready decisions awaiting coordinator application
|
|
582
|
+
- deferred decisions with timestamps
|
|
583
|
+
|
|
584
|
+
This state MUST be reconstructible from durable artifacts and live runtime state after process restart.
|
|
585
|
+
|
|
586
|
+
### 8.3 Status Output Requirements
|
|
587
|
+
|
|
588
|
+
`aop status` and dashboard projections SHOULD be updated to distinguish:
|
|
589
|
+
|
|
590
|
+
- `pending_unseen`
|
|
591
|
+
- `pending_deferred`
|
|
592
|
+
- `applied`
|
|
593
|
+
- `rejected`
|
|
594
|
+
|
|
595
|
+
If adding new outward-facing states is too disruptive for this milestone, status MUST at minimum include:
|
|
596
|
+
|
|
597
|
+
- that the request is still pending
|
|
598
|
+
- whether the supervisor has detected it
|
|
599
|
+
- whether the scheduler deferred it and why
|
|
600
|
+
|
|
601
|
+
---
|
|
602
|
+
|
|
603
|
+
## 9. Logging and Observability
|
|
604
|
+
|
|
605
|
+
### 9.1 Required Runtime Events
|
|
606
|
+
|
|
607
|
+
Add structured runtime events for:
|
|
608
|
+
|
|
609
|
+
- execution request detected
|
|
610
|
+
- execution request wake hint received
|
|
611
|
+
- scheduler evaluated request
|
|
612
|
+
- feature queued from request
|
|
613
|
+
- feature deferred from request
|
|
614
|
+
- checkpoint mini-pass scheduled
|
|
615
|
+
- checkpoint mini-pass executed
|
|
616
|
+
- request applied
|
|
617
|
+
- request rejected
|
|
618
|
+
|
|
619
|
+
### 9.2 Logging Requirements
|
|
620
|
+
|
|
621
|
+
When a request is detected, the active CLI session SHOULD emit a concise log line such as:
|
|
622
|
+
|
|
623
|
+
```text
|
|
624
|
+
[enrollment] detected request exec_req_123 for feature_a
|
|
625
|
+
```
|
|
626
|
+
|
|
627
|
+
When a feature is deferred:
|
|
628
|
+
|
|
629
|
+
```text
|
|
630
|
+
[enrollment] deferred feature_a: capacity_full
|
|
631
|
+
```
|
|
632
|
+
|
|
633
|
+
When a feature is queued:
|
|
634
|
+
|
|
635
|
+
```text
|
|
636
|
+
[enrollment] queued feature_a from request exec_req_123
|
|
637
|
+
```
|
|
638
|
+
|
|
639
|
+
This addresses the current operator blind spot.
|
|
640
|
+
|
|
641
|
+
---
|
|
642
|
+
|
|
643
|
+
## 10. Failure Handling
|
|
644
|
+
|
|
645
|
+
### 10.1 Polling Failure
|
|
646
|
+
|
|
647
|
+
If polling the execution-control artifact fails:
|
|
648
|
+
|
|
649
|
+
- supervisor should log the failure
|
|
650
|
+
- enrollment polling should retry on the next interval
|
|
651
|
+
- the run should not fail unless the failure indicates a corrupted invariant or unrecoverable schema error
|
|
652
|
+
|
|
653
|
+
### 10.2 Scheduler Failure
|
|
654
|
+
|
|
655
|
+
If the scheduler throws:
|
|
656
|
+
|
|
657
|
+
- the request MUST remain `pending`
|
|
658
|
+
- the failure should be logged with request id and feature ids
|
|
659
|
+
- the supervisor should continue running
|
|
660
|
+
|
|
661
|
+
If wake signaling fails or is dropped:
|
|
662
|
+
|
|
663
|
+
- the request must still be detected by baseline polling
|
|
664
|
+
- no request may depend solely on pub/sub delivery for correctness
|
|
665
|
+
|
|
666
|
+
### 10.3 Coordinator Application Failure
|
|
667
|
+
|
|
668
|
+
If coordinator application fails for a specific feature:
|
|
669
|
+
|
|
670
|
+
- the request MUST remain `pending` unless a deterministic reject outcome can be recorded safely
|
|
671
|
+
- partial application MUST be represented explicitly in the request outcome
|
|
672
|
+
- duplicate queue insertion MUST remain impossible
|
|
673
|
+
|
|
674
|
+
### 10.4 Restart Behavior
|
|
675
|
+
|
|
676
|
+
After supervisor restart:
|
|
677
|
+
|
|
678
|
+
- pending requests MUST still be visible from the artifact
|
|
679
|
+
- deferred work MUST be re-evaluated by the scheduler
|
|
680
|
+
- no orphan in-memory decision state may be required for correctness
|
|
681
|
+
|
|
682
|
+
---
|
|
683
|
+
|
|
684
|
+
## 11. Files To Add or Modify
|
|
685
|
+
|
|
686
|
+
### 11.1 New Files
|
|
687
|
+
|
|
688
|
+
- `apps/control-plane/src/supervisor/execution-enrollment-service.ts`
|
|
689
|
+
- `apps/control-plane/test/execution-enrollment-service.spec.ts`
|
|
690
|
+
|
|
691
|
+
### 11.2 Likely Modified Files
|
|
692
|
+
|
|
693
|
+
- `apps/control-plane/src/supervisor/runtime.ts`
|
|
694
|
+
- `apps/control-plane/src/supervisor/run-coordinator.ts`
|
|
695
|
+
- `apps/control-plane/src/supervisor/types.ts`
|
|
696
|
+
- `apps/control-plane/src/application/services/execution-control-service.ts`
|
|
697
|
+
- `apps/control-plane/src/cli/status-command-handler.ts`
|
|
698
|
+
- `apps/control-plane/test/run-coordinator.spec.ts`
|
|
699
|
+
- `apps/control-plane/test/supervisor.spec.ts`
|
|
700
|
+
- `apps/control-plane/test/cli.unit.spec.ts`
|
|
701
|
+
|
|
702
|
+
### 11.3 Optional but Recommended Files
|
|
703
|
+
|
|
704
|
+
- `apps/control-plane/src/application/services/reporting-service.ts`
|
|
705
|
+
- dashboard-related status projection utilities if they surface execution request state
|
|
706
|
+
|
|
707
|
+
---
|
|
708
|
+
|
|
709
|
+
## 12. Milestones
|
|
710
|
+
|
|
711
|
+
### M50.1 — Introduce `ExecutionEnrollmentService`
|
|
712
|
+
|
|
713
|
+
Create a dedicated supervisor component that:
|
|
714
|
+
|
|
715
|
+
- owns timer lifecycle
|
|
716
|
+
- optionally accepts wake hints
|
|
717
|
+
- polls pending execution requests
|
|
718
|
+
- buffers ready scheduling decisions
|
|
719
|
+
- exposes a coordinator-facing drain API
|
|
720
|
+
|
|
721
|
+
### M50.2 — Add Hybrid Detection
|
|
722
|
+
|
|
723
|
+
Add best-effort reactive wake signaling on top of durable polling, without making signaling the sole source of truth.
|
|
724
|
+
|
|
725
|
+
### M50.3 — Add Scheduler Abstraction
|
|
726
|
+
|
|
727
|
+
Create `EnrollmentScheduler` and default `CapacityAwareEnrollmentScheduler`.
|
|
728
|
+
|
|
729
|
+
Acceptance:
|
|
730
|
+
|
|
731
|
+
- no scheduling policy lives inside `SupervisorRuntime`
|
|
732
|
+
- future organizer-agent-backed implementation can be added without changing poller transport
|
|
733
|
+
|
|
734
|
+
### M50.4 — Coordinator Safe Checkpoints
|
|
735
|
+
|
|
736
|
+
Refactor `RunCoordinator` to call the enrollment service at safe checkpoints and apply ready decisions through coordinator-owned queue mutation.
|
|
737
|
+
|
|
738
|
+
### M50.5 — Checkpoint Mini-Pass Dispatch
|
|
739
|
+
|
|
740
|
+
Teach the coordinator to run the appropriate earlier-wave mini-pass at the next safe checkpoint when newly admitted work would otherwise wait for a full loop cycle.
|
|
741
|
+
|
|
742
|
+
### M50.6 — Request Outcome Semantics for Deferred Work
|
|
743
|
+
|
|
744
|
+
Adjust request processing semantics so deferred features keep the request pending rather than being prematurely marked applied.
|
|
745
|
+
|
|
746
|
+
### M50.7 — Logging and Status Visibility
|
|
747
|
+
|
|
748
|
+
Emit structured enrollment logs and surface deferred/pending/applied state in status output.
|
|
749
|
+
|
|
750
|
+
### M50.8 — Status-Driven Wave Routing
|
|
751
|
+
|
|
752
|
+
Make the spec- and test-level contract explicit that admitted features re-enter the matching wave by persisted status, including `--resume` and retry-driven re-entry.
|
|
753
|
+
|
|
754
|
+
### M50.9 — Retry Compatibility with Active Execution
|
|
755
|
+
|
|
756
|
+
Ensure explicit retry can re-enroll into the active execution instead of attempting to create a second supervisor run when a fresh run lease already exists.
|
|
757
|
+
|
|
758
|
+
### M50.10 — Restart and Recovery Semantics
|
|
759
|
+
|
|
760
|
+
Ensure pending/deferred requests are re-evaluated after restart with no reliance on transient state.
|
|
761
|
+
|
|
762
|
+
### M50.11 — Organizer-Agent Extension Seam
|
|
763
|
+
|
|
764
|
+
Document and test the scheduler substitution point for a future organizer-agent implementation.
|
|
765
|
+
|
|
766
|
+
---
|
|
767
|
+
|
|
768
|
+
## 13. Acceptance Criteria
|
|
769
|
+
|
|
770
|
+
Implementation is complete when all of the following are true:
|
|
771
|
+
|
|
772
|
+
1. `aop add --resume <feature-id>` is detected by a live supervisor without waiting for the next full wave cycle.
|
|
773
|
+
2. Detection occurs within the configured poll interval.
|
|
774
|
+
3. The active CLI logs that the request was detected and whether it was queued or deferred.
|
|
775
|
+
4. Queue and cluster mutation still happen only through `RunCoordinator`.
|
|
776
|
+
5. The design introduces a separate enrollment class instead of adding more control-plane logic into `SupervisorRuntime`.
|
|
777
|
+
6. Admitted features enter the wave implied by their persisted status rather than always re-entering planning.
|
|
778
|
+
7. If a newly admitted feature targets an earlier phase than the currently executing wave, the coordinator dispatches it via a checkpoint mini-pass at the next safe boundary instead of waiting for a full loop restart.
|
|
779
|
+
8. Reactive wake signaling is optional and improves latency, but durable polling remains sufficient for correctness.
|
|
780
|
+
9. Explicit retry under an active run re-enrolls through the same enrollment pipeline instead of spawning a second supervisor.
|
|
781
|
+
10. The default scheduler is replaceable with a future organizer-agent scheduler.
|
|
782
|
+
11. Deferred requests remain durable and visible; they are not silently marked applied.
|
|
783
|
+
12. Restarting the supervisor does not lose pending enrollment work.
|
|
784
|
+
13. Existing run lease, session ownership, and reconciler invariants continue to hold.
|
|
785
|
+
|
|
786
|
+
---
|
|
787
|
+
|
|
788
|
+
## 14. Test Plan
|
|
789
|
+
|
|
790
|
+
### 14.1 Unit Tests
|
|
791
|
+
|
|
792
|
+
Add tests for:
|
|
793
|
+
|
|
794
|
+
- poll interval detection of pending requests
|
|
795
|
+
- wake-hint-triggered early detection without requiring the next interval
|
|
796
|
+
- duplicate pending request fingerprints
|
|
797
|
+
- scheduler decision mapping
|
|
798
|
+
- deferred requests remaining pending
|
|
799
|
+
- ready decisions draining exactly once
|
|
800
|
+
- stop/start lifecycle behavior
|
|
801
|
+
|
|
802
|
+
### 14.2 Coordinator Tests
|
|
803
|
+
|
|
804
|
+
Add or update tests for:
|
|
805
|
+
|
|
806
|
+
- applying ready decisions at safe checkpoints
|
|
807
|
+
- immediate rebalance when capacity exists
|
|
808
|
+
- planning feature admitted during build causing a planning mini-pass at the next safe checkpoint
|
|
809
|
+
- QA feature admitted during planning or build causing the correct status-routed dispatch
|
|
810
|
+
- deferred requests remaining pending
|
|
811
|
+
- reject reasons for already active/queued/terminal features
|
|
812
|
+
- no duplicate queue insertion
|
|
813
|
+
|
|
814
|
+
### 14.3 Supervisor Integration Tests
|
|
815
|
+
|
|
816
|
+
Add integration tests for:
|
|
817
|
+
|
|
818
|
+
- submitting an add request during a live run and observing detection without restart
|
|
819
|
+
- request remaining pending while current worker unit is in-flight
|
|
820
|
+
- request applying at next safe checkpoint
|
|
821
|
+
- request detected through wake hint with polling fallback still available
|
|
822
|
+
- resumed `building` feature entering build rather than planning
|
|
823
|
+
- resumed `qa` feature entering QA rather than planning
|
|
824
|
+
- explicit retry under an active run re-enrolling via the execution enrollment path
|
|
825
|
+
- restart and recovery of deferred work
|
|
826
|
+
|
|
827
|
+
### 14.4 Status/UX Tests
|
|
828
|
+
|
|
829
|
+
Add tests for:
|
|
830
|
+
|
|
831
|
+
- status output showing detected pending requests
|
|
832
|
+
- status output showing deferred reasons
|
|
833
|
+
- runtime logging for detection, queue, and defer events
|
|
834
|
+
|
|
835
|
+
---
|
|
836
|
+
|
|
837
|
+
## 15. Open Questions
|
|
838
|
+
|
|
839
|
+
1. Should `pending_deferred` become a first-class durable request status, or should it remain `pending` with richer outcome metadata?
|
|
840
|
+
2. Should the initial scheduler always allow queue growth, or should queue admission be configurable to reserve queue ordering for the future organizer agent?
|
|
841
|
+
3. What is the correct operator-facing SLA for “near-real-time” detection in deterministic mode versus interactive mode?
|
|
842
|
+
4. Should the initial wake signal be implemented as an in-memory notifier only, or should it also support an artifact-backed trigger for multi-process robustness?
|
|
843
|
+
|
|
844
|
+
Recommended answer for this milestone:
|
|
845
|
+
|
|
846
|
+
- keep durable status as `pending`
|
|
847
|
+
- include defer reason in status projection
|
|
848
|
+
- allow queue growth by default
|
|
849
|
+
- set the default poll interval to 2000 ms
|
|
850
|
+
- treat wake signaling as a best-effort optimization layered on top of polling
|
|
851
|
+
|
|
852
|
+
---
|
|
853
|
+
|
|
854
|
+
## 16. Summary
|
|
855
|
+
|
|
856
|
+
This spec replaces coarse, loop-bound request handling with a dedicated enrollment service, optional reactive wake signaling, checkpoint mini-pass dispatch, and a pluggable scheduler architecture.
|
|
857
|
+
|
|
858
|
+
It solves the immediate problem:
|
|
859
|
+
|
|
860
|
+
- `aop add` becomes reactive enough to feel live without sacrificing deterministic coordinator ownership
|
|
861
|
+
|
|
862
|
+
while preserving the future direction:
|
|
863
|
+
|
|
864
|
+
- an external organizer agent can later become the scheduling policy without forcing a second redesign of polling, request persistence, or coordinator ownership.
|