gsd-pi 2.81.0 → 2.82.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +36 -24
- package/dist/resources/.managed-resources-content-hash +1 -1
- package/dist/resources/extensions/gsd/auto/loop.js +111 -8
- package/dist/resources/extensions/gsd/auto/phases.js +190 -97
- package/dist/resources/extensions/gsd/auto/run-unit.js +66 -3
- package/dist/resources/extensions/gsd/auto/session.js +9 -0
- package/dist/resources/extensions/gsd/auto/verification-retry-policy.js +43 -0
- package/dist/resources/extensions/gsd/auto-dashboard.js +182 -178
- package/dist/resources/extensions/gsd/auto-dispatch.js +14 -11
- package/dist/resources/extensions/gsd/auto-post-unit.js +7 -1
- package/dist/resources/extensions/gsd/auto-recovery.js +6 -181
- package/dist/resources/extensions/gsd/auto-runtime-state.js +5 -0
- package/dist/resources/extensions/gsd/auto-start.js +20 -23
- package/dist/resources/extensions/gsd/auto-unit-closeout.js +33 -5
- package/dist/resources/extensions/gsd/auto-verification.js +12 -6
- package/dist/resources/extensions/gsd/auto-worktree.js +8 -0
- package/dist/resources/extensions/gsd/auto.js +265 -76
- package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +13 -6
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +8 -2
- package/dist/resources/extensions/gsd/bootstrap/register-shortcuts.js +4 -8
- package/dist/resources/extensions/gsd/commands/handlers/notifications-handler.js +4 -10
- package/dist/resources/extensions/gsd/commands/handlers/parallel.js +9 -0
- package/dist/resources/extensions/gsd/git-service.js +2 -1
- package/dist/resources/extensions/gsd/gsd-db.js +7 -23
- package/dist/resources/extensions/gsd/health-widget-core.js +1 -1
- package/dist/resources/extensions/gsd/health-widget.js +4 -10
- package/dist/resources/extensions/gsd/markdown-renderer.js +0 -95
- package/dist/resources/extensions/gsd/native-git-bridge.js +14 -14
- package/dist/resources/extensions/gsd/notification-overlay.js +35 -40
- package/dist/resources/extensions/gsd/parallel-merge.js +53 -30
- package/dist/resources/extensions/gsd/parallel-monitor-overlay.js +25 -33
- package/dist/resources/extensions/gsd/prompts/complete-slice.md +14 -12
- package/dist/resources/extensions/gsd/prompts/discuss-headless.md +20 -2
- package/dist/resources/extensions/gsd/prompts/discuss.md +20 -2
- package/dist/resources/extensions/gsd/recovery-classification.js +15 -1
- package/dist/resources/extensions/gsd/session-lock.js +40 -0
- package/dist/resources/extensions/gsd/state-reconciliation/drift/completion.js +131 -0
- package/dist/resources/extensions/gsd/state-reconciliation/drift/merge-state.js +247 -0
- package/dist/resources/extensions/gsd/state-reconciliation/drift/project-md.js +50 -0
- package/dist/resources/extensions/gsd/state-reconciliation/drift/roadmap.js +87 -0
- package/dist/resources/extensions/gsd/state-reconciliation/drift/sketch-flag.js +50 -0
- package/dist/resources/extensions/gsd/state-reconciliation/drift/stale-render.js +124 -0
- package/dist/resources/extensions/gsd/state-reconciliation/drift/stale-worker.js +32 -0
- package/dist/resources/extensions/gsd/state-reconciliation/errors.js +41 -0
- package/dist/resources/extensions/gsd/state-reconciliation/index.js +99 -0
- package/dist/resources/extensions/gsd/state-reconciliation/registry.js +24 -0
- package/dist/resources/extensions/gsd/state-reconciliation/spawn-gate.js +43 -0
- package/dist/resources/extensions/gsd/state-reconciliation/types.js +3 -0
- package/dist/resources/extensions/gsd/state-reconciliation.js +5 -26
- package/dist/resources/extensions/gsd/tui/render-kit.js +74 -0
- package/dist/resources/extensions/gsd/watch/header-renderer.js +92 -69
- package/dist/resources/extensions/gsd/watch/splash-palette.js +10 -0
- package/dist/resources/extensions/gsd/workflow-mcp.js +2 -2
- package/dist/resources/extensions/gsd/worktree-lifecycle.js +722 -316
- package/dist/resources/extensions/gsd/worktree-telemetry.js +3 -1
- 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 +9 -9
- package/dist/web/standalone/.next/build-manifest.json +2 -2
- 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/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 +9 -9
- 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/welcome-screen.d.ts +0 -7
- package/dist/welcome-screen.js +60 -69
- package/package.json +1 -1
- package/packages/daemon/package.json +2 -2
- package/packages/mcp-server/package.json +2 -2
- package/packages/native/package.json +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/modes/interactive/components/__tests__/assistant-message-design.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/assistant-message-design.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/assistant-message-design.test.js +47 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/assistant-message-design.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js +76 -9
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/user-message-design.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/user-message-design.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/user-message-design.test.js +40 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/user-message-design.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.d.ts +0 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.js +30 -29
- package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.test.js +10 -3
- package/packages/pi-coding-agent/dist/modes/interactive/components/adaptive-layout.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js +13 -13
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/bash-execution.d.ts +1 -3
- package/packages/pi-coding-agent/dist/modes/interactive/components/bash-execution.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/bash-execution.js +58 -3
- package/packages/pi-coding-agent/dist/modes/interactive/components/bash-execution.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/diff.d.ts +2 -2
- package/packages/pi-coding-agent/dist/modes/interactive/components/diff.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/diff.js +12 -6
- package/packages/pi-coding-agent/dist/modes/interactive/components/diff.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/footer.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js +14 -41
- package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts +0 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js +86 -82
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/transcript-design.d.ts +35 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/transcript-design.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/transcript-design.js +152 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/transcript-design.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tui-style-kit.d.ts +16 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tui-style-kit.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tui-style-kit.js +73 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tui-style-kit.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.d.ts +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js +12 -8
- package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-highlight.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-highlight.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-highlight.test.js +17 -0
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-highlight.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.js +105 -1
- package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.js +27 -26
- package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/tui-mode.test.js +9 -6
- package/packages/pi-coding-agent/dist/modes/interactive/tui-mode.test.js.map +1 -1
- package/packages/pi-coding-agent/package.json +1 -1
- package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/assistant-message-design.test.ts +56 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/tool-execution.test.ts +113 -9
- package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/user-message-design.test.ts +48 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/adaptive-layout.test.ts +10 -3
- package/packages/pi-coding-agent/src/modes/interactive/components/adaptive-layout.ts +43 -42
- package/packages/pi-coding-agent/src/modes/interactive/components/assistant-message.ts +14 -14
- package/packages/pi-coding-agent/src/modes/interactive/components/bash-execution.ts +64 -3
- package/packages/pi-coding-agent/src/modes/interactive/components/diff.ts +13 -7
- package/packages/pi-coding-agent/src/modes/interactive/components/footer.ts +15 -42
- package/packages/pi-coding-agent/src/modes/interactive/components/tool-execution.ts +84 -104
- package/packages/pi-coding-agent/src/modes/interactive/components/transcript-design.ts +196 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/tui-style-kit.ts +94 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/user-message.ts +14 -9
- package/packages/pi-coding-agent/src/modes/interactive/theme/theme-highlight.test.ts +23 -0
- package/packages/pi-coding-agent/src/modes/interactive/theme/theme.ts +106 -1
- package/packages/pi-coding-agent/src/modes/interactive/theme/themes.ts +27 -26
- package/packages/pi-coding-agent/src/modes/interactive/tui-mode.test.ts +9 -6
- package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-tui/dist/__tests__/overlay-layout.test.js +14 -1
- package/packages/pi-tui/dist/__tests__/overlay-layout.test.js.map +1 -1
- package/packages/pi-tui/dist/overlay-layout.d.ts.map +1 -1
- package/packages/pi-tui/dist/overlay-layout.js +9 -6
- package/packages/pi-tui/dist/overlay-layout.js.map +1 -1
- package/packages/pi-tui/package.json +1 -1
- package/packages/pi-tui/src/__tests__/overlay-layout.test.ts +20 -1
- package/packages/pi-tui/src/overlay-layout.ts +10 -7
- package/packages/pi-tui/tsconfig.tsbuildinfo +1 -1
- package/packages/rpc-client/package.json +1 -1
- package/pkg/dist/modes/interactive/theme/theme-highlight.test.d.ts +2 -0
- package/pkg/dist/modes/interactive/theme/theme-highlight.test.d.ts.map +1 -0
- package/pkg/dist/modes/interactive/theme/theme-highlight.test.js +17 -0
- package/pkg/dist/modes/interactive/theme/theme-highlight.test.js.map +1 -0
- package/pkg/dist/modes/interactive/theme/theme.d.ts.map +1 -1
- package/pkg/dist/modes/interactive/theme/theme.js +105 -1
- package/pkg/dist/modes/interactive/theme/theme.js.map +1 -1
- package/pkg/dist/modes/interactive/theme/themes.d.ts.map +1 -1
- package/pkg/dist/modes/interactive/theme/themes.js +27 -26
- package/pkg/dist/modes/interactive/theme/themes.js.map +1 -1
- package/pkg/package.json +1 -1
- package/src/resources/extensions/gsd/auto/loop-deps.ts +9 -5
- package/src/resources/extensions/gsd/auto/loop.ts +113 -9
- package/src/resources/extensions/gsd/auto/phases.ts +144 -19
- package/src/resources/extensions/gsd/auto/run-unit.ts +69 -4
- package/src/resources/extensions/gsd/auto/session.ts +10 -0
- package/src/resources/extensions/gsd/auto/verification-retry-policy.ts +82 -0
- package/src/resources/extensions/gsd/auto-dashboard.ts +230 -183
- package/src/resources/extensions/gsd/auto-dispatch.ts +15 -1
- package/src/resources/extensions/gsd/auto-post-unit.ts +7 -1
- package/src/resources/extensions/gsd/auto-recovery.ts +7 -209
- package/src/resources/extensions/gsd/auto-runtime-state.ts +5 -0
- package/src/resources/extensions/gsd/auto-start.ts +22 -22
- package/src/resources/extensions/gsd/auto-unit-closeout.ts +51 -0
- package/src/resources/extensions/gsd/auto-verification.ts +12 -6
- package/src/resources/extensions/gsd/auto-worktree.ts +8 -0
- package/src/resources/extensions/gsd/auto.ts +295 -75
- package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +21 -6
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +6 -2
- package/src/resources/extensions/gsd/bootstrap/register-shortcuts.ts +5 -8
- package/src/resources/extensions/gsd/commands/handlers/notifications-handler.ts +4 -10
- package/src/resources/extensions/gsd/commands/handlers/parallel.ts +12 -0
- package/src/resources/extensions/gsd/git-service.ts +2 -0
- package/src/resources/extensions/gsd/gsd-db.ts +7 -23
- package/src/resources/extensions/gsd/health-widget-core.ts +1 -1
- package/src/resources/extensions/gsd/health-widget.ts +6 -10
- package/src/resources/extensions/gsd/journal.ts +2 -0
- package/src/resources/extensions/gsd/markdown-renderer.ts +4 -95
- package/src/resources/extensions/gsd/native-git-bridge.ts +14 -13
- package/src/resources/extensions/gsd/notification-overlay.ts +50 -46
- package/src/resources/extensions/gsd/parallel-merge.ts +61 -34
- package/src/resources/extensions/gsd/parallel-monitor-overlay.ts +33 -35
- package/src/resources/extensions/gsd/prompts/complete-slice.md +14 -12
- package/src/resources/extensions/gsd/prompts/discuss-headless.md +20 -2
- package/src/resources/extensions/gsd/prompts/discuss.md +20 -2
- package/src/resources/extensions/gsd/recovery-classification.ts +18 -1
- package/src/resources/extensions/gsd/session-lock.ts +41 -0
- package/src/resources/extensions/gsd/state-reconciliation/drift/completion.ts +172 -0
- package/src/resources/extensions/gsd/state-reconciliation/drift/merge-state.ts +337 -0
- package/src/resources/extensions/gsd/state-reconciliation/drift/project-md.ts +69 -0
- package/src/resources/extensions/gsd/state-reconciliation/drift/roadmap.ts +109 -0
- package/src/resources/extensions/gsd/state-reconciliation/drift/sketch-flag.ts +68 -0
- package/src/resources/extensions/gsd/state-reconciliation/drift/stale-render.ts +185 -0
- package/src/resources/extensions/gsd/state-reconciliation/drift/stale-worker.ts +46 -0
- package/src/resources/extensions/gsd/state-reconciliation/errors.ts +67 -0
- package/src/resources/extensions/gsd/state-reconciliation/index.ts +142 -0
- package/src/resources/extensions/gsd/state-reconciliation/registry.ts +27 -0
- package/src/resources/extensions/gsd/state-reconciliation/spawn-gate.ts +60 -0
- package/src/resources/extensions/gsd/state-reconciliation/types.ts +83 -0
- package/src/resources/extensions/gsd/state-reconciliation.ts +21 -53
- package/src/resources/extensions/gsd/tests/artifact-retry-cap.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/auto-dashboard.test.ts +99 -0
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +654 -176
- package/src/resources/extensions/gsd/tests/auto-paused-ui-cleanup.test.ts +291 -4
- package/src/resources/extensions/gsd/tests/auto-runtime-state.test.ts +16 -1
- package/src/resources/extensions/gsd/tests/auto-start-orphan-bootstrap.test.ts +18 -0
- package/src/resources/extensions/gsd/tests/auto-unit-closeout.test.ts +68 -0
- package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +28 -1
- package/src/resources/extensions/gsd/tests/deep-project-auto-loop.test.ts +20 -2
- package/src/resources/extensions/gsd/tests/dispatch-complete-milestone-guard.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/header-renderer.test.ts +40 -0
- package/src/resources/extensions/gsd/tests/headless-milestone-parity.test.ts +10 -0
- package/src/resources/extensions/gsd/tests/health-widget.test.ts +14 -4
- package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +26 -0
- package/src/resources/extensions/gsd/tests/integration/integration-proof.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/integration/parallel-merge.test.ts +116 -24
- package/src/resources/extensions/gsd/tests/journal-integration.test.ts +0 -1
- package/src/resources/extensions/gsd/tests/markdown-renderer.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/merge-conflict-stops-loop.test.ts +46 -11
- package/src/resources/extensions/gsd/tests/notification-overlay.test.ts +78 -41
- package/src/resources/extensions/gsd/tests/notifications-handler.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/originalbase-path-comparison.test.ts +12 -217
- package/src/resources/extensions/gsd/tests/parallel-monitor-overlay.test.ts +38 -6
- package/src/resources/extensions/gsd/tests/post-exec-retry-bypass.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/progressive-planning.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +24 -1
- package/src/resources/extensions/gsd/tests/resume-dispatch-worktree.test.ts +7 -3
- package/src/resources/extensions/gsd/tests/runtime-invariant-modules.test.ts +6 -3
- package/src/resources/extensions/gsd/tests/session-switch-abort-misclassification.test.ts +24 -0
- package/src/resources/extensions/gsd/tests/state-corruption-2945.test.ts +65 -58
- package/src/resources/extensions/gsd/tests/state-reconciliation-drift.test.ts +952 -0
- package/src/resources/extensions/gsd/tests/token-tool-gating.test.ts +4 -0
- package/src/resources/extensions/gsd/tests/tui-header-lifecycle.test.ts +121 -1
- package/src/resources/extensions/gsd/tests/tui-render-kit.test.ts +66 -0
- package/src/resources/extensions/gsd/tests/verification-retry-policy.test.ts +83 -0
- package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +6 -0
- package/src/resources/extensions/gsd/tests/worktree-journal-events.test.ts +158 -58
- package/src/resources/extensions/gsd/tests/worktree-lifecycle.test.ts +572 -118
- package/src/resources/extensions/gsd/tests/worktree-telemetry.test.ts +59 -2
- package/src/resources/extensions/gsd/tests/write-gate-planning-unit.test.ts +18 -0
- package/src/resources/extensions/gsd/tui/render-kit.ts +109 -0
- package/src/resources/extensions/gsd/watch/header-renderer.ts +121 -79
- package/src/resources/extensions/gsd/watch/splash-palette.ts +11 -0
- package/src/resources/extensions/gsd/workflow-mcp.ts +2 -2
- package/src/resources/extensions/gsd/worktree-lifecycle.ts +1151 -524
- package/src/resources/extensions/gsd/worktree-telemetry.ts +7 -2
- package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +0 -1544
- /package/dist/web/standalone/.next/static/{drLMkgfHQ8lzS229_HWYR → S44UQTFCUdA44dkjfYt6S}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{drLMkgfHQ8lzS229_HWYR → S44UQTFCUdA44dkjfYt6S}/_ssgManifest.js +0 -0
|
@@ -14,13 +14,11 @@ import { clearParseCache } from "./files.js";
|
|
|
14
14
|
import { parseRoadmap as parseLegacyRoadmap, parsePlan as parseLegacyPlan } from "./parsers-legacy.js";
|
|
15
15
|
import { isDbAvailable, getTask, getSlice, getSliceTasks, getPendingGates, updateTaskStatus, updateSliceStatus, insertSlice, getMilestone, refreshOpenDatabaseFromDisk, getCompletedMilestoneTaskFileHints, getMilestoneCommitAttributionShas, recordMilestoneCommitAttribution } from "./gsd-db.js";
|
|
16
16
|
import { isValidationTerminal } from "./state.js";
|
|
17
|
-
import {
|
|
18
|
-
import { logWarning, logError } from "./workflow-logger.js";
|
|
17
|
+
import { logWarning } from "./workflow-logger.js";
|
|
19
18
|
import { readIntegrationBranch } from "./git-service.js";
|
|
20
19
|
import { isClosedStatus } from "./status-guards.js";
|
|
21
|
-
import { nativeConflictFiles, nativeCommit, nativeCheckoutTheirs, nativeAddPaths, nativeMergeAbort, nativeRebaseAbort, nativeResetHard, } from "./native-git-bridge.js";
|
|
22
20
|
import { resolveSlicePath, resolveSliceFile, resolveTasksDir, resolveTaskFiles, relMilestoneFile, relSliceFile, buildSliceFileName, resolveMilestoneFile, clearPathCache, resolveGsdRootFile, } from "./paths.js";
|
|
23
|
-
import { existsSync, mkdirSync, readFileSync, writeFileSync,
|
|
21
|
+
import { existsSync, mkdirSync, readFileSync, writeFileSync, } from "node:fs";
|
|
24
22
|
import { execFileSync } from "node:child_process";
|
|
25
23
|
import { dirname, join } from "node:path";
|
|
26
24
|
import { resolveExpectedArtifactPath, diagnoseExpectedArtifact, } from "./auto-artifact-paths.js";
|
|
@@ -932,183 +930,10 @@ export function writeBlockerPlaceholder(unitType, unitId, base, reason) {
|
|
|
932
930
|
return diagnoseExpectedArtifact(unitType, unitId, base);
|
|
933
931
|
}
|
|
934
932
|
// ─── Merge State Reconciliation ───────────────────────────────────────────────
|
|
935
|
-
|
|
936
|
-
|
|
937
|
-
|
|
938
|
-
|
|
939
|
-
function abortAndResetMerge(basePath, hasMergeHead, squashMsgPath) {
|
|
940
|
-
if (hasMergeHead) {
|
|
941
|
-
try {
|
|
942
|
-
nativeMergeAbort(basePath);
|
|
943
|
-
}
|
|
944
|
-
catch (err) {
|
|
945
|
-
/* best-effort */
|
|
946
|
-
logWarning("recovery", `git merge-abort failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
947
|
-
}
|
|
948
|
-
}
|
|
949
|
-
else if (squashMsgPath) {
|
|
950
|
-
try {
|
|
951
|
-
unlinkSync(squashMsgPath);
|
|
952
|
-
}
|
|
953
|
-
catch (err) {
|
|
954
|
-
/* best-effort */
|
|
955
|
-
logWarning("recovery", `file unlink failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
956
|
-
}
|
|
957
|
-
}
|
|
958
|
-
try {
|
|
959
|
-
nativeResetHard(basePath);
|
|
960
|
-
}
|
|
961
|
-
catch (err) {
|
|
962
|
-
/* best-effort */
|
|
963
|
-
logError("recovery", `git reset failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
964
|
-
}
|
|
965
|
-
}
|
|
966
|
-
/**
|
|
967
|
-
* Detect and abort other in-progress git operations left behind by a SIGKILL'd
|
|
968
|
-
* worker (rebase, cherry-pick, revert). Without this, a killed worker mid-rebase
|
|
969
|
-
* leaves `.git/rebase-merge/` or `.git/CHERRY_PICK_HEAD` and the worktree is
|
|
970
|
-
* wedged until the user manually runs the matching `--abort`.
|
|
971
|
-
*
|
|
972
|
-
* Called before merge-state reconciliation because these states block any
|
|
973
|
-
* subsequent merge/commit operation. (Issue #4980 HIGH-7)
|
|
974
|
-
*/
|
|
975
|
-
function reconcileOtherInProgressGitOps(basePath, ctx) {
|
|
976
|
-
const gitDir = join(basePath, ".git");
|
|
977
|
-
const states = [
|
|
978
|
-
{
|
|
979
|
-
label: "rebase",
|
|
980
|
-
indicators: [join(gitDir, "rebase-merge"), join(gitDir, "rebase-apply")],
|
|
981
|
-
abort: () => nativeRebaseAbort(basePath),
|
|
982
|
-
},
|
|
983
|
-
{
|
|
984
|
-
label: "cherry-pick",
|
|
985
|
-
indicators: [join(gitDir, "CHERRY_PICK_HEAD")],
|
|
986
|
-
abort: () => {
|
|
987
|
-
// No native helper; fall back to git CLI.
|
|
988
|
-
try {
|
|
989
|
-
execFileSync("git", ["cherry-pick", "--abort"], {
|
|
990
|
-
cwd: basePath, stdio: ["ignore", "pipe", "pipe"], encoding: "utf-8",
|
|
991
|
-
});
|
|
992
|
-
}
|
|
993
|
-
catch (err) {
|
|
994
|
-
logWarning("recovery", `cherry-pick --abort failed: ${getErrorMessage(err)}`);
|
|
995
|
-
}
|
|
996
|
-
},
|
|
997
|
-
},
|
|
998
|
-
{
|
|
999
|
-
label: "revert",
|
|
1000
|
-
indicators: [join(gitDir, "REVERT_HEAD")],
|
|
1001
|
-
abort: () => {
|
|
1002
|
-
try {
|
|
1003
|
-
execFileSync("git", ["revert", "--abort"], {
|
|
1004
|
-
cwd: basePath, stdio: ["ignore", "pipe", "pipe"], encoding: "utf-8",
|
|
1005
|
-
});
|
|
1006
|
-
}
|
|
1007
|
-
catch (err) {
|
|
1008
|
-
logWarning("recovery", `revert --abort failed: ${getErrorMessage(err)}`);
|
|
1009
|
-
}
|
|
1010
|
-
},
|
|
1011
|
-
},
|
|
1012
|
-
];
|
|
1013
|
-
let reconciled = false;
|
|
1014
|
-
for (const s of states) {
|
|
1015
|
-
const present = s.indicators.some((p) => existsSync(p));
|
|
1016
|
-
if (!present)
|
|
1017
|
-
continue;
|
|
1018
|
-
try {
|
|
1019
|
-
s.abort();
|
|
1020
|
-
ctx.ui.notify(`Detected leftover ${s.label} state from prior session — aborted.`, "warning");
|
|
1021
|
-
reconciled = true;
|
|
1022
|
-
}
|
|
1023
|
-
catch (err) {
|
|
1024
|
-
logError("recovery", `${s.label} abort failed: ${getErrorMessage(err)}`);
|
|
1025
|
-
ctx.ui.notify(`Detected leftover ${s.label} state but auto-abort failed. ` +
|
|
1026
|
-
`Run \`git ${s.label} --abort\` manually before retrying.`, "error");
|
|
1027
|
-
return "blocked";
|
|
1028
|
-
}
|
|
1029
|
-
}
|
|
1030
|
-
return reconciled ? "reconciled" : "clean";
|
|
1031
|
-
}
|
|
1032
|
-
/**
|
|
1033
|
-
* Detect leftover merge state from a prior session and reconcile it.
|
|
1034
|
-
* If MERGE_HEAD or SQUASH_MSG exists, check whether conflicts are resolved.
|
|
1035
|
-
* If resolved: finalize the commit. If only .gsd conflicts remain: auto-resolve.
|
|
1036
|
-
* If code conflicts remain: fail safe without modifying the worktree.
|
|
1037
|
-
*/
|
|
1038
|
-
export function reconcileMergeState(basePath, ctx) {
|
|
1039
|
-
// First, abort any rebase/cherry-pick/revert left over from a SIGKILL'd
|
|
1040
|
-
// worker. Doing this before the merge-state check unblocks any merge that
|
|
1041
|
-
// would otherwise refuse with "you have unfinished operation". (HIGH-7)
|
|
1042
|
-
const otherOpsResult = reconcileOtherInProgressGitOps(basePath, ctx);
|
|
1043
|
-
if (otherOpsResult === "blocked")
|
|
1044
|
-
return "blocked";
|
|
1045
|
-
const mergeHeadPath = join(basePath, ".git", "MERGE_HEAD");
|
|
1046
|
-
const squashMsgPath = join(basePath, ".git", "SQUASH_MSG");
|
|
1047
|
-
const hasMergeHead = existsSync(mergeHeadPath);
|
|
1048
|
-
const hasSquashMsg = existsSync(squashMsgPath);
|
|
1049
|
-
if (!hasMergeHead && !hasSquashMsg) {
|
|
1050
|
-
// If we cleaned up another op type, return "reconciled" so the caller
|
|
1051
|
-
// re-derives state from a known-good baseline.
|
|
1052
|
-
return otherOpsResult === "reconciled" ? "reconciled" : "clean";
|
|
1053
|
-
}
|
|
1054
|
-
const conflictedFiles = nativeConflictFiles(basePath);
|
|
1055
|
-
if (conflictedFiles.length === 0) {
|
|
1056
|
-
// All conflicts resolved — finalize the merge/squash commit
|
|
1057
|
-
try {
|
|
1058
|
-
const commitSha = nativeCommit(basePath, "chore(gsd): reconcile merge state");
|
|
1059
|
-
if (commitSha) {
|
|
1060
|
-
const mode = hasMergeHead ? "merge" : "squash commit";
|
|
1061
|
-
ctx.ui.notify(`Finalized leftover ${mode} from prior session.`, "info");
|
|
1062
|
-
}
|
|
1063
|
-
else {
|
|
1064
|
-
ctx.ui.notify("No new commit needed for leftover merge/squash state — already committed.", "info");
|
|
1065
|
-
}
|
|
1066
|
-
}
|
|
1067
|
-
catch (err) {
|
|
1068
|
-
const errorMessage = getErrorMessage(err);
|
|
1069
|
-
ctx.ui.notify(`Failed to finalize leftover merge/squash commit: ${errorMessage}`, "error");
|
|
1070
|
-
return "blocked";
|
|
1071
|
-
}
|
|
1072
|
-
}
|
|
1073
|
-
else {
|
|
1074
|
-
// Still conflicted — try auto-resolving .gsd/ state file conflicts (#530)
|
|
1075
|
-
const gsdConflicts = conflictedFiles.filter((f) => f.startsWith(".gsd/"));
|
|
1076
|
-
const codeConflicts = conflictedFiles.filter((f) => !f.startsWith(".gsd/"));
|
|
1077
|
-
if (gsdConflicts.length > 0 && codeConflicts.length === 0) {
|
|
1078
|
-
// All conflicts are in .gsd/ state files — auto-resolve by accepting theirs
|
|
1079
|
-
let resolved = true;
|
|
1080
|
-
try {
|
|
1081
|
-
nativeCheckoutTheirs(basePath, gsdConflicts);
|
|
1082
|
-
nativeAddPaths(basePath, gsdConflicts);
|
|
1083
|
-
}
|
|
1084
|
-
catch (e) {
|
|
1085
|
-
logError("recovery", `auto-resolve .gsd/ conflicts failed: ${e.message}`);
|
|
1086
|
-
resolved = false;
|
|
1087
|
-
}
|
|
1088
|
-
if (resolved) {
|
|
1089
|
-
try {
|
|
1090
|
-
nativeCommit(basePath, "chore: auto-resolve .gsd/ state file conflicts");
|
|
1091
|
-
ctx.ui.notify(`Auto-resolved ${gsdConflicts.length} .gsd/ state file conflict(s) from prior merge.`, "info");
|
|
1092
|
-
}
|
|
1093
|
-
catch (e) {
|
|
1094
|
-
logError("recovery", `auto-commit .gsd/ conflict resolution failed: ${e.message}`);
|
|
1095
|
-
resolved = false;
|
|
1096
|
-
}
|
|
1097
|
-
}
|
|
1098
|
-
if (!resolved) {
|
|
1099
|
-
abortAndResetMerge(basePath, hasMergeHead, squashMsgPath);
|
|
1100
|
-
ctx.ui.notify("Detected leftover merge state — auto-resolve failed, cleaned up. Re-deriving state.", "warning");
|
|
1101
|
-
}
|
|
1102
|
-
}
|
|
1103
|
-
else {
|
|
1104
|
-
// Code conflicts present — fail safe and preserve any manual resolution
|
|
1105
|
-
// work instead of discarding it with merge --abort/reset --hard.
|
|
1106
|
-
ctx.ui.notify("Detected leftover merge state with unresolved code conflicts. Auto-mode will pause without modifying the worktree so manual conflict resolution is preserved.", "error");
|
|
1107
|
-
return "blocked";
|
|
1108
|
-
}
|
|
1109
|
-
}
|
|
1110
|
-
return "reconciled";
|
|
1111
|
-
}
|
|
933
|
+
// Body relocated to state-reconciliation/drift/merge-state.ts (ADR-017 #5701).
|
|
934
|
+
// Re-exported here for backward compatibility with existing call sites:
|
|
935
|
+
// auto.ts, auto/loop-deps.ts, tests/integration/auto-recovery.test.ts.
|
|
936
|
+
export { reconcileMergeState, } from "./state-reconciliation/drift/merge-state.js";
|
|
1112
937
|
// ─── Loop Remediation ─────────────────────────────────────────────────────────
|
|
1113
938
|
/**
|
|
1114
939
|
* Build concrete, manual remediation steps for a loop-detected unit failure.
|
|
@@ -33,3 +33,8 @@ export function recordToolInvocationError(toolName, errorMsg) {
|
|
|
33
33
|
autoSession.lastToolInvocationError = `${toolName}: ${errorMsg}`;
|
|
34
34
|
}
|
|
35
35
|
}
|
|
36
|
+
export function clearToolInvocationError() {
|
|
37
|
+
if (!autoSession.active)
|
|
38
|
+
return;
|
|
39
|
+
autoSession.lastToolInvocationError = null;
|
|
40
|
+
}
|
|
@@ -679,30 +679,22 @@ export async function bootstrapAutoSession(s, ctx, pi, base, verboseMode, reques
|
|
|
679
679
|
{
|
|
680
680
|
const orphan = findUnmergedCompletedMilestone(base, getIsolationMode(base));
|
|
681
681
|
if (orphan && orphan !== state.activeMilestone?.id) {
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
s.originalBasePath
|
|
685
|
-
|
|
686
|
-
|
|
682
|
+
// ADR-016 phase 2 / B4 (#5622): the swap-run-revert protocol for
|
|
683
|
+
// the orphan-merge dance is owned by `adoptOrphanWorktree`. The
|
|
684
|
+
// verb snapshots prior `s.basePath` / `s.originalBasePath`, swaps
|
|
685
|
+
// into the orphan worktree, runs the merge callback under the
|
|
686
|
+
// swap, and reverts (or holds the swap) based on the result.
|
|
687
|
+
// Callers can no longer forget the revert step on failure — the
|
|
688
|
+
// pattern that originally motivated this verb.
|
|
689
|
+
const lifecycle = buildLifecycle();
|
|
690
|
+
const result = lifecycle.adoptOrphanWorktree(orphan, base, () => _mergeOrphanCompletedMilestone(lifecycle, orphan, ctx.ui));
|
|
687
691
|
if (!result.merged) {
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
try {
|
|
691
|
-
process.chdir(base);
|
|
692
|
-
}
|
|
693
|
-
catch (err) {
|
|
694
|
-
logWarning("bootstrap", `could not restore cwd after orphan merge failure: ${err instanceof Error ? err.message : String(err)}`);
|
|
695
|
-
}
|
|
692
|
+
// Verb already restored basePath/originalBasePath to `base` and
|
|
693
|
+
// chdir'd there. Return early.
|
|
696
694
|
return releaseLockAndReturn();
|
|
697
695
|
}
|
|
698
|
-
|
|
699
|
-
|
|
700
|
-
s.originalBasePath = priorOriginalBasePath || base;
|
|
701
|
-
}
|
|
702
|
-
if (result.merged) {
|
|
703
|
-
invalidateAllCaches();
|
|
704
|
-
state = await deriveState(base);
|
|
705
|
-
}
|
|
696
|
+
invalidateAllCaches();
|
|
697
|
+
state = await deriveState(base);
|
|
706
698
|
}
|
|
707
699
|
}
|
|
708
700
|
const effectivePrefs = loadEffectiveGSDPreferences(base)?.preferences;
|
|
@@ -792,7 +784,10 @@ export async function bootstrapAutoSession(s, ctx, pi, base, verboseMode, reques
|
|
|
792
784
|
s.stepMode = requestedStepMode;
|
|
793
785
|
s.verbose = verboseMode;
|
|
794
786
|
s.cmdCtx = ctx;
|
|
795
|
-
|
|
787
|
+
// ADR-016 phase 2 / B2 (#5620): single owner of bootstrap basePath
|
|
788
|
+
// mutation. Sets s.basePath = base and s.originalBasePath = base
|
|
789
|
+
// (originalBasePath is empty on a fresh bootstrap).
|
|
790
|
+
buildLifecycle().adoptSessionRoot(base);
|
|
796
791
|
s.unitDispatchCount.clear();
|
|
797
792
|
s.unitRecoveryCount.clear();
|
|
798
793
|
s.lastBudgetAlertLevel = 0;
|
|
@@ -842,7 +837,9 @@ export async function bootstrapAutoSession(s, ctx, pi, base, verboseMode, reques
|
|
|
842
837
|
}
|
|
843
838
|
}
|
|
844
839
|
// ── Auto-worktree setup ──
|
|
845
|
-
s.originalBasePath
|
|
840
|
+
// s.originalBasePath was set to `base` by `adoptSessionRoot(base)` above
|
|
841
|
+
// (ADR-016 phase 2 / B2, #5620). The redundant assignment that used to
|
|
842
|
+
// live here is gone.
|
|
846
843
|
const isUnderGsdWorktrees = (p) => {
|
|
847
844
|
// Direct layout: /.gsd/worktrees/
|
|
848
845
|
const marker = `${pathSep}.gsd${pathSep}worktrees${pathSep}`;
|
|
@@ -1,12 +1,40 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
* snapshotting metrics + saving activity log + extracting memories
|
|
4
|
-
* that appears 6+ times in auto.ts.
|
|
5
|
-
*/
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: Auto-mode unit closeout metrics, activity capture, and ghost-run detection.
|
|
6
3
|
import { snapshotUnitMetrics } from "./metrics.js";
|
|
7
4
|
import { saveActivityLog } from "./activity-log.js";
|
|
8
5
|
import { logWarning } from "./workflow-logger.js";
|
|
9
6
|
import { writeTurnGitTransaction } from "./uok/gitops.js";
|
|
7
|
+
export const GHOST_COMPLETION_MAX_ELAPSED_MS = 500;
|
|
8
|
+
export function snapshotUnitActivity(ctx, startedAt, now = Date.now()) {
|
|
9
|
+
let toolCalls = 0;
|
|
10
|
+
let assistantMessages = 0;
|
|
11
|
+
const entries = ctx.sessionManager.getEntries() ?? [];
|
|
12
|
+
for (const entry of entries) {
|
|
13
|
+
if (entry.type !== "message")
|
|
14
|
+
continue;
|
|
15
|
+
const msg = entry.message;
|
|
16
|
+
if (!msg || msg.role !== "assistant")
|
|
17
|
+
continue;
|
|
18
|
+
assistantMessages++;
|
|
19
|
+
if (!Array.isArray(msg.content))
|
|
20
|
+
continue;
|
|
21
|
+
for (const block of msg.content) {
|
|
22
|
+
if (block?.type === "toolCall")
|
|
23
|
+
toolCalls++;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
return {
|
|
27
|
+
elapsedMs: Math.max(0, now - startedAt),
|
|
28
|
+
toolCalls,
|
|
29
|
+
assistantMessages,
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
export function isSuspiciousGhostCompletion(ctx, startedAt, maxElapsedMs = GHOST_COMPLETION_MAX_ELAPSED_MS) {
|
|
33
|
+
const activity = snapshotUnitActivity(ctx, startedAt);
|
|
34
|
+
return (activity.elapsedMs < maxElapsedMs &&
|
|
35
|
+
activity.toolCalls === 0 &&
|
|
36
|
+
activity.assistantMessages === 0);
|
|
37
|
+
}
|
|
10
38
|
/**
|
|
11
39
|
* Snapshot metrics, save activity log, and fire-and-forget memory extraction
|
|
12
40
|
* for a completed unit. Returns the activity log file path (if any).
|
|
@@ -17,6 +17,7 @@ import { runPostExecutionChecks } from "./post-execution-checks.js";
|
|
|
17
17
|
import { join } from "node:path";
|
|
18
18
|
import { resolveUokFlags } from "./uok/flags.js";
|
|
19
19
|
import { UokGateRunner } from "./uok/gate-runner.js";
|
|
20
|
+
import { verificationRetryKey } from "./auto/verification-retry-policy.js";
|
|
20
21
|
function isInfraVerificationFailure(stderr) {
|
|
21
22
|
return /\b(ENOENT|ENOTFOUND|ETIMEDOUT|ECONNRESET|EAI_AGAIN|spawn\s+\S+\s+ENOENT|command not found)\b/i.test(stderr);
|
|
22
23
|
}
|
|
@@ -238,7 +239,8 @@ export async function runPostUnitVerification(vctx, pauseAuto) {
|
|
|
238
239
|
}
|
|
239
240
|
}
|
|
240
241
|
// Write verification evidence JSON
|
|
241
|
-
const
|
|
242
|
+
const retryKey = verificationRetryKey(s.currentUnit.type, s.currentUnit.id);
|
|
243
|
+
const attempt = s.verificationRetryCount.get(retryKey) ?? 0;
|
|
242
244
|
if (mid && sid && tid) {
|
|
243
245
|
try {
|
|
244
246
|
const sDir = resolveSlicePath(s.basePath, mid, sid);
|
|
@@ -261,7 +263,8 @@ export async function runPostUnitVerification(vctx, pauseAuto) {
|
|
|
261
263
|
(result.discoverySource === "package-json" ||
|
|
262
264
|
result.checks.some((check) => isInfraVerificationFailure(check.stderr)));
|
|
263
265
|
if (advisoryFailure) {
|
|
264
|
-
s.verificationRetryCount.delete(
|
|
266
|
+
s.verificationRetryCount.delete(retryKey);
|
|
267
|
+
s.verificationRetryFailureHashes.delete(retryKey);
|
|
265
268
|
s.pendingVerificationRetry = null;
|
|
266
269
|
ctx.ui.notify(result.discoverySource === "package-json"
|
|
267
270
|
? "Verification failed in auto-discovered package.json checks — treating as advisory."
|
|
@@ -422,14 +425,16 @@ export async function runPostUnitVerification(vctx, pauseAuto) {
|
|
|
422
425
|
}
|
|
423
426
|
// ── Auto-fix retry logic ──
|
|
424
427
|
if (result.passed) {
|
|
425
|
-
s.verificationRetryCount.delete(
|
|
428
|
+
s.verificationRetryCount.delete(retryKey);
|
|
429
|
+
s.verificationRetryFailureHashes.delete(retryKey);
|
|
426
430
|
s.pendingVerificationRetry = null;
|
|
427
431
|
return "continue";
|
|
428
432
|
}
|
|
429
433
|
else if (postExecBlockingFailure) {
|
|
430
434
|
// Post-execution failures are cross-task consistency issues — retrying the same task won't fix them.
|
|
431
435
|
// Skip retry and pause immediately for human review.
|
|
432
|
-
s.verificationRetryCount.delete(
|
|
436
|
+
s.verificationRetryCount.delete(retryKey);
|
|
437
|
+
s.verificationRetryFailureHashes.delete(retryKey);
|
|
433
438
|
s.pendingVerificationRetry = null;
|
|
434
439
|
ctx.ui.notify(`Post-execution checks failed — cross-task consistency issue detected, pausing for human review`, "error");
|
|
435
440
|
await pauseAuto(ctx, pi);
|
|
@@ -437,7 +442,7 @@ export async function runPostUnitVerification(vctx, pauseAuto) {
|
|
|
437
442
|
}
|
|
438
443
|
else if (autoFixEnabled && attempt + 1 <= maxRetries) {
|
|
439
444
|
const nextAttempt = attempt + 1;
|
|
440
|
-
s.verificationRetryCount.set(
|
|
445
|
+
s.verificationRetryCount.set(retryKey, nextAttempt);
|
|
441
446
|
s.pendingVerificationRetry = {
|
|
442
447
|
unitId: s.currentUnit.id,
|
|
443
448
|
failureContext: formatFailureContext(result),
|
|
@@ -455,7 +460,8 @@ export async function runPostUnitVerification(vctx, pauseAuto) {
|
|
|
455
460
|
}
|
|
456
461
|
else {
|
|
457
462
|
// Gate failed, retries exhausted
|
|
458
|
-
s.verificationRetryCount.delete(
|
|
463
|
+
s.verificationRetryCount.delete(retryKey);
|
|
464
|
+
s.verificationRetryFailureHashes.delete(retryKey);
|
|
459
465
|
s.pendingVerificationRetry = null;
|
|
460
466
|
const exhaustedFails = result.checks
|
|
461
467
|
.filter((c) => c.exitCode !== 0)
|
|
@@ -1271,6 +1271,14 @@ function autoCommitDirtyState(cwd) {
|
|
|
1271
1271
|
* On merge conflict: throws MergeConflictError.
|
|
1272
1272
|
* On "nothing to commit" after squash: safe only if milestone work is already
|
|
1273
1273
|
* on the integration branch. Throws if unanchored code changes would be lost.
|
|
1274
|
+
*
|
|
1275
|
+
* @internal **Do not call directly.** This is the inner squash-merge primitive
|
|
1276
|
+
* for the Worktree Lifecycle Module (ADR-016 phase 2 / A3, issue #5619).
|
|
1277
|
+
* Production callers must go through `WorktreeLifecycle.mergeMilestoneStandalone`
|
|
1278
|
+
* or `WorktreeLifecycle.exitMilestone({ merge: true })`. The export keyword
|
|
1279
|
+
* is preserved only so `auto.ts:buildWorktreeLifecycleDeps()` can wire this
|
|
1280
|
+
* function through the Module's deps seam — that is the construction of the
|
|
1281
|
+
* seam, not a bypass.
|
|
1274
1282
|
*/
|
|
1275
1283
|
export function mergeMilestoneToMain(originalBasePath_, milestoneId, roadmapContent) {
|
|
1276
1284
|
const worktreeCwd = process.cwd();
|