@stigmer/react 2.0.1 → 3.0.1
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 +64 -2
- package/agent/AgentDetailView.d.ts +26 -1
- package/agent/AgentDetailView.d.ts.map +1 -1
- package/agent/AgentDetailView.js +9 -2
- package/agent/AgentDetailView.js.map +1 -1
- package/agent/useAgentSetup.d.ts +19 -0
- package/agent/useAgentSetup.d.ts.map +1 -1
- package/agent/useAgentSetup.js +15 -1
- package/agent/useAgentSetup.js.map +1 -1
- package/agent-instance/AgentInstanceDetailPanel.d.ts +26 -0
- package/agent-instance/AgentInstanceDetailPanel.d.ts.map +1 -0
- package/agent-instance/AgentInstanceDetailPanel.js +94 -0
- package/agent-instance/AgentInstanceDetailPanel.js.map +1 -0
- package/agent-instance/AgentInstanceEmptyState.d.ts +17 -0
- package/agent-instance/AgentInstanceEmptyState.d.ts.map +1 -0
- package/agent-instance/AgentInstanceEmptyState.js +21 -0
- package/agent-instance/AgentInstanceEmptyState.js.map +1 -0
- package/agent-instance/AgentInstanceList.d.ts +38 -0
- package/agent-instance/AgentInstanceList.d.ts.map +1 -0
- package/agent-instance/AgentInstanceList.js +75 -0
- package/agent-instance/AgentInstanceList.js.map +1 -0
- package/agent-instance/CreateAgentInstanceDialog.d.ts +24 -0
- package/agent-instance/CreateAgentInstanceDialog.d.ts.map +1 -0
- package/agent-instance/CreateAgentInstanceDialog.js +78 -0
- package/agent-instance/CreateAgentInstanceDialog.js.map +1 -0
- package/agent-instance/index.d.ts +14 -0
- package/agent-instance/index.d.ts.map +1 -1
- package/agent-instance/index.js +7 -0
- package/agent-instance/index.js.map +1 -1
- package/agent-instance/useAgentInstances.d.ts +34 -0
- package/agent-instance/useAgentInstances.d.ts.map +1 -0
- package/agent-instance/useAgentInstances.js +37 -0
- package/agent-instance/useAgentInstances.js.map +1 -0
- package/agent-instance/useDeleteAgentInstance.d.ts +42 -0
- package/agent-instance/useDeleteAgentInstance.d.ts.map +1 -0
- package/agent-instance/useDeleteAgentInstance.js +48 -0
- package/agent-instance/useDeleteAgentInstance.js.map +1 -0
- package/agent-instance/useUpdateAgentInstance.d.ts +36 -0
- package/agent-instance/useUpdateAgentInstance.d.ts.map +1 -0
- package/agent-instance/useUpdateAgentInstance.js +47 -0
- package/agent-instance/useUpdateAgentInstance.js.map +1 -0
- package/composer/SessionComposer.d.ts +18 -0
- package/composer/SessionComposer.d.ts.map +1 -1
- package/composer/SessionComposer.js +27 -3
- package/composer/SessionComposer.js.map +1 -1
- package/execution/ApprovalCard.d.ts.map +1 -1
- package/execution/ApprovalCard.js +6 -3
- package/execution/ApprovalCard.js.map +1 -1
- package/execution/MessageThread.d.ts +3 -0
- package/execution/MessageThread.d.ts.map +1 -1
- package/execution/MessageThread.js +12 -2
- package/execution/MessageThread.js.map +1 -1
- package/execution/PlanArtifactCard.d.ts +29 -0
- package/execution/PlanArtifactCard.d.ts.map +1 -0
- package/execution/PlanArtifactCard.js +59 -0
- package/execution/PlanArtifactCard.js.map +1 -0
- package/execution/ResultView.d.ts +24 -0
- package/execution/ResultView.d.ts.map +1 -0
- package/execution/ResultView.js +152 -0
- package/execution/ResultView.js.map +1 -0
- package/execution/SubAgentSection.js +1 -1
- package/execution/SubAgentSection.js.map +1 -1
- package/execution/ToolCallDetail.d.ts +13 -19
- package/execution/ToolCallDetail.d.ts.map +1 -1
- package/execution/ToolCallDetail.js +42 -70
- package/execution/ToolCallDetail.js.map +1 -1
- package/execution/ToolCallGroup.js +2 -2
- package/execution/ToolCallGroup.js.map +1 -1
- package/execution/ToolCallItem.d.ts.map +1 -1
- package/execution/ToolCallItem.js +13 -9
- package/execution/ToolCallItem.js.map +1 -1
- package/execution/index.d.ts +7 -1
- package/execution/index.d.ts.map +1 -1
- package/execution/index.js +4 -1
- package/execution/index.js.map +1 -1
- package/execution/tool-categories.d.ts +30 -21
- package/execution/tool-categories.d.ts.map +1 -1
- package/execution/tool-categories.js +57 -49
- package/execution/tool-categories.js.map +1 -1
- package/execution/tool-presenter.d.ts +60 -0
- package/execution/tool-presenter.d.ts.map +1 -0
- package/execution/tool-presenter.js +81 -0
- package/execution/tool-presenter.js.map +1 -0
- package/execution/useCreateAgentExecution.d.ts +9 -0
- package/execution/useCreateAgentExecution.d.ts.map +1 -1
- package/execution/useCreateAgentExecution.js +1 -0
- package/execution/useCreateAgentExecution.js.map +1 -1
- package/index.d.ts +6 -5
- package/index.d.ts.map +1 -1
- package/index.js +7 -4
- package/index.js.map +1 -1
- package/library/detect-plan-artifact.d.ts +26 -0
- package/library/detect-plan-artifact.d.ts.map +1 -0
- package/library/detect-plan-artifact.js +37 -0
- package/library/detect-plan-artifact.js.map +1 -0
- package/library/index.d.ts +1 -0
- package/library/index.d.ts.map +1 -1
- package/library/index.js +1 -0
- package/library/index.js.map +1 -1
- package/package.json +4 -4
- package/provider.d.ts +5 -3
- package/provider.d.ts.map +1 -1
- package/provider.js.map +1 -1
- package/runner-adapter.d.ts +19 -4
- package/runner-adapter.d.ts.map +1 -1
- package/runner-adapter.js.map +1 -1
- package/session/NewSessionViewer.d.ts +10 -1
- package/session/NewSessionViewer.d.ts.map +1 -1
- package/session/NewSessionViewer.js +2 -2
- package/session/NewSessionViewer.js.map +1 -1
- package/session/SessionViewer.d.ts.map +1 -1
- package/session/SessionViewer.js +17 -2
- package/session/SessionViewer.js.map +1 -1
- package/session/useCreateSession.d.ts.map +1 -1
- package/session/useCreateSession.js +4 -6
- package/session/useCreateSession.js.map +1 -1
- package/session/useLocalSessionWorker.d.ts +33 -0
- package/session/useLocalSessionWorker.d.ts.map +1 -0
- package/session/useLocalSessionWorker.js +65 -0
- package/session/useLocalSessionWorker.js.map +1 -0
- package/session/useNewSessionFlow.d.ts.map +1 -1
- package/session/useNewSessionFlow.js +22 -1
- package/session/useNewSessionFlow.js.map +1 -1
- package/session/useSessionConversation.d.ts +12 -0
- package/session/useSessionConversation.d.ts.map +1 -1
- package/session/useSessionConversation.js +11 -0
- package/session/useSessionConversation.js.map +1 -1
- package/session/useSessionPageFlow.d.ts +23 -0
- package/session/useSessionPageFlow.d.ts.map +1 -1
- package/session/useSessionPageFlow.js +21 -1
- package/session/useSessionPageFlow.js.map +1 -1
- package/src/__tests__/runner-adapter.test.tsx +14 -107
- package/src/agent/AgentDetailView.tsx +49 -1
- package/src/agent/__tests__/useAgentSetup.resolveToInstance.test.tsx +73 -0
- package/src/agent/useAgentSetup.ts +48 -1
- package/src/agent-instance/AgentInstanceDetailPanel.tsx +359 -0
- package/src/agent-instance/AgentInstanceEmptyState.tsx +87 -0
- package/src/agent-instance/AgentInstanceList.tsx +329 -0
- package/src/agent-instance/CreateAgentInstanceDialog.tsx +258 -0
- package/src/agent-instance/__tests__/agent-instance-hooks.test.tsx +213 -0
- package/src/agent-instance/index.ts +15 -0
- package/src/agent-instance/useAgentInstances.ts +66 -0
- package/src/agent-instance/useDeleteAgentInstance.ts +73 -0
- package/src/agent-instance/useUpdateAgentInstance.ts +67 -0
- package/src/composer/SessionComposer.tsx +54 -2
- package/src/execution/ApprovalCard.tsx +22 -3
- package/src/execution/MessageThread.tsx +27 -3
- package/src/execution/PlanArtifactCard.tsx +257 -0
- package/src/execution/ResultView.tsx +366 -0
- package/src/execution/SubAgentSection.tsx +5 -0
- package/src/execution/ToolCallDetail.tsx +72 -173
- package/src/execution/ToolCallGroup.tsx +2 -2
- package/src/execution/ToolCallItem.tsx +25 -12
- package/src/execution/__tests__/ApprovalCard.test.tsx +99 -0
- package/src/execution/__tests__/ResultView.test.tsx +95 -0
- package/src/execution/__tests__/subagent-thread-item.test.ts +153 -0
- package/src/execution/__tests__/tool-presenter.test.tsx +78 -0
- package/src/execution/index.ts +16 -0
- package/src/execution/tool-categories.ts +80 -66
- package/src/execution/tool-presenter.ts +118 -0
- package/src/execution/useCreateAgentExecution.ts +10 -0
- package/src/index.ts +32 -1
- package/src/library/__tests__/detect-plan-artifact.test.ts +75 -0
- package/src/library/detect-plan-artifact.ts +43 -0
- package/src/library/index.ts +6 -0
- package/src/provider.tsx +5 -3
- package/src/runner-adapter.ts +19 -4
- package/src/session/NewSessionViewer.tsx +11 -0
- package/src/session/SessionViewer.tsx +46 -2
- package/src/session/__tests__/group-sessions.test.ts +3 -5
- package/src/session/__tests__/useLocalSessionWorker.test.tsx +194 -0
- package/src/session/__tests__/useNewSessionFlow.test.tsx +80 -4
- package/src/session/__tests__/useSessionConversation.test.tsx +89 -0
- package/src/session/__tests__/useSessionPageFlow.autoApprove.test.tsx +149 -0
- package/src/session/useCreateSession.ts +4 -7
- package/src/session/useLocalSessionWorker.ts +73 -0
- package/src/session/useNewSessionFlow.ts +23 -1
- package/src/session/useSessionConversation.ts +18 -0
- package/src/session/useSessionPageFlow.ts +51 -1
- package/src/workflow/__tests__/useWorkflowExecution.test.tsx +2 -2
- package/styles.css +1 -1
- package/__tests__/hooks.test.d.ts +0 -2
- package/__tests__/hooks.test.d.ts.map +0 -1
- package/__tests__/hooks.test.js +0 -35
- package/__tests__/hooks.test.js.map +0 -1
- package/__tests__/runner-adapter.test.d.ts +0 -2
- package/__tests__/runner-adapter.test.d.ts.map +0 -1
- package/__tests__/runner-adapter.test.js +0 -153
- package/__tests__/runner-adapter.test.js.map +0 -1
- package/activity/__tests__/useRecentActivity-optimistic.test.d.ts +0 -2
- package/activity/__tests__/useRecentActivity-optimistic.test.d.ts.map +0 -1
- package/activity/__tests__/useRecentActivity-optimistic.test.js +0 -139
- package/activity/__tests__/useRecentActivity-optimistic.test.js.map +0 -1
- package/activity/__tests__/useRecentActivity.test.d.ts +0 -2
- package/activity/__tests__/useRecentActivity.test.d.ts.map +0 -1
- package/activity/__tests__/useRecentActivity.test.js +0 -107
- package/activity/__tests__/useRecentActivity.test.js.map +0 -1
- package/agent/__tests__/useAgent.test.d.ts +0 -2
- package/agent/__tests__/useAgent.test.d.ts.map +0 -1
- package/agent/__tests__/useAgent.test.js +0 -86
- package/agent/__tests__/useAgent.test.js.map +0 -1
- package/agent/__tests__/useDefaultAgent.test.d.ts +0 -2
- package/agent/__tests__/useDefaultAgent.test.d.ts.map +0 -1
- package/agent/__tests__/useDefaultAgent.test.js +0 -135
- package/agent/__tests__/useDefaultAgent.test.js.map +0 -1
- package/billing/__tests__/CreditLedgerTable.test.d.ts +0 -2
- package/billing/__tests__/CreditLedgerTable.test.d.ts.map +0 -1
- package/billing/__tests__/CreditLedgerTable.test.js +0 -74
- package/billing/__tests__/CreditLedgerTable.test.js.map +0 -1
- package/composer/__tests__/ComposerToolbar-directAction.test.d.ts +0 -2
- package/composer/__tests__/ComposerToolbar-directAction.test.d.ts.map +0 -1
- package/composer/__tests__/ComposerToolbar-directAction.test.js +0 -64
- package/composer/__tests__/ComposerToolbar-directAction.test.js.map +0 -1
- package/composer/__tests__/SessionComposer-contract.test.d.ts +0 -2
- package/composer/__tests__/SessionComposer-contract.test.d.ts.map +0 -1
- package/composer/__tests__/SessionComposer-contract.test.js +0 -87
- package/composer/__tests__/SessionComposer-contract.test.js.map +0 -1
- package/composer/__tests__/SessionComposer-fileref.test.d.ts +0 -2
- package/composer/__tests__/SessionComposer-fileref.test.d.ts.map +0 -1
- package/composer/__tests__/SessionComposer-fileref.test.js +0 -132
- package/composer/__tests__/SessionComposer-fileref.test.js.map +0 -1
- package/composer/__tests__/SessionComposer-memo.test.d.ts +0 -2
- package/composer/__tests__/SessionComposer-memo.test.d.ts.map +0 -1
- package/composer/__tests__/SessionComposer-memo.test.js +0 -28
- package/composer/__tests__/SessionComposer-memo.test.js.map +0 -1
- package/composer/__tests__/useComposer.test.d.ts +0 -2
- package/composer/__tests__/useComposer.test.d.ts.map +0 -1
- package/composer/__tests__/useComposer.test.js +0 -139
- package/composer/__tests__/useComposer.test.js.map +0 -1
- package/environment/__tests__/systemEnvVars.test.d.ts +0 -2
- package/environment/__tests__/systemEnvVars.test.d.ts.map +0 -1
- package/environment/__tests__/systemEnvVars.test.js +0 -76
- package/environment/__tests__/systemEnvVars.test.js.map +0 -1
- package/execution/__tests__/MessageThread.test.d.ts +0 -2
- package/execution/__tests__/MessageThread.test.d.ts.map +0 -1
- package/execution/__tests__/MessageThread.test.js +0 -164
- package/execution/__tests__/MessageThread.test.js.map +0 -1
- package/execution/__tests__/PlanCompletionCard.test.d.ts +0 -2
- package/execution/__tests__/PlanCompletionCard.test.d.ts.map +0 -1
- package/execution/__tests__/PlanCompletionCard.test.js +0 -53
- package/execution/__tests__/PlanCompletionCard.test.js.map +0 -1
- package/execution/__tests__/buildThreadItems-plan-completion.test.d.ts +0 -2
- package/execution/__tests__/buildThreadItems-plan-completion.test.d.ts.map +0 -1
- package/execution/__tests__/buildThreadItems-plan-completion.test.js +0 -137
- package/execution/__tests__/buildThreadItems-plan-completion.test.js.map +0 -1
- package/execution/__tests__/execution-phases.test.d.ts +0 -2
- package/execution/__tests__/execution-phases.test.d.ts.map +0 -1
- package/execution/__tests__/execution-phases.test.js +0 -25
- package/execution/__tests__/execution-phases.test.js.map +0 -1
- package/execution/__tests__/file-path-resolver.test.d.ts +0 -2
- package/execution/__tests__/file-path-resolver.test.d.ts.map +0 -1
- package/execution/__tests__/file-path-resolver.test.js +0 -180
- package/execution/__tests__/file-path-resolver.test.js.map +0 -1
- package/execution/__tests__/message-entry.test.d.ts +0 -2
- package/execution/__tests__/message-entry.test.d.ts.map +0 -1
- package/execution/__tests__/message-entry.test.js +0 -178
- package/execution/__tests__/message-entry.test.js.map +0 -1
- package/execution/__tests__/thread-keys.test.d.ts +0 -2
- package/execution/__tests__/thread-keys.test.d.ts.map +0 -1
- package/execution/__tests__/thread-keys.test.js +0 -462
- package/execution/__tests__/thread-keys.test.js.map +0 -1
- package/execution/__tests__/thread-memoization.test.d.ts +0 -2
- package/execution/__tests__/thread-memoization.test.d.ts.map +0 -1
- package/execution/__tests__/thread-memoization.test.js +0 -262
- package/execution/__tests__/thread-memoization.test.js.map +0 -1
- package/execution/__tests__/thread-skeleton.test.d.ts +0 -2
- package/execution/__tests__/thread-skeleton.test.d.ts.map +0 -1
- package/execution/__tests__/thread-skeleton.test.js +0 -35
- package/execution/__tests__/thread-skeleton.test.js.map +0 -1
- package/execution/__tests__/useContextWindow.test.d.ts +0 -2
- package/execution/__tests__/useContextWindow.test.d.ts.map +0 -1
- package/execution/__tests__/useContextWindow.test.js +0 -121
- package/execution/__tests__/useContextWindow.test.js.map +0 -1
- package/execution/__tests__/useExecutionStream.test.d.ts +0 -2
- package/execution/__tests__/useExecutionStream.test.d.ts.map +0 -1
- package/execution/__tests__/useExecutionStream.test.js +0 -253
- package/execution/__tests__/useExecutionStream.test.js.map +0 -1
- package/execution/__tests__/useSessionVariables-stability.test.d.ts +0 -2
- package/execution/__tests__/useSessionVariables-stability.test.d.ts.map +0 -1
- package/execution/__tests__/useSessionVariables-stability.test.js +0 -69
- package/execution/__tests__/useSessionVariables-stability.test.js.map +0 -1
- package/execution/__tests__/virtualized-thread.test.d.ts +0 -2
- package/execution/__tests__/virtualized-thread.test.d.ts.map +0 -1
- package/execution/__tests__/virtualized-thread.test.js +0 -274
- package/execution/__tests__/virtualized-thread.test.js.map +0 -1
- package/file-reference/__tests__/FileReferenceChipList.test.d.ts +0 -2
- package/file-reference/__tests__/FileReferenceChipList.test.d.ts.map +0 -1
- package/file-reference/__tests__/FileReferenceChipList.test.js +0 -48
- package/file-reference/__tests__/FileReferenceChipList.test.js.map +0 -1
- package/file-reference/__tests__/useFileReferences.test.d.ts +0 -2
- package/file-reference/__tests__/useFileReferences.test.d.ts.map +0 -1
- package/file-reference/__tests__/useFileReferences.test.js +0 -90
- package/file-reference/__tests__/useFileReferences.test.js.map +0 -1
- package/github/__tests__/parseGitUrl.test.d.ts +0 -2
- package/github/__tests__/parseGitUrl.test.d.ts.map +0 -1
- package/github/__tests__/parseGitUrl.test.js +0 -47
- package/github/__tests__/parseGitUrl.test.js.map +0 -1
- package/github/__tests__/useGitHubTreeLister.test.d.ts +0 -2
- package/github/__tests__/useGitHubTreeLister.test.d.ts.map +0 -1
- package/github/__tests__/useGitHubTreeLister.test.js +0 -112
- package/github/__tests__/useGitHubTreeLister.test.js.map +0 -1
- package/internal/__tests__/ResizableSplit.test.d.ts +0 -2
- package/internal/__tests__/ResizableSplit.test.d.ts.map +0 -1
- package/internal/__tests__/ResizableSplit.test.js +0 -118
- package/internal/__tests__/ResizableSplit.test.js.map +0 -1
- package/internal/__tests__/fetch-cache.test.d.ts +0 -2
- package/internal/__tests__/fetch-cache.test.d.ts.map +0 -1
- package/internal/__tests__/fetch-cache.test.js +0 -182
- package/internal/__tests__/fetch-cache.test.js.map +0 -1
- package/internal/__tests__/stream-controller.test.d.ts +0 -2
- package/internal/__tests__/stream-controller.test.d.ts.map +0 -1
- package/internal/__tests__/stream-controller.test.js +0 -327
- package/internal/__tests__/stream-controller.test.js.map +0 -1
- package/internal/__tests__/thread-animation.test.d.ts +0 -2
- package/internal/__tests__/thread-animation.test.d.ts.map +0 -1
- package/internal/__tests__/thread-animation.test.js +0 -79
- package/internal/__tests__/thread-animation.test.js.map +0 -1
- package/internal/__tests__/useAutoScroll.test.d.ts +0 -2
- package/internal/__tests__/useAutoScroll.test.d.ts.map +0 -1
- package/internal/__tests__/useAutoScroll.test.js +0 -188
- package/internal/__tests__/useAutoScroll.test.js.map +0 -1
- package/internal/__tests__/useFetch-cache.test.d.ts +0 -2
- package/internal/__tests__/useFetch-cache.test.d.ts.map +0 -1
- package/internal/__tests__/useFetch-cache.test.js +0 -137
- package/internal/__tests__/useFetch-cache.test.js.map +0 -1
- package/internal/__tests__/useFetch-identity-reset.test.d.ts +0 -2
- package/internal/__tests__/useFetch-identity-reset.test.d.ts.map +0 -1
- package/internal/__tests__/useFetch-identity-reset.test.js +0 -281
- package/internal/__tests__/useFetch-identity-reset.test.js.map +0 -1
- package/internal/__tests__/useFetch.test.d.ts +0 -2
- package/internal/__tests__/useFetch.test.d.ts.map +0 -1
- package/internal/__tests__/useFetch.test.js +0 -95
- package/internal/__tests__/useFetch.test.js.map +0 -1
- package/internal/dev/__tests__/use-key-stability.test.d.ts +0 -2
- package/internal/dev/__tests__/use-key-stability.test.d.ts.map +0 -1
- package/internal/dev/__tests__/use-key-stability.test.js +0 -72
- package/internal/dev/__tests__/use-key-stability.test.js.map +0 -1
- package/internal/dev/__tests__/use-render-tracer.test.d.ts +0 -2
- package/internal/dev/__tests__/use-render-tracer.test.d.ts.map +0 -1
- package/internal/dev/__tests__/use-render-tracer.test.js +0 -55
- package/internal/dev/__tests__/use-render-tracer.test.js.map +0 -1
- package/internal/file-tree/__tests__/FileTreeNode-drag.test.d.ts +0 -2
- package/internal/file-tree/__tests__/FileTreeNode-drag.test.d.ts.map +0 -1
- package/internal/file-tree/__tests__/FileTreeNode-drag.test.js +0 -55
- package/internal/file-tree/__tests__/FileTreeNode-drag.test.js.map +0 -1
- package/internal/file-tree/__tests__/buildFileTree.test.d.ts +0 -2
- package/internal/file-tree/__tests__/buildFileTree.test.d.ts.map +0 -1
- package/internal/file-tree/__tests__/buildFileTree.test.js +0 -102
- package/internal/file-tree/__tests__/buildFileTree.test.js.map +0 -1
- package/internal/file-tree/__tests__/filterFileTree.test.d.ts +0 -2
- package/internal/file-tree/__tests__/filterFileTree.test.d.ts.map +0 -1
- package/internal/file-tree/__tests__/filterFileTree.test.js +0 -120
- package/internal/file-tree/__tests__/filterFileTree.test.js.map +0 -1
- package/internal/store/__tests__/conversation-store.test.d.ts +0 -2
- package/internal/store/__tests__/conversation-store.test.d.ts.map +0 -1
- package/internal/store/__tests__/conversation-store.test.js +0 -200
- package/internal/store/__tests__/conversation-store.test.js.map +0 -1
- package/internal/store/__tests__/selection-store.test.d.ts +0 -2
- package/internal/store/__tests__/selection-store.test.d.ts.map +0 -1
- package/internal/store/__tests__/selection-store.test.js +0 -93
- package/internal/store/__tests__/selection-store.test.js.map +0 -1
- package/internal/store/__tests__/structural-share.test.d.ts +0 -2
- package/internal/store/__tests__/structural-share.test.d.ts.map +0 -1
- package/internal/store/__tests__/structural-share.test.js +0 -368
- package/internal/store/__tests__/structural-share.test.js.map +0 -1
- package/internal/store/__tests__/workflow-execution-event-store.test.d.ts +0 -2
- package/internal/store/__tests__/workflow-execution-event-store.test.d.ts.map +0 -1
- package/internal/store/__tests__/workflow-execution-event-store.test.js +0 -215
- package/internal/store/__tests__/workflow-execution-event-store.test.js.map +0 -1
- package/invitation/__tests__/useCreateInvitation.test.d.ts +0 -2
- package/invitation/__tests__/useCreateInvitation.test.d.ts.map +0 -1
- package/invitation/__tests__/useCreateInvitation.test.js +0 -152
- package/invitation/__tests__/useCreateInvitation.test.js.map +0 -1
- package/models/__tests__/HarnessSelector.test.d.ts +0 -2
- package/models/__tests__/HarnessSelector.test.d.ts.map +0 -1
- package/models/__tests__/HarnessSelector.test.js +0 -160
- package/models/__tests__/HarnessSelector.test.js.map +0 -1
- package/models/__tests__/harness.test.d.ts +0 -2
- package/models/__tests__/harness.test.d.ts.map +0 -1
- package/models/__tests__/harness.test.js +0 -50
- package/models/__tests__/harness.test.js.map +0 -1
- package/models/__tests__/useModelRegistry.test.d.ts +0 -2
- package/models/__tests__/useModelRegistry.test.d.ts.map +0 -1
- package/models/__tests__/useModelRegistry.test.js +0 -246
- package/models/__tests__/useModelRegistry.test.js.map +0 -1
- package/session/__tests__/execution-target.test.d.ts +0 -2
- package/session/__tests__/execution-target.test.d.ts.map +0 -1
- package/session/__tests__/execution-target.test.js +0 -34
- package/session/__tests__/execution-target.test.js.map +0 -1
- package/session/__tests__/group-sessions.test.d.ts +0 -2
- package/session/__tests__/group-sessions.test.d.ts.map +0 -1
- package/session/__tests__/group-sessions.test.js +0 -91
- package/session/__tests__/group-sessions.test.js.map +0 -1
- package/session/__tests__/session-spec-converters.test.d.ts +0 -2
- package/session/__tests__/session-spec-converters.test.d.ts.map +0 -1
- package/session/__tests__/session-spec-converters.test.js +0 -160
- package/session/__tests__/session-spec-converters.test.js.map +0 -1
- package/session/__tests__/useCreateSession.test.d.ts +0 -2
- package/session/__tests__/useCreateSession.test.d.ts.map +0 -1
- package/session/__tests__/useCreateSession.test.js +0 -228
- package/session/__tests__/useCreateSession.test.js.map +0 -1
- package/session/__tests__/useNewSessionFlow.test.d.ts +0 -2
- package/session/__tests__/useNewSessionFlow.test.d.ts.map +0 -1
- package/session/__tests__/useNewSessionFlow.test.js +0 -364
- package/session/__tests__/useNewSessionFlow.test.js.map +0 -1
- package/session/__tests__/usePersistedModel.test.d.ts +0 -2
- package/session/__tests__/usePersistedModel.test.d.ts.map +0 -1
- package/session/__tests__/usePersistedModel.test.js +0 -96
- package/session/__tests__/usePersistedModel.test.js.map +0 -1
- package/session/__tests__/useSession.test.d.ts +0 -2
- package/session/__tests__/useSession.test.d.ts.map +0 -1
- package/session/__tests__/useSession.test.js +0 -93
- package/session/__tests__/useSession.test.js.map +0 -1
- package/session/__tests__/useSessionConversation.test.d.ts +0 -2
- package/session/__tests__/useSessionConversation.test.d.ts.map +0 -1
- package/session/__tests__/useSessionConversation.test.js +0 -246
- package/session/__tests__/useSessionConversation.test.js.map +0 -1
- package/session/__tests__/useSessionList.test.d.ts +0 -2
- package/session/__tests__/useSessionList.test.d.ts.map +0 -1
- package/session/__tests__/useSessionList.test.js +0 -63
- package/session/__tests__/useSessionList.test.js.map +0 -1
- package/session/__tests__/useSessionUsage.test.d.ts +0 -2
- package/session/__tests__/useSessionUsage.test.d.ts.map +0 -1
- package/session/__tests__/useSessionUsage.test.js +0 -146
- package/session/__tests__/useSessionUsage.test.js.map +0 -1
- package/session/inspector/__tests__/useSessionInspector.test.d.ts +0 -2
- package/session/inspector/__tests__/useSessionInspector.test.d.ts.map +0 -1
- package/session/inspector/__tests__/useSessionInspector.test.js +0 -195
- package/session/inspector/__tests__/useSessionInspector.test.js.map +0 -1
- package/test/__tests__/samples.test.d.ts +0 -2
- package/test/__tests__/samples.test.d.ts.map +0 -1
- package/test/__tests__/samples.test.js +0 -152
- package/test/__tests__/samples.test.js.map +0 -1
- package/workflow/__tests__/ExecutionInspector.test.d.ts +0 -2
- package/workflow/__tests__/ExecutionInspector.test.d.ts.map +0 -1
- package/workflow/__tests__/ExecutionInspector.test.js +0 -91
- package/workflow/__tests__/ExecutionInspector.test.js.map +0 -1
- package/workflow/__tests__/WorkflowArchitectDialog.test.d.ts +0 -2
- package/workflow/__tests__/WorkflowArchitectDialog.test.d.ts.map +0 -1
- package/workflow/__tests__/WorkflowArchitectDialog.test.js +0 -126
- package/workflow/__tests__/WorkflowArchitectDialog.test.js.map +0 -1
- package/workflow/__tests__/WorkflowRefinePanel.test.d.ts +0 -2
- package/workflow/__tests__/WorkflowRefinePanel.test.d.ts.map +0 -1
- package/workflow/__tests__/WorkflowRefinePanel.test.js +0 -138
- package/workflow/__tests__/WorkflowRefinePanel.test.js.map +0 -1
- package/workflow/__tests__/WorkflowRepairCard.test.d.ts +0 -2
- package/workflow/__tests__/WorkflowRepairCard.test.d.ts.map +0 -1
- package/workflow/__tests__/WorkflowRepairCard.test.js +0 -158
- package/workflow/__tests__/WorkflowRepairCard.test.js.map +0 -1
- package/workflow/__tests__/WorkflowTaskApprovalCard.test.d.ts +0 -2
- package/workflow/__tests__/WorkflowTaskApprovalCard.test.d.ts.map +0 -1
- package/workflow/__tests__/WorkflowTaskApprovalCard.test.js +0 -221
- package/workflow/__tests__/WorkflowTaskApprovalCard.test.js.map +0 -1
- package/workflow/__tests__/WorkflowTaskApprovalSummary.test.d.ts +0 -2
- package/workflow/__tests__/WorkflowTaskApprovalSummary.test.d.ts.map +0 -1
- package/workflow/__tests__/WorkflowTaskApprovalSummary.test.js +0 -94
- package/workflow/__tests__/WorkflowTaskApprovalSummary.test.js.map +0 -1
- package/workflow/__tests__/agent-call-live-experience.test.d.ts +0 -11
- package/workflow/__tests__/agent-call-live-experience.test.d.ts.map +0 -1
- package/workflow/__tests__/agent-call-live-experience.test.js +0 -379
- package/workflow/__tests__/agent-call-live-experience.test.js.map +0 -1
- package/workflow/__tests__/branch-commands.test.d.ts +0 -2
- package/workflow/__tests__/branch-commands.test.d.ts.map +0 -1
- package/workflow/__tests__/branch-commands.test.js +0 -165
- package/workflow/__tests__/branch-commands.test.js.map +0 -1
- package/workflow/__tests__/caption-dimensions.test.d.ts +0 -2
- package/workflow/__tests__/caption-dimensions.test.d.ts.map +0 -1
- package/workflow/__tests__/caption-dimensions.test.js +0 -89
- package/workflow/__tests__/caption-dimensions.test.js.map +0 -1
- package/workflow/__tests__/clipboard.test.d.ts +0 -2
- package/workflow/__tests__/clipboard.test.d.ts.map +0 -1
- package/workflow/__tests__/clipboard.test.js +0 -172
- package/workflow/__tests__/clipboard.test.js.map +0 -1
- package/workflow/__tests__/cncf-yaml-to-graph.test.d.ts +0 -2
- package/workflow/__tests__/cncf-yaml-to-graph.test.d.ts.map +0 -1
- package/workflow/__tests__/cncf-yaml-to-graph.test.js +0 -479
- package/workflow/__tests__/cncf-yaml-to-graph.test.js.map +0 -1
- package/workflow/__tests__/context-menu-logic.test.d.ts +0 -2
- package/workflow/__tests__/context-menu-logic.test.d.ts.map +0 -1
- package/workflow/__tests__/context-menu-logic.test.js +0 -97
- package/workflow/__tests__/context-menu-logic.test.js.map +0 -1
- package/workflow/__tests__/derive-execution-overlays.test.d.ts +0 -2
- package/workflow/__tests__/derive-execution-overlays.test.d.ts.map +0 -1
- package/workflow/__tests__/derive-execution-overlays.test.js +0 -338
- package/workflow/__tests__/derive-execution-overlays.test.js.map +0 -1
- package/workflow/__tests__/derive-task-detail.test.d.ts +0 -2
- package/workflow/__tests__/derive-task-detail.test.d.ts.map +0 -1
- package/workflow/__tests__/derive-task-detail.test.js +0 -1035
- package/workflow/__tests__/derive-task-detail.test.js.map +0 -1
- package/workflow/__tests__/derive-waterfall-entries.test.d.ts +0 -2
- package/workflow/__tests__/derive-waterfall-entries.test.d.ts.map +0 -1
- package/workflow/__tests__/derive-waterfall-entries.test.js +0 -419
- package/workflow/__tests__/derive-waterfall-entries.test.js.map +0 -1
- package/workflow/__tests__/execution-graph.test.d.ts +0 -2
- package/workflow/__tests__/execution-graph.test.d.ts.map +0 -1
- package/workflow/__tests__/execution-graph.test.js +0 -251
- package/workflow/__tests__/execution-graph.test.js.map +0 -1
- package/workflow/__tests__/execution-inspector.test.d.ts +0 -2
- package/workflow/__tests__/execution-inspector.test.d.ts.map +0 -1
- package/workflow/__tests__/execution-inspector.test.js +0 -248
- package/workflow/__tests__/execution-inspector.test.js.map +0 -1
- package/workflow/__tests__/extract-workflow-yaml.test.d.ts +0 -2
- package/workflow/__tests__/extract-workflow-yaml.test.d.ts.map +0 -1
- package/workflow/__tests__/extract-workflow-yaml.test.js +0 -135
- package/workflow/__tests__/extract-workflow-yaml.test.js.map +0 -1
- package/workflow/__tests__/format-utils.test.d.ts +0 -2
- package/workflow/__tests__/format-utils.test.d.ts.map +0 -1
- package/workflow/__tests__/format-utils.test.js +0 -128
- package/workflow/__tests__/format-utils.test.js.map +0 -1
- package/workflow/__tests__/inspector-commands.test.d.ts +0 -2
- package/workflow/__tests__/inspector-commands.test.d.ts.map +0 -1
- package/workflow/__tests__/inspector-commands.test.js +0 -110
- package/workflow/__tests__/inspector-commands.test.js.map +0 -1
- package/workflow/__tests__/inspector-forms.test.d.ts +0 -2
- package/workflow/__tests__/inspector-forms.test.d.ts.map +0 -1
- package/workflow/__tests__/inspector-forms.test.js +0 -114
- package/workflow/__tests__/inspector-forms.test.js.map +0 -1
- package/workflow/__tests__/inspector-tabs.test.d.ts +0 -2
- package/workflow/__tests__/inspector-tabs.test.d.ts.map +0 -1
- package/workflow/__tests__/inspector-tabs.test.js +0 -81
- package/workflow/__tests__/inspector-tabs.test.js.map +0 -1
- package/workflow/__tests__/kind-metadata.test.d.ts +0 -2
- package/workflow/__tests__/kind-metadata.test.d.ts.map +0 -1
- package/workflow/__tests__/kind-metadata.test.js +0 -80
- package/workflow/__tests__/kind-metadata.test.js.map +0 -1
- package/workflow/__tests__/motion-preference.test.d.ts +0 -2
- package/workflow/__tests__/motion-preference.test.d.ts.map +0 -1
- package/workflow/__tests__/motion-preference.test.js +0 -42
- package/workflow/__tests__/motion-preference.test.js.map +0 -1
- package/workflow/__tests__/node-popover.test.d.ts +0 -2
- package/workflow/__tests__/node-popover.test.d.ts.map +0 -1
- package/workflow/__tests__/node-popover.test.js +0 -130
- package/workflow/__tests__/node-popover.test.js.map +0 -1
- package/workflow/__tests__/node-shell.test.d.ts +0 -2
- package/workflow/__tests__/node-shell.test.d.ts.map +0 -1
- package/workflow/__tests__/node-shell.test.js +0 -210
- package/workflow/__tests__/node-shell.test.js.map +0 -1
- package/workflow/__tests__/overview-graph.test.d.ts +0 -2
- package/workflow/__tests__/overview-graph.test.d.ts.map +0 -1
- package/workflow/__tests__/overview-graph.test.js +0 -83
- package/workflow/__tests__/overview-graph.test.js.map +0 -1
- package/workflow/__tests__/overview-summary.test.d.ts +0 -2
- package/workflow/__tests__/overview-summary.test.d.ts.map +0 -1
- package/workflow/__tests__/overview-summary.test.js +0 -73
- package/workflow/__tests__/overview-summary.test.js.map +0 -1
- package/workflow/__tests__/shortcut-registry.test.d.ts +0 -2
- package/workflow/__tests__/shortcut-registry.test.d.ts.map +0 -1
- package/workflow/__tests__/shortcut-registry.test.js +0 -111
- package/workflow/__tests__/shortcut-registry.test.js.map +0 -1
- package/workflow/__tests__/starter-workflow-yaml.test.d.ts +0 -2
- package/workflow/__tests__/starter-workflow-yaml.test.d.ts.map +0 -1
- package/workflow/__tests__/starter-workflow-yaml.test.js +0 -44
- package/workflow/__tests__/starter-workflow-yaml.test.js.map +0 -1
- package/workflow/__tests__/structured-data-viewer.test.d.ts +0 -2
- package/workflow/__tests__/structured-data-viewer.test.d.ts.map +0 -1
- package/workflow/__tests__/structured-data-viewer.test.js +0 -438
- package/workflow/__tests__/structured-data-viewer.test.js.map +0 -1
- package/workflow/__tests__/t09-branch-management.test.d.ts +0 -2
- package/workflow/__tests__/t09-branch-management.test.d.ts.map +0 -1
- package/workflow/__tests__/t09-branch-management.test.js +0 -433
- package/workflow/__tests__/t09-branch-management.test.js.map +0 -1
- package/workflow/__tests__/task-type-visual-registry.test.d.ts +0 -2
- package/workflow/__tests__/task-type-visual-registry.test.d.ts.map +0 -1
- package/workflow/__tests__/task-type-visual-registry.test.js +0 -99
- package/workflow/__tests__/task-type-visual-registry.test.js.map +0 -1
- package/workflow/__tests__/useActiveTaskName.test.d.ts +0 -2
- package/workflow/__tests__/useActiveTaskName.test.d.ts.map +0 -1
- package/workflow/__tests__/useActiveTaskName.test.js +0 -80
- package/workflow/__tests__/useActiveTaskName.test.js.map +0 -1
- package/workflow/__tests__/useDiagnoseExecutionFlow.test.d.ts +0 -2
- package/workflow/__tests__/useDiagnoseExecutionFlow.test.d.ts.map +0 -1
- package/workflow/__tests__/useDiagnoseExecutionFlow.test.js +0 -363
- package/workflow/__tests__/useDiagnoseExecutionFlow.test.js.map +0 -1
- package/workflow/__tests__/useExecutionAnnouncements.test.d.ts +0 -2
- package/workflow/__tests__/useExecutionAnnouncements.test.d.ts.map +0 -1
- package/workflow/__tests__/useExecutionAnnouncements.test.js +0 -85
- package/workflow/__tests__/useExecutionAnnouncements.test.js.map +0 -1
- package/workflow/__tests__/useFollowExecution.test.d.ts +0 -2
- package/workflow/__tests__/useFollowExecution.test.d.ts.map +0 -1
- package/workflow/__tests__/useFollowExecution.test.js +0 -130
- package/workflow/__tests__/useFollowExecution.test.js.map +0 -1
- package/workflow/__tests__/useRefineWorkflowFlow.test.d.ts +0 -2
- package/workflow/__tests__/useRefineWorkflowFlow.test.d.ts.map +0 -1
- package/workflow/__tests__/useRefineWorkflowFlow.test.js +0 -367
- package/workflow/__tests__/useRefineWorkflowFlow.test.js.map +0 -1
- package/workflow/__tests__/useRunWorkflowFlow.test.d.ts +0 -2
- package/workflow/__tests__/useRunWorkflowFlow.test.d.ts.map +0 -1
- package/workflow/__tests__/useRunWorkflowFlow.test.js +0 -385
- package/workflow/__tests__/useRunWorkflowFlow.test.js.map +0 -1
- package/workflow/__tests__/useWorkflowArchitectFlow.test.d.ts +0 -2
- package/workflow/__tests__/useWorkflowArchitectFlow.test.d.ts.map +0 -1
- package/workflow/__tests__/useWorkflowArchitectFlow.test.js +0 -376
- package/workflow/__tests__/useWorkflowArchitectFlow.test.js.map +0 -1
- package/workflow/__tests__/useWorkflowExecution.test.d.ts +0 -2
- package/workflow/__tests__/useWorkflowExecution.test.d.ts.map +0 -1
- package/workflow/__tests__/useWorkflowExecution.test.js +0 -229
- package/workflow/__tests__/useWorkflowExecution.test.js.map +0 -1
- package/workflow/__tests__/useWorkflowExecutionActions.test.d.ts +0 -2
- package/workflow/__tests__/useWorkflowExecutionActions.test.d.ts.map +0 -1
- package/workflow/__tests__/useWorkflowExecutionActions.test.js +0 -191
- package/workflow/__tests__/useWorkflowExecutionActions.test.js.map +0 -1
- package/workflow/__tests__/useWorkflowExecutionEventStream.test.d.ts +0 -2
- package/workflow/__tests__/useWorkflowExecutionEventStream.test.d.ts.map +0 -1
- package/workflow/__tests__/useWorkflowExecutionEventStream.test.js +0 -291
- package/workflow/__tests__/useWorkflowExecutionEventStream.test.js.map +0 -1
- package/workflow/__tests__/workflow-instance-hooks.test.d.ts +0 -2
- package/workflow/__tests__/workflow-instance-hooks.test.d.ts.map +0 -1
- package/workflow/__tests__/workflow-instance-hooks.test.js +0 -153
- package/workflow/__tests__/workflow-instance-hooks.test.js.map +0 -1
- package/workflow/__tests__/workflow-summary-panel.test.d.ts +0 -2
- package/workflow/__tests__/workflow-summary-panel.test.d.ts.map +0 -1
- package/workflow/__tests__/workflow-summary-panel.test.js +0 -85
- package/workflow/__tests__/workflow-summary-panel.test.js.map +0 -1
- package/workflow/__tests__/workflow-uses-trigger-input.test.d.ts +0 -2
- package/workflow/__tests__/workflow-uses-trigger-input.test.d.ts.map +0 -1
- package/workflow/__tests__/workflow-uses-trigger-input.test.js +0 -144
- package/workflow/__tests__/workflow-uses-trigger-input.test.js.map +0 -1
- package/workflow/__tests__/workflow-yaml-diff.test.d.ts +0 -2
- package/workflow/__tests__/workflow-yaml-diff.test.d.ts.map +0 -1
- package/workflow/__tests__/workflow-yaml-diff.test.js +0 -110
- package/workflow/__tests__/workflow-yaml-diff.test.js.map +0 -1
- package/workflow/diff/__tests__/build-diff-graph.test.d.ts +0 -2
- package/workflow/diff/__tests__/build-diff-graph.test.d.ts.map +0 -1
- package/workflow/diff/__tests__/build-diff-graph.test.js +0 -115
- package/workflow/diff/__tests__/build-diff-graph.test.js.map +0 -1
- package/workflow/diff/__tests__/graph-diff.test.d.ts +0 -2
- package/workflow/diff/__tests__/graph-diff.test.d.ts.map +0 -1
- package/workflow/diff/__tests__/graph-diff.test.js +0 -196
- package/workflow/diff/__tests__/graph-diff.test.js.map +0 -1
- package/workflow/execution-comparison/__tests__/derive-execution-comparison.test.d.ts +0 -2
- package/workflow/execution-comparison/__tests__/derive-execution-comparison.test.d.ts.map +0 -1
- package/workflow/execution-comparison/__tests__/derive-execution-comparison.test.js +0 -263
- package/workflow/execution-comparison/__tests__/derive-execution-comparison.test.js.map +0 -1
- package/workflow/execution-history/__tests__/derive-execution-row.test.d.ts +0 -2
- package/workflow/execution-history/__tests__/derive-execution-row.test.d.ts.map +0 -1
- package/workflow/execution-history/__tests__/derive-execution-row.test.js +0 -276
- package/workflow/execution-history/__tests__/derive-execution-row.test.js.map +0 -1
- package/workflow/execution-history/__tests__/derive-failure-analysis.test.d.ts +0 -2
- package/workflow/execution-history/__tests__/derive-failure-analysis.test.d.ts.map +0 -1
- package/workflow/execution-history/__tests__/derive-failure-analysis.test.js +0 -132
- package/workflow/execution-history/__tests__/derive-failure-analysis.test.js.map +0 -1
- package/workflow/layout/__tests__/dagre-layout-engine.test.d.ts +0 -2
- package/workflow/layout/__tests__/dagre-layout-engine.test.d.ts.map +0 -1
- package/workflow/layout/__tests__/dagre-layout-engine.test.js +0 -105
- package/workflow/layout/__tests__/dagre-layout-engine.test.js.map +0 -1
- package/workflow/layout/__tests__/layout-postprocessor.test.d.ts +0 -2
- package/workflow/layout/__tests__/layout-postprocessor.test.d.ts.map +0 -1
- package/workflow/layout/__tests__/layout-postprocessor.test.js +0 -123
- package/workflow/layout/__tests__/layout-postprocessor.test.js.map +0 -1
- package/workflow/layout/__tests__/port-assignment.test.d.ts +0 -2
- package/workflow/layout/__tests__/port-assignment.test.d.ts.map +0 -1
- package/workflow/layout/__tests__/port-assignment.test.js +0 -200
- package/workflow/layout/__tests__/port-assignment.test.js.map +0 -1
- package/workflow/layout/__tests__/registry-dimensions.test.d.ts +0 -2
- package/workflow/layout/__tests__/registry-dimensions.test.d.ts.map +0 -1
- package/workflow/layout/__tests__/registry-dimensions.test.js +0 -104
- package/workflow/layout/__tests__/registry-dimensions.test.js.map +0 -1
- package/workflow/layout/__tests__/useElkLayoutEngine.test.d.ts +0 -2
- package/workflow/layout/__tests__/useElkLayoutEngine.test.d.ts.map +0 -1
- package/workflow/layout/__tests__/useElkLayoutEngine.test.js +0 -106
- package/workflow/layout/__tests__/useElkLayoutEngine.test.js.map +0 -1
- package/workflow/layout/__tests__/workflow-preprocessor.test.d.ts +0 -2
- package/workflow/layout/__tests__/workflow-preprocessor.test.d.ts.map +0 -1
- package/workflow/layout/__tests__/workflow-preprocessor.test.js +0 -138
- package/workflow/layout/__tests__/workflow-preprocessor.test.js.map +0 -1
- package/workflow/picker/__tests__/compatibility.test.d.ts +0 -2
- package/workflow/picker/__tests__/compatibility.test.d.ts.map +0 -1
- package/workflow/picker/__tests__/compatibility.test.js +0 -93
- package/workflow/picker/__tests__/compatibility.test.js.map +0 -1
- package/workflow/picker/__tests__/insertion-context.test.d.ts +0 -2
- package/workflow/picker/__tests__/insertion-context.test.d.ts.map +0 -1
- package/workflow/picker/__tests__/insertion-context.test.js +0 -67
- package/workflow/picker/__tests__/insertion-context.test.js.map +0 -1
- package/workflow/picker/__tests__/recents.test.d.ts +0 -2
- package/workflow/picker/__tests__/recents.test.d.ts.map +0 -1
- package/workflow/picker/__tests__/recents.test.js +0 -81
- package/workflow/picker/__tests__/recents.test.js.map +0 -1
- package/workflow/picker/__tests__/suggestions.test.d.ts +0 -2
- package/workflow/picker/__tests__/suggestions.test.d.ts.map +0 -1
- package/workflow/picker/__tests__/suggestions.test.js +0 -111
- package/workflow/picker/__tests__/suggestions.test.js.map +0 -1
- package/workflow/templates/__tests__/derive-template-metadata.test.d.ts +0 -2
- package/workflow/templates/__tests__/derive-template-metadata.test.d.ts.map +0 -1
- package/workflow/templates/__tests__/derive-template-metadata.test.js +0 -317
- package/workflow/templates/__tests__/derive-template-metadata.test.js.map +0 -1
- package/workflow/templates/__tests__/workflow-template-gallery.test.d.ts +0 -2
- package/workflow/templates/__tests__/workflow-template-gallery.test.d.ts.map +0 -1
- package/workflow/templates/__tests__/workflow-template-gallery.test.js +0 -119
- package/workflow/templates/__tests__/workflow-template-gallery.test.js.map +0 -1
- package/workspace/__tests__/WorkspaceEditor-initialPanel.test.d.ts +0 -2
- package/workspace/__tests__/WorkspaceEditor-initialPanel.test.d.ts.map +0 -1
- package/workspace/__tests__/WorkspaceEditor-initialPanel.test.js +0 -82
- package/workspace/__tests__/WorkspaceEditor-initialPanel.test.js.map +0 -1
- package/workspace/__tests__/useWorkspaceEntries-stability.test.d.ts +0 -2
- package/workspace/__tests__/useWorkspaceEntries-stability.test.d.ts.map +0 -1
- package/workspace/__tests__/useWorkspaceEntries-stability.test.js +0 -57
- package/workspace/__tests__/useWorkspaceEntries-stability.test.js.map +0 -1
- package/workspace/__tests__/useWorkspaceFiles.test.d.ts +0 -2
- package/workspace/__tests__/useWorkspaceFiles.test.d.ts.map +0 -1
- package/workspace/__tests__/useWorkspaceFiles.test.js +0 -128
- package/workspace/__tests__/useWorkspaceFiles.test.js.map +0 -1
- package/workspace/__tests__/useWorkspaceSources.test.d.ts +0 -2
- package/workspace/__tests__/useWorkspaceSources.test.d.ts.map +0 -1
- package/workspace/__tests__/useWorkspaceSources.test.js +0 -98
- package/workspace/__tests__/useWorkspaceSources.test.js.map +0 -1
|
@@ -1,376 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, vi, beforeEach } from "vitest";
|
|
2
|
-
import { renderHook, act, waitFor } from "@testing-library/react";
|
|
3
|
-
vi.mock("../../session/useCreateSession", () => ({
|
|
4
|
-
useCreateSession: vi.fn(),
|
|
5
|
-
}));
|
|
6
|
-
vi.mock("../../execution/useCreateAgentExecution", () => ({
|
|
7
|
-
useCreateAgentExecution: vi.fn(),
|
|
8
|
-
}));
|
|
9
|
-
vi.mock("../../execution/useExecutionStream", () => ({
|
|
10
|
-
useExecutionStream: vi.fn(),
|
|
11
|
-
}));
|
|
12
|
-
vi.mock("../../internal/store", () => ({
|
|
13
|
-
useConversationStoreRef: vi.fn(() => ({ current: null })),
|
|
14
|
-
}));
|
|
15
|
-
vi.mock("../../hooks", () => ({
|
|
16
|
-
useStigmer: vi.fn(),
|
|
17
|
-
}));
|
|
18
|
-
vi.mock("../serialize-workflow-yaml", () => ({
|
|
19
|
-
parseWorkflowYaml: vi.fn(),
|
|
20
|
-
}));
|
|
21
|
-
import { useWorkflowArchitectFlow } from "../useWorkflowArchitectFlow";
|
|
22
|
-
import { useCreateSession } from "../../session/useCreateSession";
|
|
23
|
-
import { useCreateAgentExecution } from "../../execution/useCreateAgentExecution";
|
|
24
|
-
import { useExecutionStream } from "../../execution/useExecutionStream";
|
|
25
|
-
import { useStigmer } from "../../hooks";
|
|
26
|
-
import { parseWorkflowYaml } from "../serialize-workflow-yaml";
|
|
27
|
-
const mockCreateSession = vi.fn();
|
|
28
|
-
const mockCreateExecution = vi.fn();
|
|
29
|
-
const mockApply = vi.fn();
|
|
30
|
-
function makeExecution(yamlContent) {
|
|
31
|
-
const messages = [];
|
|
32
|
-
if (yamlContent) {
|
|
33
|
-
messages.push({
|
|
34
|
-
type: 2,
|
|
35
|
-
content: `Here is the workflow:\n\n\`\`\`yaml\n${yamlContent}\n\`\`\`\n\nThis workflow does X.`,
|
|
36
|
-
});
|
|
37
|
-
}
|
|
38
|
-
else {
|
|
39
|
-
messages.push({
|
|
40
|
-
type: 2,
|
|
41
|
-
content: "I analyzed the execution and found a runtime error.",
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
return { status: { messages, phase: 4 } };
|
|
45
|
-
}
|
|
46
|
-
function makeExecutionWithStructuredOutput(structured) {
|
|
47
|
-
return {
|
|
48
|
-
status: {
|
|
49
|
-
messages: [{ type: 2, content: "Agent response" }],
|
|
50
|
-
phase: 4,
|
|
51
|
-
structuredOutput: structured,
|
|
52
|
-
},
|
|
53
|
-
};
|
|
54
|
-
}
|
|
55
|
-
function defaultStreamReturn(overrides = {}) {
|
|
56
|
-
return {
|
|
57
|
-
execution: null,
|
|
58
|
-
phase: 0,
|
|
59
|
-
isStreaming: false,
|
|
60
|
-
isConnecting: false,
|
|
61
|
-
error: null,
|
|
62
|
-
...overrides,
|
|
63
|
-
};
|
|
64
|
-
}
|
|
65
|
-
function defaultOptions() {
|
|
66
|
-
return {
|
|
67
|
-
org: "test-org",
|
|
68
|
-
onSuccess: vi.fn(),
|
|
69
|
-
onError: vi.fn(),
|
|
70
|
-
};
|
|
71
|
-
}
|
|
72
|
-
describe("useWorkflowArchitectFlow", () => {
|
|
73
|
-
beforeEach(() => {
|
|
74
|
-
vi.clearAllMocks();
|
|
75
|
-
mockCreateSession.mockResolvedValue({ sessionId: "sess-123" });
|
|
76
|
-
mockCreateExecution.mockResolvedValue({ executionId: "exec-456" });
|
|
77
|
-
mockApply.mockResolvedValue({
|
|
78
|
-
metadata: { org: "test-org", slug: "generated-workflow" },
|
|
79
|
-
});
|
|
80
|
-
useCreateSession.mockReturnValue({
|
|
81
|
-
create: mockCreateSession,
|
|
82
|
-
isCreating: false,
|
|
83
|
-
error: null,
|
|
84
|
-
clearError: vi.fn(),
|
|
85
|
-
});
|
|
86
|
-
useCreateAgentExecution.mockReturnValue({
|
|
87
|
-
create: mockCreateExecution,
|
|
88
|
-
isCreating: false,
|
|
89
|
-
error: null,
|
|
90
|
-
clearError: vi.fn(),
|
|
91
|
-
});
|
|
92
|
-
useExecutionStream.mockReturnValue(defaultStreamReturn());
|
|
93
|
-
useStigmer.mockReturnValue({
|
|
94
|
-
workflow: { apply: mockApply },
|
|
95
|
-
});
|
|
96
|
-
parseWorkflowYaml.mockReturnValue({
|
|
97
|
-
name: "generated-workflow",
|
|
98
|
-
org: "test-org",
|
|
99
|
-
document: {},
|
|
100
|
-
tasks: [],
|
|
101
|
-
});
|
|
102
|
-
});
|
|
103
|
-
it("starts in idle phase with empty prompt", () => {
|
|
104
|
-
const { result } = renderHook(() => useWorkflowArchitectFlow(defaultOptions()));
|
|
105
|
-
expect(result.current.phase).toBe("idle");
|
|
106
|
-
expect(result.current.prompt).toBe("");
|
|
107
|
-
expect(result.current.error).toBeNull();
|
|
108
|
-
expect(result.current.extractedYaml).toBeNull();
|
|
109
|
-
});
|
|
110
|
-
it("setPrompt updates prompt value", () => {
|
|
111
|
-
const { result } = renderHook(() => useWorkflowArchitectFlow(defaultOptions()));
|
|
112
|
-
act(() => {
|
|
113
|
-
result.current.setPrompt("test prompt value");
|
|
114
|
-
});
|
|
115
|
-
expect(result.current.prompt).toBe("test prompt value");
|
|
116
|
-
});
|
|
117
|
-
it("rejects prompt shorter than 10 characters", async () => {
|
|
118
|
-
const { result } = renderHook(() => useWorkflowArchitectFlow(defaultOptions()));
|
|
119
|
-
act(() => {
|
|
120
|
-
result.current.setPrompt("short");
|
|
121
|
-
});
|
|
122
|
-
await act(async () => {
|
|
123
|
-
await result.current.generate();
|
|
124
|
-
});
|
|
125
|
-
expect(result.current.error).toContain("at least 10 characters");
|
|
126
|
-
expect(result.current.phase).toBe("idle");
|
|
127
|
-
});
|
|
128
|
-
it("generate creates session and execution with structuredOutputSchema", async () => {
|
|
129
|
-
const { result } = renderHook(() => useWorkflowArchitectFlow(defaultOptions()));
|
|
130
|
-
act(() => {
|
|
131
|
-
result.current.setPrompt("Create a workflow that processes user onboarding");
|
|
132
|
-
});
|
|
133
|
-
await act(async () => {
|
|
134
|
-
await result.current.generate();
|
|
135
|
-
});
|
|
136
|
-
expect(mockCreateSession).toHaveBeenCalledOnce();
|
|
137
|
-
expect(mockCreateExecution).toHaveBeenCalledOnce();
|
|
138
|
-
expect(mockCreateExecution).toHaveBeenCalledWith(expect.objectContaining({
|
|
139
|
-
org: "test-org",
|
|
140
|
-
sessionId: "sess-123",
|
|
141
|
-
message: "Create a workflow that processes user onboarding",
|
|
142
|
-
structuredOutputSchema: expect.objectContaining({
|
|
143
|
-
type: "object",
|
|
144
|
-
required: ["action", "explanation"],
|
|
145
|
-
}),
|
|
146
|
-
}));
|
|
147
|
-
});
|
|
148
|
-
it("transitions from starting to streaming", async () => {
|
|
149
|
-
const { result } = renderHook(() => useWorkflowArchitectFlow(defaultOptions()));
|
|
150
|
-
act(() => {
|
|
151
|
-
result.current.setPrompt("Create a workflow that processes user onboarding");
|
|
152
|
-
});
|
|
153
|
-
await act(async () => {
|
|
154
|
-
await result.current.generate();
|
|
155
|
-
});
|
|
156
|
-
expect(result.current.phase).toBe("streaming");
|
|
157
|
-
});
|
|
158
|
-
it("extracts YAML on terminal phase → complete", async () => {
|
|
159
|
-
const { result, rerender } = renderHook(() => useWorkflowArchitectFlow(defaultOptions()));
|
|
160
|
-
act(() => {
|
|
161
|
-
result.current.setPrompt("Create a workflow that processes user onboarding");
|
|
162
|
-
});
|
|
163
|
-
await act(async () => {
|
|
164
|
-
await result.current.generate();
|
|
165
|
-
});
|
|
166
|
-
expect(result.current.phase).toBe("streaming");
|
|
167
|
-
const yamlContent = "apiVersion: v1\nname: generated-workflow";
|
|
168
|
-
useExecutionStream.mockReturnValue(defaultStreamReturn({
|
|
169
|
-
phase: 4,
|
|
170
|
-
execution: makeExecution(yamlContent),
|
|
171
|
-
isStreaming: false,
|
|
172
|
-
}));
|
|
173
|
-
rerender();
|
|
174
|
-
await waitFor(() => {
|
|
175
|
-
expect(result.current.phase).toBe("complete");
|
|
176
|
-
});
|
|
177
|
-
expect(result.current.extractedYaml).toBe(yamlContent);
|
|
178
|
-
});
|
|
179
|
-
it("no YAML at terminal → extraction-failed with error", async () => {
|
|
180
|
-
const { result, rerender } = renderHook(() => useWorkflowArchitectFlow(defaultOptions()));
|
|
181
|
-
act(() => {
|
|
182
|
-
result.current.setPrompt("Create a workflow that processes user onboarding");
|
|
183
|
-
});
|
|
184
|
-
await act(async () => {
|
|
185
|
-
await result.current.generate();
|
|
186
|
-
});
|
|
187
|
-
useExecutionStream.mockReturnValue(defaultStreamReturn({
|
|
188
|
-
phase: 4,
|
|
189
|
-
execution: makeExecution(),
|
|
190
|
-
isStreaming: false,
|
|
191
|
-
}));
|
|
192
|
-
rerender();
|
|
193
|
-
await waitFor(() => {
|
|
194
|
-
expect(result.current.phase).toBe("extraction-failed");
|
|
195
|
-
});
|
|
196
|
-
expect(result.current.error).toContain("did not produce a YAML");
|
|
197
|
-
});
|
|
198
|
-
it("surfaces stream error", async () => {
|
|
199
|
-
const opts = defaultOptions();
|
|
200
|
-
const { result, rerender } = renderHook(() => useWorkflowArchitectFlow(opts));
|
|
201
|
-
act(() => {
|
|
202
|
-
result.current.setPrompt("Create a workflow that processes user onboarding");
|
|
203
|
-
});
|
|
204
|
-
await act(async () => {
|
|
205
|
-
await result.current.generate();
|
|
206
|
-
});
|
|
207
|
-
useExecutionStream.mockReturnValue(defaultStreamReturn({
|
|
208
|
-
error: new Error("WebSocket closed"),
|
|
209
|
-
}));
|
|
210
|
-
rerender();
|
|
211
|
-
await waitFor(() => {
|
|
212
|
-
expect(result.current.phase).toBe("error");
|
|
213
|
-
});
|
|
214
|
-
expect(opts.onError).toHaveBeenCalled();
|
|
215
|
-
});
|
|
216
|
-
it("surfaces RPC failure", async () => {
|
|
217
|
-
const opts = defaultOptions();
|
|
218
|
-
mockCreateSession.mockRejectedValueOnce(new Error("Network error"));
|
|
219
|
-
const { result } = renderHook(() => useWorkflowArchitectFlow(opts));
|
|
220
|
-
act(() => {
|
|
221
|
-
result.current.setPrompt("Create a workflow that processes user onboarding");
|
|
222
|
-
});
|
|
223
|
-
await act(async () => {
|
|
224
|
-
await result.current.generate();
|
|
225
|
-
});
|
|
226
|
-
expect(result.current.phase).toBe("error");
|
|
227
|
-
expect(result.current.error).toBeTruthy();
|
|
228
|
-
expect(opts.onError).toHaveBeenCalled();
|
|
229
|
-
});
|
|
230
|
-
it("createWorkflow calls apply and onSuccess", async () => {
|
|
231
|
-
const opts = defaultOptions();
|
|
232
|
-
const { result, rerender } = renderHook(() => useWorkflowArchitectFlow(opts));
|
|
233
|
-
act(() => {
|
|
234
|
-
result.current.setPrompt("Create a workflow that processes user onboarding");
|
|
235
|
-
});
|
|
236
|
-
await act(async () => {
|
|
237
|
-
await result.current.generate();
|
|
238
|
-
});
|
|
239
|
-
const yamlContent = "apiVersion: v1\nname: generated-workflow";
|
|
240
|
-
useExecutionStream.mockReturnValue(defaultStreamReturn({
|
|
241
|
-
phase: 4,
|
|
242
|
-
execution: makeExecution(yamlContent),
|
|
243
|
-
isStreaming: false,
|
|
244
|
-
}));
|
|
245
|
-
rerender();
|
|
246
|
-
await waitFor(() => {
|
|
247
|
-
expect(result.current.phase).toBe("complete");
|
|
248
|
-
});
|
|
249
|
-
await act(async () => {
|
|
250
|
-
await result.current.createWorkflow();
|
|
251
|
-
});
|
|
252
|
-
expect(parseWorkflowYaml).toHaveBeenCalledWith(yamlContent, "test-org");
|
|
253
|
-
expect(mockApply).toHaveBeenCalledOnce();
|
|
254
|
-
expect(opts.onSuccess).toHaveBeenCalledWith("test-org", "generated-workflow");
|
|
255
|
-
});
|
|
256
|
-
it("createWorkflow handles apply error", async () => {
|
|
257
|
-
const opts = defaultOptions();
|
|
258
|
-
mockApply.mockRejectedValueOnce(new Error("Validation failed"));
|
|
259
|
-
const { result, rerender } = renderHook(() => useWorkflowArchitectFlow(opts));
|
|
260
|
-
act(() => {
|
|
261
|
-
result.current.setPrompt("Create a workflow that processes user onboarding");
|
|
262
|
-
});
|
|
263
|
-
await act(async () => {
|
|
264
|
-
await result.current.generate();
|
|
265
|
-
});
|
|
266
|
-
const yamlContent = "apiVersion: v1\nname: generated-workflow";
|
|
267
|
-
useExecutionStream.mockReturnValue(defaultStreamReturn({
|
|
268
|
-
phase: 4,
|
|
269
|
-
execution: makeExecution(yamlContent),
|
|
270
|
-
isStreaming: false,
|
|
271
|
-
}));
|
|
272
|
-
rerender();
|
|
273
|
-
await waitFor(() => {
|
|
274
|
-
expect(result.current.phase).toBe("complete");
|
|
275
|
-
});
|
|
276
|
-
await act(async () => {
|
|
277
|
-
await result.current.createWorkflow();
|
|
278
|
-
});
|
|
279
|
-
expect(result.current.phase).toBe("error");
|
|
280
|
-
expect(result.current.error).toBeTruthy();
|
|
281
|
-
});
|
|
282
|
-
it("reset clears all state", async () => {
|
|
283
|
-
const { result, rerender } = renderHook(() => useWorkflowArchitectFlow(defaultOptions()));
|
|
284
|
-
act(() => {
|
|
285
|
-
result.current.setPrompt("Create a workflow that processes user onboarding");
|
|
286
|
-
});
|
|
287
|
-
await act(async () => {
|
|
288
|
-
await result.current.generate();
|
|
289
|
-
});
|
|
290
|
-
const yamlContent = "apiVersion: v1\nname: generated-workflow";
|
|
291
|
-
useExecutionStream.mockReturnValue(defaultStreamReturn({
|
|
292
|
-
phase: 4,
|
|
293
|
-
execution: makeExecution(yamlContent),
|
|
294
|
-
isStreaming: false,
|
|
295
|
-
}));
|
|
296
|
-
rerender();
|
|
297
|
-
await waitFor(() => {
|
|
298
|
-
expect(result.current.phase).toBe("complete");
|
|
299
|
-
});
|
|
300
|
-
act(() => {
|
|
301
|
-
result.current.reset();
|
|
302
|
-
});
|
|
303
|
-
expect(result.current.phase).toBe("idle");
|
|
304
|
-
expect(result.current.prompt).toBe("");
|
|
305
|
-
expect(result.current.extractedYaml).toBeNull();
|
|
306
|
-
expect(result.current.error).toBeNull();
|
|
307
|
-
});
|
|
308
|
-
it("reads YAML from structuredOutput when available", async () => {
|
|
309
|
-
const { result, rerender } = renderHook(() => useWorkflowArchitectFlow(defaultOptions()));
|
|
310
|
-
act(() => {
|
|
311
|
-
result.current.setPrompt("Create a workflow that processes user onboarding");
|
|
312
|
-
});
|
|
313
|
-
await act(async () => {
|
|
314
|
-
await result.current.generate();
|
|
315
|
-
});
|
|
316
|
-
const yamlContent = "apiVersion: v1\nname: from-structured";
|
|
317
|
-
useExecutionStream.mockReturnValue(defaultStreamReturn({
|
|
318
|
-
phase: 4,
|
|
319
|
-
execution: makeExecutionWithStructuredOutput({
|
|
320
|
-
action: "generated_yaml",
|
|
321
|
-
yaml: yamlContent,
|
|
322
|
-
explanation: "Created a user onboarding workflow.",
|
|
323
|
-
}),
|
|
324
|
-
isStreaming: false,
|
|
325
|
-
}));
|
|
326
|
-
rerender();
|
|
327
|
-
await waitFor(() => {
|
|
328
|
-
expect(result.current.phase).toBe("complete");
|
|
329
|
-
});
|
|
330
|
-
expect(result.current.extractedYaml).toBe(yamlContent);
|
|
331
|
-
expect(result.current.explanation).toBe("Created a user onboarding workflow.");
|
|
332
|
-
});
|
|
333
|
-
it("structured output with clarification action → extraction-failed", async () => {
|
|
334
|
-
const { result, rerender } = renderHook(() => useWorkflowArchitectFlow(defaultOptions()));
|
|
335
|
-
act(() => {
|
|
336
|
-
result.current.setPrompt("Create a workflow that processes user onboarding");
|
|
337
|
-
});
|
|
338
|
-
await act(async () => {
|
|
339
|
-
await result.current.generate();
|
|
340
|
-
});
|
|
341
|
-
useExecutionStream.mockReturnValue(defaultStreamReturn({
|
|
342
|
-
phase: 4,
|
|
343
|
-
execution: makeExecutionWithStructuredOutput({
|
|
344
|
-
action: "clarification",
|
|
345
|
-
explanation: "Which organization should own this workflow?",
|
|
346
|
-
}),
|
|
347
|
-
isStreaming: false,
|
|
348
|
-
}));
|
|
349
|
-
rerender();
|
|
350
|
-
await waitFor(() => {
|
|
351
|
-
expect(result.current.phase).toBe("extraction-failed");
|
|
352
|
-
});
|
|
353
|
-
expect(result.current.error).toBe("Which organization should own this workflow?");
|
|
354
|
-
});
|
|
355
|
-
it("falls back to regex extraction when structuredOutput is absent", async () => {
|
|
356
|
-
const { result, rerender } = renderHook(() => useWorkflowArchitectFlow(defaultOptions()));
|
|
357
|
-
act(() => {
|
|
358
|
-
result.current.setPrompt("Create a workflow that processes user onboarding");
|
|
359
|
-
});
|
|
360
|
-
await act(async () => {
|
|
361
|
-
await result.current.generate();
|
|
362
|
-
});
|
|
363
|
-
const yamlContent = "apiVersion: v1\nname: from-regex";
|
|
364
|
-
useExecutionStream.mockReturnValue(defaultStreamReturn({
|
|
365
|
-
phase: 4,
|
|
366
|
-
execution: makeExecution(yamlContent),
|
|
367
|
-
isStreaming: false,
|
|
368
|
-
}));
|
|
369
|
-
rerender();
|
|
370
|
-
await waitFor(() => {
|
|
371
|
-
expect(result.current.phase).toBe("complete");
|
|
372
|
-
});
|
|
373
|
-
expect(result.current.extractedYaml).toBe(yamlContent);
|
|
374
|
-
});
|
|
375
|
-
});
|
|
376
|
-
//# sourceMappingURL=useWorkflowArchitectFlow.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useWorkflowArchitectFlow.test.js","sourceRoot":"","sources":["../../../src/workflow/__tests__/useWorkflowArchitectFlow.test.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useWorkflowExecution.test.d.ts","sourceRoot":"","sources":["../../../src/workflow/__tests__/useWorkflowExecution.test.tsx"],"names":[],"mappings":""}
|
|
@@ -1,229 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, vi, beforeEach } from "vitest";
|
|
2
|
-
import { renderHook, act } from "@testing-library/react";
|
|
3
|
-
import { createElement } from "react";
|
|
4
|
-
import { StigmerContext } from "../../context";
|
|
5
|
-
import { RunnerAdapterContext } from "../../runner-adapter";
|
|
6
|
-
import { ExecutionTargetContext } from "../../execution-target-context";
|
|
7
|
-
import { useWorkflowExecution } from "../useWorkflowExecution";
|
|
8
|
-
// ---------------------------------------------------------------------------
|
|
9
|
-
// Helpers
|
|
10
|
-
// ---------------------------------------------------------------------------
|
|
11
|
-
async function flush() {
|
|
12
|
-
await act(async () => {
|
|
13
|
-
await Promise.resolve();
|
|
14
|
-
});
|
|
15
|
-
}
|
|
16
|
-
function makeExecution(id, phase, opts) {
|
|
17
|
-
return {
|
|
18
|
-
metadata: { id, name: opts?.name ?? `exec-${id}`, org: "org-1" },
|
|
19
|
-
status: { phase },
|
|
20
|
-
spec: {},
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
|
-
// Phase constants matching the proto enum
|
|
24
|
-
const PHASE = {
|
|
25
|
-
IN_PROGRESS: 2,
|
|
26
|
-
COMPLETED: 3,
|
|
27
|
-
FAILED: 4,
|
|
28
|
-
CANCELLED: 5,
|
|
29
|
-
TERMINATED: 6,
|
|
30
|
-
};
|
|
31
|
-
function makeMockClient(getFn) {
|
|
32
|
-
return {
|
|
33
|
-
workflowExecution: { get: getFn },
|
|
34
|
-
};
|
|
35
|
-
}
|
|
36
|
-
function makeMockAdapter() {
|
|
37
|
-
const calls = [];
|
|
38
|
-
return {
|
|
39
|
-
calls,
|
|
40
|
-
onSessionCreated: vi.fn(async (id) => { calls.push(["onSessionCreated", id]); }),
|
|
41
|
-
onSessionTerminated: vi.fn(async (id) => { calls.push(["onSessionTerminated", id]); }),
|
|
42
|
-
onWorkflowExecutionCreated: vi.fn(async (id) => { calls.push(["onWorkflowExecutionCreated", id]); }),
|
|
43
|
-
onWorkflowExecutionTerminated: vi.fn(async (id) => { calls.push(["onWorkflowExecutionTerminated", id]); }),
|
|
44
|
-
};
|
|
45
|
-
}
|
|
46
|
-
function createWrapper(client, adapter = null, executionTarget = "local") {
|
|
47
|
-
return function Wrapper({ children }) {
|
|
48
|
-
return createElement(StigmerContext.Provider, { value: client }, createElement(RunnerAdapterContext.Provider, { value: adapter }, createElement(ExecutionTargetContext.Provider, { value: executionTarget }, children)));
|
|
49
|
-
};
|
|
50
|
-
}
|
|
51
|
-
beforeEach(() => {
|
|
52
|
-
vi.clearAllMocks();
|
|
53
|
-
});
|
|
54
|
-
// ---------------------------------------------------------------------------
|
|
55
|
-
// Core data fetching
|
|
56
|
-
// ---------------------------------------------------------------------------
|
|
57
|
-
describe("useWorkflowExecution — data fetching", () => {
|
|
58
|
-
it("fetches execution by id", async () => {
|
|
59
|
-
const exec = makeExecution("wex-001", PHASE.IN_PROGRESS);
|
|
60
|
-
const getFn = vi.fn(async () => exec);
|
|
61
|
-
const client = makeMockClient(getFn);
|
|
62
|
-
const { result } = renderHook(() => useWorkflowExecution("wex-001"), { wrapper: createWrapper(client) });
|
|
63
|
-
await flush();
|
|
64
|
-
expect(result.current.execution).toBe(exec);
|
|
65
|
-
expect(result.current.isLoading).toBe(false);
|
|
66
|
-
expect(result.current.error).toBeNull();
|
|
67
|
-
expect(getFn).toHaveBeenCalledWith("wex-001");
|
|
68
|
-
});
|
|
69
|
-
it("returns null execution when id is null", async () => {
|
|
70
|
-
const getFn = vi.fn(async () => makeExecution("wex-001", PHASE.IN_PROGRESS));
|
|
71
|
-
const client = makeMockClient(getFn);
|
|
72
|
-
const { result } = renderHook(() => useWorkflowExecution(null), { wrapper: createWrapper(client) });
|
|
73
|
-
await flush();
|
|
74
|
-
expect(result.current.execution).toBeNull();
|
|
75
|
-
expect(result.current.isLoading).toBe(false);
|
|
76
|
-
expect(getFn).not.toHaveBeenCalled();
|
|
77
|
-
});
|
|
78
|
-
it("handles NOT_FOUND by returning null without error", async () => {
|
|
79
|
-
const notFoundErr = new Error("not found");
|
|
80
|
-
notFoundErr.code = "NOT_FOUND";
|
|
81
|
-
// The hook uses isNotFound from @stigmer/sdk, so mock it globally
|
|
82
|
-
const getFn = vi.fn(async () => {
|
|
83
|
-
throw notFoundErr;
|
|
84
|
-
});
|
|
85
|
-
const client = makeMockClient(getFn);
|
|
86
|
-
const { result } = renderHook(() => useWorkflowExecution("wex-gone"), { wrapper: createWrapper(client) });
|
|
87
|
-
await flush();
|
|
88
|
-
// The hook will either return null (if isNotFound handles it) or set an error.
|
|
89
|
-
// Either way, verify we don't crash.
|
|
90
|
-
expect(result.current.isLoading).toBe(false);
|
|
91
|
-
});
|
|
92
|
-
});
|
|
93
|
-
// ---------------------------------------------------------------------------
|
|
94
|
-
// Identity guard: Layer 2 defense against stale data
|
|
95
|
-
//
|
|
96
|
-
// This is the critical test suite that validates the fix for the premature
|
|
97
|
-
// worker shutdown bug. The identity guard ensures that
|
|
98
|
-
// onWorkflowExecutionTerminated is ONLY called when the fetched execution's
|
|
99
|
-
// metadata.id matches the currently requested executionId.
|
|
100
|
-
// ---------------------------------------------------------------------------
|
|
101
|
-
describe("useWorkflowExecution — identity guard (Layer 2)", () => {
|
|
102
|
-
it("calls onWorkflowExecutionTerminated when execution reaches terminal phase", async () => {
|
|
103
|
-
const exec = makeExecution("wex-done", PHASE.COMPLETED);
|
|
104
|
-
const getFn = vi.fn(async () => exec);
|
|
105
|
-
const client = makeMockClient(getFn);
|
|
106
|
-
const adapter = makeMockAdapter();
|
|
107
|
-
const { result } = renderHook(() => useWorkflowExecution("wex-done"), { wrapper: createWrapper(client, adapter, "local") });
|
|
108
|
-
await flush();
|
|
109
|
-
expect(result.current.execution).toBe(exec);
|
|
110
|
-
expect(adapter.onWorkflowExecutionTerminated).toHaveBeenCalledWith("wex-done");
|
|
111
|
-
expect(adapter.onWorkflowExecutionTerminated).toHaveBeenCalledTimes(1);
|
|
112
|
-
});
|
|
113
|
-
it("does NOT call onWorkflowExecutionTerminated for non-terminal phases", async () => {
|
|
114
|
-
const exec = makeExecution("wex-running", PHASE.IN_PROGRESS);
|
|
115
|
-
const getFn = vi.fn(async () => exec);
|
|
116
|
-
const client = makeMockClient(getFn);
|
|
117
|
-
const adapter = makeMockAdapter();
|
|
118
|
-
renderHook(() => useWorkflowExecution("wex-running"), { wrapper: createWrapper(client, adapter, "local") });
|
|
119
|
-
await flush();
|
|
120
|
-
expect(adapter.onWorkflowExecutionTerminated).not.toHaveBeenCalled();
|
|
121
|
-
});
|
|
122
|
-
it("does NOT call onWorkflowExecutionTerminated when adapter is null (cloud mode)", async () => {
|
|
123
|
-
const exec = makeExecution("wex-cloud", PHASE.COMPLETED);
|
|
124
|
-
const getFn = vi.fn(async () => exec);
|
|
125
|
-
const client = makeMockClient(getFn);
|
|
126
|
-
renderHook(() => useWorkflowExecution("wex-cloud"), { wrapper: createWrapper(client, null, "cloud") });
|
|
127
|
-
await flush();
|
|
128
|
-
// No adapter, no call — cloud deployments don't manage runners
|
|
129
|
-
});
|
|
130
|
-
it("does NOT fire termination for stale data from a different execution ID", async () => {
|
|
131
|
-
// This is the exact scenario that caused the premature worker shutdown:
|
|
132
|
-
// - User navigates from completed exec-A to running exec-B
|
|
133
|
-
// - useFetch briefly holds exec-A's COMPLETED data while exec-B loads
|
|
134
|
-
// - Without the identity guard, the termination effect would fire
|
|
135
|
-
// onWorkflowExecutionTerminated("exec-B") using exec-A's phase
|
|
136
|
-
//
|
|
137
|
-
// The fix: `fetchedId === executionId` guard prevents this.
|
|
138
|
-
const execA = makeExecution("exec-A", PHASE.COMPLETED);
|
|
139
|
-
const execB = makeExecution("exec-B", PHASE.IN_PROGRESS);
|
|
140
|
-
let currentId = "exec-A";
|
|
141
|
-
const getFn = vi.fn(async (id) => {
|
|
142
|
-
if (id === "exec-A")
|
|
143
|
-
return execA;
|
|
144
|
-
if (id === "exec-B")
|
|
145
|
-
return execB;
|
|
146
|
-
return null;
|
|
147
|
-
});
|
|
148
|
-
const client = makeMockClient(getFn);
|
|
149
|
-
const adapter = makeMockAdapter();
|
|
150
|
-
const { rerender } = renderHook(() => useWorkflowExecution(currentId), { wrapper: createWrapper(client, adapter, "local") });
|
|
151
|
-
// Exec-A completes → termination fires for exec-A
|
|
152
|
-
await flush();
|
|
153
|
-
expect(adapter.onWorkflowExecutionTerminated).toHaveBeenCalledWith("exec-A");
|
|
154
|
-
expect(adapter.onWorkflowExecutionTerminated).toHaveBeenCalledTimes(1);
|
|
155
|
-
// Clear mocks to track new calls
|
|
156
|
-
vi.clearAllMocks();
|
|
157
|
-
// Switch to exec-B (running) — the key moment
|
|
158
|
-
currentId = "exec-B";
|
|
159
|
-
rerender();
|
|
160
|
-
// useFetch should reset data to null (initialData) due to cache miss.
|
|
161
|
-
// Even if stale exec-A data briefly appears, the identity guard
|
|
162
|
-
// (fetchedId === executionId) prevents termination of exec-B.
|
|
163
|
-
await flush();
|
|
164
|
-
// onWorkflowExecutionTerminated must NOT have been called for exec-B
|
|
165
|
-
// because exec-B is IN_PROGRESS, not terminal.
|
|
166
|
-
expect(adapter.onWorkflowExecutionTerminated).not.toHaveBeenCalled();
|
|
167
|
-
});
|
|
168
|
-
it("fires termination only once per execution (dedup via terminatedRef)", async () => {
|
|
169
|
-
const exec = makeExecution("wex-dedup", PHASE.FAILED);
|
|
170
|
-
const getFn = vi.fn(async () => exec);
|
|
171
|
-
const client = makeMockClient(getFn);
|
|
172
|
-
const adapter = makeMockAdapter();
|
|
173
|
-
const { result } = renderHook(() => useWorkflowExecution("wex-dedup"), { wrapper: createWrapper(client, adapter, "local") });
|
|
174
|
-
await flush();
|
|
175
|
-
expect(adapter.onWorkflowExecutionTerminated).toHaveBeenCalledTimes(1);
|
|
176
|
-
// Trigger a refetch — the execution is still FAILED
|
|
177
|
-
await act(async () => {
|
|
178
|
-
result.current.refetch();
|
|
179
|
-
});
|
|
180
|
-
await flush();
|
|
181
|
-
// Should NOT fire again due to terminatedRef dedup
|
|
182
|
-
expect(adapter.onWorkflowExecutionTerminated).toHaveBeenCalledTimes(1);
|
|
183
|
-
});
|
|
184
|
-
it("resets terminatedRef when executionId changes", async () => {
|
|
185
|
-
const execX = makeExecution("wex-X", PHASE.COMPLETED);
|
|
186
|
-
const execY = makeExecution("wex-Y", PHASE.COMPLETED);
|
|
187
|
-
let currentId = "wex-X";
|
|
188
|
-
const getFn = vi.fn(async (id) => {
|
|
189
|
-
if (id === "wex-X")
|
|
190
|
-
return execX;
|
|
191
|
-
if (id === "wex-Y")
|
|
192
|
-
return execY;
|
|
193
|
-
return null;
|
|
194
|
-
});
|
|
195
|
-
const client = makeMockClient(getFn);
|
|
196
|
-
const adapter = makeMockAdapter();
|
|
197
|
-
const { rerender } = renderHook(() => useWorkflowExecution(currentId), { wrapper: createWrapper(client, adapter, "local") });
|
|
198
|
-
await flush();
|
|
199
|
-
expect(adapter.onWorkflowExecutionTerminated).toHaveBeenCalledWith("wex-X");
|
|
200
|
-
expect(adapter.onWorkflowExecutionTerminated).toHaveBeenCalledTimes(1);
|
|
201
|
-
// Switch to a different completed execution
|
|
202
|
-
currentId = "wex-Y";
|
|
203
|
-
rerender();
|
|
204
|
-
await flush();
|
|
205
|
-
// terminatedRef should have been reset by the executionId change effect,
|
|
206
|
-
// so termination fires for wex-Y too
|
|
207
|
-
expect(adapter.onWorkflowExecutionTerminated).toHaveBeenCalledWith("wex-Y");
|
|
208
|
-
expect(adapter.onWorkflowExecutionTerminated).toHaveBeenCalledTimes(2);
|
|
209
|
-
});
|
|
210
|
-
it("handles all terminal phases correctly", async () => {
|
|
211
|
-
const terminalPhases = [
|
|
212
|
-
PHASE.COMPLETED,
|
|
213
|
-
PHASE.FAILED,
|
|
214
|
-
PHASE.CANCELLED,
|
|
215
|
-
PHASE.TERMINATED,
|
|
216
|
-
];
|
|
217
|
-
for (const phase of terminalPhases) {
|
|
218
|
-
vi.clearAllMocks();
|
|
219
|
-
const exec = makeExecution(`wex-${phase}`, phase);
|
|
220
|
-
const getFn = vi.fn(async () => exec);
|
|
221
|
-
const client = makeMockClient(getFn);
|
|
222
|
-
const adapter = makeMockAdapter();
|
|
223
|
-
renderHook(() => useWorkflowExecution(`wex-${phase}`), { wrapper: createWrapper(client, adapter, "local") });
|
|
224
|
-
await flush();
|
|
225
|
-
expect(adapter.onWorkflowExecutionTerminated).toHaveBeenCalledTimes(1);
|
|
226
|
-
}
|
|
227
|
-
});
|
|
228
|
-
});
|
|
229
|
-
//# sourceMappingURL=useWorkflowExecution.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useWorkflowExecution.test.js","sourceRoot":"","sources":["../../../src/workflow/__tests__/useWorkflowExecution.test.tsx"],"names":[],"mappings":"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"}
|