@opengsd/gsd-pi 1.2.0-dev.0b870afa → 1.2.0-dev.23d85b63
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/cli-model-override.d.ts +15 -0
- package/dist/cli-model-override.js +21 -0
- package/dist/cli.js +14 -19
- package/dist/headless-events.d.ts +16 -1
- package/dist/headless-events.js +19 -2
- package/dist/headless.js +8 -1
- package/dist/loader.js +6 -4
- package/dist/onboarding.js +9 -4
- package/dist/provider-migrations.d.ts +23 -0
- package/dist/provider-migrations.js +41 -0
- package/dist/register-agent-bundles.d.ts +11 -2
- package/dist/register-agent-bundles.js +18 -4
- package/dist/resource-loader.d.ts +10 -5
- package/dist/resource-loader.js +121 -6
- package/dist/resources/.managed-resources-content-hash +1 -1
- package/dist/resources/extensions/ask-user-questions.js +3 -2
- package/dist/resources/extensions/claude-code-cli/stream-adapter.js +447 -215
- package/dist/resources/extensions/claude-code-cli/turn-assembler.js +33 -1
- package/dist/resources/extensions/google-cli/stream-adapter.js +16 -1
- package/dist/resources/extensions/gsd/auto/closeout.js +215 -0
- package/dist/resources/extensions/gsd/auto/dispatch-history.js +21 -6
- package/dist/resources/extensions/gsd/auto/dispatch.js +365 -0
- package/dist/resources/extensions/gsd/auto/finalize.js +347 -0
- package/dist/resources/extensions/gsd/auto/loop.js +4 -1
- package/dist/resources/extensions/gsd/auto/milestone-lease-reclaim.js +56 -0
- package/dist/resources/extensions/gsd/auto/orchestrator.js +119 -18
- package/dist/resources/extensions/gsd/auto/phase-helpers.js +146 -0
- package/dist/resources/extensions/gsd/auto/phases.js +17 -2372
- package/dist/resources/extensions/gsd/auto/pre-dispatch.js +542 -0
- package/dist/resources/extensions/gsd/auto/unit-phase.js +694 -0
- package/dist/resources/extensions/gsd/auto/workflow-unit-dispatch.js +1 -1
- package/dist/resources/extensions/gsd/auto/worktree-safety-phase.js +125 -0
- package/dist/resources/extensions/gsd/auto-closeout-messaging.js +90 -0
- package/dist/resources/extensions/gsd/auto-dashboard.js +255 -431
- package/dist/resources/extensions/gsd/auto-direct-dispatch.js +15 -3
- package/dist/resources/extensions/gsd/auto-dispatch.js +19 -1
- package/dist/resources/extensions/gsd/auto-model-selection.js +9 -6
- package/dist/resources/extensions/gsd/auto-post-unit.js +12 -8
- package/dist/resources/extensions/gsd/auto-prompts.js +5 -1
- package/dist/resources/extensions/gsd/auto-recovery.js +52 -6
- package/dist/resources/extensions/gsd/auto-start.js +28 -7
- package/dist/resources/extensions/gsd/auto-worktree.js +48 -3
- package/dist/resources/extensions/gsd/auto.js +83 -19
- package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +4 -2
- package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +37 -7
- package/dist/resources/extensions/gsd/bootstrap/register-extension.js +3 -1
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +32 -3
- package/dist/resources/extensions/gsd/bootstrap/write-gate.js +56 -16
- package/dist/resources/extensions/gsd/closeout-wizard.js +8 -3
- package/dist/resources/extensions/gsd/commands/handlers/core.js +22 -8
- package/dist/resources/extensions/gsd/commands/handlers/ops.js +2 -2
- package/dist/resources/extensions/gsd/commands-mcp-status.js +2 -2
- package/dist/resources/extensions/gsd/commands-prefs-wizard.js +8 -0
- package/dist/resources/extensions/gsd/commands-workflow-templates.js +9 -2
- package/dist/resources/extensions/gsd/config-overlay.js +11 -8
- package/dist/resources/extensions/gsd/db/engine.js +24 -6
- package/dist/resources/extensions/gsd/db/queries.js +30 -0
- package/dist/resources/extensions/gsd/db/writers/reconcile.js +19 -1
- package/dist/resources/extensions/gsd/db-migration-backup.js +51 -8
- package/dist/resources/extensions/gsd/db-transaction.js +27 -23
- package/dist/resources/extensions/gsd/db-writer.js +8 -17
- package/dist/resources/extensions/gsd/doctor-environment.js +256 -125
- package/dist/resources/extensions/gsd/doctor-git-checks.js +5 -1
- package/dist/resources/extensions/gsd/doctor-providers.js +1 -1
- package/dist/resources/extensions/gsd/doctor-runtime-checks.js +11 -9
- package/dist/resources/extensions/gsd/gsd-db.js +15 -20
- package/dist/resources/extensions/gsd/guided-flow.js +88 -2
- package/dist/resources/extensions/gsd/health-widget.js +87 -28
- package/dist/resources/extensions/gsd/mcp-bridge.js +10 -0
- package/dist/resources/extensions/gsd/memory-relations.js +1 -1
- package/dist/resources/extensions/gsd/milestone-settlement.js +2 -2
- package/dist/resources/extensions/gsd/notifications.js +12 -7
- package/dist/resources/extensions/gsd/preferences-models.js +17 -9
- package/dist/resources/extensions/gsd/preferences.js +91 -5
- package/dist/resources/extensions/gsd/prompts/complete-milestone.md +8 -2
- package/dist/resources/extensions/gsd/prompts/complete-slice.md +6 -2
- package/dist/resources/extensions/gsd/prompts/execute-task.md +7 -2
- package/dist/resources/extensions/gsd/prompts/quick-task.md +1 -1
- package/dist/resources/extensions/gsd/prompts/reactive-execute.md +2 -2
- package/dist/resources/extensions/gsd/prompts/run-uat.md +7 -1
- package/dist/resources/extensions/gsd/prompts/triage-captures.md +1 -1
- package/dist/resources/extensions/gsd/prompts/workflow-start.md +2 -1
- package/dist/resources/extensions/gsd/provider-error-guidance.js +24 -0
- package/dist/resources/extensions/gsd/session-lock.js +4 -3
- package/dist/resources/extensions/gsd/skill-activation.js +3 -6
- package/dist/resources/extensions/gsd/state-reconciliation/drift/artifact-db.js +13 -6
- package/dist/resources/extensions/gsd/state.js +6 -2
- package/dist/resources/extensions/gsd/tool-surface-readiness.js +83 -31
- package/dist/resources/extensions/gsd/tools/complete-task.js +62 -0
- package/dist/resources/extensions/gsd/tools/exec-tool.js +2 -109
- package/dist/resources/extensions/gsd/tui/render-kit.js +38 -13
- package/dist/resources/extensions/gsd/unit-context-composer.js +1 -1
- package/dist/resources/extensions/gsd/unit-registry.js +34 -4
- package/dist/resources/extensions/gsd/workflow-logger.js +4 -0
- package/dist/resources/extensions/gsd/workflow-mcp-auto-prep.js +2 -0
- package/dist/resources/extensions/gsd/workflow-mcp-readiness-cache.js +105 -0
- package/dist/resources/extensions/gsd/worktree-manager.js +101 -2
- package/dist/resources/extensions/gsd/worktree-safety.js +28 -26
- package/dist/resources/extensions/gsd/worktree-shell-guard.js +113 -0
- package/dist/resources/extensions/gsd/worktree.js +8 -1
- package/dist/resources/extensions/mcp-client/manager.js +6 -1
- package/dist/resources/extensions/search-the-web/index.js +41 -9
- package/dist/resources/extensions/search-the-web/native-search.js +18 -4
- package/dist/resources/extensions/shared/gsd-browser-cli.js +40 -2
- package/dist/resources/extensions/subagent/index.js +20 -15
- package/dist/resources/extensions/subagent/worktree-cwd.js +31 -0
- package/dist/resources/skills/create-skill/SKILL.md +3 -0
- package/dist/resources/skills/create-skill/references/skill-structure.md +1 -0
- package/dist/runtime-checks.d.ts +10 -0
- package/dist/runtime-checks.js +27 -0
- package/dist/tsconfig.extensions.tsbuildinfo +1 -1
- package/dist/web/standalone/.next/BUILD_ID +1 -1
- package/dist/web/standalone/.next/app-path-routes-manifest.json +10 -10
- package/dist/web/standalone/.next/build-manifest.json +2 -2
- package/dist/web/standalone/.next/prerender-manifest.json +3 -3
- package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/api/boot/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/captures/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/cleanup/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/doctor/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/export-data/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/files/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/forensics/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/git/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/history/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/hooks/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/inspect/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/knowledge/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/live-state/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/mcp-connections/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/notifications/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/onboarding/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/projects/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/recovery/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/session/browser/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/session/command/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/session/events/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/session/manage/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/settings-data/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/shutdown/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/skill-health/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/steer/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/switch-root/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/undo/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/visualizer/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/index.html +1 -1
- package/dist/web/standalone/.next/server/app/index.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app-paths-manifest.json +10 -10
- package/dist/web/standalone/.next/server/chunks/{5942.js → 1128.js} +1 -1
- package/dist/web/standalone/.next/server/chunks/8357.js +1 -1
- package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
- package/dist/web/standalone/.next/server/pages/404.html +1 -1
- package/dist/web/standalone/.next/server/pages/500.html +1 -1
- package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
- package/dist/web/standalone/node_modules/node-pty/build/Makefile +1 -1
- package/package.json +4 -4
- package/packages/cloud-mcp-gateway/package.json +2 -2
- package/packages/contracts/package.json +1 -1
- package/packages/daemon/package.json +4 -4
- package/packages/gsd-agent-core/dist/sdk.d.ts.map +1 -1
- package/packages/gsd-agent-core/dist/sdk.js +12 -6
- package/packages/gsd-agent-core/dist/sdk.js.map +1 -1
- package/packages/gsd-agent-core/package.json +5 -5
- package/packages/gsd-agent-modes/dist/modes/interactive/components/assistant-message.d.ts +5 -5
- package/packages/gsd-agent-modes/dist/modes/interactive/components/assistant-message.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/assistant-message.js +12 -24
- package/packages/gsd-agent-modes/dist/modes/interactive/components/assistant-message.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/bash-execution.js +5 -5
- package/packages/gsd-agent-modes/dist/modes/interactive/components/bash-execution.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/branch-summary-message.d.ts +3 -3
- package/packages/gsd-agent-modes/dist/modes/interactive/components/branch-summary-message.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/branch-summary-message.js +20 -11
- package/packages/gsd-agent-modes/dist/modes/interactive/components/branch-summary-message.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/chat-turn-connect.d.ts +4 -3
- package/packages/gsd-agent-modes/dist/modes/interactive/components/chat-turn-connect.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/chat-turn-connect.js +5 -54
- package/packages/gsd-agent-modes/dist/modes/interactive/components/chat-turn-connect.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/compaction-summary-message.d.ts +2 -4
- package/packages/gsd-agent-modes/dist/modes/interactive/components/compaction-summary-message.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/compaction-summary-message.js +2 -4
- package/packages/gsd-agent-modes/dist/modes/interactive/components/compaction-summary-message.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/custom-editor.d.ts +2 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/custom-editor.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/custom-editor.js +4 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/custom-editor.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/footer.d.ts +9 -12
- package/packages/gsd-agent-modes/dist/modes/interactive/components/footer.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/footer.js +100 -166
- package/packages/gsd-agent-modes/dist/modes/interactive/components/footer.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/gsd-progress-state.d.ts +2 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/gsd-progress-state.d.ts.map +1 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/gsd-progress-state.js +4 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/gsd-progress-state.js.map +1 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/gsd-status-widget.d.ts +23 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/gsd-status-widget.d.ts.map +1 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/gsd-status-widget.js +178 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/gsd-status-widget.js.map +1 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/login-dialog.d.ts +8 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/login-dialog.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/login-dialog.js +21 -9
- package/packages/gsd-agent-modes/dist/modes/interactive/components/login-dialog.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.d.ts +2 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.js +10 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/skill-invocation-message.d.ts +2 -3
- package/packages/gsd-agent-modes/dist/modes/interactive/components/skill-invocation-message.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/skill-invocation-message.js +2 -3
- package/packages/gsd-agent-modes/dist/modes/interactive/components/skill-invocation-message.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts +11 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js +85 -19
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.d.ts +71 -3
- package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.js +257 -37
- package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/user-message.d.ts +3 -3
- package/packages/gsd-agent-modes/dist/modes/interactive/components/user-message.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/user-message.js +19 -19
- package/packages/gsd-agent-modes/dist/modes/interactive/components/user-message.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.d.ts +3 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js +26 -10
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/extension-ui-controller.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/extension-ui-controller.js +12 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/extension-ui-controller.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js +5 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-autocomplete.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-autocomplete.js +3 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-autocomplete.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js +3 -5
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-extension-dialogs.js +2 -2
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-extension-dialogs.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-extension-widgets.d.ts +1 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-extension-widgets.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-extension-widgets.js +25 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-extension-widgets.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-key-handlers.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-key-handlers.js +1 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-key-handlers.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode-init.d.ts +1 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode-init.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode-init.js +20 -49
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode-init.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode-state.d.ts +4 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode-state.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode-state.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.d.ts +10 -2
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.js +48 -6
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.js +4 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-ui-messaging.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-ui-messaging.js +0 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-ui-messaging.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js +3 -0
- package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js.map +1 -1
- package/packages/gsd-agent-modes/package.json +7 -7
- package/packages/mcp-server/README.md +12 -3
- package/packages/mcp-server/dist/cli-runner.d.ts +40 -0
- package/packages/mcp-server/dist/cli-runner.d.ts.map +1 -0
- package/packages/mcp-server/dist/cli-runner.js +137 -0
- package/packages/mcp-server/dist/cli-runner.js.map +1 -0
- package/packages/mcp-server/dist/cli.js +2 -58
- package/packages/mcp-server/dist/cli.js.map +1 -1
- package/packages/mcp-server/dist/pid-registry.d.ts +46 -0
- package/packages/mcp-server/dist/pid-registry.d.ts.map +1 -0
- package/packages/mcp-server/dist/pid-registry.js +459 -0
- package/packages/mcp-server/dist/pid-registry.js.map +1 -0
- package/packages/mcp-server/dist/probe-mode.d.ts +4 -0
- package/packages/mcp-server/dist/probe-mode.d.ts.map +1 -0
- package/packages/mcp-server/dist/probe-mode.js +10 -0
- package/packages/mcp-server/dist/probe-mode.js.map +1 -0
- package/packages/mcp-server/dist/stdio-watchdog.d.ts +8 -0
- package/packages/mcp-server/dist/stdio-watchdog.d.ts.map +1 -0
- package/packages/mcp-server/dist/stdio-watchdog.js +40 -0
- package/packages/mcp-server/dist/stdio-watchdog.js.map +1 -0
- package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.js +62 -43
- package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
- package/packages/mcp-server/package.json +5 -5
- package/packages/native/package.json +1 -1
- package/packages/pi-agent-core/dist/agent-loop.js +52 -2
- package/packages/pi-agent-core/dist/agent-loop.js.map +1 -1
- package/packages/pi-agent-core/package.json +1 -1
- package/packages/pi-ai/package.json +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/extension-upstream-types.d.ts +28 -2
- package/packages/pi-coding-agent/dist/core/extensions/extension-upstream-types.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/extension-upstream-types.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.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts +5 -1
- package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/runner.js +3 -1
- package/packages/pi-coding-agent/dist/core/extensions/runner.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/settings-manager.d.ts +3 -0
- package/packages/pi-coding-agent/dist/core/settings-manager.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/settings-manager.js +11 -0
- package/packages/pi-coding-agent/dist/core/settings-manager.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.map +1 -1
- package/packages/pi-coding-agent/dist/theme/theme.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/theme/theme.js +45 -17
- package/packages/pi-coding-agent/dist/theme/theme.js.map +1 -1
- package/packages/pi-coding-agent/package.json +8 -8
- package/packages/pi-tui/README.md +15 -0
- package/packages/pi-tui/dist/autocomplete.d.ts.map +1 -1
- package/packages/pi-tui/dist/autocomplete.js +6 -1
- package/packages/pi-tui/dist/autocomplete.js.map +1 -1
- package/packages/pi-tui/dist/components/input.js +1 -1
- package/packages/pi-tui/dist/components/input.js.map +1 -1
- package/packages/pi-tui/dist/components/loader.d.ts.map +1 -1
- package/packages/pi-tui/dist/components/loader.js +1 -0
- package/packages/pi-tui/dist/components/loader.js.map +1 -1
- package/packages/pi-tui/dist/components/select-list.d.ts.map +1 -1
- package/packages/pi-tui/dist/components/select-list.js +8 -2
- package/packages/pi-tui/dist/components/select-list.js.map +1 -1
- package/packages/pi-tui/dist/index.d.ts +2 -2
- package/packages/pi-tui/dist/index.d.ts.map +1 -1
- package/packages/pi-tui/dist/index.js +2 -2
- package/packages/pi-tui/dist/index.js.map +1 -1
- package/packages/pi-tui/dist/terminal-image.d.ts +33 -0
- package/packages/pi-tui/dist/terminal-image.d.ts.map +1 -1
- package/packages/pi-tui/dist/terminal-image.js +54 -2
- package/packages/pi-tui/dist/terminal-image.js.map +1 -1
- package/packages/pi-tui/dist/terminal.d.ts +12 -0
- package/packages/pi-tui/dist/terminal.d.ts.map +1 -1
- package/packages/pi-tui/dist/terminal.js +70 -25
- package/packages/pi-tui/dist/terminal.js.map +1 -1
- package/packages/pi-tui/dist/tui.d.ts +15 -0
- package/packages/pi-tui/dist/tui.d.ts.map +1 -1
- package/packages/pi-tui/dist/tui.js +106 -21
- package/packages/pi-tui/dist/tui.js.map +1 -1
- package/packages/pi-tui/dist/utils.d.ts.map +1 -1
- package/packages/pi-tui/dist/utils.js +110 -36
- package/packages/pi-tui/dist/utils.js.map +1 -1
- package/packages/pi-tui/package.json +2 -2
- package/packages/rpc-client/package.json +2 -2
- package/pkg/dist/theme/theme.d.ts.map +1 -1
- package/pkg/dist/theme/theme.js +45 -17
- package/pkg/dist/theme/theme.js.map +1 -1
- package/pkg/package.json +1 -1
- package/src/resources/extensions/ask-user-questions.ts +7 -2
- package/src/resources/extensions/browser-tools/tests/gsd-browser-launch-config.test.mjs +80 -0
- package/src/resources/extensions/claude-code-cli/stream-adapter.ts +531 -226
- package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +672 -7
- package/src/resources/extensions/claude-code-cli/turn-assembler.ts +38 -1
- package/src/resources/extensions/google-cli/stream-adapter.ts +22 -1
- package/src/resources/extensions/gsd/auto/closeout.ts +309 -0
- package/src/resources/extensions/gsd/auto/dispatch-history.ts +22 -6
- package/src/resources/extensions/gsd/auto/dispatch.ts +449 -0
- package/src/resources/extensions/gsd/auto/finalize.ts +445 -0
- package/src/resources/extensions/gsd/auto/loop.ts +4 -1
- package/src/resources/extensions/gsd/auto/milestone-lease-reclaim.ts +74 -0
- package/src/resources/extensions/gsd/auto/orchestrator.ts +140 -18
- package/src/resources/extensions/gsd/auto/phase-helpers.ts +199 -0
- package/src/resources/extensions/gsd/auto/phases.ts +58 -3061
- package/src/resources/extensions/gsd/auto/pre-dispatch.ts +716 -0
- package/src/resources/extensions/gsd/auto/unit-phase.ts +910 -0
- package/src/resources/extensions/gsd/auto/workflow-unit-dispatch.ts +1 -1
- package/src/resources/extensions/gsd/auto/worktree-safety-phase.ts +149 -0
- package/src/resources/extensions/gsd/auto-closeout-messaging.ts +90 -0
- package/src/resources/extensions/gsd/auto-dashboard.ts +310 -454
- package/src/resources/extensions/gsd/auto-direct-dispatch.ts +15 -2
- package/src/resources/extensions/gsd/auto-dispatch.ts +24 -2
- package/src/resources/extensions/gsd/auto-model-selection.ts +20 -5
- package/src/resources/extensions/gsd/auto-post-unit.ts +16 -9
- package/src/resources/extensions/gsd/auto-prompts.ts +5 -1
- package/src/resources/extensions/gsd/auto-recovery.ts +62 -8
- package/src/resources/extensions/gsd/auto-start.ts +44 -7
- package/src/resources/extensions/gsd/auto-worktree.ts +51 -3
- package/src/resources/extensions/gsd/auto.ts +118 -18
- package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +6 -2
- package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +56 -6
- package/src/resources/extensions/gsd/bootstrap/register-extension.ts +2 -1
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +36 -3
- package/src/resources/extensions/gsd/bootstrap/write-gate.ts +69 -16
- package/src/resources/extensions/gsd/closeout-wizard.ts +11 -2
- package/src/resources/extensions/gsd/commands/handlers/core.ts +27 -8
- package/src/resources/extensions/gsd/commands/handlers/ops.ts +5 -2
- package/src/resources/extensions/gsd/commands-mcp-status.ts +2 -2
- package/src/resources/extensions/gsd/commands-prefs-wizard.ts +7 -0
- package/src/resources/extensions/gsd/commands-workflow-templates.ts +11 -4
- package/src/resources/extensions/gsd/config-overlay.ts +22 -9
- package/src/resources/extensions/gsd/db/engine.ts +26 -6
- package/src/resources/extensions/gsd/db/queries.ts +29 -0
- package/src/resources/extensions/gsd/db/writers/reconcile.ts +24 -1
- package/src/resources/extensions/gsd/db-migration-backup.ts +56 -7
- package/src/resources/extensions/gsd/db-transaction.ts +37 -20
- package/src/resources/extensions/gsd/db-writer.ts +11 -19
- package/src/resources/extensions/gsd/doctor-environment.ts +267 -142
- package/src/resources/extensions/gsd/doctor-git-checks.ts +4 -1
- package/src/resources/extensions/gsd/doctor-providers.ts +1 -1
- package/src/resources/extensions/gsd/doctor-runtime-checks.ts +10 -10
- package/src/resources/extensions/gsd/gsd-db.ts +15 -19
- package/src/resources/extensions/gsd/guided-flow.ts +128 -2
- package/src/resources/extensions/gsd/health-widget.ts +91 -27
- package/src/resources/extensions/gsd/mcp-bridge.ts +39 -0
- package/src/resources/extensions/gsd/memory-relations.ts +1 -1
- package/src/resources/extensions/gsd/milestone-settlement.ts +2 -2
- package/src/resources/extensions/gsd/notifications.ts +13 -6
- package/src/resources/extensions/gsd/preferences-models.ts +26 -8
- package/src/resources/extensions/gsd/preferences.ts +111 -5
- package/src/resources/extensions/gsd/prompts/complete-milestone.md +8 -2
- package/src/resources/extensions/gsd/prompts/complete-slice.md +6 -2
- package/src/resources/extensions/gsd/prompts/execute-task.md +7 -2
- package/src/resources/extensions/gsd/prompts/quick-task.md +1 -1
- package/src/resources/extensions/gsd/prompts/reactive-execute.md +2 -2
- package/src/resources/extensions/gsd/prompts/run-uat.md +7 -1
- package/src/resources/extensions/gsd/prompts/triage-captures.md +1 -1
- package/src/resources/extensions/gsd/prompts/workflow-start.md +2 -1
- package/src/resources/extensions/gsd/provider-error-guidance.ts +32 -0
- package/src/resources/extensions/gsd/session-lock.ts +8 -7
- package/src/resources/extensions/gsd/skill-activation.ts +3 -6
- package/src/resources/extensions/gsd/state-reconciliation/drift/artifact-db.ts +23 -10
- package/src/resources/extensions/gsd/state.ts +7 -1
- package/src/resources/extensions/gsd/tests/auto-abort-pause-regression.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/auto-blocked-remediation-message.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/auto-closeout-messaging.test.ts +71 -0
- package/src/resources/extensions/gsd/tests/auto-dashboard.test.ts +68 -116
- package/src/resources/extensions/gsd/tests/auto-direct-dispatch-parse.test.ts +33 -0
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +206 -22
- package/src/resources/extensions/gsd/tests/auto-model-selection-tool-poisoning.test.ts +7 -2
- package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +16 -1
- package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +89 -22
- package/src/resources/extensions/gsd/tests/auto-pause-double-entry-guard.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/auto-paused-ui-cleanup.test.ts +97 -4
- package/src/resources/extensions/gsd/tests/auto-phases-lifecycle.test.ts +2 -1
- package/src/resources/extensions/gsd/tests/auto-start-orphan-bootstrap.test.ts +236 -0
- package/src/resources/extensions/gsd/tests/auto-unit-closeout.test.ts +169 -1
- package/src/resources/extensions/gsd/tests/auto-verification.test.ts +36 -0
- package/src/resources/extensions/gsd/tests/blocker-placeholder-logs.test.ts +218 -0
- package/src/resources/extensions/gsd/tests/complete-milestone-prompt-rendering.test.ts +6 -2
- package/src/resources/extensions/gsd/tests/complete-task.test.ts +141 -5
- package/src/resources/extensions/gsd/tests/core-overlay-fallback.test.ts +1 -0
- package/src/resources/extensions/gsd/tests/db-engine-logs.test.ts +207 -0
- package/src/resources/extensions/gsd/tests/db-migration-backup.test.ts +68 -19
- package/src/resources/extensions/gsd/tests/db-transaction.test.ts +59 -0
- package/src/resources/extensions/gsd/tests/db-writer.test.ts +15 -4
- package/src/resources/extensions/gsd/tests/deep-project-auto-loop.test.ts +2 -1
- package/src/resources/extensions/gsd/tests/derive-state-helpers.test.ts +62 -0
- package/src/resources/extensions/gsd/tests/discuss-routing-fixes.test.ts +12 -2
- package/src/resources/extensions/gsd/tests/dispatch-db-degradation-logs.test.ts +98 -0
- package/src/resources/extensions/gsd/tests/dispatch-history.test.ts +55 -0
- package/src/resources/extensions/gsd/tests/dispatch-logs.test.ts +103 -0
- package/src/resources/extensions/gsd/tests/dispatch-reactive-logs.test.ts +98 -0
- package/src/resources/extensions/gsd/tests/dist-redirect.mjs +8 -0
- package/src/resources/extensions/gsd/tests/doctor-providers.test.ts +6 -4
- package/src/resources/extensions/gsd/tests/engine-interfaces-contract.test.ts +117 -91
- package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +113 -0
- package/src/resources/extensions/gsd/tests/flat-rate-routing-guard.test.ts +2 -1
- package/src/resources/extensions/gsd/tests/gsd-command-home.test.ts +40 -7
- package/src/resources/extensions/gsd/tests/gsd-db.test.ts +19 -0
- package/src/resources/extensions/gsd/tests/guided-dispatch-root.test.ts +16 -0
- package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +75 -0
- package/src/resources/extensions/gsd/tests/integration/auto-worktree.test.ts +15 -0
- package/src/resources/extensions/gsd/tests/integration/doctor-environment-async.test.ts +104 -0
- package/src/resources/extensions/gsd/tests/integration/run-uat.test.ts +18 -0
- package/src/resources/extensions/gsd/tests/interactive-routing-bypass.test.ts +1 -0
- package/src/resources/extensions/gsd/tests/journal-integration.test.ts +47 -16
- package/src/resources/extensions/gsd/tests/loop.test.ts +60 -0
- package/src/resources/extensions/gsd/tests/mcp-readiness-preflight.test.ts +205 -0
- package/src/resources/extensions/gsd/tests/mcp-status.test.ts +6 -5
- package/src/resources/extensions/gsd/tests/milestone-merge-stash-restore.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/milestone-report-path.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/milestone-settlement.test.ts +92 -0
- package/src/resources/extensions/gsd/tests/milestone-transition-state-rebuild.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/model-router.test.ts +139 -0
- package/src/resources/extensions/gsd/tests/notifications.test.ts +64 -9
- package/src/resources/extensions/gsd/tests/oauth-api-model-routing.test.ts +13 -1
- package/src/resources/extensions/gsd/tests/orchestrator-legacy-parity.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/orchestrator-logs.test.ts +335 -0
- package/src/resources/extensions/gsd/tests/parallel-skill-prompt-integration.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/parsers-legacy-importers.test.ts +5 -0
- package/src/resources/extensions/gsd/tests/phases-merge-error-stops-auto.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/phases-terminal-complete-idempotent.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/plan-gate-failed-doctor-heal-hint.test.ts +3 -3
- package/src/resources/extensions/gsd/tests/prefs-missing-models-crash.test.ts +35 -4
- package/src/resources/extensions/gsd/tests/progress-strip-test-helpers.ts +79 -0
- package/src/resources/extensions/gsd/tests/prompt-budget-enforcement.test.ts +2 -0
- package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +11 -2
- package/src/resources/extensions/gsd/tests/provider-error-guidance.test.ts +15 -0
- package/src/resources/extensions/gsd/tests/provider-errors.test.ts +2 -4
- package/src/resources/extensions/gsd/tests/reconcile-logs.test.ts +244 -0
- package/src/resources/extensions/gsd/tests/recovery-finalize-logs.test.ts +119 -0
- package/src/resources/extensions/gsd/tests/recovery-verify-logs.test.ts +428 -0
- package/src/resources/extensions/gsd/tests/register-extension-guard.test.ts +25 -0
- package/src/resources/extensions/gsd/tests/remote-notification-from-desktop.test.ts +31 -81
- package/src/resources/extensions/gsd/tests/resume-missing-worktree-warning.test.ts +5 -5
- package/src/resources/extensions/gsd/tests/runtime-invariant-modules.test.ts +7 -1
- package/src/resources/extensions/gsd/tests/session-start-footer.test.ts +68 -0
- package/src/resources/extensions/gsd/tests/show-config-command.test.ts +3 -0
- package/src/resources/extensions/gsd/tests/single-writer-invariant.test.ts +170 -48
- package/src/resources/extensions/gsd/tests/skill-activation.test.ts +20 -17
- package/src/resources/extensions/gsd/tests/start-auto-detached.test.ts +7 -3
- package/src/resources/extensions/gsd/tests/state-reconciliation-drift.test.ts +17 -1
- package/src/resources/extensions/gsd/tests/stop-auto-race-null-unit.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/teardown-chdir-failure-clears-registry.test.ts +17 -0
- package/src/resources/extensions/gsd/tests/thinking-level-resolution.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/token-tool-gating.test.ts +4 -2
- package/src/resources/extensions/gsd/tests/tool-surface-readiness.test.ts +184 -10
- package/src/resources/extensions/gsd/tests/tui-header-lifecycle.test.ts +40 -86
- package/src/resources/extensions/gsd/tests/tui-render-kit.test.ts +44 -6
- package/src/resources/extensions/gsd/tests/uok-audit.test.ts +194 -0
- package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/workflow-mcp-readiness-cache.test.ts +119 -0
- package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +65 -2
- package/src/resources/extensions/gsd/tests/workflow-phase-contract-matrix.test.ts +332 -0
- package/src/resources/extensions/gsd/tests/workflow-templates.test.ts +92 -0
- package/src/resources/extensions/gsd/tests/worktree-health-dispatch.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/worktree-manager.test.ts +36 -0
- package/src/resources/extensions/gsd/tests/worktree-project-root-degrade.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/worktree-safety-phase.test.ts +100 -0
- package/src/resources/extensions/gsd/tests/worktree-safety.test.ts +72 -0
- package/src/resources/extensions/gsd/tests/worktree-teardown-safety.test.ts +22 -0
- package/src/resources/extensions/gsd/tests/worktree-write-gate.test.ts +75 -3
- package/src/resources/extensions/gsd/tests/worktree.test.ts +18 -0
- package/src/resources/extensions/gsd/tool-surface-readiness.ts +126 -19
- package/src/resources/extensions/gsd/tools/complete-task.ts +87 -0
- package/src/resources/extensions/gsd/tools/exec-tool.ts +2 -118
- package/src/resources/extensions/gsd/tui/render-kit.ts +56 -13
- package/src/resources/extensions/gsd/unit-context-composer.ts +1 -1
- package/src/resources/extensions/gsd/unit-registry.ts +34 -4
- package/src/resources/extensions/gsd/workflow-logger.ts +5 -0
- package/src/resources/extensions/gsd/workflow-mcp-auto-prep.ts +2 -0
- package/src/resources/extensions/gsd/workflow-mcp-readiness-cache.ts +150 -0
- package/src/resources/extensions/gsd/worktree-manager.ts +97 -2
- package/src/resources/extensions/gsd/worktree-safety.ts +41 -39
- package/src/resources/extensions/gsd/worktree-shell-guard.ts +123 -0
- package/src/resources/extensions/gsd/worktree.ts +7 -1
- package/src/resources/extensions/mcp-client/manager.ts +7 -1
- package/src/resources/extensions/search-the-web/index.ts +45 -9
- package/src/resources/extensions/search-the-web/native-search.ts +16 -4
- package/src/resources/extensions/shared/gsd-browser-cli.ts +41 -2
- package/src/resources/extensions/subagent/index.ts +20 -15
- package/src/resources/extensions/subagent/tests/worktree-cwd.test.ts +57 -0
- package/src/resources/extensions/subagent/worktree-cwd.ts +35 -0
- package/src/resources/skills/create-skill/SKILL.md +3 -0
- package/src/resources/skills/create-skill/references/skill-structure.md +1 -0
- package/dist/resources/skills/gsd-browser/SKILL.md +0 -41
- package/src/resources/skills/gsd-browser/SKILL.md +0 -41
- /package/dist/web/standalone/.next/static/{T-LTxEw5wir5Lm5T3qEVd → Wn9u2NYq0cyUigB_3Z0_N}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{T-LTxEw5wir5Lm5T3qEVd → Wn9u2NYq0cyUigB_3Z0_N}/_ssgManifest.js +0 -0
|
@@ -1,13 +1,23 @@
|
|
|
1
1
|
// Project/App: gsd-pi
|
|
2
2
|
// File Purpose: Regression tests for auto-unit closeout activity classification.
|
|
3
3
|
|
|
4
|
-
import
|
|
4
|
+
import { mkdtempSync, writeFileSync, rmSync } from "node:fs";
|
|
5
|
+
import { tmpdir } from "node:os";
|
|
6
|
+
import { execSync } from "node:child_process";
|
|
7
|
+
import { join } from "node:path";
|
|
8
|
+
import test, { type TestContext } from "node:test";
|
|
5
9
|
import assert from "node:assert/strict";
|
|
6
10
|
|
|
7
11
|
import {
|
|
8
12
|
isSuspiciousGhostCompletion,
|
|
9
13
|
snapshotUnitActivity,
|
|
10
14
|
} from "../auto-unit-closeout.ts";
|
|
15
|
+
import {
|
|
16
|
+
closeUnit,
|
|
17
|
+
type UnitCloseoutRequest,
|
|
18
|
+
type UnitCloseoutDeps,
|
|
19
|
+
} from "../unit-closeout.ts";
|
|
20
|
+
import type { NotifySeverity } from "../notification-store.js";
|
|
11
21
|
|
|
12
22
|
function makeCtx(entries: unknown[]) {
|
|
13
23
|
return {
|
|
@@ -17,6 +27,38 @@ function makeCtx(entries: unknown[]) {
|
|
|
17
27
|
} as any;
|
|
18
28
|
}
|
|
19
29
|
|
|
30
|
+
function createTempGitRepo(t: TestContext): string {
|
|
31
|
+
const dir = mkdtempSync(join(tmpdir(), "closeout-test-"));
|
|
32
|
+
t.after(() => rmSync(dir, { recursive: true, force: true }));
|
|
33
|
+
execSync("git init", { cwd: dir });
|
|
34
|
+
execSync("git config user.email test@test.com", { cwd: dir });
|
|
35
|
+
execSync("git config user.name Test", { cwd: dir });
|
|
36
|
+
return dir;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
function makeMockDeps(overrides: Partial<UnitCloseoutDeps> = {}): UnitCloseoutDeps & { notifications: Array<{ message: string; severity: NotifySeverity }> } {
|
|
40
|
+
const notifications: Array<{ message: string; severity: NotifySeverity }> = [];
|
|
41
|
+
return {
|
|
42
|
+
isolationMode: () => "none",
|
|
43
|
+
currentBranch: () => "main",
|
|
44
|
+
commit: () => null,
|
|
45
|
+
notify: (message, severity) => notifications.push({ message, severity }),
|
|
46
|
+
notifications,
|
|
47
|
+
...overrides,
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
function baseRequest(overrides: Partial<UnitCloseoutRequest> = {}): UnitCloseoutRequest {
|
|
52
|
+
return {
|
|
53
|
+
basePath: "/tmp/ignored",
|
|
54
|
+
unitType: "complete-milestone",
|
|
55
|
+
unitId: "M001",
|
|
56
|
+
boundary: "milestone",
|
|
57
|
+
outcome: "complete",
|
|
58
|
+
...overrides,
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
|
|
20
62
|
test("isSuspiciousGhostCompletion rejects fast completions with no assistant output or tools", () => {
|
|
21
63
|
const startedAt = Date.now();
|
|
22
64
|
const ctx = makeCtx([]);
|
|
@@ -66,3 +108,129 @@ test("snapshotUnitActivity counts assistant messages and tool calls", () => {
|
|
|
66
108
|
assistantMessages: 1,
|
|
67
109
|
});
|
|
68
110
|
});
|
|
111
|
+
|
|
112
|
+
test("closeUnit: nothing-to-commit / isolation none", (t) => {
|
|
113
|
+
const dir = createTempGitRepo(t);
|
|
114
|
+
const deps = makeMockDeps({
|
|
115
|
+
isolationMode: () => "none",
|
|
116
|
+
commit: () => null,
|
|
117
|
+
});
|
|
118
|
+
|
|
119
|
+
const result = closeUnit(baseRequest({ basePath: dir, boundary: "milestone" }), deps);
|
|
120
|
+
|
|
121
|
+
assert.equal(result.gitVerdict, "nothing-to-commit");
|
|
122
|
+
assert.equal(result.commitMessage, null);
|
|
123
|
+
assert.equal(result.notice, undefined);
|
|
124
|
+
assert.equal(deps.notifications.length, 0);
|
|
125
|
+
});
|
|
126
|
+
|
|
127
|
+
test("closeUnit: committed / isolation none", (t) => {
|
|
128
|
+
const dir = createTempGitRepo(t);
|
|
129
|
+
writeFileSync(join(dir, "file.txt"), "hello");
|
|
130
|
+
execSync("git add file.txt", { cwd: dir });
|
|
131
|
+
|
|
132
|
+
const deps = makeMockDeps({
|
|
133
|
+
isolationMode: () => "none",
|
|
134
|
+
commit: () => "Add file.txt",
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
const result = closeUnit(baseRequest({ basePath: dir, boundary: "milestone" }), deps);
|
|
138
|
+
|
|
139
|
+
assert.equal(result.gitVerdict, "committed");
|
|
140
|
+
assert.equal(result.commitMessage, "Add file.txt");
|
|
141
|
+
assert.equal(result.notice, undefined);
|
|
142
|
+
assert.equal(deps.notifications.length, 0);
|
|
143
|
+
});
|
|
144
|
+
|
|
145
|
+
test("closeUnit: milestone-branch / worktree isolation", (t) => {
|
|
146
|
+
const dir = createTempGitRepo(t);
|
|
147
|
+
const deps = makeMockDeps({
|
|
148
|
+
isolationMode: () => "worktree",
|
|
149
|
+
currentBranch: () => "milestone/M001",
|
|
150
|
+
commit: () => "Complete M001",
|
|
151
|
+
});
|
|
152
|
+
|
|
153
|
+
const result = closeUnit(baseRequest({ basePath: dir, boundary: "milestone" }), deps);
|
|
154
|
+
|
|
155
|
+
assert.equal(result.gitVerdict, "milestone-branch");
|
|
156
|
+
assert.equal(result.commitMessage, "Complete M001");
|
|
157
|
+
assert.ok(result.notice);
|
|
158
|
+
assert.equal(deps.notifications.length, 1);
|
|
159
|
+
assert.equal(deps.notifications[0].severity, "info");
|
|
160
|
+
assert.match(deps.notifications[0].message, /Merge it to the integration branch/);
|
|
161
|
+
});
|
|
162
|
+
|
|
163
|
+
test("closeUnit: isolation-bypassed / worktree isolation", (t) => {
|
|
164
|
+
const dir = createTempGitRepo(t);
|
|
165
|
+
const deps = makeMockDeps({
|
|
166
|
+
isolationMode: () => "worktree",
|
|
167
|
+
currentBranch: () => "main",
|
|
168
|
+
commit: () => "Complete M001",
|
|
169
|
+
});
|
|
170
|
+
|
|
171
|
+
const result = closeUnit(baseRequest({ basePath: dir, boundary: "milestone" }), deps);
|
|
172
|
+
|
|
173
|
+
assert.equal(result.gitVerdict, "isolation-bypassed");
|
|
174
|
+
assert.equal(result.commitMessage, "Complete M001");
|
|
175
|
+
assert.ok(result.notice);
|
|
176
|
+
assert.equal(deps.notifications.length, 1);
|
|
177
|
+
assert.equal(deps.notifications[0].severity, "warning");
|
|
178
|
+
assert.match(deps.notifications[0].message, /completed outside a milestone worktree\/branch/);
|
|
179
|
+
});
|
|
180
|
+
|
|
181
|
+
test("closeUnit: isolation-bypassed / branch isolation", (t) => {
|
|
182
|
+
const dir = createTempGitRepo(t);
|
|
183
|
+
const deps = makeMockDeps({
|
|
184
|
+
isolationMode: () => "branch",
|
|
185
|
+
currentBranch: () => "main",
|
|
186
|
+
commit: () => "Complete M001",
|
|
187
|
+
});
|
|
188
|
+
|
|
189
|
+
const result = closeUnit(baseRequest({ basePath: dir, boundary: "milestone" }), deps);
|
|
190
|
+
|
|
191
|
+
assert.equal(result.gitVerdict, "isolation-bypassed");
|
|
192
|
+
assert.equal(result.commitMessage, "Complete M001");
|
|
193
|
+
assert.ok(result.notice);
|
|
194
|
+
assert.equal(deps.notifications.length, 1);
|
|
195
|
+
assert.equal(deps.notifications[0].severity, "warning");
|
|
196
|
+
assert.match(deps.notifications[0].message, /completed outside a milestone worktree\/branch/);
|
|
197
|
+
});
|
|
198
|
+
|
|
199
|
+
test("closeUnit: commit-failed", (t) => {
|
|
200
|
+
const dir = createTempGitRepo(t);
|
|
201
|
+
const deps = makeMockDeps({
|
|
202
|
+
isolationMode: () => "none",
|
|
203
|
+
commit: () => {
|
|
204
|
+
throw new Error("simulated commit failure");
|
|
205
|
+
},
|
|
206
|
+
});
|
|
207
|
+
|
|
208
|
+
const result = closeUnit(baseRequest({ basePath: dir, boundary: "milestone" }), deps);
|
|
209
|
+
|
|
210
|
+
assert.equal(result.gitVerdict, "commit-failed");
|
|
211
|
+
assert.equal(result.commitMessage, null);
|
|
212
|
+
assert.ok(result.notice);
|
|
213
|
+
assert.match(result.notice!, /simulated commit failure/);
|
|
214
|
+
assert.equal(deps.notifications.length, 1);
|
|
215
|
+
assert.equal(deps.notifications[0].severity, "error");
|
|
216
|
+
});
|
|
217
|
+
|
|
218
|
+
test("closeUnit: task boundary ignores isolation verdict", (t) => {
|
|
219
|
+
const dir = createTempGitRepo(t);
|
|
220
|
+
const deps = makeMockDeps({
|
|
221
|
+
isolationMode: () => "worktree",
|
|
222
|
+
currentBranch: () => "main",
|
|
223
|
+
commit: () => "Complete task",
|
|
224
|
+
});
|
|
225
|
+
|
|
226
|
+
const result = closeUnit(
|
|
227
|
+
baseRequest({ basePath: dir, boundary: "task", unitType: "execute-task", unitId: "M001/S01/T01" }),
|
|
228
|
+
deps,
|
|
229
|
+
);
|
|
230
|
+
|
|
231
|
+
assert.equal(result.gitVerdict, "committed");
|
|
232
|
+
assert.equal(result.commitMessage, "Complete task");
|
|
233
|
+
assert.equal(result.notice, undefined);
|
|
234
|
+
assert.equal(deps.notifications.length, 0);
|
|
235
|
+
});
|
|
236
|
+
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import assert from "node:assert/strict";
|
|
2
|
+
import test from "node:test";
|
|
3
|
+
import { runPostUnitVerification } from "../auto-verification.ts";
|
|
4
|
+
|
|
5
|
+
function createVerificationContext(currentUnit: { type: string; id: string } | null) {
|
|
6
|
+
return {
|
|
7
|
+
s: {
|
|
8
|
+
currentUnit,
|
|
9
|
+
},
|
|
10
|
+
ctx: {
|
|
11
|
+
ui: {
|
|
12
|
+
notify() {
|
|
13
|
+
throw new Error("notify should not be called for pass-through units");
|
|
14
|
+
},
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
pi: {},
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
test("post-unit verification continues when no host-owned verification is needed", async () => {
|
|
22
|
+
let paused = false;
|
|
23
|
+
const pauseAuto = async () => {
|
|
24
|
+
paused = true;
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
assert.equal(await runPostUnitVerification(createVerificationContext(null) as never, pauseAuto), "continue");
|
|
28
|
+
assert.equal(
|
|
29
|
+
await runPostUnitVerification(
|
|
30
|
+
createVerificationContext({ type: "plan-slice", id: "M001-S001" }) as never,
|
|
31
|
+
pauseAuto,
|
|
32
|
+
),
|
|
33
|
+
"continue",
|
|
34
|
+
);
|
|
35
|
+
assert.equal(paused, false);
|
|
36
|
+
});
|
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
// gsd-pi — Blocker-placeholder recovery log coverage.
|
|
2
|
+
//
|
|
3
|
+
// writeBlockerPlaceholder (auto-recovery.ts:782) writes a placeholder artifact
|
|
4
|
+
// so the pipeline can advance past a stuck unit, then marks the task/slice
|
|
5
|
+
// complete in the DB and appends a workflow event so reconciliation can replay
|
|
6
|
+
// the recovery. Each of those side-effects is individually best-effort and logs
|
|
7
|
+
// a recovery warning on failure (auto-recovery.ts:837/840/843/844/853/854). No
|
|
8
|
+
// test asserted any of them. We trigger each by breaking the specific sink
|
|
9
|
+
// (drop the relevant DB table, or block the events-file append) and assert the
|
|
10
|
+
// warning lands.
|
|
11
|
+
|
|
12
|
+
import { test } from "node:test";
|
|
13
|
+
import assert from "node:assert/strict";
|
|
14
|
+
import { mkdtempSync, mkdirSync, rmSync, writeFileSync } from "node:fs";
|
|
15
|
+
import { join } from "node:path";
|
|
16
|
+
import { tmpdir } from "node:os";
|
|
17
|
+
|
|
18
|
+
import { writeBlockerPlaceholder } from "../auto-recovery.ts";
|
|
19
|
+
import { writeReactiveExecuteBlocker } from "../auto-recovery.ts";
|
|
20
|
+
import {
|
|
21
|
+
closeDatabase,
|
|
22
|
+
insertMilestone,
|
|
23
|
+
insertSlice,
|
|
24
|
+
insertTask,
|
|
25
|
+
openDatabase,
|
|
26
|
+
_getAdapter,
|
|
27
|
+
} from "../gsd-db.ts";
|
|
28
|
+
import {
|
|
29
|
+
drainLogs,
|
|
30
|
+
setStderrLoggingEnabled,
|
|
31
|
+
_resetLogs,
|
|
32
|
+
type LogEntry,
|
|
33
|
+
} from "../workflow-logger.ts";
|
|
34
|
+
|
|
35
|
+
function makeBase(prefix = "gsd-blocker-logs-"): string {
|
|
36
|
+
const base = mkdtempSync(join(tmpdir(), prefix));
|
|
37
|
+
// Slice projection dirs so the placeholder path resolves.
|
|
38
|
+
mkdirSync(join(base, ".gsd", "milestones", "M001", "slices", "S01", "tasks"), { recursive: true });
|
|
39
|
+
return base;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
function captureLogs<T>(fn: () => T): { result: T; logs: LogEntry[] } {
|
|
43
|
+
const previous = setStderrLoggingEnabled(false);
|
|
44
|
+
_resetLogs();
|
|
45
|
+
try {
|
|
46
|
+
const result = fn();
|
|
47
|
+
return { result, logs: drainLogs() };
|
|
48
|
+
} finally {
|
|
49
|
+
_resetLogs();
|
|
50
|
+
setStderrLoggingEnabled(previous);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
function recoveryWarnings(logs: readonly LogEntry[]): LogEntry[] {
|
|
55
|
+
return logs.filter((e) => e.component === "recovery" && e.severity === "warn");
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
test("writeBlockerPlaceholder logs a recovery warning when updateTaskStatus throws (auto-recovery.ts:837)", () => {
|
|
59
|
+
const base = makeBase();
|
|
60
|
+
try {
|
|
61
|
+
openDatabase(join(base, ".gsd", "gsd.db"));
|
|
62
|
+
// Drop tasks so updateTaskStatus throws inside the execute-task DB block.
|
|
63
|
+
_getAdapter()!.exec("DROP TABLE tasks");
|
|
64
|
+
|
|
65
|
+
const { logs } = captureLogs(() =>
|
|
66
|
+
writeBlockerPlaceholder("execute-task", "M001/S01/T01", base, "exhausted retries"),
|
|
67
|
+
);
|
|
68
|
+
|
|
69
|
+
const warn = recoveryWarnings(logs).find((w) => /updateTaskStatus failed during context exhaustion/u.test(w.message));
|
|
70
|
+
assert.ok(warn, "a recovery warning must be logged when updateTaskStatus throws");
|
|
71
|
+
} finally {
|
|
72
|
+
closeDatabase();
|
|
73
|
+
rmSync(base, { recursive: true, force: true });
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
|
|
77
|
+
test("writeBlockerPlaceholder logs a recovery warning when updateSliceStatus throws (auto-recovery.ts:843)", () => {
|
|
78
|
+
const base = makeBase();
|
|
79
|
+
try {
|
|
80
|
+
openDatabase(join(base, ".gsd", "gsd.db"));
|
|
81
|
+
// Drop slices so updateSliceStatus throws inside the complete-slice DB block.
|
|
82
|
+
_getAdapter()!.exec("DROP TABLE slices");
|
|
83
|
+
|
|
84
|
+
const { logs } = captureLogs(() =>
|
|
85
|
+
writeBlockerPlaceholder("complete-slice", "M001/S01", base, "exhausted retries"),
|
|
86
|
+
);
|
|
87
|
+
|
|
88
|
+
const warn = recoveryWarnings(logs).find((w) => /updateSliceStatus failed during context exhaustion/u.test(w.message));
|
|
89
|
+
assert.ok(warn, "a recovery warning must be logged when updateSliceStatus throws");
|
|
90
|
+
} finally {
|
|
91
|
+
closeDatabase();
|
|
92
|
+
rmSync(base, { recursive: true, force: true });
|
|
93
|
+
}
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
test("writeBlockerPlaceholder logs a recovery warning when the plan-milestone insertSlice throws (auto-recovery.ts:853)", () => {
|
|
97
|
+
const base = makeBase();
|
|
98
|
+
try {
|
|
99
|
+
openDatabase(join(base, ".gsd", "gsd.db"));
|
|
100
|
+
// Drop slices so the S00-blocker insertSlice throws inside the
|
|
101
|
+
// plan-milestone placeholder branch.
|
|
102
|
+
_getAdapter()!.exec("DROP TABLE slices");
|
|
103
|
+
|
|
104
|
+
const { logs } = captureLogs(() =>
|
|
105
|
+
writeBlockerPlaceholder("plan-milestone", "M001", base, "exhausted retries"),
|
|
106
|
+
);
|
|
107
|
+
|
|
108
|
+
const warn = recoveryWarnings(logs).find((w) =>
|
|
109
|
+
/insertSlice placeholder failed for plan-milestone recovery/u.test(w.message),
|
|
110
|
+
);
|
|
111
|
+
assert.ok(warn, "a recovery warning must be logged when the blocker slice insert throws");
|
|
112
|
+
} finally {
|
|
113
|
+
closeDatabase();
|
|
114
|
+
rmSync(base, { recursive: true, force: true });
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
test("writeBlockerPlaceholder logs a recovery warning when the workflow-event append throws (auto-recovery.ts:840)", () => {
|
|
119
|
+
const base = makeBase();
|
|
120
|
+
try {
|
|
121
|
+
openDatabase(join(base, ".gsd", "gsd.db"));
|
|
122
|
+
// Block the workflow-events append by turning its target into a directory
|
|
123
|
+
// (appendFileSync on a directory throws EISDIR). The placeholder write still
|
|
124
|
+
// succeeds because it targets a different path under milestones/.
|
|
125
|
+
mkdirSync(join(base, ".gsd", "event-log.jsonl"), { recursive: true });
|
|
126
|
+
|
|
127
|
+
const { logs } = captureLogs(() =>
|
|
128
|
+
writeBlockerPlaceholder("execute-task", "M001/S01/T01", base, "exhausted retries"),
|
|
129
|
+
);
|
|
130
|
+
|
|
131
|
+
const warn = recoveryWarnings(logs).find((w) => /appendEvent failed for task recovery/u.test(w.message));
|
|
132
|
+
assert.ok(warn, "a recovery warning must be logged when the recovery event append fails");
|
|
133
|
+
} finally {
|
|
134
|
+
closeDatabase();
|
|
135
|
+
rmSync(base, { recursive: true, force: true });
|
|
136
|
+
}
|
|
137
|
+
});
|
|
138
|
+
|
|
139
|
+
test("writeBlockerPlaceholder logs a recovery warning when the complete-slice appendEvent throws (auto-recovery.ts:898)", () => {
|
|
140
|
+
const base = makeBase("gsd-blocker-logs-cs-");
|
|
141
|
+
try {
|
|
142
|
+
openDatabase(join(base, ".gsd", "gsd.db"));
|
|
143
|
+
// Slices table intact so updateSliceStatus (:897) succeeds; block the
|
|
144
|
+
// workflow-event append so the complete-slice appendEvent (:898) throws.
|
|
145
|
+
mkdirSync(join(base, ".gsd", "event-log.jsonl"), { recursive: true });
|
|
146
|
+
|
|
147
|
+
const { logs } = captureLogs(() =>
|
|
148
|
+
writeBlockerPlaceholder("complete-slice", "M001/S01", base, "exhausted retries"),
|
|
149
|
+
);
|
|
150
|
+
|
|
151
|
+
const warn = recoveryWarnings(logs).find((w) => /appendEvent failed for slice recovery/u.test(w.message));
|
|
152
|
+
assert.ok(warn, "a recovery warning must be logged when the complete-slice appendEvent throws");
|
|
153
|
+
} finally {
|
|
154
|
+
closeDatabase();
|
|
155
|
+
rmSync(base, { recursive: true, force: true });
|
|
156
|
+
}
|
|
157
|
+
});
|
|
158
|
+
|
|
159
|
+
test("writeBlockerPlaceholder logs a recovery warning when the plan-milestone appendEvent throws (auto-recovery.ts:908)", () => {
|
|
160
|
+
const base = mkdtempSync(join(tmpdir(), "gsd-blocker-logs-pm-"));
|
|
161
|
+
mkdirSync(join(base, ".gsd", "milestones", "M001"), { recursive: true });
|
|
162
|
+
try {
|
|
163
|
+
openDatabase(join(base, ".gsd", "gsd.db"));
|
|
164
|
+
// Slices table intact so the S00-blocker insertSlice (:907) succeeds;
|
|
165
|
+
// block the workflow-event append so the plan-milestone appendEvent (:908) throws.
|
|
166
|
+
mkdirSync(join(base, ".gsd", "event-log.jsonl"), { recursive: true });
|
|
167
|
+
|
|
168
|
+
const { logs } = captureLogs(() =>
|
|
169
|
+
writeBlockerPlaceholder("plan-milestone", "M001", base, "exhausted retries"),
|
|
170
|
+
);
|
|
171
|
+
|
|
172
|
+
const warn = recoveryWarnings(logs).find((w) => /appendEvent failed for plan-milestone recovery/u.test(w.message));
|
|
173
|
+
assert.ok(warn, "a recovery warning must be logged when the plan-milestone appendEvent throws");
|
|
174
|
+
} finally {
|
|
175
|
+
closeDatabase();
|
|
176
|
+
rmSync(base, { recursive: true, force: true });
|
|
177
|
+
}
|
|
178
|
+
});
|
|
179
|
+
|
|
180
|
+
// ── writeReactiveExecuteBlocker append-event warnings (:755 / :768) ────────
|
|
181
|
+
// These fire after the reactive batch recovery transaction commits, when the
|
|
182
|
+
// per-task workflow-event append throws. We seed a real slice with two tasks,
|
|
183
|
+
// plant the event-log target as a directory (appendFileSync → EISDIR), and call
|
|
184
|
+
// writeReactiveExecuteBlocker; both the complete-task and skip-task appends fail.
|
|
185
|
+
|
|
186
|
+
test("writeReactiveExecuteBlocker logs recovery warnings when the post-recovery event appends throw (auto-recovery.ts:755/:768)", () => {
|
|
187
|
+
const base = mkdtempSync(join(tmpdir(), "gsd-blocker-logs-reactive-"));
|
|
188
|
+
mkdirSync(join(base, ".gsd", "milestones", "M001", "slices", "S01", "tasks"), { recursive: true });
|
|
189
|
+
try {
|
|
190
|
+
openDatabase(join(base, ".gsd", "gsd.db"));
|
|
191
|
+
insertMilestone({ id: "M001", title: "M", status: "active" });
|
|
192
|
+
insertSlice({ id: "S01", milestoneId: "M001", title: "S", status: "active", risk: "low", depends: [], demo: "", sequence: 1 });
|
|
193
|
+
insertTask({ id: "T01", sliceId: "S01", milestoneId: "M001", title: "T1", status: "active" });
|
|
194
|
+
insertTask({ id: "T02", sliceId: "S01", milestoneId: "M001", title: "T2", status: "active" });
|
|
195
|
+
// T01 has a summary (→ complete recovery path → :755), T02 does not
|
|
196
|
+
// (→ skip recovery path → :768).
|
|
197
|
+
writeFileSync(join(base, ".gsd", "milestones", "M001", "slices", "S01", "tasks", "T01-SUMMARY.md"), "# T01\n", "utf-8");
|
|
198
|
+
// Block the workflow-event append (event-log.jsonl is the real ledger file).
|
|
199
|
+
mkdirSync(join(base, ".gsd", "event-log.jsonl"), { recursive: true });
|
|
200
|
+
|
|
201
|
+
const { logs } = captureLogs(() =>
|
|
202
|
+
writeReactiveExecuteBlocker("M001/S01/reactive+T01,T02", base, "batch exhausted"),
|
|
203
|
+
);
|
|
204
|
+
|
|
205
|
+
const warnings = recoveryWarnings(logs).map((w) => w.message);
|
|
206
|
+
assert.ok(
|
|
207
|
+
warnings.some((m) => /appendEvent failed for reactive complete recovery/u.test(m)),
|
|
208
|
+
"the complete-task append warning must be logged (:755)",
|
|
209
|
+
);
|
|
210
|
+
assert.ok(
|
|
211
|
+
warnings.some((m) => /appendEvent failed for reactive skip recovery/u.test(m)),
|
|
212
|
+
"the skip-task append warning must be logged (:768)",
|
|
213
|
+
);
|
|
214
|
+
} finally {
|
|
215
|
+
closeDatabase();
|
|
216
|
+
rmSync(base, { recursive: true, force: true });
|
|
217
|
+
}
|
|
218
|
+
});
|
|
@@ -42,7 +42,11 @@ test("complete milestone prompt renders compact verification and completion guid
|
|
|
42
42
|
assert.match(prompt, /Decision Re-evaluation/);
|
|
43
43
|
assert.match(prompt, /self-diff/i);
|
|
44
44
|
assert.match(prompt, /GSD-(?:Task|Unit)/);
|
|
45
|
-
assert.match(prompt, /
|
|
46
|
-
assert.match(prompt, /
|
|
45
|
+
assert.match(prompt, /Closeout messaging \(auto-mode\)/);
|
|
46
|
+
assert.match(prompt, /Never say "Milestone M001 is complete"/);
|
|
47
|
+
assert.match(prompt, /Milestone M001 closeout submitted/);
|
|
48
|
+
assert.match(prompt, /Do not say the milestone is complete/);
|
|
49
|
+
assert.match(prompt, /VERIFICATION FAILED/);
|
|
50
|
+
assert.doesNotMatch(prompt, /emit only one closeout line: "Milestone M001 complete\."/);
|
|
47
51
|
assert.doesNotMatch(prompt, /\{\{[a-zA-Z][a-zA-Z0-9_]*\}\}/);
|
|
48
52
|
});
|
|
@@ -80,6 +80,20 @@ function createTempProject(): { basePath: string; planPath: string } {
|
|
|
80
80
|
return { basePath, planPath };
|
|
81
81
|
}
|
|
82
82
|
|
|
83
|
+
function writeProjectPreferences(basePath: string, yaml: string): void {
|
|
84
|
+
fs.writeFileSync(path.join(basePath, '.gsd', 'PREFERENCES.md'), `---\n${yaml}---\n`);
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
async function withWorkingDirectory<T>(cwd: string, action: () => Promise<T>): Promise<T> {
|
|
88
|
+
const previousCwd = process.cwd();
|
|
89
|
+
process.chdir(cwd);
|
|
90
|
+
try {
|
|
91
|
+
return await action();
|
|
92
|
+
} finally {
|
|
93
|
+
process.chdir(previousCwd);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
|
|
83
97
|
function makeValidParams() {
|
|
84
98
|
return {
|
|
85
99
|
taskId: 'T01',
|
|
@@ -104,6 +118,13 @@ function makeValidParams() {
|
|
|
104
118
|
};
|
|
105
119
|
}
|
|
106
120
|
|
|
121
|
+
function makeEscalationOptions() {
|
|
122
|
+
return [
|
|
123
|
+
{ id: 'continue', label: 'Continue', tradeoffs: 'Keeps execution moving with the default path.' },
|
|
124
|
+
{ id: 'pause', label: 'Pause', tradeoffs: 'Stops execution until the blocker is reviewed.' },
|
|
125
|
+
];
|
|
126
|
+
}
|
|
127
|
+
|
|
107
128
|
// ═══════════════════════════════════════════════════════════════════════════
|
|
108
129
|
// complete-task: Fresh DB is migrated to the current schema version
|
|
109
130
|
// ═══════════════════════════════════════════════════════════════════════════
|
|
@@ -359,6 +380,105 @@ console.log('\n=== complete-task: handler happy path ===');
|
|
|
359
380
|
cleanup(dbPath);
|
|
360
381
|
}
|
|
361
382
|
|
|
383
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
384
|
+
// complete-task: hard-blocker escalation with mid-execution escalation disabled
|
|
385
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
386
|
+
|
|
387
|
+
console.log('\n=== complete-task: disabled hard-blocker escalation rolls back completion ===');
|
|
388
|
+
{
|
|
389
|
+
const dbPath = tempDbPath();
|
|
390
|
+
openDatabase(dbPath);
|
|
391
|
+
|
|
392
|
+
const { basePath } = createTempProject();
|
|
393
|
+
writeProjectPreferences(basePath, 'phases:\n mid_execution_escalation: false\n');
|
|
394
|
+
|
|
395
|
+
insertMilestone({ id: 'M001', title: 'Test Milestone' });
|
|
396
|
+
insertSlice({ id: 'S01', milestoneId: 'M001', title: 'Test Slice' });
|
|
397
|
+
|
|
398
|
+
const params = {
|
|
399
|
+
...makeValidParams(),
|
|
400
|
+
blockerDiscovered: true,
|
|
401
|
+
escalation: {
|
|
402
|
+
question: 'Should execution pause for the hard blocker?',
|
|
403
|
+
options: makeEscalationOptions(),
|
|
404
|
+
recommendation: 'pause',
|
|
405
|
+
recommendationRationale: 'The blocker should not be silently advanced.',
|
|
406
|
+
continueWithDefault: false,
|
|
407
|
+
},
|
|
408
|
+
};
|
|
409
|
+
|
|
410
|
+
const result = await withWorkingDirectory(basePath, () => handleCompleteTask(params, basePath));
|
|
411
|
+
|
|
412
|
+
assertTrue('error' in result, 'hard-blocker escalation should fail when escalation handling is disabled');
|
|
413
|
+
if ('error' in result) {
|
|
414
|
+
assertMatch(result.error, /hard-blocker escalation/, 'error should mention hard-blocker escalation');
|
|
415
|
+
assertMatch(result.error, /mid_execution_escalation is disabled/, 'error should mention disabled preference');
|
|
416
|
+
}
|
|
417
|
+
|
|
418
|
+
const task = getTask('M001', 'S01', 'T01');
|
|
419
|
+
assertTrue(task !== null, 'task row should remain after rollback');
|
|
420
|
+
assertEq(task!.status, 'pending', 'task status should be rolled back to pending');
|
|
421
|
+
assertEq(task!.blocker_discovered, true, 'blocker flag should remain recorded for visibility');
|
|
422
|
+
assertEq(task!.escalation_pending, 0, 'disabled preference should not create a pending escalation flag');
|
|
423
|
+
assertEq(task!.escalation_awaiting_review, 0, 'disabled preference should not create an awaiting-review flag');
|
|
424
|
+
|
|
425
|
+
const adapter = _getAdapter()!;
|
|
426
|
+
const evRows = adapter.prepare(
|
|
427
|
+
"SELECT * FROM verification_evidence WHERE task_id = 'T01' AND slice_id = 'S01' AND milestone_id = 'M001'"
|
|
428
|
+
).all();
|
|
429
|
+
assertEq(evRows.length, 0, 'verification evidence should be deleted when completion rolls back');
|
|
430
|
+
|
|
431
|
+
cleanupDir(basePath);
|
|
432
|
+
cleanup(dbPath);
|
|
433
|
+
}
|
|
434
|
+
|
|
435
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
436
|
+
// complete-task: soft escalation with mid-execution escalation disabled
|
|
437
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
438
|
+
|
|
439
|
+
console.log('\n=== complete-task: disabled soft escalation still completes ===');
|
|
440
|
+
{
|
|
441
|
+
const dbPath = tempDbPath();
|
|
442
|
+
openDatabase(dbPath);
|
|
443
|
+
|
|
444
|
+
const { basePath } = createTempProject();
|
|
445
|
+
writeProjectPreferences(basePath, 'phases:\n mid_execution_escalation: false\n');
|
|
446
|
+
|
|
447
|
+
insertMilestone({ id: 'M001', title: 'Test Milestone' });
|
|
448
|
+
insertSlice({ id: 'S01', milestoneId: 'M001', title: 'Test Slice' });
|
|
449
|
+
|
|
450
|
+
const params = {
|
|
451
|
+
...makeValidParams(),
|
|
452
|
+
escalation: {
|
|
453
|
+
question: 'Should execution continue with the default?',
|
|
454
|
+
options: makeEscalationOptions(),
|
|
455
|
+
recommendation: 'continue',
|
|
456
|
+
recommendationRationale: 'The default path is safe enough to continue.',
|
|
457
|
+
continueWithDefault: true,
|
|
458
|
+
},
|
|
459
|
+
};
|
|
460
|
+
|
|
461
|
+
const result = await withWorkingDirectory(basePath, () => handleCompleteTask(params, basePath));
|
|
462
|
+
|
|
463
|
+
assertTrue(!('error' in result), 'soft escalation should still complete when escalation handling is disabled');
|
|
464
|
+
if (!('error' in result)) {
|
|
465
|
+
assertTrue(!result.escalation, 'disabled preference should not return escalation metadata');
|
|
466
|
+
}
|
|
467
|
+
|
|
468
|
+
const task = getTask('M001', 'S01', 'T01');
|
|
469
|
+
assertTrue(task !== null, 'task row should exist');
|
|
470
|
+
assertEq(task!.status, 'complete', 'soft escalation should leave task complete');
|
|
471
|
+
|
|
472
|
+
const adapter = _getAdapter()!;
|
|
473
|
+
const evRows = adapter.prepare(
|
|
474
|
+
"SELECT * FROM verification_evidence WHERE task_id = 'T01' AND slice_id = 'S01' AND milestone_id = 'M001'"
|
|
475
|
+
).all();
|
|
476
|
+
assertEq(evRows.length, 1, 'verification evidence should remain for soft escalation completion');
|
|
477
|
+
|
|
478
|
+
cleanupDir(basePath);
|
|
479
|
+
cleanup(dbPath);
|
|
480
|
+
}
|
|
481
|
+
|
|
362
482
|
// ═══════════════════════════════════════════════════════════════════════════
|
|
363
483
|
// complete-task: Handler validation errors
|
|
364
484
|
// ═══════════════════════════════════════════════════════════════════════════
|
|
@@ -414,6 +534,9 @@ console.log('\n=== complete-task: handler idempotency ===');
|
|
|
414
534
|
// First call should succeed
|
|
415
535
|
const r1 = await handleCompleteTask(params, basePath);
|
|
416
536
|
assertTrue(!('error' in r1), 'first call should succeed');
|
|
537
|
+
if ('error' in r1) {
|
|
538
|
+
throw new Error(r1.error);
|
|
539
|
+
}
|
|
417
540
|
|
|
418
541
|
// Verify complete-task did not duplicate T01. S01-PLAN.md is a projection,
|
|
419
542
|
// so the remaining plan task is not imported implicitly.
|
|
@@ -421,16 +544,29 @@ console.log('\n=== complete-task: handler idempotency ===');
|
|
|
421
544
|
assertEq(tasks.length, 1, 'should only have the completed DB task after first call');
|
|
422
545
|
assertEq(tasks.filter(t => t.id === 'T01').length, 1, 'should have exactly one T01 row after first call');
|
|
423
546
|
|
|
424
|
-
//
|
|
547
|
+
// If the DB row is complete but the projection was lost, the duplicate call
|
|
548
|
+
// should repair the missing summary from full_summary_md instead of forcing a
|
|
549
|
+
// reopen/re-complete loop.
|
|
550
|
+
fs.unlinkSync(r1.summaryPath);
|
|
551
|
+
assertTrue(!fs.existsSync(r1.summaryPath), 'fixture should remove the task summary before repair');
|
|
425
552
|
const r2 = await handleCompleteTask(params, basePath);
|
|
426
|
-
assertTrue('error' in r2, 'second call should
|
|
553
|
+
assertTrue(!('error' in r2), 'second call should repair missing summary for DB-complete task');
|
|
427
554
|
if ('error' in r2) {
|
|
428
|
-
|
|
555
|
+
throw new Error(r2.error);
|
|
556
|
+
}
|
|
557
|
+
assertTrue(fs.existsSync(r2.summaryPath), 'missing summary should be restored on disk');
|
|
558
|
+
assertEq(r2.duplicate, true, 'repair should be reported as a duplicate/no-op state mutation');
|
|
559
|
+
|
|
560
|
+
// Third call with the summary present — state machine guard rejects (task is already complete)
|
|
561
|
+
const r3 = await handleCompleteTask(params, basePath);
|
|
562
|
+
assertTrue('error' in r3, 'third call should return error (task already complete)');
|
|
563
|
+
if ('error' in r3) {
|
|
564
|
+
assertMatch(r3.error, /already complete/, 'error should mention already complete');
|
|
429
565
|
}
|
|
430
566
|
|
|
431
|
-
// Still no duplicate rows from the rejected
|
|
567
|
+
// Still no duplicate rows from the repair or rejected third call.
|
|
432
568
|
const tasksAfter = getSliceTasks('M001', 'S01');
|
|
433
|
-
assertEq(tasksAfter.length, 1, 'should still only have T01 after rejected
|
|
569
|
+
assertEq(tasksAfter.length, 1, 'should still only have T01 after duplicate repair and rejected third call');
|
|
434
570
|
assertEq(tasksAfter.filter(t => t.id === 'T01').length, 1, 'should still have exactly one T01 row');
|
|
435
571
|
|
|
436
572
|
cleanupDir(basePath);
|
|
@@ -13,6 +13,7 @@ function makeCtx(customResult: unknown) {
|
|
|
13
13
|
const customCalls: Array<{ options: any }> = [];
|
|
14
14
|
return {
|
|
15
15
|
hasUI: true,
|
|
16
|
+
modelRegistry: { getAvailable: () => [] },
|
|
16
17
|
ui: {
|
|
17
18
|
custom: async (_factory: unknown, options: any) => {
|
|
18
19
|
customCalls.push({ options });
|