@roackb2/heddle 0.0.2
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 +273 -0
- package/dist/examples/conversation.d.ts +2 -0
- package/dist/examples/conversation.d.ts.map +1 -0
- package/dist/examples/conversation.js +3 -0
- package/dist/examples/conversation.js.map +1 -0
- package/dist/examples/repo-investigator.d.ts +2 -0
- package/dist/examples/repo-investigator.d.ts.map +1 -0
- package/dist/examples/repo-investigator.js +57 -0
- package/dist/examples/repo-investigator.js.map +1 -0
- package/dist/src/__tests__/chat-activity-format.test.d.ts +2 -0
- package/dist/src/__tests__/chat-activity-format.test.d.ts.map +1 -0
- package/dist/src/__tests__/chat-activity-format.test.js +41 -0
- package/dist/src/__tests__/chat-activity-format.test.js.map +1 -0
- package/dist/src/__tests__/chat-compaction.test.d.ts +2 -0
- package/dist/src/__tests__/chat-compaction.test.d.ts.map +1 -0
- package/dist/src/__tests__/chat-compaction.test.js +24 -0
- package/dist/src/__tests__/chat-compaction.test.js.map +1 -0
- package/dist/src/__tests__/chat-format.test.d.ts +2 -0
- package/dist/src/__tests__/chat-format.test.d.ts.map +1 -0
- package/dist/src/__tests__/chat-format.test.js +124 -0
- package/dist/src/__tests__/chat-format.test.js.map +1 -0
- package/dist/src/__tests__/chat-runtime.test.d.ts +2 -0
- package/dist/src/__tests__/chat-runtime.test.d.ts.map +1 -0
- package/dist/src/__tests__/chat-runtime.test.js +39 -0
- package/dist/src/__tests__/chat-runtime.test.js.map +1 -0
- package/dist/src/__tests__/core-utils.test.d.ts +2 -0
- package/dist/src/__tests__/core-utils.test.d.ts.map +1 -0
- package/dist/src/__tests__/core-utils.test.js +87 -0
- package/dist/src/__tests__/core-utils.test.js.map +1 -0
- package/dist/src/__tests__/llm-factory.test.d.ts +2 -0
- package/dist/src/__tests__/llm-factory.test.d.ts.map +1 -0
- package/dist/src/__tests__/llm-factory.test.js +45 -0
- package/dist/src/__tests__/llm-factory.test.js.map +1 -0
- package/dist/src/__tests__/local-commands.test.d.ts +2 -0
- package/dist/src/__tests__/local-commands.test.d.ts.map +1 -0
- package/dist/src/__tests__/local-commands.test.js +163 -0
- package/dist/src/__tests__/local-commands.test.js.map +1 -0
- package/dist/src/__tests__/project-approval-rules.test.d.ts +2 -0
- package/dist/src/__tests__/project-approval-rules.test.d.ts.map +1 -0
- package/dist/src/__tests__/project-approval-rules.test.js +135 -0
- package/dist/src/__tests__/project-approval-rules.test.js.map +1 -0
- package/dist/src/__tests__/prompts.test.d.ts +2 -0
- package/dist/src/__tests__/prompts.test.d.ts.map +1 -0
- package/dist/src/__tests__/prompts.test.js +43 -0
- package/dist/src/__tests__/prompts.test.js.map +1 -0
- package/dist/src/__tests__/run-agent.test.d.ts +2 -0
- package/dist/src/__tests__/run-agent.test.d.ts.map +1 -0
- package/dist/src/__tests__/run-agent.test.js +1276 -0
- package/dist/src/__tests__/run-agent.test.js.map +1 -0
- package/dist/src/__tests__/run-shell.command.test.d.ts +2 -0
- package/dist/src/__tests__/run-shell.command.test.d.ts.map +1 -0
- package/dist/src/__tests__/run-shell.command.test.js +188 -0
- package/dist/src/__tests__/run-shell.command.test.js.map +1 -0
- package/dist/src/__tests__/smoke.test.d.ts +2 -0
- package/dist/src/__tests__/smoke.test.d.ts.map +1 -0
- package/dist/src/__tests__/smoke.test.js +314 -0
- package/dist/src/__tests__/smoke.test.js.map +1 -0
- package/dist/src/__tests__/tools.test.d.ts +2 -0
- package/dist/src/__tests__/tools.test.d.ts.map +1 -0
- package/dist/src/__tests__/tools.test.js +557 -0
- package/dist/src/__tests__/tools.test.js.map +1 -0
- package/dist/src/__tests__/trace-format.test.d.ts +2 -0
- package/dist/src/__tests__/trace-format.test.d.ts.map +1 -0
- package/dist/src/__tests__/trace-format.test.js +148 -0
- package/dist/src/__tests__/trace-format.test.js.map +1 -0
- package/dist/src/cli/ask.d.ts +11 -0
- package/dist/src/cli/ask.d.ts.map +1 -0
- package/dist/src/cli/ask.js +59 -0
- package/dist/src/cli/ask.js.map +1 -0
- package/dist/src/cli/chat/App.d.ts +5 -0
- package/dist/src/cli/chat/App.d.ts.map +1 -0
- package/dist/src/cli/chat/App.js +348 -0
- package/dist/src/cli/chat/App.js.map +1 -0
- package/dist/src/cli/chat/actions.d.ts +47 -0
- package/dist/src/cli/chat/actions.d.ts.map +1 -0
- package/dist/src/cli/chat/actions.js +215 -0
- package/dist/src/cli/chat/actions.js.map +1 -0
- package/dist/src/cli/chat/components/ActivityPanel.d.ts +11 -0
- package/dist/src/cli/chat/components/ActivityPanel.d.ts.map +1 -0
- package/dist/src/cli/chat/components/ActivityPanel.js +20 -0
- package/dist/src/cli/chat/components/ActivityPanel.js.map +1 -0
- package/dist/src/cli/chat/components/ApprovalComposer.d.ts +6 -0
- package/dist/src/cli/chat/components/ApprovalComposer.d.ts.map +1 -0
- package/dist/src/cli/chat/components/ApprovalComposer.js +30 -0
- package/dist/src/cli/chat/components/ApprovalComposer.js.map +1 -0
- package/dist/src/cli/chat/components/CommandHintPanel.d.ts +5 -0
- package/dist/src/cli/chat/components/CommandHintPanel.d.ts.map +1 -0
- package/dist/src/cli/chat/components/CommandHintPanel.js +13 -0
- package/dist/src/cli/chat/components/CommandHintPanel.js.map +1 -0
- package/dist/src/cli/chat/components/ConversationPanel.d.ts +16 -0
- package/dist/src/cli/chat/components/ConversationPanel.d.ts.map +1 -0
- package/dist/src/cli/chat/components/ConversationPanel.js +218 -0
- package/dist/src/cli/chat/components/ConversationPanel.js.map +1 -0
- package/dist/src/cli/chat/components/ModelPickerPanel.d.ts +7 -0
- package/dist/src/cli/chat/components/ModelPickerPanel.d.ts.map +1 -0
- package/dist/src/cli/chat/components/ModelPickerPanel.js +32 -0
- package/dist/src/cli/chat/components/ModelPickerPanel.js.map +1 -0
- package/dist/src/cli/chat/components/PromptInput.d.ts +29 -0
- package/dist/src/cli/chat/components/PromptInput.d.ts.map +1 -0
- package/dist/src/cli/chat/components/PromptInput.js +132 -0
- package/dist/src/cli/chat/components/PromptInput.js.map +1 -0
- package/dist/src/cli/chat/components/RecentTurnsPanel.d.ts +5 -0
- package/dist/src/cli/chat/components/RecentTurnsPanel.d.ts.map +1 -0
- package/dist/src/cli/chat/components/RecentTurnsPanel.js +10 -0
- package/dist/src/cli/chat/components/RecentTurnsPanel.js.map +1 -0
- package/dist/src/cli/chat/components/SessionPickerPanel.d.ts +12 -0
- package/dist/src/cli/chat/components/SessionPickerPanel.d.ts.map +1 -0
- package/dist/src/cli/chat/components/SessionPickerPanel.js +32 -0
- package/dist/src/cli/chat/components/SessionPickerPanel.js.map +1 -0
- package/dist/src/cli/chat/components/SlashHintPanel.d.ts +8 -0
- package/dist/src/cli/chat/components/SlashHintPanel.d.ts.map +1 -0
- package/dist/src/cli/chat/components/SlashHintPanel.js +38 -0
- package/dist/src/cli/chat/components/SlashHintPanel.js.map +1 -0
- package/dist/src/cli/chat/components/index.d.ts +10 -0
- package/dist/src/cli/chat/components/index.d.ts.map +1 -0
- package/dist/src/cli/chat/components/index.js +10 -0
- package/dist/src/cli/chat/components/index.js.map +1 -0
- package/dist/src/cli/chat/format.d.ts +23 -0
- package/dist/src/cli/chat/format.d.ts.map +1 -0
- package/dist/src/cli/chat/format.js +243 -0
- package/dist/src/cli/chat/format.js.map +1 -0
- package/dist/src/cli/chat/hooks/useAgentRun.d.ts +61 -0
- package/dist/src/cli/chat/hooks/useAgentRun.d.ts.map +1 -0
- package/dist/src/cli/chat/hooks/useAgentRun.js +463 -0
- package/dist/src/cli/chat/hooks/useAgentRun.js.map +1 -0
- package/dist/src/cli/chat/hooks/useApprovalFlow.d.ts +31 -0
- package/dist/src/cli/chat/hooks/useApprovalFlow.d.ts.map +1 -0
- package/dist/src/cli/chat/hooks/useApprovalFlow.js +145 -0
- package/dist/src/cli/chat/hooks/useApprovalFlow.js.map +1 -0
- package/dist/src/cli/chat/hooks/useChatSessions.d.ts +23 -0
- package/dist/src/cli/chat/hooks/useChatSessions.d.ts.map +1 -0
- package/dist/src/cli/chat/hooks/useChatSessions.js +124 -0
- package/dist/src/cli/chat/hooks/useChatSessions.js.map +1 -0
- package/dist/src/cli/chat/hooks/useProjectApprovals.d.ts +8 -0
- package/dist/src/cli/chat/hooks/useProjectApprovals.d.ts.map +1 -0
- package/dist/src/cli/chat/hooks/useProjectApprovals.js +33 -0
- package/dist/src/cli/chat/hooks/useProjectApprovals.js.map +1 -0
- package/dist/src/cli/chat/index.d.ts +4 -0
- package/dist/src/cli/chat/index.d.ts.map +1 -0
- package/dist/src/cli/chat/index.js +9 -0
- package/dist/src/cli/chat/index.js.map +1 -0
- package/dist/src/cli/chat/local-commands.d.ts +17 -0
- package/dist/src/cli/chat/local-commands.d.ts.map +1 -0
- package/dist/src/cli/chat/local-commands.js +180 -0
- package/dist/src/cli/chat/local-commands.js.map +1 -0
- package/dist/src/cli/chat/panels.d.ts +37 -0
- package/dist/src/cli/chat/panels.d.ts.map +1 -0
- package/dist/src/cli/chat/panels.js +142 -0
- package/dist/src/cli/chat/panels.js.map +1 -0
- package/dist/src/cli/chat/runtime.d.ts +26 -0
- package/dist/src/cli/chat/runtime.d.ts.map +1 -0
- package/dist/src/cli/chat/runtime.js +28 -0
- package/dist/src/cli/chat/runtime.js.map +1 -0
- package/dist/src/cli/chat/state/approval-rules.d.ts +21 -0
- package/dist/src/cli/chat/state/approval-rules.d.ts.map +1 -0
- package/dist/src/cli/chat/state/approval-rules.js +196 -0
- package/dist/src/cli/chat/state/approval-rules.js.map +1 -0
- package/dist/src/cli/chat/state/compaction.d.ts +13 -0
- package/dist/src/cli/chat/state/compaction.d.ts.map +1 -0
- package/dist/src/cli/chat/state/compaction.js +143 -0
- package/dist/src/cli/chat/state/compaction.js.map +1 -0
- package/dist/src/cli/chat/state/local-commands.d.ts +17 -0
- package/dist/src/cli/chat/state/local-commands.d.ts.map +1 -0
- package/dist/src/cli/chat/state/local-commands.js +169 -0
- package/dist/src/cli/chat/state/local-commands.js.map +1 -0
- package/dist/src/cli/chat/state/storage.d.ts +14 -0
- package/dist/src/cli/chat/state/storage.d.ts.map +1 -0
- package/dist/src/cli/chat/state/storage.js +144 -0
- package/dist/src/cli/chat/state/storage.js.map +1 -0
- package/dist/src/cli/chat/state/types.d.ts +69 -0
- package/dist/src/cli/chat/state/types.d.ts.map +1 -0
- package/dist/src/cli/chat/state/types.js +2 -0
- package/dist/src/cli/chat/state/types.js.map +1 -0
- package/dist/src/cli/chat/storage.d.ts +13 -0
- package/dist/src/cli/chat/storage.d.ts.map +1 -0
- package/dist/src/cli/chat/storage.js +126 -0
- package/dist/src/cli/chat/storage.js.map +1 -0
- package/dist/src/cli/chat/submit.d.ts +28 -0
- package/dist/src/cli/chat/submit.d.ts.map +1 -0
- package/dist/src/cli/chat/submit.js +90 -0
- package/dist/src/cli/chat/submit.js.map +1 -0
- package/dist/src/cli/chat/types.d.ts +51 -0
- package/dist/src/cli/chat/types.d.ts.map +1 -0
- package/dist/src/cli/chat/types.js +2 -0
- package/dist/src/cli/chat/types.js.map +1 -0
- package/dist/src/cli/chat/use-run-state.d.ts +23 -0
- package/dist/src/cli/chat/use-run-state.d.ts.map +1 -0
- package/dist/src/cli/chat/use-run-state.js +118 -0
- package/dist/src/cli/chat/use-run-state.js.map +1 -0
- package/dist/src/cli/chat/use-sessions.d.ts +21 -0
- package/dist/src/cli/chat/use-sessions.d.ts.map +1 -0
- package/dist/src/cli/chat/use-sessions.js +111 -0
- package/dist/src/cli/chat/use-sessions.js.map +1 -0
- package/dist/src/cli/chat/utils/format.d.ts +41 -0
- package/dist/src/cli/chat/utils/format.d.ts.map +1 -0
- package/dist/src/cli/chat/utils/format.js +578 -0
- package/dist/src/cli/chat/utils/format.js.map +1 -0
- package/dist/src/cli/chat/utils/runtime.d.ts +31 -0
- package/dist/src/cli/chat/utils/runtime.d.ts.map +1 -0
- package/dist/src/cli/chat/utils/runtime.js +56 -0
- package/dist/src/cli/chat/utils/runtime.js.map +1 -0
- package/dist/src/cli/chat-actions.d.ts +47 -0
- package/dist/src/cli/chat-actions.d.ts.map +1 -0
- package/dist/src/cli/chat-actions.js +215 -0
- package/dist/src/cli/chat-actions.js.map +1 -0
- package/dist/src/cli/chat-format.d.ts +23 -0
- package/dist/src/cli/chat-format.d.ts.map +1 -0
- package/dist/src/cli/chat-format.js +243 -0
- package/dist/src/cli/chat-format.js.map +1 -0
- package/dist/src/cli/chat-local-commands.d.ts +17 -0
- package/dist/src/cli/chat-local-commands.d.ts.map +1 -0
- package/dist/src/cli/chat-local-commands.js +180 -0
- package/dist/src/cli/chat-local-commands.js.map +1 -0
- package/dist/src/cli/chat-panels.d.ts +37 -0
- package/dist/src/cli/chat-panels.d.ts.map +1 -0
- package/dist/src/cli/chat-panels.js +142 -0
- package/dist/src/cli/chat-panels.js.map +1 -0
- package/dist/src/cli/chat-runtime.d.ts +26 -0
- package/dist/src/cli/chat-runtime.d.ts.map +1 -0
- package/dist/src/cli/chat-runtime.js +28 -0
- package/dist/src/cli/chat-runtime.js.map +1 -0
- package/dist/src/cli/chat-storage.d.ts +13 -0
- package/dist/src/cli/chat-storage.d.ts.map +1 -0
- package/dist/src/cli/chat-storage.js +126 -0
- package/dist/src/cli/chat-storage.js.map +1 -0
- package/dist/src/cli/chat-submit.d.ts +28 -0
- package/dist/src/cli/chat-submit.d.ts.map +1 -0
- package/dist/src/cli/chat-submit.js +90 -0
- package/dist/src/cli/chat-submit.js.map +1 -0
- package/dist/src/cli/chat-types.d.ts +51 -0
- package/dist/src/cli/chat-types.d.ts.map +1 -0
- package/dist/src/cli/chat-types.js +2 -0
- package/dist/src/cli/chat-types.js.map +1 -0
- package/dist/src/cli/chat.d.ts +4 -0
- package/dist/src/cli/chat.d.ts.map +1 -0
- package/dist/src/cli/chat.js +153 -0
- package/dist/src/cli/chat.js.map +1 -0
- package/dist/src/cli/main.d.ts +3 -0
- package/dist/src/cli/main.d.ts.map +1 -0
- package/dist/src/cli/main.js +190 -0
- package/dist/src/cli/main.js.map +1 -0
- package/dist/src/cli/useChatRunState.d.ts +23 -0
- package/dist/src/cli/useChatRunState.d.ts.map +1 -0
- package/dist/src/cli/useChatRunState.js +118 -0
- package/dist/src/cli/useChatRunState.js.map +1 -0
- package/dist/src/cli/useChatSessions.d.ts +21 -0
- package/dist/src/cli/useChatSessions.d.ts.map +1 -0
- package/dist/src/cli/useChatSessions.js +111 -0
- package/dist/src/cli/useChatSessions.js.map +1 -0
- package/dist/src/config.d.ts +4 -0
- package/dist/src/config.d.ts.map +1 -0
- package/dist/src/config.js +7 -0
- package/dist/src/config.js.map +1 -0
- package/dist/src/index.d.ts +36 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +31 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/llm/anthropic.d.ts +7 -0
- package/dist/src/llm/anthropic.d.ts.map +1 -0
- package/dist/src/llm/anthropic.js +115 -0
- package/dist/src/llm/anthropic.js.map +1 -0
- package/dist/src/llm/factory.d.ts +10 -0
- package/dist/src/llm/factory.d.ts.map +1 -0
- package/dist/src/llm/factory.js +53 -0
- package/dist/src/llm/factory.js.map +1 -0
- package/dist/src/llm/openai-models.d.ts +15 -0
- package/dist/src/llm/openai-models.d.ts.map +1 -0
- package/dist/src/llm/openai-models.js +97 -0
- package/dist/src/llm/openai-models.js.map +1 -0
- package/dist/src/llm/openai.d.ts +10 -0
- package/dist/src/llm/openai.d.ts.map +1 -0
- package/dist/src/llm/openai.js +170 -0
- package/dist/src/llm/openai.js.map +1 -0
- package/dist/src/llm/types.d.ts +64 -0
- package/dist/src/llm/types.d.ts.map +1 -0
- package/dist/src/llm/types.js +5 -0
- package/dist/src/llm/types.js.map +1 -0
- package/dist/src/prompts/system-prompt.d.ts +6 -0
- package/dist/src/prompts/system-prompt.d.ts.map +1 -0
- package/dist/src/prompts/system-prompt.js +117 -0
- package/dist/src/prompts/system-prompt.js.map +1 -0
- package/dist/src/run-agent/history.d.ts +3 -0
- package/dist/src/run-agent/history.d.ts.map +1 -0
- package/dist/src/run-agent/history.js +36 -0
- package/dist/src/run-agent/history.js.map +1 -0
- package/dist/src/run-agent/mutation-tracking.d.ts +22 -0
- package/dist/src/run-agent/mutation-tracking.d.ts.map +1 -0
- package/dist/src/run-agent/mutation-tracking.js +116 -0
- package/dist/src/run-agent/mutation-tracking.js.map +1 -0
- package/dist/src/run-agent/post-mutation.d.ts +23 -0
- package/dist/src/run-agent/post-mutation.d.ts.map +1 -0
- package/dist/src/run-agent/post-mutation.js +106 -0
- package/dist/src/run-agent/post-mutation.js.map +1 -0
- package/dist/src/run-agent/progress-reminders.d.ts +13 -0
- package/dist/src/run-agent/progress-reminders.d.ts.map +1 -0
- package/dist/src/run-agent/progress-reminders.js +65 -0
- package/dist/src/run-agent/progress-reminders.js.map +1 -0
- package/dist/src/run-agent/tool-dispatch.d.ts +31 -0
- package/dist/src/run-agent/tool-dispatch.d.ts.map +1 -0
- package/dist/src/run-agent/tool-dispatch.js +114 -0
- package/dist/src/run-agent/tool-dispatch.js.map +1 -0
- package/dist/src/run-agent/util.d.ts +10 -0
- package/dist/src/run-agent/util.d.ts.map +1 -0
- package/dist/src/run-agent/util.js +64 -0
- package/dist/src/run-agent/util.js.map +1 -0
- package/dist/src/run-agent.d.ts +36 -0
- package/dist/src/run-agent.d.ts.map +1 -0
- package/dist/src/run-agent.js +477 -0
- package/dist/src/run-agent.js.map +1 -0
- package/dist/src/tools/edit-file.d.ts +10 -0
- package/dist/src/tools/edit-file.d.ts.map +1 -0
- package/dist/src/tools/edit-file.js +268 -0
- package/dist/src/tools/edit-file.js.map +1 -0
- package/dist/src/tools/execute-tool.d.ts +8 -0
- package/dist/src/tools/execute-tool.d.ts.map +1 -0
- package/dist/src/tools/execute-tool.js +31 -0
- package/dist/src/tools/execute-tool.js.map +1 -0
- package/dist/src/tools/list-files.d.ts +3 -0
- package/dist/src/tools/list-files.d.ts.map +1 -0
- package/dist/src/tools/list-files.js +49 -0
- package/dist/src/tools/list-files.js.map +1 -0
- package/dist/src/tools/read-file.d.ts +3 -0
- package/dist/src/tools/read-file.d.ts.map +1 -0
- package/dist/src/tools/read-file.js +73 -0
- package/dist/src/tools/read-file.js.map +1 -0
- package/dist/src/tools/registry.d.ts +11 -0
- package/dist/src/tools/registry.d.ts.map +1 -0
- package/dist/src/tools/registry.js +27 -0
- package/dist/src/tools/registry.js.map +1 -0
- package/dist/src/tools/report-state.d.ts +3 -0
- package/dist/src/tools/report-state.d.ts.map +1 -0
- package/dist/src/tools/report-state.js +63 -0
- package/dist/src/tools/report-state.js.map +1 -0
- package/dist/src/tools/run-shell.d.ts +41 -0
- package/dist/src/tools/run-shell.d.ts.map +1 -0
- package/dist/src/tools/run-shell.js +407 -0
- package/dist/src/tools/run-shell.js.map +1 -0
- package/dist/src/tools/search-files.d.ts +8 -0
- package/dist/src/tools/search-files.d.ts.map +1 -0
- package/dist/src/tools/search-files.js +86 -0
- package/dist/src/tools/search-files.js.map +1 -0
- package/dist/src/tools/update-plan.d.ts +8 -0
- package/dist/src/tools/update-plan.d.ts.map +1 -0
- package/dist/src/tools/update-plan.js +85 -0
- package/dist/src/tools/update-plan.js.map +1 -0
- package/dist/src/trace/format.d.ts +6 -0
- package/dist/src/trace/format.d.ts.map +1 -0
- package/dist/src/trace/format.js +94 -0
- package/dist/src/trace/format.js.map +1 -0
- package/dist/src/trace/recorder.d.ts +11 -0
- package/dist/src/trace/recorder.d.ts.map +1 -0
- package/dist/src/trace/recorder.js +21 -0
- package/dist/src/trace/recorder.js.map +1 -0
- package/dist/src/types.d.ts +110 -0
- package/dist/src/types.d.ts.map +1 -0
- package/dist/src/types.js +6 -0
- package/dist/src/types.js.map +1 -0
- package/dist/src/utils/budget.d.ts +13 -0
- package/dist/src/utils/budget.d.ts.map +1 -0
- package/dist/src/utils/budget.js +22 -0
- package/dist/src/utils/budget.js.map +1 -0
- package/dist/src/utils/errors.d.ts +14 -0
- package/dist/src/utils/errors.d.ts.map +1 -0
- package/dist/src/utils/errors.js +31 -0
- package/dist/src/utils/errors.js.map +1 -0
- package/dist/src/utils/logger.d.ts +17 -0
- package/dist/src/utils/logger.d.ts.map +1 -0
- package/dist/src/utils/logger.js +50 -0
- package/dist/src/utils/logger.js.map +1 -0
- package/package.json +57 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core-utils.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/core-utils.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { createToolRegistry } from '../tools/registry.js';
|
|
3
|
+
import { createBudget } from '../utils/budget.js';
|
|
4
|
+
import { createTraceRecorder } from '../trace/recorder.js';
|
|
5
|
+
import { isRepoReviewCommand } from '../run-agent/mutation-tracking.js';
|
|
6
|
+
describe('createToolRegistry', () => {
|
|
7
|
+
const fakeTool = {
|
|
8
|
+
name: 'test_tool',
|
|
9
|
+
description: 'A test tool',
|
|
10
|
+
parameters: { type: 'object', properties: {} },
|
|
11
|
+
execute: async () => ({ ok: true, output: 'hello' }),
|
|
12
|
+
};
|
|
13
|
+
it('registers and retrieves a tool by name', () => {
|
|
14
|
+
const registry = createToolRegistry([fakeTool]);
|
|
15
|
+
expect(registry.get('test_tool')).toBe(fakeTool);
|
|
16
|
+
});
|
|
17
|
+
it('returns undefined for unknown tools', () => {
|
|
18
|
+
const registry = createToolRegistry([fakeTool]);
|
|
19
|
+
expect(registry.get('nonexistent')).toBeUndefined();
|
|
20
|
+
});
|
|
21
|
+
it('lists all tool names', () => {
|
|
22
|
+
const another = { ...fakeTool, name: 'another' };
|
|
23
|
+
const registry = createToolRegistry([fakeTool, another]);
|
|
24
|
+
expect(registry.names()).toEqual(['test_tool', 'another']);
|
|
25
|
+
});
|
|
26
|
+
it('throws on duplicate tool names', () => {
|
|
27
|
+
expect(() => createToolRegistry([fakeTool, fakeTool])).toThrow('Duplicate tool name');
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
describe('createBudget', () => {
|
|
31
|
+
it('counts steps and reports exhaustion', () => {
|
|
32
|
+
const budget = createBudget(3);
|
|
33
|
+
expect(budget.remaining()).toBe(3);
|
|
34
|
+
expect(budget.exhausted()).toBe(false);
|
|
35
|
+
budget.step();
|
|
36
|
+
expect(budget.remaining()).toBe(2);
|
|
37
|
+
budget.step();
|
|
38
|
+
budget.step();
|
|
39
|
+
expect(budget.remaining()).toBe(0);
|
|
40
|
+
expect(budget.exhausted()).toBe(true);
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
describe('createTraceRecorder', () => {
|
|
44
|
+
it('records events and exports them', () => {
|
|
45
|
+
const recorder = createTraceRecorder();
|
|
46
|
+
const event1 = { type: 'run.started', goal: 'test', timestamp: '2024-01-01T00:00:00Z' };
|
|
47
|
+
const event2 = {
|
|
48
|
+
type: 'run.finished',
|
|
49
|
+
outcome: 'done',
|
|
50
|
+
summary: 'all good',
|
|
51
|
+
step: 1,
|
|
52
|
+
timestamp: '2024-01-01T00:00:01Z',
|
|
53
|
+
};
|
|
54
|
+
recorder.record(event1);
|
|
55
|
+
recorder.record(event2);
|
|
56
|
+
const trace = recorder.getTrace();
|
|
57
|
+
expect(trace).toHaveLength(2);
|
|
58
|
+
expect(trace[0]).toEqual(event1);
|
|
59
|
+
expect(trace[1]).toEqual(event2);
|
|
60
|
+
});
|
|
61
|
+
it('exports valid JSON', () => {
|
|
62
|
+
const recorder = createTraceRecorder();
|
|
63
|
+
recorder.record({ type: 'run.started', goal: 'test', timestamp: '2024-01-01T00:00:00Z' });
|
|
64
|
+
const json = recorder.toJSON();
|
|
65
|
+
const parsed = JSON.parse(json);
|
|
66
|
+
expect(parsed).toHaveLength(1);
|
|
67
|
+
expect(parsed[0].type).toBe('run.started');
|
|
68
|
+
});
|
|
69
|
+
it('returns a copy from getTrace so mutations do not affect the recorder', () => {
|
|
70
|
+
const recorder = createTraceRecorder();
|
|
71
|
+
recorder.record({ type: 'run.started', goal: 'test', timestamp: '2024-01-01T00:00:00Z' });
|
|
72
|
+
const trace = recorder.getTrace();
|
|
73
|
+
trace.pop();
|
|
74
|
+
expect(recorder.getTrace()).toHaveLength(1);
|
|
75
|
+
});
|
|
76
|
+
});
|
|
77
|
+
describe('isRepoReviewCommand', () => {
|
|
78
|
+
it('only accepts the stricter git evidence commands', () => {
|
|
79
|
+
expect(isRepoReviewCommand('git diff --stat')).toBe(true);
|
|
80
|
+
expect(isRepoReviewCommand('git diff --stat=10')).toBe(true);
|
|
81
|
+
expect(isRepoReviewCommand('git status --short')).toBe(true);
|
|
82
|
+
expect(isRepoReviewCommand('git diff')).toBe(false);
|
|
83
|
+
expect(isRepoReviewCommand('git status')).toBe(false);
|
|
84
|
+
expect(isRepoReviewCommand('git status --long')).toBe(false);
|
|
85
|
+
});
|
|
86
|
+
});
|
|
87
|
+
//# sourceMappingURL=core-utils.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core-utils.test.js","sourceRoot":"","sources":["../../../src/__tests__/core-utils.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"llm-factory.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/llm-factory.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { createAnthropicAdapter } from '../llm/anthropic.js';
|
|
3
|
+
import { createLlmAdapter, inferProviderFromModel, resolveLlmProvider } from '../llm/factory.js';
|
|
4
|
+
describe('llm adapter factory', () => {
|
|
5
|
+
it('infers provider from known model prefixes', () => {
|
|
6
|
+
expect(inferProviderFromModel('gpt-5.1-codex')).toBe('openai');
|
|
7
|
+
expect(inferProviderFromModel('claude-sonnet-4-6')).toBe('anthropic');
|
|
8
|
+
expect(inferProviderFromModel('gemini-2.5-pro')).toBe('google');
|
|
9
|
+
});
|
|
10
|
+
it('prefers an explicit provider over model inference', () => {
|
|
11
|
+
expect(resolveLlmProvider({ provider: 'openai', model: 'claude-sonnet-4-6' })).toBe('openai');
|
|
12
|
+
});
|
|
13
|
+
it('returns an OpenAI adapter with provider metadata for OpenAI models', () => {
|
|
14
|
+
const adapter = createLlmAdapter({ model: 'gpt-5.1-codex', apiKey: 'test-key' });
|
|
15
|
+
expect(adapter.info).toEqual({
|
|
16
|
+
provider: 'openai',
|
|
17
|
+
model: 'gpt-5.1-codex',
|
|
18
|
+
capabilities: {
|
|
19
|
+
toolCalls: true,
|
|
20
|
+
systemMessages: true,
|
|
21
|
+
reasoningSummaries: true,
|
|
22
|
+
parallelToolCalls: true,
|
|
23
|
+
},
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
it('returns an Anthropic adapter with provider metadata for Claude models', () => {
|
|
27
|
+
const adapter = createLlmAdapter({ model: 'claude-sonnet-4-6', apiKey: 'test-key' });
|
|
28
|
+
expect(adapter.info).toEqual({
|
|
29
|
+
provider: 'anthropic',
|
|
30
|
+
model: 'claude-sonnet-4-6',
|
|
31
|
+
capabilities: {
|
|
32
|
+
toolCalls: true,
|
|
33
|
+
systemMessages: true,
|
|
34
|
+
reasoningSummaries: false,
|
|
35
|
+
parallelToolCalls: false,
|
|
36
|
+
},
|
|
37
|
+
});
|
|
38
|
+
});
|
|
39
|
+
it('exports a direct Anthropic adapter constructor', () => {
|
|
40
|
+
const adapter = createAnthropicAdapter({ model: 'claude-sonnet-4-6', apiKey: 'test-key' });
|
|
41
|
+
expect(adapter.info?.provider).toBe('anthropic');
|
|
42
|
+
expect(adapter.info?.model).toBe('claude-sonnet-4-6');
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
//# sourceMappingURL=llm-factory.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"llm-factory.test.js","sourceRoot":"","sources":["../../../src/__tests__/llm-factory.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAEjG,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;IACnC,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,MAAM,CAAC,sBAAsB,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC/D,MAAM,CAAC,sBAAsB,CAAC,mBAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACtE,MAAM,CAAC,sBAAsB,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAClE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;QAC3D,MAAM,CAAC,kBAAkB,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,mBAAmB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAChG,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oEAAoE,EAAE,GAAG,EAAE;QAC5E,MAAM,OAAO,GAAG,gBAAgB,CAAC,EAAE,KAAK,EAAE,eAAe,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC;QAEjF,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC;YAC3B,QAAQ,EAAE,QAAQ;YAClB,KAAK,EAAE,eAAe;YACtB,YAAY,EAAE;gBACZ,SAAS,EAAE,IAAI;gBACf,cAAc,EAAE,IAAI;gBACpB,kBAAkB,EAAE,IAAI;gBACxB,iBAAiB,EAAE,IAAI;aACxB;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uEAAuE,EAAE,GAAG,EAAE;QAC/E,MAAM,OAAO,GAAG,gBAAgB,CAAC,EAAE,KAAK,EAAE,mBAAmB,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC;QAErF,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC;YAC3B,QAAQ,EAAE,WAAW;YACrB,KAAK,EAAE,mBAAmB;YAC1B,YAAY,EAAE;gBACZ,SAAS,EAAE,IAAI;gBACf,cAAc,EAAE,IAAI;gBACpB,kBAAkB,EAAE,KAAK;gBACzB,iBAAiB,EAAE,KAAK;aACzB;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE,GAAG,EAAE;QACxD,MAAM,OAAO,GAAG,sBAAsB,CAAC,EAAE,KAAK,EAAE,mBAAmB,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC;QAC3F,MAAM,CAAC,OAAO,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACjD,MAAM,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"local-commands.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/local-commands.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from 'vitest';
|
|
2
|
+
import { runLocalCommand } from '../cli/chat/state/local-commands.js';
|
|
3
|
+
describe('runLocalCommand', () => {
|
|
4
|
+
it('lists grouped common built-in model choices with multi-line formatting', () => {
|
|
5
|
+
const result = runLocalCommand({
|
|
6
|
+
prompt: '/model list',
|
|
7
|
+
activeModel: 'gpt-5.1-codex',
|
|
8
|
+
setActiveModel: vi.fn(),
|
|
9
|
+
sessions: [],
|
|
10
|
+
recentSessions: [],
|
|
11
|
+
activeSessionId: 'session-1',
|
|
12
|
+
switchSession: vi.fn(),
|
|
13
|
+
createSession: vi.fn(),
|
|
14
|
+
renameSession: vi.fn(),
|
|
15
|
+
removeSession: vi.fn(),
|
|
16
|
+
clearConversation: vi.fn(),
|
|
17
|
+
listRecentSessionsMessage: [],
|
|
18
|
+
});
|
|
19
|
+
expect(result).toMatchObject({
|
|
20
|
+
handled: true,
|
|
21
|
+
kind: 'message',
|
|
22
|
+
});
|
|
23
|
+
if (!result.handled || result.kind !== 'message') {
|
|
24
|
+
throw new Error('expected /model list to return a message result');
|
|
25
|
+
}
|
|
26
|
+
expect(result.message).toContain('Common built-in model choices');
|
|
27
|
+
expect(result.message).toContain('OpenAI · GPT-5.4\n - gpt-5.4\n - gpt-5.4-pro\n - gpt-5.4-mini\n - gpt-5.4-nano');
|
|
28
|
+
expect(result.message).toContain('OpenAI · GPT-4.1\n - gpt-4.1\n - gpt-4.1-mini\n - gpt-4.1-nano');
|
|
29
|
+
expect(result.message).toContain('Anthropic · Claude 4\n - claude-opus-4-6\n - claude-sonnet-4-6\n - claude-haiku-4-5');
|
|
30
|
+
expect(result.message).toContain('Anthropic · Earlier Claude 4\n - claude-opus-4-1\n - claude-opus-4-0\n - claude-sonnet-4-0');
|
|
31
|
+
expect(result.message).toContain('Anthropic · Claude 3.5\n - claude-3-5-sonnet-latest\n - claude-3-5-haiku-latest');
|
|
32
|
+
});
|
|
33
|
+
it('keeps /models as a compatibility alias for /model list', () => {
|
|
34
|
+
const result = runLocalCommand({
|
|
35
|
+
prompt: '/models',
|
|
36
|
+
activeModel: 'gpt-5.1-codex',
|
|
37
|
+
setActiveModel: vi.fn(),
|
|
38
|
+
sessions: [],
|
|
39
|
+
recentSessions: [],
|
|
40
|
+
activeSessionId: 'session-1',
|
|
41
|
+
switchSession: vi.fn(),
|
|
42
|
+
createSession: vi.fn(),
|
|
43
|
+
renameSession: vi.fn(),
|
|
44
|
+
removeSession: vi.fn(),
|
|
45
|
+
clearConversation: vi.fn(),
|
|
46
|
+
listRecentSessionsMessage: [],
|
|
47
|
+
});
|
|
48
|
+
expect(result).toMatchObject({
|
|
49
|
+
handled: true,
|
|
50
|
+
kind: 'message',
|
|
51
|
+
});
|
|
52
|
+
if (!result.handled || result.kind !== 'message') {
|
|
53
|
+
throw new Error('expected /models to return a message result');
|
|
54
|
+
}
|
|
55
|
+
expect(result.message).toContain('Common built-in model choices');
|
|
56
|
+
expect(result.message).toContain('OpenAI · GPT-5.4\n - gpt-5.4');
|
|
57
|
+
expect(result.message).toContain('Anthropic · Claude 4\n - claude-opus-4-6');
|
|
58
|
+
});
|
|
59
|
+
it('recognizes supported shortlist models when switching', () => {
|
|
60
|
+
const setActiveModel = vi.fn();
|
|
61
|
+
const result = runLocalCommand({
|
|
62
|
+
prompt: '/model gpt-5.4-mini',
|
|
63
|
+
activeModel: 'gpt-5.1-codex',
|
|
64
|
+
setActiveModel,
|
|
65
|
+
sessions: [],
|
|
66
|
+
recentSessions: [],
|
|
67
|
+
activeSessionId: 'session-1',
|
|
68
|
+
switchSession: vi.fn(),
|
|
69
|
+
createSession: vi.fn(),
|
|
70
|
+
renameSession: vi.fn(),
|
|
71
|
+
removeSession: vi.fn(),
|
|
72
|
+
clearConversation: vi.fn(),
|
|
73
|
+
listRecentSessionsMessage: [],
|
|
74
|
+
});
|
|
75
|
+
expect(setActiveModel).toHaveBeenCalledWith('gpt-5.4-mini');
|
|
76
|
+
expect(result).toEqual({
|
|
77
|
+
handled: true,
|
|
78
|
+
kind: 'message',
|
|
79
|
+
message: 'Switched model to gpt-5.4-mini',
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
it('does not treat /model set as a literal model name', () => {
|
|
83
|
+
const setActiveModel = vi.fn();
|
|
84
|
+
const result = runLocalCommand({
|
|
85
|
+
prompt: '/model set',
|
|
86
|
+
activeModel: 'gpt-5.1-codex',
|
|
87
|
+
setActiveModel,
|
|
88
|
+
sessions: [],
|
|
89
|
+
recentSessions: [],
|
|
90
|
+
activeSessionId: 'session-1',
|
|
91
|
+
switchSession: vi.fn(),
|
|
92
|
+
createSession: vi.fn(),
|
|
93
|
+
renameSession: vi.fn(),
|
|
94
|
+
removeSession: vi.fn(),
|
|
95
|
+
clearConversation: vi.fn(),
|
|
96
|
+
listRecentSessionsMessage: [],
|
|
97
|
+
});
|
|
98
|
+
expect(setActiveModel).not.toHaveBeenCalled();
|
|
99
|
+
expect(result).toEqual({
|
|
100
|
+
handled: true,
|
|
101
|
+
kind: 'message',
|
|
102
|
+
message: 'Use /model set <query> to filter models, then use arrows and Enter to choose one.',
|
|
103
|
+
});
|
|
104
|
+
});
|
|
105
|
+
it('allows switching sessions by recent-session index', () => {
|
|
106
|
+
const switchSession = vi.fn();
|
|
107
|
+
const result = runLocalCommand({
|
|
108
|
+
prompt: '/session switch 2',
|
|
109
|
+
activeModel: 'gpt-5.1-codex',
|
|
110
|
+
setActiveModel: vi.fn(),
|
|
111
|
+
sessions: [
|
|
112
|
+
{ id: 'session-a', name: 'A', history: [], messages: [], turns: [], createdAt: '2024-01-01', updatedAt: '2024-01-01' },
|
|
113
|
+
{ id: 'session-b', name: 'B', history: [], messages: [], turns: [], createdAt: '2024-01-02', updatedAt: '2024-01-02' },
|
|
114
|
+
],
|
|
115
|
+
recentSessions: [
|
|
116
|
+
{ id: 'session-a', name: 'A', history: [], messages: [], turns: [], createdAt: '2024-01-01', updatedAt: '2024-01-01' },
|
|
117
|
+
{ id: 'session-b', name: 'B', history: [], messages: [], turns: [], createdAt: '2024-01-02', updatedAt: '2024-01-02' },
|
|
118
|
+
],
|
|
119
|
+
activeSessionId: 'session-a',
|
|
120
|
+
switchSession,
|
|
121
|
+
createSession: vi.fn(),
|
|
122
|
+
renameSession: vi.fn(),
|
|
123
|
+
removeSession: vi.fn(),
|
|
124
|
+
clearConversation: vi.fn(),
|
|
125
|
+
listRecentSessionsMessage: [],
|
|
126
|
+
});
|
|
127
|
+
expect(switchSession).toHaveBeenCalledWith('session-b');
|
|
128
|
+
expect(result).toEqual({
|
|
129
|
+
handled: true,
|
|
130
|
+
kind: 'message',
|
|
131
|
+
message: 'Switched to session-b (B).\n0 turns • no turns yet',
|
|
132
|
+
});
|
|
133
|
+
});
|
|
134
|
+
it('allows continuing sessions by recent-session index', () => {
|
|
135
|
+
const result = runLocalCommand({
|
|
136
|
+
prompt: '/session continue 2',
|
|
137
|
+
activeModel: 'gpt-5.1-codex',
|
|
138
|
+
setActiveModel: vi.fn(),
|
|
139
|
+
sessions: [
|
|
140
|
+
{ id: 'session-a', name: 'A', history: [], messages: [], turns: [], createdAt: '2024-01-01', updatedAt: '2024-01-01' },
|
|
141
|
+
{ id: 'session-b', name: 'B', history: [], messages: [], turns: [], createdAt: '2024-01-02', updatedAt: '2024-01-02' },
|
|
142
|
+
],
|
|
143
|
+
recentSessions: [
|
|
144
|
+
{ id: 'session-a', name: 'A', history: [], messages: [], turns: [], createdAt: '2024-01-01', updatedAt: '2024-01-01' },
|
|
145
|
+
{ id: 'session-b', name: 'B', history: [], messages: [], turns: [], createdAt: '2024-01-02', updatedAt: '2024-01-02' },
|
|
146
|
+
],
|
|
147
|
+
activeSessionId: 'session-a',
|
|
148
|
+
switchSession: vi.fn(),
|
|
149
|
+
createSession: vi.fn(),
|
|
150
|
+
renameSession: vi.fn(),
|
|
151
|
+
removeSession: vi.fn(),
|
|
152
|
+
clearConversation: vi.fn(),
|
|
153
|
+
listRecentSessionsMessage: [],
|
|
154
|
+
});
|
|
155
|
+
expect(result).toEqual({
|
|
156
|
+
handled: true,
|
|
157
|
+
kind: 'continue',
|
|
158
|
+
sessionId: 'session-b',
|
|
159
|
+
message: 'Switched to session-b (B).\nContinuing from that session transcript.',
|
|
160
|
+
});
|
|
161
|
+
});
|
|
162
|
+
});
|
|
163
|
+
//# sourceMappingURL=local-commands.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"local-commands.test.js","sourceRoot":"","sources":["../../../src/__tests__/local-commands.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project-approval-rules.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/project-approval-rules.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
import { mkdtempSync, writeFileSync } from 'node:fs';
|
|
2
|
+
import { join } from 'node:path';
|
|
3
|
+
import { tmpdir } from 'node:os';
|
|
4
|
+
import { describe, expect, it } from 'vitest';
|
|
5
|
+
import { createProjectApprovalRule, createProjectApprovalRuleForCall, describeProjectApprovalRule, extractApprovalTarget, findMatchingApprovalRule, loadProjectApprovalRules, normalizeApprovedCommand, saveProjectApprovalRules, } from '../cli/chat/state/approval-rules.js';
|
|
6
|
+
describe('project approval rules', () => {
|
|
7
|
+
it('normalizes repeated whitespace in saved commands', () => {
|
|
8
|
+
expect(normalizeApprovedCommand(' yarn test --watch ')).toBe('yarn test --watch');
|
|
9
|
+
});
|
|
10
|
+
it('saves and reloads project approval rules', () => {
|
|
11
|
+
const root = mkdtempSync(join(tmpdir(), 'heddle-approval-rules-'));
|
|
12
|
+
const filePath = join(root, 'command-approvals.json');
|
|
13
|
+
const rule = createProjectApprovalRule('yarn test');
|
|
14
|
+
saveProjectApprovalRules(filePath, [rule]);
|
|
15
|
+
expect(loadProjectApprovalRules(filePath)).toEqual([rule]);
|
|
16
|
+
});
|
|
17
|
+
it('matches exact normalized mutate commands only', () => {
|
|
18
|
+
const rules = [createProjectApprovalRule('gh pr view 123')];
|
|
19
|
+
expect(findMatchingApprovalRule(rules, 'run_shell_mutate', { command: 'gh pr view 123' })).toBeDefined();
|
|
20
|
+
expect(findMatchingApprovalRule(rules, 'run_shell_mutate', { command: 'gh pr view 124' })).toBeUndefined();
|
|
21
|
+
expect(findMatchingApprovalRule(rules, 'run_shell_inspect', { command: 'yarn test' })).toBeUndefined();
|
|
22
|
+
});
|
|
23
|
+
it('broadens low-risk workspace verification approvals to a command-family prefix', () => {
|
|
24
|
+
const rule = createProjectApprovalRule('yarn test src/__tests__/tools.test.ts');
|
|
25
|
+
expect(rule.mode).toBe('prefix');
|
|
26
|
+
expect(rule.command).toBe('yarn test');
|
|
27
|
+
expect(rule.scope).toBe('workspace');
|
|
28
|
+
expect(rule.capability).toBe('verification');
|
|
29
|
+
expect(findMatchingApprovalRule([rule], 'run_shell_mutate', { command: 'yarn test' })).toBeDefined();
|
|
30
|
+
expect(findMatchingApprovalRule([rule], 'run_shell_mutate', { command: 'yarn test src/__tests__/run-agent.test.ts' })).toBeDefined();
|
|
31
|
+
expect(findMatchingApprovalRule([rule], 'run_shell_mutate', { command: 'yarn build' })).toBeUndefined();
|
|
32
|
+
});
|
|
33
|
+
it('creates a project-wide edit_file approval rule from a tool call', () => {
|
|
34
|
+
const rule = createProjectApprovalRuleForCall({
|
|
35
|
+
id: 'tool-1',
|
|
36
|
+
tool: 'edit_file',
|
|
37
|
+
input: { path: 'src/example.ts', oldText: 'a', newText: 'b' },
|
|
38
|
+
});
|
|
39
|
+
expect(rule).toMatchObject({
|
|
40
|
+
tool: 'edit_file',
|
|
41
|
+
mode: 'tool',
|
|
42
|
+
command: '*',
|
|
43
|
+
scope: 'workspace',
|
|
44
|
+
capability: 'file_edit',
|
|
45
|
+
});
|
|
46
|
+
expect(findMatchingApprovalRule([rule], 'edit_file', { path: 'src/another.ts', content: 'x', createIfMissing: true })).toBeDefined();
|
|
47
|
+
});
|
|
48
|
+
it('loads legacy mutate approval rules from disk without dropping them', () => {
|
|
49
|
+
const root = mkdtempSync(join(tmpdir(), 'heddle-approval-rules-legacy-'));
|
|
50
|
+
const filePath = join(root, 'command-approvals.json');
|
|
51
|
+
saveProjectApprovalRules(filePath, [
|
|
52
|
+
{
|
|
53
|
+
tool: 'run_shell_mutate',
|
|
54
|
+
mode: 'exact',
|
|
55
|
+
command: 'ffmpeg -i input.mp4 output.gif',
|
|
56
|
+
scope: 'workspace',
|
|
57
|
+
capability: 'unknown_workspace',
|
|
58
|
+
createdAt: new Date().toISOString(),
|
|
59
|
+
},
|
|
60
|
+
]);
|
|
61
|
+
const legacyFilePath = join(root, 'legacy-command-approvals.json');
|
|
62
|
+
const legacyRules = [
|
|
63
|
+
{
|
|
64
|
+
tool: 'run_shell_mutate',
|
|
65
|
+
command: 'yarn test',
|
|
66
|
+
createdAt: new Date().toISOString(),
|
|
67
|
+
},
|
|
68
|
+
];
|
|
69
|
+
writeFileSync(legacyFilePath, `${JSON.stringify(legacyRules, null, 2)}\n`);
|
|
70
|
+
const loaded = loadProjectApprovalRules(legacyFilePath);
|
|
71
|
+
expect(loaded[0]).toMatchObject({
|
|
72
|
+
tool: 'run_shell_mutate',
|
|
73
|
+
mode: 'prefix',
|
|
74
|
+
command: 'yarn test',
|
|
75
|
+
});
|
|
76
|
+
});
|
|
77
|
+
it('describes approval rules based on tool and mode', () => {
|
|
78
|
+
const editRule = {
|
|
79
|
+
tool: 'edit_file',
|
|
80
|
+
mode: 'tool',
|
|
81
|
+
command: '*',
|
|
82
|
+
scope: 'workspace',
|
|
83
|
+
capability: 'file_edit',
|
|
84
|
+
createdAt: new Date().toISOString(),
|
|
85
|
+
};
|
|
86
|
+
const prefixRule = {
|
|
87
|
+
tool: 'run_shell_mutate',
|
|
88
|
+
mode: 'prefix',
|
|
89
|
+
command: 'yarn lint',
|
|
90
|
+
scope: 'workspace',
|
|
91
|
+
capability: 'verification',
|
|
92
|
+
createdAt: new Date().toISOString(),
|
|
93
|
+
};
|
|
94
|
+
const exactRule = {
|
|
95
|
+
tool: 'run_shell_mutate',
|
|
96
|
+
mode: 'exact',
|
|
97
|
+
command: 'gh pr view 123',
|
|
98
|
+
scope: 'workspace',
|
|
99
|
+
capability: 'unknown_workspace',
|
|
100
|
+
createdAt: new Date().toISOString(),
|
|
101
|
+
};
|
|
102
|
+
expect(describeProjectApprovalRule(editRule)).toContain('allow edit_file');
|
|
103
|
+
expect(describeProjectApprovalRule(prefixRule)).toContain('command family');
|
|
104
|
+
expect(describeProjectApprovalRule(exactRule)).toContain('exact command');
|
|
105
|
+
});
|
|
106
|
+
it('normalizes run shell and edit file approvals', () => {
|
|
107
|
+
expect(extractApprovalTarget('run_shell_mutate', ' yarn test ')).toBe('yarn test');
|
|
108
|
+
expect(extractApprovalTarget('run_shell_mutate', { command: ' yarn test src/ ' })).toBe('yarn test src/');
|
|
109
|
+
expect(extractApprovalTarget('run_shell_mutate', { command: '' })).toBeUndefined();
|
|
110
|
+
expect(extractApprovalTarget('run_shell_mutate', 42)).toBeUndefined();
|
|
111
|
+
expect(extractApprovalTarget('edit_file', '.')).toBe('.');
|
|
112
|
+
expect(extractApprovalTarget('edit_file', './')).toBe('.');
|
|
113
|
+
expect(extractApprovalTarget('edit_file', './src/')).toBe('./src');
|
|
114
|
+
expect(extractApprovalTarget('edit_file', { path: './foo/bar/' })).toBe('./foo/bar');
|
|
115
|
+
expect(extractApprovalTarget('edit_file', { path: '' })).toBeUndefined();
|
|
116
|
+
});
|
|
117
|
+
it('falls back to unknown workspace rules when the shell command is blocked', () => {
|
|
118
|
+
const rule = createProjectApprovalRule('yarn test; echo hi');
|
|
119
|
+
expect(rule.mode).toBe('exact');
|
|
120
|
+
expect(rule.scope).toBe('workspace');
|
|
121
|
+
expect(rule.capability).toBe('unknown_workspace');
|
|
122
|
+
expect(rule.command).toBe('yarn test; echo hi');
|
|
123
|
+
});
|
|
124
|
+
it('deduplicates duplicate rules when loading from disk', () => {
|
|
125
|
+
const root = mkdtempSync(join(tmpdir(), 'heddle-approval-rules-dedupe-'));
|
|
126
|
+
const filePath = join(root, 'command-approvals.json');
|
|
127
|
+
const rule = createProjectApprovalRule('yarn lint');
|
|
128
|
+
const duplicate = { ...rule, createdAt: new Date().toISOString() };
|
|
129
|
+
writeFileSync(filePath, `${JSON.stringify([rule, duplicate], null, 2)}\n`);
|
|
130
|
+
const loaded = loadProjectApprovalRules(filePath);
|
|
131
|
+
expect(loaded).toHaveLength(1);
|
|
132
|
+
expect(loaded[0].command).toBe(rule.command);
|
|
133
|
+
});
|
|
134
|
+
});
|
|
135
|
+
//# sourceMappingURL=project-approval-rules.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project-approval-rules.test.js","sourceRoot":"","sources":["../../../src/__tests__/project-approval-rules.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prompts.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/prompts.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { buildSystemPrompt } from '../prompts/system-prompt.js';
|
|
3
|
+
describe('buildSystemPrompt', () => {
|
|
4
|
+
it('frames Heddle as a coding and workspace agent rather than a generic chatbot', () => {
|
|
5
|
+
const prompt = buildSystemPrompt('Explain this project.', ['list_files', 'read_file', 'run_shell_inspect']);
|
|
6
|
+
expect(prompt).toContain('You are Heddle, a conversational coding and workspace agent.');
|
|
7
|
+
expect(prompt).toContain('You are not a generic chatbot.');
|
|
8
|
+
expect(prompt).toContain('## Default Workflow');
|
|
9
|
+
expect(prompt).toContain('1. Clarify the real task.');
|
|
10
|
+
expect(prompt).toContain('2. Gather the minimum relevant evidence first.');
|
|
11
|
+
expect(prompt).toContain('3. Form a grounded conclusion or proposal.');
|
|
12
|
+
expect(prompt).toContain('4. Carry the task through when action is needed.');
|
|
13
|
+
expect(prompt).toContain('5. Finish with a useful operator answer.');
|
|
14
|
+
expect(prompt).toContain('If the user asks what Heddle itself is');
|
|
15
|
+
expect(prompt).toContain('If the user asks how to use Heddle');
|
|
16
|
+
expect(prompt).toContain('direct shell commands');
|
|
17
|
+
expect(prompt).toContain('distinguish observed facts from inference');
|
|
18
|
+
expect(prompt).toContain('You MUST call report_state before continuing');
|
|
19
|
+
expect(prompt).toContain('Do not lead with internal tool names or implementation details');
|
|
20
|
+
expect(prompt).toContain('prefer plain-language descriptions over enumerating internal tool names');
|
|
21
|
+
expect(prompt).toContain('prefer carrying the task through implementation and verification instead of stopping at analysis or a plan unless you are blocked');
|
|
22
|
+
expect(prompt).toContain('If the user asks to improve tests or coverage');
|
|
23
|
+
expect(prompt).toContain('Prefer the first-class file editing tool for creating or changing file contents');
|
|
24
|
+
expect(prompt).toContain('If a shell command is arbitrary, uses inline scripts, needs redirects/heredocs, or inspect rejects it, switch to run_shell_mutate');
|
|
25
|
+
expect(prompt).toContain('do not stop at "inspect is blocked."');
|
|
26
|
+
expect(prompt).toContain('Do not ask unnecessary questions when the answer can be discovered from the workspace');
|
|
27
|
+
expect(prompt).toContain('Do not jump from one narrow local detail to a project-level recommendation');
|
|
28
|
+
expect(prompt).toContain('If the user asks for the next step, propose a concrete high-leverage next step based on the project goal and current state');
|
|
29
|
+
expect(prompt).toContain('If you identify a reasonable bounded change that directly serves the user goal, make it and verify it instead of only describing it.');
|
|
30
|
+
expect(prompt).toContain('Once you choose a concrete next step, execute that step instead of repeatedly restating the plan');
|
|
31
|
+
expect(prompt).toContain('Do not spend multiple turns narrating the same intent without either gathering new evidence or making progress on the implementation.');
|
|
32
|
+
expect(prompt).toContain('record a short plan with update_plan');
|
|
33
|
+
expect(prompt).toContain('If you recorded a plan, do not stop after only one small slice');
|
|
34
|
+
expect(prompt).toContain('Use update_plan for substantial tasks');
|
|
35
|
+
});
|
|
36
|
+
it('includes project-specific context when provided', () => {
|
|
37
|
+
const prompt = buildSystemPrompt('Help in this repo.', ['list_files'], 'Source: AGENTS.md\nUse yarn and keep answers concise.');
|
|
38
|
+
expect(prompt).toContain('## Project Context');
|
|
39
|
+
expect(prompt).toContain('Source: AGENTS.md');
|
|
40
|
+
expect(prompt).toContain('Use yarn and keep answers concise.');
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
//# sourceMappingURL=prompts.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prompts.test.js","sourceRoot":"","sources":["../../../src/__tests__/prompts.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run-agent.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/run-agent.test.ts"],"names":[],"mappings":""}
|