gsd-pi 2.33.1 → 2.34.0-dev.bbb5216
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/dist/bundled-resource-path.d.ts +8 -0
- package/dist/bundled-resource-path.js +14 -0
- package/dist/cli.js +16 -0
- package/dist/headless-query.js +6 -6
- package/dist/resource-loader.d.ts +2 -0
- package/dist/resource-loader.js +39 -4
- package/dist/resources/extensions/ask-user-questions.js +217 -0
- package/dist/resources/extensions/async-jobs/async-bash-tool.js +180 -0
- package/dist/resources/extensions/async-jobs/await-tool.js +90 -0
- package/dist/resources/extensions/async-jobs/cancel-job-tool.js +28 -0
- package/dist/resources/extensions/async-jobs/index.js +119 -0
- package/dist/resources/extensions/async-jobs/job-manager.js +159 -0
- package/dist/resources/extensions/aws-auth/index.js +138 -0
- package/dist/resources/extensions/bg-shell/bg-shell-command.js +182 -0
- package/dist/resources/extensions/bg-shell/bg-shell-lifecycle.js +343 -0
- package/dist/resources/extensions/bg-shell/bg-shell-tool.js +831 -0
- package/dist/resources/extensions/bg-shell/index.js +41 -0
- package/dist/resources/extensions/bg-shell/interaction.js +160 -0
- package/dist/resources/extensions/bg-shell/output-formatter.js +245 -0
- package/dist/resources/extensions/bg-shell/overlay.js +378 -0
- package/dist/resources/extensions/bg-shell/process-manager.js +413 -0
- package/dist/resources/extensions/bg-shell/readiness-detector.js +109 -0
- package/dist/resources/extensions/bg-shell/types.js +96 -0
- package/dist/resources/extensions/bg-shell/utilities.js +50 -0
- package/dist/resources/extensions/browser-tools/capture.js +179 -0
- package/dist/resources/extensions/browser-tools/core.js +899 -0
- package/dist/resources/extensions/browser-tools/{evaluate-helpers.ts → evaluate-helpers.js} +0 -1
- package/dist/resources/extensions/browser-tools/index.js +123 -0
- package/dist/resources/extensions/browser-tools/lifecycle.js +222 -0
- package/dist/resources/extensions/browser-tools/refs.js +254 -0
- package/dist/resources/extensions/browser-tools/settle.js +173 -0
- package/dist/resources/extensions/browser-tools/state.js +126 -0
- package/dist/resources/extensions/browser-tools/tools/action-cache.js +179 -0
- package/dist/resources/extensions/browser-tools/tools/assertions.js +320 -0
- package/dist/resources/extensions/browser-tools/tools/codegen.js +242 -0
- package/dist/resources/extensions/browser-tools/tools/device.js +162 -0
- package/dist/resources/extensions/browser-tools/tools/extract.js +191 -0
- package/dist/resources/extensions/browser-tools/tools/forms.js +710 -0
- package/dist/resources/extensions/browser-tools/tools/injection-detect.js +178 -0
- package/dist/resources/extensions/browser-tools/tools/inspection.js +426 -0
- package/dist/resources/extensions/browser-tools/tools/intent.js +556 -0
- package/dist/resources/extensions/browser-tools/tools/interaction.js +776 -0
- package/dist/resources/extensions/browser-tools/tools/navigation.js +208 -0
- package/dist/resources/extensions/browser-tools/tools/network-mock.js +194 -0
- package/dist/resources/extensions/browser-tools/tools/pages.js +280 -0
- package/dist/resources/extensions/browser-tools/tools/pdf.js +74 -0
- package/dist/resources/extensions/browser-tools/tools/refs.js +485 -0
- package/dist/resources/extensions/browser-tools/tools/screenshot.js +87 -0
- package/dist/resources/extensions/browser-tools/tools/session.js +375 -0
- package/dist/resources/extensions/browser-tools/tools/state-persistence.js +180 -0
- package/dist/resources/extensions/browser-tools/tools/visual-diff.js +174 -0
- package/dist/resources/extensions/browser-tools/tools/wait.js +201 -0
- package/dist/resources/extensions/browser-tools/tools/zoom.js +90 -0
- package/dist/resources/extensions/browser-tools/utils.js +490 -0
- package/dist/resources/extensions/context7/index.js +337 -0
- package/dist/resources/extensions/get-secrets-from-user.js +492 -0
- package/dist/resources/extensions/google-search/index.js +373 -0
- package/dist/resources/extensions/gsd/activity-log.js +146 -0
- package/dist/resources/extensions/gsd/atomic-write.js +38 -0
- package/dist/resources/extensions/gsd/auto/session.js +182 -0
- package/dist/resources/extensions/gsd/auto-budget.js +30 -0
- package/dist/resources/extensions/gsd/auto-dashboard.js +429 -0
- package/dist/resources/extensions/gsd/auto-direct-dispatch.js +185 -0
- package/dist/resources/extensions/gsd/auto-dispatch.js +353 -0
- package/dist/resources/extensions/gsd/auto-loop.js +956 -0
- package/dist/resources/extensions/gsd/auto-model-selection.js +133 -0
- package/dist/resources/extensions/gsd/auto-observability.js +56 -0
- package/dist/resources/extensions/gsd/auto-post-unit.js +385 -0
- package/dist/resources/extensions/gsd/auto-prompts.js +1153 -0
- package/dist/resources/extensions/gsd/auto-recovery.js +512 -0
- package/dist/resources/extensions/gsd/auto-start.js +414 -0
- package/dist/resources/extensions/gsd/auto-supervisor.js +47 -0
- package/dist/resources/extensions/gsd/auto-timeout-recovery.js +183 -0
- package/dist/resources/extensions/gsd/auto-timers.js +180 -0
- package/dist/resources/extensions/gsd/auto-tool-tracking.js +50 -0
- package/dist/resources/extensions/gsd/auto-unit-closeout.js +30 -0
- package/dist/resources/extensions/gsd/auto-verification.js +171 -0
- package/dist/resources/extensions/gsd/auto-worktree-sync.js +167 -0
- package/dist/resources/extensions/gsd/auto-worktree.js +830 -0
- package/dist/resources/extensions/gsd/auto.js +765 -0
- package/dist/resources/extensions/gsd/{cache.ts → cache.js} +5 -7
- package/dist/resources/extensions/gsd/captures.js +354 -0
- package/dist/resources/extensions/gsd/claude-import.js +540 -0
- package/dist/resources/extensions/gsd/collision-diagnostics.js +226 -0
- package/dist/resources/extensions/gsd/commands-bootstrap.js +223 -0
- package/dist/resources/extensions/gsd/commands-config.js +89 -0
- package/dist/resources/extensions/gsd/commands-extensions.js +259 -0
- package/dist/resources/extensions/gsd/commands-handlers.js +310 -0
- package/dist/resources/extensions/gsd/commands-inspect.js +70 -0
- package/dist/resources/extensions/gsd/commands-logs.js +468 -0
- package/dist/resources/extensions/gsd/commands-maintenance.js +185 -0
- package/dist/resources/extensions/gsd/commands-prefs-wizard.js +660 -0
- package/dist/resources/extensions/gsd/commands-workflow-templates.js +408 -0
- package/dist/resources/extensions/gsd/commands.js +1024 -0
- package/dist/resources/extensions/gsd/complexity-classifier.js +257 -0
- package/dist/resources/extensions/gsd/{constants.ts → constants.js} +0 -6
- package/dist/resources/extensions/gsd/context-budget.js +187 -0
- package/dist/resources/extensions/gsd/context-store.js +165 -0
- package/dist/resources/extensions/gsd/crash-recovery.js +110 -0
- package/dist/resources/extensions/gsd/dashboard-overlay.js +562 -0
- package/dist/resources/extensions/gsd/db-writer.js +298 -0
- package/dist/resources/extensions/gsd/debug-logger.js +161 -0
- package/dist/resources/extensions/gsd/detection.js +373 -0
- package/dist/resources/extensions/gsd/diff-context.js +168 -0
- package/dist/resources/extensions/gsd/dispatch-guard.js +75 -0
- package/dist/resources/extensions/gsd/docs/preferences-reference.md +25 -18
- package/dist/resources/extensions/gsd/doctor-checks.js +562 -0
- package/dist/resources/extensions/gsd/doctor-environment.js +429 -0
- package/dist/resources/extensions/gsd/doctor-format.js +71 -0
- package/dist/resources/extensions/gsd/doctor-proactive.js +239 -0
- package/dist/resources/extensions/gsd/doctor-providers.js +292 -0
- package/dist/resources/extensions/gsd/doctor-types.js +12 -0
- package/dist/resources/extensions/gsd/doctor.js +672 -0
- package/dist/resources/extensions/gsd/error-utils.js +6 -0
- package/dist/resources/extensions/gsd/{errors.ts → errors.js} +6 -11
- package/dist/resources/extensions/gsd/exit-command.js +11 -0
- package/dist/resources/extensions/gsd/{export-html.ts → export-html.js} +482 -614
- package/dist/resources/extensions/gsd/export.js +268 -0
- package/dist/resources/extensions/gsd/file-watcher.js +76 -0
- package/dist/resources/extensions/gsd/files.js +937 -0
- package/dist/resources/extensions/gsd/forensics.js +511 -0
- package/dist/resources/extensions/gsd/{git-constants.ts → git-constants.js} +4 -5
- package/dist/resources/extensions/gsd/git-self-heal.js +113 -0
- package/dist/resources/extensions/gsd/git-service.js +460 -0
- package/dist/resources/extensions/gsd/{gitignore.ts → gitignore.js} +98 -125
- package/dist/resources/extensions/gsd/gsd-db.js +735 -0
- package/dist/resources/extensions/gsd/guided-flow-queue.js +366 -0
- package/dist/resources/extensions/gsd/guided-flow.js +1158 -0
- package/dist/resources/extensions/gsd/health-widget.js +141 -0
- package/dist/resources/extensions/gsd/history.js +118 -0
- package/dist/resources/extensions/gsd/index.js +1114 -0
- package/dist/resources/extensions/gsd/init-wizard.js +479 -0
- package/dist/resources/extensions/gsd/json-persistence.js +62 -0
- package/dist/resources/extensions/gsd/{jsonl-utils.ts → jsonl-utils.js} +10 -7
- package/dist/resources/extensions/gsd/key-manager.js +829 -0
- package/dist/resources/extensions/gsd/marketplace-discovery.js +356 -0
- package/dist/resources/extensions/gsd/md-importer.js +440 -0
- package/dist/resources/extensions/gsd/memory-extractor.js +295 -0
- package/dist/resources/extensions/gsd/memory-store.js +351 -0
- package/dist/resources/extensions/gsd/metrics.js +377 -0
- package/dist/resources/extensions/gsd/migrate/command.js +157 -0
- package/dist/resources/extensions/gsd/migrate/index.js +7 -0
- package/dist/resources/extensions/gsd/migrate/parser.js +268 -0
- package/dist/resources/extensions/gsd/migrate/parsers.js +477 -0
- package/dist/resources/extensions/gsd/migrate/preview.js +47 -0
- package/dist/resources/extensions/gsd/migrate/transformer.js +278 -0
- package/dist/resources/extensions/gsd/migrate/types.js +4 -0
- package/dist/resources/extensions/gsd/migrate/validator.js +41 -0
- package/dist/resources/extensions/gsd/migrate/writer.js +477 -0
- package/dist/resources/extensions/gsd/migrate-external.js +130 -0
- package/dist/resources/extensions/gsd/milestone-actions.js +111 -0
- package/dist/resources/extensions/gsd/{milestone-ids.ts → milestone-ids.js} +50 -63
- package/dist/resources/extensions/gsd/model-cost-table.js +48 -0
- package/dist/resources/extensions/gsd/model-router.js +187 -0
- package/dist/resources/extensions/gsd/namespaced-registry.js +322 -0
- package/dist/resources/extensions/gsd/namespaced-resolver.js +176 -0
- package/dist/resources/extensions/gsd/native-git-bridge.js +842 -0
- package/dist/resources/extensions/gsd/native-parser-bridge.js +156 -0
- package/dist/resources/extensions/gsd/notifications.js +58 -0
- package/dist/resources/extensions/gsd/observability-validator.js +398 -0
- package/dist/resources/extensions/gsd/parallel-eligibility.js +182 -0
- package/dist/resources/extensions/gsd/parallel-merge.js +121 -0
- package/dist/resources/extensions/gsd/parallel-orchestrator.js +687 -0
- package/dist/resources/extensions/gsd/paths.js +414 -0
- package/dist/resources/extensions/gsd/plugin-importer.js +254 -0
- package/dist/resources/extensions/gsd/post-unit-hooks.js +433 -0
- package/dist/resources/extensions/gsd/preferences-models.js +294 -0
- package/dist/resources/extensions/gsd/preferences-skills.js +154 -0
- package/dist/resources/extensions/gsd/preferences-types.js +73 -0
- package/dist/resources/extensions/gsd/preferences-validation.js +607 -0
- package/dist/resources/extensions/gsd/preferences.js +325 -0
- package/dist/resources/extensions/gsd/progress-score.js +102 -0
- package/dist/resources/extensions/gsd/prompt-cache-optimizer.js +150 -0
- package/dist/resources/extensions/gsd/prompt-compressor.js +393 -0
- package/dist/resources/extensions/gsd/prompt-loader.js +119 -0
- package/dist/resources/extensions/gsd/prompt-ordering.js +170 -0
- package/dist/resources/extensions/gsd/provider-error-pause.js +60 -0
- package/dist/resources/extensions/gsd/queue-order.js +178 -0
- package/dist/resources/extensions/gsd/queue-reorder-ui.js +234 -0
- package/dist/resources/extensions/gsd/quick.js +206 -0
- package/dist/resources/extensions/gsd/repo-identity.js +187 -0
- package/dist/resources/extensions/gsd/{reports.ts → reports.js} +146 -241
- package/dist/resources/extensions/gsd/{resource-version.ts → resource-version.js} +50 -53
- package/dist/resources/extensions/gsd/roadmap-slices.js +130 -0
- package/dist/resources/extensions/gsd/routing-history.js +210 -0
- package/dist/resources/extensions/gsd/safe-fs.js +52 -0
- package/dist/resources/extensions/gsd/semantic-chunker.js +254 -0
- package/dist/resources/extensions/gsd/session-forensics.js +427 -0
- package/dist/resources/extensions/gsd/session-lock.js +397 -0
- package/dist/resources/extensions/gsd/session-status-io.js +134 -0
- package/dist/resources/extensions/gsd/skill-discovery.js +121 -0
- package/dist/resources/extensions/gsd/skill-health.js +324 -0
- package/dist/resources/extensions/gsd/{skill-telemetry.ts → skill-telemetry.js} +58 -74
- package/dist/resources/extensions/gsd/state.js +653 -0
- package/dist/resources/extensions/gsd/structured-data-formatter.js +97 -0
- package/dist/resources/extensions/gsd/summary-distiller.js +212 -0
- package/dist/resources/extensions/gsd/templates/preferences.md +1 -0
- package/dist/resources/extensions/gsd/token-counter.js +54 -0
- package/dist/resources/extensions/gsd/triage-resolution.js +217 -0
- package/dist/resources/extensions/gsd/triage-ui.js +125 -0
- package/dist/resources/extensions/gsd/types.js +4 -0
- package/dist/resources/extensions/gsd/undo.js +205 -0
- package/dist/resources/extensions/gsd/unit-id.js +7 -0
- package/dist/resources/extensions/gsd/unit-runtime.js +131 -0
- package/dist/resources/extensions/gsd/validate-directory.js +143 -0
- package/dist/resources/extensions/gsd/verification-evidence.js +122 -0
- package/dist/resources/extensions/gsd/verification-gate.js +514 -0
- package/dist/resources/extensions/gsd/visualizer-data.js +612 -0
- package/dist/resources/extensions/gsd/visualizer-overlay.js +501 -0
- package/dist/resources/extensions/gsd/visualizer-views.js +893 -0
- package/dist/resources/extensions/gsd/workflow-templates.js +188 -0
- package/dist/resources/extensions/gsd/workspace-index.js +139 -0
- package/dist/resources/extensions/gsd/worktree-command-bootstrap.js +40 -0
- package/dist/resources/extensions/gsd/worktree-command.js +682 -0
- package/dist/resources/extensions/gsd/worktree-manager.js +358 -0
- package/dist/resources/extensions/gsd/worktree-resolver.js +344 -0
- package/dist/resources/extensions/gsd/worktree.js +199 -0
- package/dist/resources/extensions/mac-tools/index.js +768 -0
- package/dist/resources/extensions/mcp-client/index.js +363 -0
- package/dist/resources/extensions/package.json +3 -0
- package/dist/resources/extensions/remote-questions/config.js +70 -0
- package/dist/resources/extensions/remote-questions/discord-adapter.js +134 -0
- package/dist/resources/extensions/remote-questions/format.js +234 -0
- package/dist/resources/extensions/remote-questions/http-client.js +43 -0
- package/dist/resources/extensions/remote-questions/manager.js +156 -0
- package/dist/resources/extensions/remote-questions/{mod.ts → mod.js} +1 -10
- package/dist/resources/extensions/remote-questions/notify.js +89 -0
- package/dist/resources/extensions/remote-questions/remote-command.js +453 -0
- package/dist/resources/extensions/remote-questions/slack-adapter.js +123 -0
- package/dist/resources/extensions/remote-questions/status.js +25 -0
- package/dist/resources/extensions/remote-questions/store.js +70 -0
- package/dist/resources/extensions/remote-questions/telegram-adapter.js +123 -0
- package/dist/resources/extensions/remote-questions/types.js +5 -0
- package/dist/resources/extensions/search-the-web/cache.js +74 -0
- package/dist/resources/extensions/search-the-web/command-search-provider.js +79 -0
- package/dist/resources/extensions/search-the-web/format.js +161 -0
- package/dist/resources/extensions/search-the-web/http.js +178 -0
- package/dist/resources/extensions/search-the-web/index.js +41 -0
- package/dist/resources/extensions/search-the-web/native-search.js +166 -0
- package/dist/resources/extensions/search-the-web/provider.js +143 -0
- package/dist/resources/extensions/search-the-web/tavily.js +82 -0
- package/dist/resources/extensions/search-the-web/tool-fetch-page.js +452 -0
- package/dist/resources/extensions/search-the-web/tool-llm-context.js +455 -0
- package/dist/resources/extensions/search-the-web/tool-search.js +482 -0
- package/dist/resources/extensions/search-the-web/url-utils.js +121 -0
- package/dist/resources/extensions/shared/confirm-ui.js +96 -0
- package/dist/resources/extensions/shared/{format-utils.ts → format-utils.js} +85 -91
- package/dist/resources/extensions/shared/frontmatter.js +109 -0
- package/dist/resources/extensions/shared/interview-ui.js +569 -0
- package/dist/resources/extensions/shared/{mod.ts → mod.js} +2 -24
- package/dist/resources/extensions/shared/next-action-ui.js +168 -0
- package/dist/resources/extensions/shared/{path-display.ts → path-display.js} +2 -3
- package/dist/resources/extensions/shared/sanitize.js +17 -0
- package/dist/resources/extensions/shared/terminal.js +21 -0
- package/dist/resources/extensions/shared/ui.js +245 -0
- package/dist/resources/extensions/shared/wizard-ui.js +478 -0
- package/dist/resources/extensions/slash-commands/audit.js +72 -0
- package/dist/resources/extensions/slash-commands/clear.js +8 -0
- package/dist/resources/extensions/slash-commands/create-extension.js +264 -0
- package/dist/resources/extensions/slash-commands/create-slash-command.js +208 -0
- package/dist/resources/extensions/slash-commands/index.js +10 -0
- package/dist/resources/extensions/subagent/agents.js +103 -0
- package/dist/resources/extensions/subagent/index.js +905 -0
- package/dist/resources/extensions/subagent/isolation.js +384 -0
- package/dist/resources/extensions/subagent/worker-registry.js +73 -0
- package/dist/resources/extensions/ttsr/index.js +144 -0
- package/dist/resources/extensions/ttsr/rule-loader.js +70 -0
- package/dist/resources/extensions/ttsr/ttsr-manager.js +380 -0
- package/dist/resources/extensions/universal-config/discovery.js +94 -0
- package/dist/resources/extensions/universal-config/format.js +178 -0
- package/dist/resources/extensions/universal-config/index.js +99 -0
- package/dist/resources/extensions/universal-config/scanners.js +574 -0
- package/dist/resources/extensions/universal-config/tools.js +57 -0
- package/dist/resources/extensions/universal-config/types.js +8 -0
- package/dist/resources/extensions/voice/index.js +247 -0
- package/dist/startup-timings.d.ts +2 -0
- package/dist/startup-timings.js +22 -0
- package/dist/tool-bootstrap.js +59 -11
- package/dist/worktree-cli.js +7 -7
- package/package.json +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session.js +9 -0
- package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/index.d.ts +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/index.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/index.js +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/index.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts +1 -0
- package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/loader.js +31 -4
- package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/index.js +1 -1
- package/packages/pi-coding-agent/dist/index.js.map +1 -1
- package/packages/pi-coding-agent/package.json +1 -1
- package/packages/pi-coding-agent/src/core/agent-session.ts +9 -0
- package/packages/pi-coding-agent/src/core/extensions/index.ts +1 -0
- package/packages/pi-coding-agent/src/core/extensions/loader.ts +35 -4
- package/packages/pi-coding-agent/src/index.ts +1 -0
- package/pkg/package.json +1 -1
- package/src/resources/extensions/bg-shell/index.ts +41 -46
- package/src/resources/extensions/browser-tools/index.ts +156 -67
- package/src/resources/extensions/gsd/auto/session.ts +47 -30
- package/src/resources/extensions/gsd/auto-dashboard.ts +28 -131
- package/src/resources/extensions/gsd/auto-direct-dispatch.ts +6 -1
- package/src/resources/extensions/gsd/auto-dispatch.ts +135 -91
- package/src/resources/extensions/gsd/auto-loop.ts +1665 -0
- package/src/resources/extensions/gsd/auto-observability.ts +4 -2
- package/src/resources/extensions/gsd/auto-post-unit.ts +85 -228
- package/src/resources/extensions/gsd/auto-prompts.ts +138 -109
- package/src/resources/extensions/gsd/auto-recovery.ts +124 -118
- package/src/resources/extensions/gsd/auto-start.ts +440 -354
- package/src/resources/extensions/gsd/auto-supervisor.ts +5 -12
- package/src/resources/extensions/gsd/auto-timeout-recovery.ts +8 -8
- package/src/resources/extensions/gsd/auto-timers.ts +3 -4
- package/src/resources/extensions/gsd/auto-verification.ts +76 -72
- package/src/resources/extensions/gsd/auto-worktree-sync.ts +204 -0
- package/src/resources/extensions/gsd/auto-worktree.ts +453 -133
- package/src/resources/extensions/gsd/auto.ts +516 -1189
- package/src/resources/extensions/gsd/captures.ts +10 -4
- package/src/resources/extensions/gsd/commands-bootstrap.ts +252 -0
- package/src/resources/extensions/gsd/commands.ts +39 -31
- package/src/resources/extensions/gsd/dispatch-guard.ts +13 -9
- package/src/resources/extensions/gsd/docs/preferences-reference.md +25 -18
- package/src/resources/extensions/gsd/doctor-checks.ts +3 -4
- package/src/resources/extensions/gsd/git-service.ts +32 -12
- package/src/resources/extensions/gsd/gitignore.ts +4 -2
- package/src/resources/extensions/gsd/gsd-db.ts +375 -180
- package/src/resources/extensions/gsd/guided-flow.ts +22 -11
- package/src/resources/extensions/gsd/index.ts +76 -163
- package/src/resources/extensions/gsd/post-unit-hooks.ts +13 -13
- package/src/resources/extensions/gsd/progress-score.ts +65 -200
- package/src/resources/extensions/gsd/quick.ts +121 -76
- package/src/resources/extensions/gsd/repo-identity.ts +56 -22
- package/src/resources/extensions/gsd/session-lock.ts +17 -0
- package/src/resources/extensions/gsd/templates/preferences.md +1 -0
- package/src/resources/extensions/gsd/tests/agent-end-retry.test.ts +32 -59
- package/src/resources/extensions/gsd/tests/all-milestones-complete-merge.test.ts +75 -27
- package/src/resources/extensions/gsd/tests/auto-budget-alerts.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/auto-lock-creation.test.ts +37 -0
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +1458 -0
- package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +8 -162
- package/src/resources/extensions/gsd/tests/auto-secrets-gate.test.ts +2 -108
- package/src/resources/extensions/gsd/tests/auto-session-encapsulation.test.ts +1 -3
- package/src/resources/extensions/gsd/tests/auto-worktree-milestone-merge.test.ts +0 -3
- package/src/resources/extensions/gsd/tests/auto-worktree.test.ts +58 -0
- package/src/resources/extensions/gsd/tests/dispatch-guard.test.ts +0 -55
- package/src/resources/extensions/gsd/tests/git-service.test.ts +16 -7
- package/src/resources/extensions/gsd/tests/headless-query.test.ts +22 -0
- package/src/resources/extensions/gsd/tests/milestone-transition-worktree.test.ts +8 -11
- package/src/resources/extensions/gsd/tests/provider-errors.test.ts +4 -6
- package/src/resources/extensions/gsd/tests/quick-branch-lifecycle.test.ts +281 -0
- package/src/resources/extensions/gsd/tests/repo-identity-worktree.test.ts +71 -0
- package/src/resources/extensions/gsd/tests/run-uat.test.ts +3 -3
- package/src/resources/extensions/gsd/tests/session-lock-regression.test.ts +64 -0
- package/src/resources/extensions/gsd/tests/sidecar-queue.test.ts +181 -0
- package/src/resources/extensions/gsd/tests/stale-worktree-cwd.test.ts +0 -3
- package/src/resources/extensions/gsd/tests/token-profile.test.ts +6 -6
- package/src/resources/extensions/gsd/tests/triage-dispatch.test.ts +6 -6
- package/src/resources/extensions/gsd/tests/undo.test.ts +6 -0
- package/src/resources/extensions/gsd/tests/verification-evidence.test.ts +24 -26
- package/src/resources/extensions/gsd/tests/verification-gate.test.ts +7 -136
- package/src/resources/extensions/gsd/tests/worktree-db-integration.test.ts +205 -0
- package/src/resources/extensions/gsd/tests/worktree-db.test.ts +442 -0
- package/src/resources/extensions/gsd/tests/worktree-e2e.test.ts +0 -3
- package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +705 -0
- package/src/resources/extensions/gsd/tests/worktree-sync-milestones.test.ts +57 -106
- package/src/resources/extensions/gsd/tests/worktree.test.ts +5 -1
- package/src/resources/extensions/gsd/tests/write-gate.test.ts +43 -132
- package/src/resources/extensions/gsd/types.ts +90 -77
- package/src/resources/extensions/gsd/undo.ts +42 -46
- package/src/resources/extensions/gsd/unit-runtime.ts +14 -18
- package/src/resources/extensions/gsd/verification-evidence.ts +0 -2
- package/src/resources/extensions/gsd/verification-gate.ts +4 -16
- package/src/resources/extensions/gsd/worktree-command-bootstrap.ts +46 -0
- package/src/resources/extensions/gsd/worktree-command.ts +29 -11
- package/src/resources/extensions/gsd/worktree-manager.ts +2 -3
- package/src/resources/extensions/gsd/worktree-resolver.ts +485 -0
- package/src/resources/extensions/gsd/worktree.ts +7 -44
- package/src/resources/extensions/package.json +3 -0
- package/src/resources/extensions/search-the-web/command-search-provider.ts +1 -1
- package/src/resources/extensions/search-the-web/index.ts +35 -52
- package/src/resources/extensions/search-the-web/tavily.ts +1 -1
- package/dist/resources/extensions/ask-user-questions.ts +0 -290
- package/dist/resources/extensions/async-jobs/async-bash-tool.ts +0 -212
- package/dist/resources/extensions/async-jobs/await-tool.ts +0 -103
- package/dist/resources/extensions/async-jobs/cancel-job-tool.ts +0 -35
- package/dist/resources/extensions/async-jobs/index.ts +0 -141
- package/dist/resources/extensions/async-jobs/job-manager.ts +0 -211
- package/dist/resources/extensions/aws-auth/index.ts +0 -144
- package/dist/resources/extensions/bg-shell/bg-shell-command.ts +0 -219
- package/dist/resources/extensions/bg-shell/bg-shell-lifecycle.ts +0 -400
- package/dist/resources/extensions/bg-shell/bg-shell-tool.ts +0 -985
- package/dist/resources/extensions/bg-shell/index.ts +0 -59
- package/dist/resources/extensions/bg-shell/interaction.ts +0 -198
- package/dist/resources/extensions/bg-shell/output-formatter.ts +0 -279
- package/dist/resources/extensions/bg-shell/overlay.ts +0 -437
- package/dist/resources/extensions/bg-shell/process-manager.ts +0 -464
- package/dist/resources/extensions/bg-shell/readiness-detector.ts +0 -126
- package/dist/resources/extensions/bg-shell/types.ts +0 -303
- package/dist/resources/extensions/bg-shell/utilities.ts +0 -57
- package/dist/resources/extensions/browser-tools/capture.ts +0 -199
- package/dist/resources/extensions/browser-tools/core.ts +0 -1196
- package/dist/resources/extensions/browser-tools/index.ts +0 -71
- package/dist/resources/extensions/browser-tools/lifecycle.ts +0 -270
- package/dist/resources/extensions/browser-tools/refs.ts +0 -264
- package/dist/resources/extensions/browser-tools/settle.ts +0 -197
- package/dist/resources/extensions/browser-tools/state.ts +0 -408
- package/dist/resources/extensions/browser-tools/tools/action-cache.ts +0 -216
- package/dist/resources/extensions/browser-tools/tools/assertions.ts +0 -342
- package/dist/resources/extensions/browser-tools/tools/codegen.ts +0 -274
- package/dist/resources/extensions/browser-tools/tools/device.ts +0 -183
- package/dist/resources/extensions/browser-tools/tools/extract.ts +0 -229
- package/dist/resources/extensions/browser-tools/tools/forms.ts +0 -801
- package/dist/resources/extensions/browser-tools/tools/injection-detect.ts +0 -221
- package/dist/resources/extensions/browser-tools/tools/inspection.ts +0 -492
- package/dist/resources/extensions/browser-tools/tools/intent.ts +0 -614
- package/dist/resources/extensions/browser-tools/tools/interaction.ts +0 -865
- package/dist/resources/extensions/browser-tools/tools/navigation.ts +0 -232
- package/dist/resources/extensions/browser-tools/tools/network-mock.ts +0 -244
- package/dist/resources/extensions/browser-tools/tools/pages.ts +0 -303
- package/dist/resources/extensions/browser-tools/tools/pdf.ts +0 -92
- package/dist/resources/extensions/browser-tools/tools/refs.ts +0 -541
- package/dist/resources/extensions/browser-tools/tools/screenshot.ts +0 -101
- package/dist/resources/extensions/browser-tools/tools/session.ts +0 -400
- package/dist/resources/extensions/browser-tools/tools/state-persistence.ts +0 -202
- package/dist/resources/extensions/browser-tools/tools/visual-diff.ts +0 -209
- package/dist/resources/extensions/browser-tools/tools/wait.ts +0 -247
- package/dist/resources/extensions/browser-tools/tools/zoom.ts +0 -104
- package/dist/resources/extensions/browser-tools/utils.ts +0 -660
- package/dist/resources/extensions/context7/index.ts +0 -428
- package/dist/resources/extensions/get-secrets-from-user.ts +0 -607
- package/dist/resources/extensions/google-search/index.ts +0 -466
- package/dist/resources/extensions/gsd/activity-log.ts +0 -162
- package/dist/resources/extensions/gsd/atomic-write.ts +0 -35
- package/dist/resources/extensions/gsd/auto/session.ts +0 -236
- package/dist/resources/extensions/gsd/auto-budget.ts +0 -32
- package/dist/resources/extensions/gsd/auto-constants.ts +0 -6
- package/dist/resources/extensions/gsd/auto-dashboard.ts +0 -626
- package/dist/resources/extensions/gsd/auto-direct-dispatch.ts +0 -224
- package/dist/resources/extensions/gsd/auto-dispatch.ts +0 -409
- package/dist/resources/extensions/gsd/auto-idempotency.ts +0 -151
- package/dist/resources/extensions/gsd/auto-model-selection.ts +0 -179
- package/dist/resources/extensions/gsd/auto-observability.ts +0 -72
- package/dist/resources/extensions/gsd/auto-post-unit.ts +0 -618
- package/dist/resources/extensions/gsd/auto-prompts.ts +0 -1273
- package/dist/resources/extensions/gsd/auto-recovery.ts +0 -578
- package/dist/resources/extensions/gsd/auto-start.ts +0 -483
- package/dist/resources/extensions/gsd/auto-stuck-detection.ts +0 -221
- package/dist/resources/extensions/gsd/auto-supervisor.ts +0 -61
- package/dist/resources/extensions/gsd/auto-timeout-recovery.ts +0 -263
- package/dist/resources/extensions/gsd/auto-timers.ts +0 -224
- package/dist/resources/extensions/gsd/auto-tool-tracking.ts +0 -54
- package/dist/resources/extensions/gsd/auto-unit-closeout.ts +0 -48
- package/dist/resources/extensions/gsd/auto-verification.ts +0 -229
- package/dist/resources/extensions/gsd/auto-worktree.ts +0 -658
- package/dist/resources/extensions/gsd/auto.ts +0 -1834
- package/dist/resources/extensions/gsd/captures.ts +0 -427
- package/dist/resources/extensions/gsd/claude-import.ts +0 -656
- package/dist/resources/extensions/gsd/collision-diagnostics.ts +0 -332
- package/dist/resources/extensions/gsd/commands-config.ts +0 -102
- package/dist/resources/extensions/gsd/commands-extensions.ts +0 -328
- package/dist/resources/extensions/gsd/commands-handlers.ts +0 -395
- package/dist/resources/extensions/gsd/commands-inspect.ts +0 -91
- package/dist/resources/extensions/gsd/commands-logs.ts +0 -536
- package/dist/resources/extensions/gsd/commands-maintenance.ts +0 -206
- package/dist/resources/extensions/gsd/commands-prefs-wizard.ts +0 -780
- package/dist/resources/extensions/gsd/commands-workflow-templates.ts +0 -543
- package/dist/resources/extensions/gsd/commands.ts +0 -1149
- package/dist/resources/extensions/gsd/complexity-classifier.ts +0 -320
- package/dist/resources/extensions/gsd/context-budget.ts +0 -266
- package/dist/resources/extensions/gsd/context-store.ts +0 -195
- package/dist/resources/extensions/gsd/crash-recovery.ts +0 -121
- package/dist/resources/extensions/gsd/dashboard-overlay.ts +0 -681
- package/dist/resources/extensions/gsd/db-writer.ts +0 -360
- package/dist/resources/extensions/gsd/debug-logger.ts +0 -178
- package/dist/resources/extensions/gsd/detection.ts +0 -470
- package/dist/resources/extensions/gsd/diff-context.ts +0 -214
- package/dist/resources/extensions/gsd/dispatch-guard.ts +0 -81
- package/dist/resources/extensions/gsd/doctor-checks.ts +0 -612
- package/dist/resources/extensions/gsd/doctor-environment.ts +0 -497
- package/dist/resources/extensions/gsd/doctor-format.ts +0 -78
- package/dist/resources/extensions/gsd/doctor-proactive.ts +0 -292
- package/dist/resources/extensions/gsd/doctor-providers.ts +0 -343
- package/dist/resources/extensions/gsd/doctor-types.ts +0 -87
- package/dist/resources/extensions/gsd/doctor.ts +0 -722
- package/dist/resources/extensions/gsd/error-utils.ts +0 -6
- package/dist/resources/extensions/gsd/exit-command.ts +0 -18
- package/dist/resources/extensions/gsd/export.ts +0 -317
- package/dist/resources/extensions/gsd/file-watcher.ts +0 -97
- package/dist/resources/extensions/gsd/files.ts +0 -1058
- package/dist/resources/extensions/gsd/forensics.ts +0 -629
- package/dist/resources/extensions/gsd/git-self-heal.ts +0 -127
- package/dist/resources/extensions/gsd/git-service.ts +0 -580
- package/dist/resources/extensions/gsd/gsd-db.ts +0 -685
- package/dist/resources/extensions/gsd/guided-flow-queue.ts +0 -440
- package/dist/resources/extensions/gsd/guided-flow.ts +0 -1303
- package/dist/resources/extensions/gsd/health-widget.ts +0 -167
- package/dist/resources/extensions/gsd/history.ts +0 -143
- package/dist/resources/extensions/gsd/index.ts +0 -1390
- package/dist/resources/extensions/gsd/init-wizard.ts +0 -587
- package/dist/resources/extensions/gsd/json-persistence.ts +0 -67
- package/dist/resources/extensions/gsd/key-manager.ts +0 -996
- package/dist/resources/extensions/gsd/marketplace-discovery.ts +0 -508
- package/dist/resources/extensions/gsd/md-importer.ts +0 -527
- package/dist/resources/extensions/gsd/mechanical-completion.ts +0 -430
- package/dist/resources/extensions/gsd/memory-extractor.ts +0 -352
- package/dist/resources/extensions/gsd/memory-store.ts +0 -441
- package/dist/resources/extensions/gsd/metrics.ts +0 -532
- package/dist/resources/extensions/gsd/migrate/command.ts +0 -219
- package/dist/resources/extensions/gsd/migrate/index.ts +0 -42
- package/dist/resources/extensions/gsd/migrate/parser.ts +0 -323
- package/dist/resources/extensions/gsd/migrate/parsers.ts +0 -539
- package/dist/resources/extensions/gsd/migrate/preview.ts +0 -48
- package/dist/resources/extensions/gsd/migrate/transformer.ts +0 -346
- package/dist/resources/extensions/gsd/migrate/types.ts +0 -370
- package/dist/resources/extensions/gsd/migrate/validator.ts +0 -55
- package/dist/resources/extensions/gsd/migrate/writer.ts +0 -579
- package/dist/resources/extensions/gsd/migrate-external.ts +0 -140
- package/dist/resources/extensions/gsd/milestone-actions.ts +0 -126
- package/dist/resources/extensions/gsd/model-cost-table.ts +0 -65
- package/dist/resources/extensions/gsd/model-router.ts +0 -256
- package/dist/resources/extensions/gsd/namespaced-registry.ts +0 -467
- package/dist/resources/extensions/gsd/namespaced-resolver.ts +0 -307
- package/dist/resources/extensions/gsd/native-git-bridge.ts +0 -1041
- package/dist/resources/extensions/gsd/native-parser-bridge.ts +0 -267
- package/dist/resources/extensions/gsd/notifications.ts +0 -87
- package/dist/resources/extensions/gsd/observability-validator.ts +0 -429
- package/dist/resources/extensions/gsd/parallel-eligibility.ts +0 -233
- package/dist/resources/extensions/gsd/parallel-merge.ts +0 -157
- package/dist/resources/extensions/gsd/parallel-orchestrator.ts +0 -826
- package/dist/resources/extensions/gsd/paths.ts +0 -449
- package/dist/resources/extensions/gsd/plugin-importer.ts +0 -411
- package/dist/resources/extensions/gsd/post-unit-hooks.ts +0 -520
- package/dist/resources/extensions/gsd/preferences-models.ts +0 -329
- package/dist/resources/extensions/gsd/preferences-skills.ts +0 -169
- package/dist/resources/extensions/gsd/preferences-types.ts +0 -229
- package/dist/resources/extensions/gsd/preferences-validation.ts +0 -590
- package/dist/resources/extensions/gsd/preferences.ts +0 -416
- package/dist/resources/extensions/gsd/progress-score.ts +0 -273
- package/dist/resources/extensions/gsd/prompt-cache-optimizer.ts +0 -213
- package/dist/resources/extensions/gsd/prompt-compressor.ts +0 -508
- package/dist/resources/extensions/gsd/prompt-loader.ts +0 -130
- package/dist/resources/extensions/gsd/prompt-ordering.ts +0 -200
- package/dist/resources/extensions/gsd/provider-error-pause.ts +0 -88
- package/dist/resources/extensions/gsd/queue-order.ts +0 -230
- package/dist/resources/extensions/gsd/queue-reorder-ui.ts +0 -276
- package/dist/resources/extensions/gsd/quick.ts +0 -212
- package/dist/resources/extensions/gsd/repo-identity.ts +0 -169
- package/dist/resources/extensions/gsd/roadmap-slices.ts +0 -149
- package/dist/resources/extensions/gsd/routing-history.ts +0 -286
- package/dist/resources/extensions/gsd/safe-fs.ts +0 -47
- package/dist/resources/extensions/gsd/semantic-chunker.ts +0 -336
- package/dist/resources/extensions/gsd/session-forensics.ts +0 -537
- package/dist/resources/extensions/gsd/session-lock.ts +0 -426
- package/dist/resources/extensions/gsd/session-status-io.ts +0 -179
- package/dist/resources/extensions/gsd/skill-discovery.ts +0 -139
- package/dist/resources/extensions/gsd/skill-health.ts +0 -417
- package/dist/resources/extensions/gsd/state.ts +0 -727
- package/dist/resources/extensions/gsd/structured-data-formatter.ts +0 -144
- package/dist/resources/extensions/gsd/summary-distiller.ts +0 -258
- package/dist/resources/extensions/gsd/tests/activity-log.test.ts +0 -213
- package/dist/resources/extensions/gsd/tests/agent-end-retry.test.ts +0 -107
- package/dist/resources/extensions/gsd/tests/all-milestones-complete-merge.test.ts +0 -200
- package/dist/resources/extensions/gsd/tests/auto-budget-alerts.test.ts +0 -50
- package/dist/resources/extensions/gsd/tests/auto-dashboard.test.ts +0 -166
- package/dist/resources/extensions/gsd/tests/auto-dispatch-loop.test.ts +0 -691
- package/dist/resources/extensions/gsd/tests/auto-lock-creation.test.ts +0 -186
- package/dist/resources/extensions/gsd/tests/auto-preflight.test.ts +0 -40
- package/dist/resources/extensions/gsd/tests/auto-recovery.test.ts +0 -640
- package/dist/resources/extensions/gsd/tests/auto-reentrancy-guard.test.ts +0 -127
- package/dist/resources/extensions/gsd/tests/auto-secrets-gate.test.ts +0 -302
- package/dist/resources/extensions/gsd/tests/auto-session-encapsulation.test.ts +0 -257
- package/dist/resources/extensions/gsd/tests/auto-skip-loop.test.ts +0 -123
- package/dist/resources/extensions/gsd/tests/auto-worktree-milestone-merge.test.ts +0 -340
- package/dist/resources/extensions/gsd/tests/auto-worktree.test.ts +0 -167
- package/dist/resources/extensions/gsd/tests/budget-prediction.test.ts +0 -220
- package/dist/resources/extensions/gsd/tests/cache-staleness-regression.test.ts +0 -317
- package/dist/resources/extensions/gsd/tests/captures.test.ts +0 -438
- package/dist/resources/extensions/gsd/tests/claude-import-tui.test.ts +0 -351
- package/dist/resources/extensions/gsd/tests/collect-from-manifest.test.ts +0 -469
- package/dist/resources/extensions/gsd/tests/collision-diagnostics.test.ts +0 -705
- package/dist/resources/extensions/gsd/tests/commands-logs.test.ts +0 -241
- package/dist/resources/extensions/gsd/tests/complete-milestone.test.ts +0 -209
- package/dist/resources/extensions/gsd/tests/complexity-classifier.test.ts +0 -181
- package/dist/resources/extensions/gsd/tests/context-budget.test.ts +0 -352
- package/dist/resources/extensions/gsd/tests/context-compression.test.ts +0 -193
- package/dist/resources/extensions/gsd/tests/context-store.test.ts +0 -462
- package/dist/resources/extensions/gsd/tests/continue-here.test.ts +0 -285
- package/dist/resources/extensions/gsd/tests/cost-projection.test.ts +0 -134
- package/dist/resources/extensions/gsd/tests/crash-recovery.test.ts +0 -134
- package/dist/resources/extensions/gsd/tests/dashboard-budget.test.ts +0 -346
- package/dist/resources/extensions/gsd/tests/db-writer.test.ts +0 -602
- package/dist/resources/extensions/gsd/tests/debug-logger.test.ts +0 -185
- package/dist/resources/extensions/gsd/tests/derive-state-db.test.ts +0 -405
- package/dist/resources/extensions/gsd/tests/derive-state-deps.test.ts +0 -421
- package/dist/resources/extensions/gsd/tests/derive-state-draft.test.ts +0 -308
- package/dist/resources/extensions/gsd/tests/derive-state.test.ts +0 -788
- package/dist/resources/extensions/gsd/tests/detection.test.ts +0 -398
- package/dist/resources/extensions/gsd/tests/diff-context.test.ts +0 -136
- package/dist/resources/extensions/gsd/tests/discuss-prompt.test.ts +0 -15
- package/dist/resources/extensions/gsd/tests/dispatch-guard.test.ts +0 -128
- package/dist/resources/extensions/gsd/tests/dispatch-missing-task-plans.test.ts +0 -132
- package/dist/resources/extensions/gsd/tests/dispatch-stall-guard.test.ts +0 -126
- package/dist/resources/extensions/gsd/tests/doctor-environment.test.ts +0 -314
- package/dist/resources/extensions/gsd/tests/doctor-fixlevel.test.ts +0 -245
- package/dist/resources/extensions/gsd/tests/doctor-git.test.ts +0 -344
- package/dist/resources/extensions/gsd/tests/doctor-proactive.test.ts +0 -278
- package/dist/resources/extensions/gsd/tests/doctor-providers.test.ts +0 -298
- package/dist/resources/extensions/gsd/tests/doctor-runtime.test.ts +0 -302
- package/dist/resources/extensions/gsd/tests/doctor.test.ts +0 -652
- package/dist/resources/extensions/gsd/tests/draft-promotion.test.ts +0 -169
- package/dist/resources/extensions/gsd/tests/exit-command.test.ts +0 -50
- package/dist/resources/extensions/gsd/tests/export-html-all.test.ts +0 -105
- package/dist/resources/extensions/gsd/tests/export-html-enhancements.test.ts +0 -378
- package/dist/resources/extensions/gsd/tests/extension-selector-separator.test.ts +0 -144
- package/dist/resources/extensions/gsd/tests/feature-branch-lifecycle-integration.test.ts +0 -424
- package/dist/resources/extensions/gsd/tests/git-self-heal.test.ts +0 -131
- package/dist/resources/extensions/gsd/tests/git-service.test.ts +0 -1172
- package/dist/resources/extensions/gsd/tests/gsd-db.test.ts +0 -353
- package/dist/resources/extensions/gsd/tests/gsd-inspect.test.ts +0 -125
- package/dist/resources/extensions/gsd/tests/gsd-tools.test.ts +0 -326
- package/dist/resources/extensions/gsd/tests/headless-answers.test.ts +0 -340
- package/dist/resources/extensions/gsd/tests/headless-query.test.ts +0 -162
- package/dist/resources/extensions/gsd/tests/idle-recovery.test.ts +0 -485
- package/dist/resources/extensions/gsd/tests/in-flight-tool-tracking.test.ts +0 -32
- package/dist/resources/extensions/gsd/tests/init-wizard.test.ts +0 -197
- package/dist/resources/extensions/gsd/tests/integration/headless-command.ts +0 -534
- package/dist/resources/extensions/gsd/tests/integration-edge.test.ts +0 -228
- package/dist/resources/extensions/gsd/tests/integration-lifecycle.test.ts +0 -277
- package/dist/resources/extensions/gsd/tests/integration-mixed-milestones.test.ts +0 -523
- package/dist/resources/extensions/gsd/tests/key-manager.test.ts +0 -414
- package/dist/resources/extensions/gsd/tests/knowledge.test.ts +0 -161
- package/dist/resources/extensions/gsd/tests/loop-regression.test.ts +0 -877
- package/dist/resources/extensions/gsd/tests/manifest-status.test.ts +0 -283
- package/dist/resources/extensions/gsd/tests/marketplace-test-fixtures.ts +0 -91
- package/dist/resources/extensions/gsd/tests/md-importer.test.ts +0 -410
- package/dist/resources/extensions/gsd/tests/mechanical-completion.test.ts +0 -356
- package/dist/resources/extensions/gsd/tests/memory-extractor.test.ts +0 -180
- package/dist/resources/extensions/gsd/tests/memory-leak-guards.test.ts +0 -91
- package/dist/resources/extensions/gsd/tests/memory-store.test.ts +0 -345
- package/dist/resources/extensions/gsd/tests/metrics.test.ts +0 -253
- package/dist/resources/extensions/gsd/tests/migrate-command.test.ts +0 -369
- package/dist/resources/extensions/gsd/tests/migrate-parser.test.ts +0 -757
- package/dist/resources/extensions/gsd/tests/migrate-transformer.test.ts +0 -635
- package/dist/resources/extensions/gsd/tests/migrate-validator-parsers.test.ts +0 -414
- package/dist/resources/extensions/gsd/tests/migrate-writer-integration.test.ts +0 -303
- package/dist/resources/extensions/gsd/tests/migrate-writer.test.ts +0 -398
- package/dist/resources/extensions/gsd/tests/milestone-transition-worktree.test.ts +0 -147
- package/dist/resources/extensions/gsd/tests/model-cost-table.test.ts +0 -69
- package/dist/resources/extensions/gsd/tests/model-isolation.test.ts +0 -157
- package/dist/resources/extensions/gsd/tests/model-router.test.ts +0 -167
- package/dist/resources/extensions/gsd/tests/must-have-parser.test.ts +0 -291
- package/dist/resources/extensions/gsd/tests/namespaced-registry.test.ts +0 -1027
- package/dist/resources/extensions/gsd/tests/namespaced-resolver.test.ts +0 -671
- package/dist/resources/extensions/gsd/tests/native-has-changes-cache.test.ts +0 -61
- package/dist/resources/extensions/gsd/tests/next-milestone-id.test.ts +0 -23
- package/dist/resources/extensions/gsd/tests/none-mode-gates.test.ts +0 -114
- package/dist/resources/extensions/gsd/tests/notifications.test.ts +0 -67
- package/dist/resources/extensions/gsd/tests/overrides.test.ts +0 -131
- package/dist/resources/extensions/gsd/tests/parallel-budget-atomicity.test.ts +0 -331
- package/dist/resources/extensions/gsd/tests/parallel-crash-recovery.test.ts +0 -298
- package/dist/resources/extensions/gsd/tests/parallel-merge.test.ts +0 -468
- package/dist/resources/extensions/gsd/tests/parallel-orchestration.test.ts +0 -685
- package/dist/resources/extensions/gsd/tests/parallel-worker-monitoring.test.ts +0 -171
- package/dist/resources/extensions/gsd/tests/parallel-workers-multi-milestone-e2e.test.ts +0 -354
- package/dist/resources/extensions/gsd/tests/park-edge-cases.test.ts +0 -276
- package/dist/resources/extensions/gsd/tests/park-milestone.test.ts +0 -401
- package/dist/resources/extensions/gsd/tests/parsers.test.ts +0 -1704
- package/dist/resources/extensions/gsd/tests/plan-milestone.test.ts +0 -133
- package/dist/resources/extensions/gsd/tests/plan-quality-validator.test.ts +0 -363
- package/dist/resources/extensions/gsd/tests/plan-slice-prompt.test.ts +0 -42
- package/dist/resources/extensions/gsd/tests/plugin-importer-live.test.ts +0 -481
- package/dist/resources/extensions/gsd/tests/plugin-importer.test.ts +0 -1383
- package/dist/resources/extensions/gsd/tests/post-unit-hooks.test.ts +0 -337
- package/dist/resources/extensions/gsd/tests/preferences.test.ts +0 -276
- package/dist/resources/extensions/gsd/tests/progress-score.test.ts +0 -206
- package/dist/resources/extensions/gsd/tests/prompt-budget-enforcement.test.ts +0 -464
- package/dist/resources/extensions/gsd/tests/prompt-cache-optimizer.test.ts +0 -314
- package/dist/resources/extensions/gsd/tests/prompt-compressor.test.ts +0 -529
- package/dist/resources/extensions/gsd/tests/prompt-db.test.ts +0 -385
- package/dist/resources/extensions/gsd/tests/prompt-ordering.test.ts +0 -296
- package/dist/resources/extensions/gsd/tests/provider-errors.test.ts +0 -338
- package/dist/resources/extensions/gsd/tests/queue-draft-detection.test.ts +0 -126
- package/dist/resources/extensions/gsd/tests/queue-order.test.ts +0 -204
- package/dist/resources/extensions/gsd/tests/queue-reorder-e2e.test.ts +0 -282
- package/dist/resources/extensions/gsd/tests/reassess-detection.test.ts +0 -154
- package/dist/resources/extensions/gsd/tests/reassess-prompt.test.ts +0 -145
- package/dist/resources/extensions/gsd/tests/regex-hardening.test.ts +0 -281
- package/dist/resources/extensions/gsd/tests/remote-questions.test.ts +0 -642
- package/dist/resources/extensions/gsd/tests/remote-status.test.ts +0 -99
- package/dist/resources/extensions/gsd/tests/replan-slice.test.ts +0 -538
- package/dist/resources/extensions/gsd/tests/requirements.test.ts +0 -106
- package/dist/resources/extensions/gsd/tests/roadmap-parse-regression.test.ts +0 -358
- package/dist/resources/extensions/gsd/tests/roadmap-slices.test.ts +0 -66
- package/dist/resources/extensions/gsd/tests/routing-history.test.ts +0 -240
- package/dist/resources/extensions/gsd/tests/run-uat.test.ts +0 -416
- package/dist/resources/extensions/gsd/tests/secure-env-collect.test.ts +0 -185
- package/dist/resources/extensions/gsd/tests/semantic-chunker.test.ts +0 -426
- package/dist/resources/extensions/gsd/tests/session-lock-regression.test.ts +0 -216
- package/dist/resources/extensions/gsd/tests/session-lock.test.ts +0 -434
- package/dist/resources/extensions/gsd/tests/skill-lifecycle.test.ts +0 -126
- package/dist/resources/extensions/gsd/tests/smart-entry-draft.test.ts +0 -123
- package/dist/resources/extensions/gsd/tests/stale-worktree-cwd.test.ts +0 -142
- package/dist/resources/extensions/gsd/tests/stop-auto-remote.test.ts +0 -156
- package/dist/resources/extensions/gsd/tests/structured-data-formatter.test.ts +0 -365
- package/dist/resources/extensions/gsd/tests/summary-distiller.test.ts +0 -323
- package/dist/resources/extensions/gsd/tests/test-helpers.ts +0 -61
- package/dist/resources/extensions/gsd/tests/token-counter.test.ts +0 -129
- package/dist/resources/extensions/gsd/tests/token-optimization-benchmark.test.ts +0 -1272
- package/dist/resources/extensions/gsd/tests/token-optimization-prefs.test.ts +0 -164
- package/dist/resources/extensions/gsd/tests/token-profile.test.ts +0 -268
- package/dist/resources/extensions/gsd/tests/token-savings.test.ts +0 -366
- package/dist/resources/extensions/gsd/tests/triage-dispatch.test.ts +0 -340
- package/dist/resources/extensions/gsd/tests/triage-resolution.test.ts +0 -416
- package/dist/resources/extensions/gsd/tests/undo.test.ts +0 -136
- package/dist/resources/extensions/gsd/tests/unique-milestone-ids.test.ts +0 -219
- package/dist/resources/extensions/gsd/tests/unit-runtime.test.ts +0 -258
- package/dist/resources/extensions/gsd/tests/update-command.test.ts +0 -67
- package/dist/resources/extensions/gsd/tests/validate-directory.test.ts +0 -222
- package/dist/resources/extensions/gsd/tests/validate-milestone.test.ts +0 -375
- package/dist/resources/extensions/gsd/tests/verification-evidence.test.ts +0 -745
- package/dist/resources/extensions/gsd/tests/verification-gate.test.ts +0 -1208
- package/dist/resources/extensions/gsd/tests/visualizer-critical-path.test.ts +0 -145
- package/dist/resources/extensions/gsd/tests/visualizer-data.test.ts +0 -446
- package/dist/resources/extensions/gsd/tests/visualizer-overlay.test.ts +0 -237
- package/dist/resources/extensions/gsd/tests/visualizer-views.test.ts +0 -718
- package/dist/resources/extensions/gsd/tests/worker-registry.test.ts +0 -148
- package/dist/resources/extensions/gsd/tests/workflow-templates.test.ts +0 -173
- package/dist/resources/extensions/gsd/tests/workspace-index.test.ts +0 -38
- package/dist/resources/extensions/gsd/tests/worktree-bugfix.test.ts +0 -120
- package/dist/resources/extensions/gsd/tests/worktree-e2e.test.ts +0 -244
- package/dist/resources/extensions/gsd/tests/worktree-integration.test.ts +0 -207
- package/dist/resources/extensions/gsd/tests/worktree-manager.test.ts +0 -141
- package/dist/resources/extensions/gsd/tests/worktree-post-create-hook.test.ts +0 -165
- package/dist/resources/extensions/gsd/tests/worktree-sync-milestones.test.ts +0 -206
- package/dist/resources/extensions/gsd/tests/worktree.test.ts +0 -171
- package/dist/resources/extensions/gsd/tests/write-gate.test.ts +0 -211
- package/dist/resources/extensions/gsd/token-counter.ts +0 -65
- package/dist/resources/extensions/gsd/triage-resolution.ts +0 -284
- package/dist/resources/extensions/gsd/triage-ui.ts +0 -175
- package/dist/resources/extensions/gsd/types.ts +0 -425
- package/dist/resources/extensions/gsd/undo.ts +0 -223
- package/dist/resources/extensions/gsd/unit-id.ts +0 -14
- package/dist/resources/extensions/gsd/unit-runtime.ts +0 -192
- package/dist/resources/extensions/gsd/validate-directory.ts +0 -164
- package/dist/resources/extensions/gsd/verification-evidence.ts +0 -188
- package/dist/resources/extensions/gsd/verification-gate.ts +0 -643
- package/dist/resources/extensions/gsd/visualizer-data.ts +0 -866
- package/dist/resources/extensions/gsd/visualizer-overlay.ts +0 -566
- package/dist/resources/extensions/gsd/visualizer-views.ts +0 -1171
- package/dist/resources/extensions/gsd/workflow-templates.ts +0 -241
- package/dist/resources/extensions/gsd/workspace-index.ts +0 -217
- package/dist/resources/extensions/gsd/worktree-command.ts +0 -807
- package/dist/resources/extensions/gsd/worktree-manager.ts +0 -449
- package/dist/resources/extensions/gsd/worktree.ts +0 -257
- package/dist/resources/extensions/mac-tools/index.ts +0 -852
- package/dist/resources/extensions/mcp-client/index.ts +0 -459
- package/dist/resources/extensions/remote-questions/config.ts +0 -83
- package/dist/resources/extensions/remote-questions/discord-adapter.ts +0 -148
- package/dist/resources/extensions/remote-questions/format.ts +0 -315
- package/dist/resources/extensions/remote-questions/http-client.ts +0 -76
- package/dist/resources/extensions/remote-questions/manager.ts +0 -184
- package/dist/resources/extensions/remote-questions/notify.ts +0 -90
- package/dist/resources/extensions/remote-questions/remote-command.ts +0 -457
- package/dist/resources/extensions/remote-questions/slack-adapter.ts +0 -141
- package/dist/resources/extensions/remote-questions/status.ts +0 -31
- package/dist/resources/extensions/remote-questions/store.ts +0 -81
- package/dist/resources/extensions/remote-questions/telegram-adapter.ts +0 -149
- package/dist/resources/extensions/remote-questions/types.ts +0 -102
- package/dist/resources/extensions/search-the-web/cache.ts +0 -78
- package/dist/resources/extensions/search-the-web/command-search-provider.ts +0 -101
- package/dist/resources/extensions/search-the-web/format.ts +0 -258
- package/dist/resources/extensions/search-the-web/http.ts +0 -238
- package/dist/resources/extensions/search-the-web/index.ts +0 -65
- package/dist/resources/extensions/search-the-web/native-search.ts +0 -193
- package/dist/resources/extensions/search-the-web/provider.ts +0 -148
- package/dist/resources/extensions/search-the-web/tavily.ts +0 -116
- package/dist/resources/extensions/search-the-web/tool-fetch-page.ts +0 -589
- package/dist/resources/extensions/search-the-web/tool-llm-context.ts +0 -608
- package/dist/resources/extensions/search-the-web/tool-search.ts +0 -649
- package/dist/resources/extensions/search-the-web/url-utils.ts +0 -125
- package/dist/resources/extensions/shared/confirm-ui.ts +0 -126
- package/dist/resources/extensions/shared/frontmatter.ts +0 -117
- package/dist/resources/extensions/shared/interview-ui.ts +0 -613
- package/dist/resources/extensions/shared/next-action-ui.ts +0 -212
- package/dist/resources/extensions/shared/sanitize.ts +0 -19
- package/dist/resources/extensions/shared/terminal.ts +0 -23
- package/dist/resources/extensions/shared/tests/format-utils.test.ts +0 -153
- package/dist/resources/extensions/shared/ui.ts +0 -400
- package/dist/resources/extensions/shared/wizard-ui.ts +0 -551
- package/dist/resources/extensions/slash-commands/audit.ts +0 -88
- package/dist/resources/extensions/slash-commands/clear.ts +0 -10
- package/dist/resources/extensions/slash-commands/create-extension.ts +0 -297
- package/dist/resources/extensions/slash-commands/create-slash-command.ts +0 -234
- package/dist/resources/extensions/slash-commands/index.ts +0 -12
- package/dist/resources/extensions/subagent/agents.ts +0 -126
- package/dist/resources/extensions/subagent/index.ts +0 -1121
- package/dist/resources/extensions/subagent/isolation.ts +0 -501
- package/dist/resources/extensions/subagent/worker-registry.ts +0 -99
- package/dist/resources/extensions/ttsr/index.ts +0 -168
- package/dist/resources/extensions/ttsr/rule-loader.ts +0 -74
- package/dist/resources/extensions/ttsr/ttsr-manager.ts +0 -456
- package/dist/resources/extensions/universal-config/discovery.ts +0 -104
- package/dist/resources/extensions/universal-config/format.ts +0 -191
- package/dist/resources/extensions/universal-config/index.ts +0 -120
- package/dist/resources/extensions/universal-config/scanners.ts +0 -642
- package/dist/resources/extensions/universal-config/tests/discovery.test.ts +0 -119
- package/dist/resources/extensions/universal-config/tests/format.test.ts +0 -127
- package/dist/resources/extensions/universal-config/tests/scanners.test.ts +0 -456
- package/dist/resources/extensions/universal-config/tools.ts +0 -60
- package/dist/resources/extensions/universal-config/types.ts +0 -135
- package/dist/resources/extensions/voice/index.ts +0 -272
- package/dist/resources/skills/create-gsd-extension/templates/extension-skeleton.ts +0 -51
- package/dist/resources/skills/create-gsd-extension/templates/stateful-tool-skeleton.ts +0 -143
- package/src/resources/extensions/gsd/auto-constants.ts +0 -6
- package/src/resources/extensions/gsd/auto-idempotency.ts +0 -151
- package/src/resources/extensions/gsd/auto-stuck-detection.ts +0 -221
- package/src/resources/extensions/gsd/mechanical-completion.ts +0 -430
- package/src/resources/extensions/gsd/tests/auto-dispatch-loop.test.ts +0 -691
- package/src/resources/extensions/gsd/tests/auto-reentrancy-guard.test.ts +0 -127
- package/src/resources/extensions/gsd/tests/auto-skip-loop.test.ts +0 -123
- package/src/resources/extensions/gsd/tests/dispatch-stall-guard.test.ts +0 -126
- package/src/resources/extensions/gsd/tests/loop-regression.test.ts +0 -877
- package/src/resources/extensions/gsd/tests/mechanical-completion.test.ts +0 -356
- package/src/resources/extensions/gsd/tests/progress-score.test.ts +0 -206
- package/src/resources/extensions/gsd/tests/session-lock.test.ts +0 -434
|
@@ -1,206 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* progress-score.test.ts — Tests for progress score / traffic light (#1221).
|
|
3
|
-
*
|
|
4
|
-
* Tests:
|
|
5
|
-
* - Score computation from health signals
|
|
6
|
-
* - Signal evaluation (trend, error streak, recent errors)
|
|
7
|
-
* - Context-aware scoring (retry counts, unit progress)
|
|
8
|
-
* - Formatting (single-line, detailed report)
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
import {
|
|
12
|
-
recordHealthSnapshot,
|
|
13
|
-
resetProactiveHealing,
|
|
14
|
-
} from "../doctor-proactive.ts";
|
|
15
|
-
|
|
16
|
-
import {
|
|
17
|
-
computeProgressScore,
|
|
18
|
-
computeProgressScoreWithContext,
|
|
19
|
-
formatProgressLine,
|
|
20
|
-
formatProgressReport,
|
|
21
|
-
} from "../progress-score.ts";
|
|
22
|
-
|
|
23
|
-
import { createTestContext } from "./test-helpers.ts";
|
|
24
|
-
|
|
25
|
-
const { assertEq, assertTrue, assertMatch, report } = createTestContext();
|
|
26
|
-
|
|
27
|
-
async function main(): Promise<void> {
|
|
28
|
-
try {
|
|
29
|
-
// ── Base Score: No Data ─────────────────────────────────────────────
|
|
30
|
-
console.log("\n=== progress: green with no data ===");
|
|
31
|
-
{
|
|
32
|
-
resetProactiveHealing();
|
|
33
|
-
const score = computeProgressScore();
|
|
34
|
-
assertEq(score.level, "green", "green when no data available");
|
|
35
|
-
assertTrue(score.summary.includes("Progressing well"), "summary says progressing");
|
|
36
|
-
assertTrue(score.signals.length > 0, "has signals");
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
// ── Green: Clean Health Data ────────────────────────────────────────
|
|
40
|
-
console.log("\n=== progress: green with clean health ===");
|
|
41
|
-
{
|
|
42
|
-
resetProactiveHealing();
|
|
43
|
-
for (let i = 0; i < 5; i++) {
|
|
44
|
-
recordHealthSnapshot(0, 0, 0);
|
|
45
|
-
}
|
|
46
|
-
const score = computeProgressScore();
|
|
47
|
-
assertEq(score.level, "green", "green with all clean snapshots");
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
// ── Yellow: Some Warnings ──────────────────────────────────────────
|
|
51
|
-
console.log("\n=== progress: yellow with error streak ===");
|
|
52
|
-
{
|
|
53
|
-
resetProactiveHealing();
|
|
54
|
-
recordHealthSnapshot(1, 2, 0);
|
|
55
|
-
recordHealthSnapshot(1, 1, 0);
|
|
56
|
-
const score = computeProgressScore();
|
|
57
|
-
assertEq(score.level, "yellow", "yellow with consecutive errors");
|
|
58
|
-
assertTrue(score.summary.includes("Struggling"), "summary says struggling");
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
// ── Red: Degrading Health ──────────────────────────────────────────
|
|
62
|
-
console.log("\n=== progress: red with degrading trend ===");
|
|
63
|
-
{
|
|
64
|
-
resetProactiveHealing();
|
|
65
|
-
// 5 older clean snapshots
|
|
66
|
-
for (let i = 0; i < 5; i++) {
|
|
67
|
-
recordHealthSnapshot(0, 0, 0);
|
|
68
|
-
}
|
|
69
|
-
// 5 recent error snapshots — triggers degrading trend
|
|
70
|
-
for (let i = 0; i < 5; i++) {
|
|
71
|
-
recordHealthSnapshot(3, 5, 0);
|
|
72
|
-
}
|
|
73
|
-
const score = computeProgressScore();
|
|
74
|
-
assertEq(score.level, "red", "red with degrading trend and persistent errors");
|
|
75
|
-
assertTrue(score.summary.includes("Stuck"), "summary says stuck");
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
// ── Red: High Error Streak ─────────────────────────────────────────
|
|
79
|
-
console.log("\n=== progress: red with high error streak ===");
|
|
80
|
-
{
|
|
81
|
-
resetProactiveHealing();
|
|
82
|
-
for (let i = 0; i < 4; i++) {
|
|
83
|
-
recordHealthSnapshot(2, 0, 0);
|
|
84
|
-
}
|
|
85
|
-
const score = computeProgressScore();
|
|
86
|
-
assertEq(score.level, "red", "red with 4 consecutive error units");
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
// ── Context-Aware Scoring ──────────────────────────────────────────
|
|
90
|
-
console.log("\n=== progress: context with retries ===");
|
|
91
|
-
{
|
|
92
|
-
resetProactiveHealing();
|
|
93
|
-
for (let i = 0; i < 3; i++) {
|
|
94
|
-
recordHealthSnapshot(0, 0, 0);
|
|
95
|
-
}
|
|
96
|
-
const score = computeProgressScoreWithContext({
|
|
97
|
-
currentUnitId: "M001/S01/T03",
|
|
98
|
-
completedUnits: 2,
|
|
99
|
-
totalUnits: 5,
|
|
100
|
-
retryCount: 0,
|
|
101
|
-
maxRetries: 5,
|
|
102
|
-
});
|
|
103
|
-
assertEq(score.level, "green", "green with no retries");
|
|
104
|
-
assertTrue(score.summary.includes("M001/S01/T03"), "summary includes unit ID");
|
|
105
|
-
assertTrue(score.summary.includes("2 of 5"), "summary includes progress");
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
console.log("\n=== progress: context with high retry count ===");
|
|
109
|
-
{
|
|
110
|
-
resetProactiveHealing();
|
|
111
|
-
for (let i = 0; i < 3; i++) {
|
|
112
|
-
recordHealthSnapshot(0, 0, 0);
|
|
113
|
-
}
|
|
114
|
-
const score = computeProgressScoreWithContext({
|
|
115
|
-
currentUnitId: "M001/S01/T03",
|
|
116
|
-
retryCount: 4,
|
|
117
|
-
maxRetries: 5,
|
|
118
|
-
});
|
|
119
|
-
assertEq(score.level, "red", "red with high retry count");
|
|
120
|
-
assertTrue(score.summary.includes("looping"), "summary mentions looping");
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
console.log("\n=== progress: context with moderate retries ===");
|
|
124
|
-
{
|
|
125
|
-
resetProactiveHealing();
|
|
126
|
-
for (let i = 0; i < 3; i++) {
|
|
127
|
-
recordHealthSnapshot(0, 0, 0);
|
|
128
|
-
}
|
|
129
|
-
const score = computeProgressScoreWithContext({
|
|
130
|
-
currentUnitId: "M001/S01/T03",
|
|
131
|
-
retryCount: 1,
|
|
132
|
-
maxRetries: 5,
|
|
133
|
-
});
|
|
134
|
-
assertEq(score.level, "yellow", "yellow with 1 retry");
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
// ── Formatting ─────────────────────────────────────────────────────
|
|
138
|
-
console.log("\n=== progress: formatProgressLine ===");
|
|
139
|
-
{
|
|
140
|
-
resetProactiveHealing();
|
|
141
|
-
const score = computeProgressScore();
|
|
142
|
-
const line = formatProgressLine(score);
|
|
143
|
-
assertTrue(line.includes("Progressing well"), "line includes summary");
|
|
144
|
-
// Should start with green circle emoji
|
|
145
|
-
assertTrue(line.startsWith("\uD83D\uDFE2"), "starts with green circle");
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
console.log("\n=== progress: formatProgressLine yellow ===");
|
|
149
|
-
{
|
|
150
|
-
resetProactiveHealing();
|
|
151
|
-
recordHealthSnapshot(1, 0, 0);
|
|
152
|
-
recordHealthSnapshot(1, 0, 0);
|
|
153
|
-
const score = computeProgressScore();
|
|
154
|
-
const line = formatProgressLine(score);
|
|
155
|
-
assertTrue(line.startsWith("\uD83D\uDFE1"), "starts with yellow circle");
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
console.log("\n=== progress: formatProgressReport ===");
|
|
159
|
-
{
|
|
160
|
-
resetProactiveHealing();
|
|
161
|
-
recordHealthSnapshot(0, 1, 0);
|
|
162
|
-
const score = computeProgressScore();
|
|
163
|
-
const detailed = formatProgressReport(score);
|
|
164
|
-
assertTrue(detailed.includes("Signals:"), "report has signals section");
|
|
165
|
-
assertTrue(detailed.includes("health_trend"), "report includes trend signal");
|
|
166
|
-
assertTrue(detailed.includes("error_streak"), "report includes streak signal");
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
// ── Signal Details ─────────────────────────────────────────────────
|
|
170
|
-
console.log("\n=== progress: signal names are consistent ===");
|
|
171
|
-
{
|
|
172
|
-
resetProactiveHealing();
|
|
173
|
-
recordHealthSnapshot(0, 0, 0);
|
|
174
|
-
const score = computeProgressScore();
|
|
175
|
-
const names = score.signals.map(s => s.name);
|
|
176
|
-
assertTrue(names.includes("health_trend"), "has health_trend signal");
|
|
177
|
-
assertTrue(names.includes("error_streak"), "has error_streak signal");
|
|
178
|
-
assertTrue(names.includes("recent_errors"), "has recent_errors signal");
|
|
179
|
-
assertTrue(names.includes("artifact_production"), "has artifact_production signal");
|
|
180
|
-
assertTrue(names.includes("dispatch_velocity"), "has dispatch_velocity signal");
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
console.log("\n=== progress: all signals have valid levels ===");
|
|
184
|
-
{
|
|
185
|
-
resetProactiveHealing();
|
|
186
|
-
for (let i = 0; i < 5; i++) {
|
|
187
|
-
recordHealthSnapshot(1, 1, 1);
|
|
188
|
-
}
|
|
189
|
-
const score = computeProgressScore();
|
|
190
|
-
for (const signal of score.signals) {
|
|
191
|
-
assertTrue(
|
|
192
|
-
signal.level === "green" || signal.level === "yellow" || signal.level === "red",
|
|
193
|
-
`signal ${signal.name} has valid level: ${signal.level}`,
|
|
194
|
-
);
|
|
195
|
-
assertTrue(signal.detail.length > 0, `signal ${signal.name} has non-empty detail`);
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
} finally {
|
|
200
|
-
resetProactiveHealing();
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
report();
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
main();
|
|
@@ -1,464 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Prompt budget enforcement tests — verifies that budget-aware prompt builders
|
|
3
|
-
* truncate content at section boundaries and that plan-slice includes executor
|
|
4
|
-
* context constraints.
|
|
5
|
-
*
|
|
6
|
-
* Tests:
|
|
7
|
-
* 1. inlineDependencySummaries() truncates when budget is small, passes through when large
|
|
8
|
-
* 2. plan-slice.md template includes {{executorContextConstraints}} placeholder
|
|
9
|
-
* 3. Executor constraints formatting varies with context window size
|
|
10
|
-
* 4. Different context windows produce different budget-constrained outputs
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
import { describe, it, beforeEach, afterEach } from "node:test";
|
|
14
|
-
import assert from "node:assert/strict";
|
|
15
|
-
import { mkdtempSync, mkdirSync, rmSync, writeFileSync, readFileSync } from "node:fs";
|
|
16
|
-
import { join, dirname } from "node:path";
|
|
17
|
-
import { tmpdir } from "node:os";
|
|
18
|
-
import { fileURLToPath } from "node:url";
|
|
19
|
-
|
|
20
|
-
import { inlineDependencySummaries } from "../auto-prompts.js";
|
|
21
|
-
import { computeBudgets, truncateAtSectionBoundary } from "../context-budget.js";
|
|
22
|
-
|
|
23
|
-
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
24
|
-
|
|
25
|
-
// ─── Fixture helpers ──────────────────────────────────────────────────────────
|
|
26
|
-
|
|
27
|
-
function createFixtureBase(): string {
|
|
28
|
-
return mkdtempSync(join(tmpdir(), "gsd-prompt-budget-test-"));
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
function cleanup(base: string): void {
|
|
32
|
-
rmSync(base, { recursive: true, force: true });
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
/**
|
|
36
|
-
* Set up a minimal milestone with a roadmap declaring slice dependencies and
|
|
37
|
-
* dependency slice summaries on disk.
|
|
38
|
-
*/
|
|
39
|
-
function setupDependencyFixture(
|
|
40
|
-
base: string,
|
|
41
|
-
mid: string,
|
|
42
|
-
sid: string,
|
|
43
|
-
deps: string[],
|
|
44
|
-
summaries: Record<string, string>,
|
|
45
|
-
): void {
|
|
46
|
-
const msDir = join(base, ".gsd", "milestones", mid);
|
|
47
|
-
mkdirSync(msDir, { recursive: true });
|
|
48
|
-
|
|
49
|
-
// Build roadmap content — sid depends on deps
|
|
50
|
-
const depStr = deps.join(", ");
|
|
51
|
-
const sliceLines = [
|
|
52
|
-
`- [x] **${deps[0]}: Done dep** \`risk:low\` \`depends:[]\``,
|
|
53
|
-
`- [ ] **${sid}: Current slice** \`risk:medium\` \`depends:[${depStr}]\``,
|
|
54
|
-
];
|
|
55
|
-
// Add any extra deps as completed slices
|
|
56
|
-
for (let i = 1; i < deps.length; i++) {
|
|
57
|
-
sliceLines.unshift(`- [x] **${deps[i]}: Another dep** \`risk:low\` \`depends:[]\``);
|
|
58
|
-
}
|
|
59
|
-
const roadmapContent = [
|
|
60
|
-
"# Roadmap",
|
|
61
|
-
"",
|
|
62
|
-
"## Slices",
|
|
63
|
-
"",
|
|
64
|
-
...sliceLines,
|
|
65
|
-
].join("\n");
|
|
66
|
-
writeFileSync(join(msDir, `${mid}-ROADMAP.md`), roadmapContent);
|
|
67
|
-
|
|
68
|
-
// Write dependency slice summaries
|
|
69
|
-
for (const [depId, content] of Object.entries(summaries)) {
|
|
70
|
-
const sliceDir = join(msDir, "slices", depId);
|
|
71
|
-
mkdirSync(sliceDir, { recursive: true });
|
|
72
|
-
writeFileSync(join(sliceDir, `${depId}-SUMMARY.md`), content);
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
// Ensure target slice dir exists
|
|
76
|
-
const targetSliceDir = join(msDir, "slices", sid);
|
|
77
|
-
mkdirSync(targetSliceDir, { recursive: true });
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
// ─── inlineDependencySummaries truncation ─────────────────────────────────────
|
|
81
|
-
|
|
82
|
-
describe("prompt-budget: inlineDependencySummaries truncation", () => {
|
|
83
|
-
let base: string;
|
|
84
|
-
|
|
85
|
-
beforeEach(() => {
|
|
86
|
-
base = createFixtureBase();
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
afterEach(() => {
|
|
90
|
-
cleanup(base);
|
|
91
|
-
});
|
|
92
|
-
|
|
93
|
-
it("passes through all content when budget is larger than total", async () => {
|
|
94
|
-
const summaryContent = "### Results\n\nEverything works.\n\n### Forward Intelligence\n\nWatch out for X.";
|
|
95
|
-
setupDependencyFixture(base, "M001", "S02", ["S01"], {
|
|
96
|
-
S01: summaryContent,
|
|
97
|
-
});
|
|
98
|
-
|
|
99
|
-
const result = await inlineDependencySummaries("M001", "S02", base, 100_000);
|
|
100
|
-
assert.ok(result.includes("Everything works."), "should include full summary content");
|
|
101
|
-
assert.ok(result.includes("Watch out for X."), "should include forward intelligence");
|
|
102
|
-
assert.ok(!result.includes("[...truncated"), "should not have truncation marker");
|
|
103
|
-
});
|
|
104
|
-
|
|
105
|
-
it("truncates at section boundaries when budget is small", async () => {
|
|
106
|
-
// Create a large summary with multiple sections
|
|
107
|
-
const sections = [];
|
|
108
|
-
for (let i = 0; i < 10; i++) {
|
|
109
|
-
sections.push(`### Section ${i}\n\n${"Lorem ipsum dolor sit amet. ".repeat(50)}`);
|
|
110
|
-
}
|
|
111
|
-
const largeSummary = sections.join("\n\n");
|
|
112
|
-
|
|
113
|
-
setupDependencyFixture(base, "M001", "S02", ["S01"], {
|
|
114
|
-
S01: largeSummary,
|
|
115
|
-
});
|
|
116
|
-
|
|
117
|
-
// Use a budget smaller than total content
|
|
118
|
-
const result = await inlineDependencySummaries("M001", "S02", base, 500);
|
|
119
|
-
assert.ok(result.includes("[...truncated"), "should have truncation marker when over budget");
|
|
120
|
-
assert.ok(result.length <= 600, `result should be near budget limit, got ${result.length}`);
|
|
121
|
-
});
|
|
122
|
-
|
|
123
|
-
it("returns content unchanged when no budget is provided (backward compat)", async () => {
|
|
124
|
-
const sections = [];
|
|
125
|
-
for (let i = 0; i < 5; i++) {
|
|
126
|
-
sections.push(`### Section ${i}\n\n${"Content block. ".repeat(30)}`);
|
|
127
|
-
}
|
|
128
|
-
const largeSummary = sections.join("\n\n");
|
|
129
|
-
|
|
130
|
-
setupDependencyFixture(base, "M001", "S02", ["S01"], {
|
|
131
|
-
S01: largeSummary,
|
|
132
|
-
});
|
|
133
|
-
|
|
134
|
-
// No budget parameter — backward-compatible behavior
|
|
135
|
-
const result = await inlineDependencySummaries("M001", "S02", base);
|
|
136
|
-
assert.ok(!result.includes("[...truncated"), "should not truncate without budget");
|
|
137
|
-
assert.ok(result.includes("Section 4"), "should include all sections");
|
|
138
|
-
});
|
|
139
|
-
|
|
140
|
-
it("handles multiple dependency summaries with truncation", async () => {
|
|
141
|
-
const summary1 = "### S01 Results\n\nFirst dep done.\n\n### S01 Notes\n\nSome notes.";
|
|
142
|
-
const summary2 = "### S02 Results\n\nSecond dep done.\n\n### S02 Notes\n\nMore notes.";
|
|
143
|
-
setupDependencyFixture(base, "M001", "S03", ["S01", "S02"], {
|
|
144
|
-
S01: summary1,
|
|
145
|
-
S02: summary2,
|
|
146
|
-
});
|
|
147
|
-
|
|
148
|
-
// Budget large enough for all content
|
|
149
|
-
const fullResult = await inlineDependencySummaries("M001", "S03", base, 100_000);
|
|
150
|
-
assert.ok(fullResult.includes("First dep done."), "should have S01 content");
|
|
151
|
-
assert.ok(fullResult.includes("Second dep done."), "should have S02 content");
|
|
152
|
-
|
|
153
|
-
// Budget too small for all
|
|
154
|
-
const truncResult = await inlineDependencySummaries("M001", "S03", base, 200);
|
|
155
|
-
assert.ok(truncResult.includes("[...truncated"), "should truncate when budget is small");
|
|
156
|
-
});
|
|
157
|
-
|
|
158
|
-
it("returns no-dependencies marker when slice has no deps", async () => {
|
|
159
|
-
const msDir = join(base, ".gsd", "milestones", "M001");
|
|
160
|
-
mkdirSync(msDir, { recursive: true });
|
|
161
|
-
const roadmap = "# Roadmap\n\n## Slices\n\n- [ ] **S01: Solo** `risk:low` `depends:[]`\n";
|
|
162
|
-
writeFileSync(join(msDir, "M001-ROADMAP.md"), roadmap);
|
|
163
|
-
|
|
164
|
-
const result = await inlineDependencySummaries("M001", "S01", base, 1000);
|
|
165
|
-
assert.equal(result, "- (no dependencies)");
|
|
166
|
-
});
|
|
167
|
-
});
|
|
168
|
-
|
|
169
|
-
// ─── plan-slice template includes executor constraints placeholder ────────────
|
|
170
|
-
|
|
171
|
-
describe("prompt-budget: plan-slice template", () => {
|
|
172
|
-
it("contains {{executorContextConstraints}} placeholder", () => {
|
|
173
|
-
const templatePath = join(__dirname, "..", "prompts", "plan-slice.md");
|
|
174
|
-
const template = readFileSync(templatePath, "utf-8");
|
|
175
|
-
assert.ok(
|
|
176
|
-
template.includes("{{executorContextConstraints}}"),
|
|
177
|
-
"plan-slice.md should contain {{executorContextConstraints}} placeholder",
|
|
178
|
-
);
|
|
179
|
-
});
|
|
180
|
-
});
|
|
181
|
-
|
|
182
|
-
// ─── Executor constraints formatting ──────────────────────────────────────────
|
|
183
|
-
|
|
184
|
-
describe("prompt-budget: executor constraints formatting", () => {
|
|
185
|
-
it("128K window produces different constraints than 1M window", () => {
|
|
186
|
-
const budget128K = computeBudgets(128_000);
|
|
187
|
-
const budget1M = computeBudgets(1_000_000);
|
|
188
|
-
|
|
189
|
-
// Task count ranges should differ
|
|
190
|
-
assert.notEqual(
|
|
191
|
-
budget128K.taskCountRange.max,
|
|
192
|
-
budget1M.taskCountRange.max,
|
|
193
|
-
"128K and 1M should have different max task counts",
|
|
194
|
-
);
|
|
195
|
-
|
|
196
|
-
// Inline context budgets should differ
|
|
197
|
-
assert.ok(
|
|
198
|
-
budget1M.inlineContextBudgetChars > budget128K.inlineContextBudgetChars,
|
|
199
|
-
"1M should have larger inline context budget than 128K",
|
|
200
|
-
);
|
|
201
|
-
|
|
202
|
-
// Format constraint blocks and verify they differ
|
|
203
|
-
const format = (b: ReturnType<typeof computeBudgets>, windowTokens: number) => {
|
|
204
|
-
const { min, max } = b.taskCountRange;
|
|
205
|
-
const execWindowK = Math.round(windowTokens / 1000);
|
|
206
|
-
const perTaskBudgetK = Math.round(b.inlineContextBudgetChars / 1000);
|
|
207
|
-
return [
|
|
208
|
-
`## Executor Context Constraints`,
|
|
209
|
-
``,
|
|
210
|
-
`The agent that executes each task has a **${execWindowK}K token** context window.`,
|
|
211
|
-
`- Recommended task count for this slice: **${min}–${max} tasks**`,
|
|
212
|
-
`- Each task gets ~${perTaskBudgetK}K chars of inline context (plans, code, decisions)`,
|
|
213
|
-
`- Keep individual tasks completable within a single context window — if a task needs more context than fits, split it`,
|
|
214
|
-
].join("\n");
|
|
215
|
-
};
|
|
216
|
-
|
|
217
|
-
const constraints128K = format(budget128K, 128_000);
|
|
218
|
-
const constraints1M = format(budget1M, 1_000_000);
|
|
219
|
-
|
|
220
|
-
assert.ok(constraints128K.includes("128K token"), "128K constraints should reference 128K");
|
|
221
|
-
assert.ok(constraints1M.includes("1000K token"), "1M constraints should reference 1000K");
|
|
222
|
-
assert.ok(constraints128K.includes("2–5 tasks"), "128K should recommend 2–5 tasks");
|
|
223
|
-
assert.ok(constraints1M.includes("2–8 tasks"), "1M should recommend 2–8 tasks");
|
|
224
|
-
assert.notEqual(constraints128K, constraints1M, "constraint blocks should differ");
|
|
225
|
-
});
|
|
226
|
-
|
|
227
|
-
it("undefined context window falls back to 200K defaults", () => {
|
|
228
|
-
// computeBudgets(0) defaults to 200K (D002)
|
|
229
|
-
const budgetDefault = computeBudgets(0);
|
|
230
|
-
const budget200K = computeBudgets(200_000);
|
|
231
|
-
|
|
232
|
-
assert.equal(budgetDefault.summaryBudgetChars, budget200K.summaryBudgetChars);
|
|
233
|
-
assert.equal(budgetDefault.inlineContextBudgetChars, budget200K.inlineContextBudgetChars);
|
|
234
|
-
assert.equal(budgetDefault.taskCountRange.max, budget200K.taskCountRange.max);
|
|
235
|
-
});
|
|
236
|
-
});
|
|
237
|
-
|
|
238
|
-
// ─── Budget-constrained output varies with context window ─────────────────────
|
|
239
|
-
|
|
240
|
-
describe("prompt-budget: different context windows produce different outputs", () => {
|
|
241
|
-
it("small window truncates content that large window preserves", () => {
|
|
242
|
-
// Simulate assembled inlinedContext with multiple sections
|
|
243
|
-
const sections = [];
|
|
244
|
-
for (let i = 0; i < 20; i++) {
|
|
245
|
-
sections.push(`### Section ${i}: Important Context\n\n${"Detailed content for this section. ".repeat(100)}`);
|
|
246
|
-
}
|
|
247
|
-
const largeContent = `## Inlined Context\n\n${sections.join("\n\n---\n\n")}`;
|
|
248
|
-
|
|
249
|
-
// 128K context window budget
|
|
250
|
-
const budget128K = computeBudgets(128_000);
|
|
251
|
-
const r128K = truncateAtSectionBoundary(largeContent, budget128K.inlineContextBudgetChars);
|
|
252
|
-
|
|
253
|
-
// 1M context window budget
|
|
254
|
-
const budget1M = computeBudgets(1_000_000);
|
|
255
|
-
const r1M = truncateAtSectionBoundary(largeContent, budget1M.inlineContextBudgetChars);
|
|
256
|
-
|
|
257
|
-
// The large content (~70K chars) should fit in 1M budget (~1.6M chars) but
|
|
258
|
-
// if we make content bigger, the 128K budget (~204K chars) would truncate
|
|
259
|
-
assert.ok(
|
|
260
|
-
r128K.content.length <= budget128K.inlineContextBudgetChars + 100, // +100 for truncation marker
|
|
261
|
-
"128K result should respect budget",
|
|
262
|
-
);
|
|
263
|
-
assert.ok(
|
|
264
|
-
r1M.content.length <= budget1M.inlineContextBudgetChars + 100,
|
|
265
|
-
"1M result should respect budget",
|
|
266
|
-
);
|
|
267
|
-
|
|
268
|
-
// With content smaller than both budgets, both should pass through unchanged
|
|
269
|
-
const smallContent = "### One Section\n\nSmall content.";
|
|
270
|
-
const small128K = truncateAtSectionBoundary(smallContent, budget128K.inlineContextBudgetChars);
|
|
271
|
-
const small1M = truncateAtSectionBoundary(smallContent, budget1M.inlineContextBudgetChars);
|
|
272
|
-
assert.equal(small128K.content, smallContent, "small content unchanged for 128K");
|
|
273
|
-
assert.equal(small128K.droppedSections, 0);
|
|
274
|
-
assert.equal(small1M.content, smallContent, "small content unchanged for 1M");
|
|
275
|
-
assert.equal(small1M.droppedSections, 0);
|
|
276
|
-
});
|
|
277
|
-
|
|
278
|
-
it("128K budget truncates very large content while 1M preserves it", () => {
|
|
279
|
-
// Create content that exceeds 128K budget (~204K chars) but fits in 1M (~1.6M chars)
|
|
280
|
-
const sections = [];
|
|
281
|
-
for (let i = 0; i < 100; i++) {
|
|
282
|
-
sections.push(`### Section ${i}\n\n${"X".repeat(3000)}`);
|
|
283
|
-
}
|
|
284
|
-
const content = sections.join("\n\n");
|
|
285
|
-
// ~310K chars total
|
|
286
|
-
|
|
287
|
-
const budget128K = computeBudgets(128_000);
|
|
288
|
-
const result128K = truncateAtSectionBoundary(content, budget128K.inlineContextBudgetChars);
|
|
289
|
-
|
|
290
|
-
const budget1M = computeBudgets(1_000_000);
|
|
291
|
-
const result1M = truncateAtSectionBoundary(content, budget1M.inlineContextBudgetChars);
|
|
292
|
-
|
|
293
|
-
assert.ok(result128K.content.includes("[...truncated"), "128K should truncate ~310K content");
|
|
294
|
-
assert.ok(result128K.droppedSections > 0, "128K should report dropped sections");
|
|
295
|
-
assert.ok(!result1M.content.includes("[...truncated"), "1M should preserve ~310K content");
|
|
296
|
-
assert.equal(result1M.droppedSections, 0);
|
|
297
|
-
assert.ok(result128K.content.length < result1M.content.length, "128K result should be shorter than 1M result");
|
|
298
|
-
});
|
|
299
|
-
});
|
|
300
|
-
|
|
301
|
-
// ─── execute-task template includes verificationBudget placeholder ─────────
|
|
302
|
-
|
|
303
|
-
describe("prompt-budget: execute-task template", () => {
|
|
304
|
-
it("contains {{verificationBudget}} placeholder", () => {
|
|
305
|
-
const templatePath = join(__dirname, "..", "prompts", "execute-task.md");
|
|
306
|
-
const template = readFileSync(templatePath, "utf-8");
|
|
307
|
-
assert.ok(
|
|
308
|
-
template.includes("{{verificationBudget}}"),
|
|
309
|
-
"execute-task.md should contain {{verificationBudget}} placeholder",
|
|
310
|
-
);
|
|
311
|
-
});
|
|
312
|
-
|
|
313
|
-
it("verificationBudget format varies with context window size", () => {
|
|
314
|
-
const budget128K = computeBudgets(128_000);
|
|
315
|
-
const budget1M = computeBudgets(1_000_000);
|
|
316
|
-
|
|
317
|
-
const format128K = `~${Math.round(budget128K.verificationBudgetChars / 1000)}K chars`;
|
|
318
|
-
const format1M = `~${Math.round(budget1M.verificationBudgetChars / 1000)}K chars`;
|
|
319
|
-
|
|
320
|
-
assert.notEqual(format128K, format1M, "128K and 1M should produce different verification budget strings");
|
|
321
|
-
assert.ok(format128K.includes("~51K"), `128K should produce ~51K, got ${format128K}`);
|
|
322
|
-
assert.ok(format1M.includes("~400K"), `1M should produce ~400K, got ${format1M}`);
|
|
323
|
-
});
|
|
324
|
-
});
|
|
325
|
-
|
|
326
|
-
// ─── buildCompleteSlicePrompt budget enforcement (simulated) ─────────────────
|
|
327
|
-
|
|
328
|
-
describe("prompt-budget: complete-slice builder truncation pattern", () => {
|
|
329
|
-
it("truncateAtSectionBoundary truncates assembled inlinedContext for complete-slice pattern", () => {
|
|
330
|
-
// Simulate buildCompleteSlicePrompt: roadmap + slice plan + task summaries
|
|
331
|
-
const inlined: string[] = [];
|
|
332
|
-
inlined.push("### Milestone Roadmap\n\nRoadmap content here.");
|
|
333
|
-
inlined.push("### Slice Plan\n\nSlice plan content here.");
|
|
334
|
-
// Add many task summaries that push past budget
|
|
335
|
-
for (let i = 0; i < 50; i++) {
|
|
336
|
-
inlined.push(`### Task Summary: T${String(i).padStart(2, "0")}\nSource: \`tasks/T${String(i).padStart(2, "0")}-SUMMARY.md\`\n\n${"Task result details. ".repeat(200)}`);
|
|
337
|
-
}
|
|
338
|
-
|
|
339
|
-
const assembledContent = `## Inlined Context (preloaded — do not re-read these files)\n\n${inlined.join("\n\n---\n\n")}`;
|
|
340
|
-
|
|
341
|
-
// Small context window (128K) should truncate
|
|
342
|
-
const budget128K = computeBudgets(128_000);
|
|
343
|
-
const result128K = truncateAtSectionBoundary(assembledContent, budget128K.inlineContextBudgetChars);
|
|
344
|
-
assert.ok(result128K.content.includes("[...truncated"), "128K should truncate many task summaries");
|
|
345
|
-
assert.ok(result128K.content.includes("### Milestone Roadmap"), "should preserve early sections");
|
|
346
|
-
assert.ok(result128K.droppedSections > 0, "128K should report dropped sections");
|
|
347
|
-
|
|
348
|
-
// Large context window (1M) should preserve all
|
|
349
|
-
const budget1M = computeBudgets(1_000_000);
|
|
350
|
-
const result1M = truncateAtSectionBoundary(assembledContent, budget1M.inlineContextBudgetChars);
|
|
351
|
-
assert.ok(!result1M.content.includes("[...truncated"), "1M should preserve all task summaries");
|
|
352
|
-
assert.equal(result1M.droppedSections, 0);
|
|
353
|
-
});
|
|
354
|
-
|
|
355
|
-
it("small content passes through unchanged at any context window size", () => {
|
|
356
|
-
const smallContent = "## Inlined Context\n\n### Roadmap\n\nSmall roadmap.\n\n---\n\n### Plan\n\nSmall plan.";
|
|
357
|
-
|
|
358
|
-
const budget128K = computeBudgets(128_000);
|
|
359
|
-
const result128K = truncateAtSectionBoundary(smallContent, budget128K.inlineContextBudgetChars);
|
|
360
|
-
assert.equal(result128K.content, smallContent, "small content unchanged for 128K");
|
|
361
|
-
assert.equal(result128K.droppedSections, 0);
|
|
362
|
-
|
|
363
|
-
const budget1M = computeBudgets(1_000_000);
|
|
364
|
-
const result1M = truncateAtSectionBoundary(smallContent, budget1M.inlineContextBudgetChars);
|
|
365
|
-
assert.equal(result1M.content, smallContent, "small content unchanged for 1M");
|
|
366
|
-
assert.equal(result1M.droppedSections, 0);
|
|
367
|
-
});
|
|
368
|
-
});
|
|
369
|
-
|
|
370
|
-
// ─── buildCompleteMilestonePrompt budget enforcement (simulated) ─────────────
|
|
371
|
-
|
|
372
|
-
describe("prompt-budget: complete-milestone builder truncation pattern", () => {
|
|
373
|
-
it("truncateAtSectionBoundary truncates assembled inlinedContext for complete-milestone pattern", () => {
|
|
374
|
-
// Simulate buildCompleteMilestonePrompt: roadmap + slice summaries + root files
|
|
375
|
-
const inlined: string[] = [];
|
|
376
|
-
inlined.push("### Milestone Roadmap\n\nRoadmap content here.");
|
|
377
|
-
// Add many slice summaries that push past budget
|
|
378
|
-
for (let i = 0; i < 30; i++) {
|
|
379
|
-
inlined.push(`### S${String(i).padStart(2, "0")} Summary\n\n${"Slice summary with detailed results and forward intelligence. ".repeat(200)}`);
|
|
380
|
-
}
|
|
381
|
-
inlined.push("### Requirements\n\nProject requirements.");
|
|
382
|
-
inlined.push("### Decisions\n\nProject decisions.");
|
|
383
|
-
|
|
384
|
-
const assembledContent = `## Inlined Context (preloaded — do not re-read these files)\n\n${inlined.join("\n\n---\n\n")}`;
|
|
385
|
-
|
|
386
|
-
// Small context window (128K) should truncate
|
|
387
|
-
const budget128K = computeBudgets(128_000);
|
|
388
|
-
const result128K = truncateAtSectionBoundary(assembledContent, budget128K.inlineContextBudgetChars);
|
|
389
|
-
assert.ok(result128K.content.includes("[...truncated"), "128K should truncate many slice summaries");
|
|
390
|
-
assert.ok(result128K.droppedSections > 0);
|
|
391
|
-
|
|
392
|
-
// Large context window (1M) should preserve all
|
|
393
|
-
const budget1M = computeBudgets(1_000_000);
|
|
394
|
-
const result1M = truncateAtSectionBoundary(assembledContent, budget1M.inlineContextBudgetChars);
|
|
395
|
-
assert.ok(!result1M.content.includes("[...truncated"), "1M should preserve all slice summaries");
|
|
396
|
-
assert.equal(result1M.droppedSections, 0);
|
|
397
|
-
});
|
|
398
|
-
|
|
399
|
-
it("different context windows produce different truncation for milestone completion", () => {
|
|
400
|
-
// Create content that exceeds 128K budget but not 200K budget
|
|
401
|
-
const inlined: string[] = [];
|
|
402
|
-
inlined.push("### Roadmap\n\nRoadmap.");
|
|
403
|
-
for (let i = 0; i < 15; i++) {
|
|
404
|
-
inlined.push(`### S${i} Summary\n\n${"X".repeat(15000)}`);
|
|
405
|
-
}
|
|
406
|
-
const content = `## Inlined Context\n\n${inlined.join("\n\n---\n\n")}`;
|
|
407
|
-
// ~225K chars total
|
|
408
|
-
|
|
409
|
-
const budget128K = computeBudgets(128_000);
|
|
410
|
-
const budget200K = computeBudgets(200_000);
|
|
411
|
-
const budget1M = computeBudgets(1_000_000);
|
|
412
|
-
|
|
413
|
-
const result128K = truncateAtSectionBoundary(content, budget128K.inlineContextBudgetChars);
|
|
414
|
-
const result200K = truncateAtSectionBoundary(content, budget200K.inlineContextBudgetChars);
|
|
415
|
-
const result1M = truncateAtSectionBoundary(content, budget1M.inlineContextBudgetChars);
|
|
416
|
-
|
|
417
|
-
// 128K (budget ~204K) should truncate ~225K content
|
|
418
|
-
assert.ok(result128K.content.includes("[...truncated"), "128K should truncate ~225K content");
|
|
419
|
-
assert.ok(result128K.droppedSections > 0);
|
|
420
|
-
// 200K (budget ~320K) should not truncate ~225K content
|
|
421
|
-
assert.ok(!result200K.content.includes("[...truncated"), "200K should preserve ~225K content");
|
|
422
|
-
assert.equal(result200K.droppedSections, 0);
|
|
423
|
-
// 1M should not truncate
|
|
424
|
-
assert.ok(!result1M.content.includes("[...truncated"), "1M should preserve ~225K content");
|
|
425
|
-
assert.equal(result1M.droppedSections, 0);
|
|
426
|
-
// 128K result should be shorter
|
|
427
|
-
assert.ok(result128K.content.length < result200K.content.length, "128K result should be shorter than 200K");
|
|
428
|
-
});
|
|
429
|
-
});
|
|
430
|
-
|
|
431
|
-
// ─── buildExecuteTaskPrompt budget enforcement (simulated) ───────────────────
|
|
432
|
-
|
|
433
|
-
describe("prompt-budget: execute-task builder truncation pattern", () => {
|
|
434
|
-
it("truncateAtSectionBoundary truncates assembled carry-forward + task plan + slice excerpt", () => {
|
|
435
|
-
// Simulate the assembled content from buildExecuteTaskPrompt
|
|
436
|
-
const carryForward = "## Carry-Forward Context\n" + Array.from({ length: 20 }, (_, i) =>
|
|
437
|
-
`- \`tasks/T${String(i).padStart(2, "0")}-SUMMARY.md\` — ${"Summary details. ".repeat(100)}`
|
|
438
|
-
).join("\n");
|
|
439
|
-
|
|
440
|
-
const taskPlan = "## Inlined Task Plan\n\n" + Array.from({ length: 10 }, (_, i) =>
|
|
441
|
-
`### Step ${i}\n\n${"Implementation step details. ".repeat(200)}`
|
|
442
|
-
).join("\n\n");
|
|
443
|
-
|
|
444
|
-
const sliceExcerpt = "## Slice Plan Excerpt\n\n" + "Slice goal and verification details. ".repeat(100);
|
|
445
|
-
|
|
446
|
-
const assembled = [carryForward, taskPlan, sliceExcerpt].join("\n\n---\n\n");
|
|
447
|
-
|
|
448
|
-
// Small context window should truncate
|
|
449
|
-
const budget128K = computeBudgets(128_000);
|
|
450
|
-
const result = truncateAtSectionBoundary(assembled, budget128K.inlineContextBudgetChars);
|
|
451
|
-
|
|
452
|
-
// Content should respect budget
|
|
453
|
-
assert.ok(
|
|
454
|
-
result.content.length <= budget128K.inlineContextBudgetChars + 100,
|
|
455
|
-
`result should respect 128K budget, got ${result.content.length} chars vs budget ${budget128K.inlineContextBudgetChars}`,
|
|
456
|
-
);
|
|
457
|
-
|
|
458
|
-
// Large content should be truncated
|
|
459
|
-
if (assembled.length > budget128K.inlineContextBudgetChars) {
|
|
460
|
-
assert.ok(result.content.includes("[...truncated"), "should truncate when content exceeds 128K budget");
|
|
461
|
-
assert.ok(result.droppedSections > 0, "should report dropped sections");
|
|
462
|
-
}
|
|
463
|
-
});
|
|
464
|
-
});
|