groundswell 0.0.3 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (292) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +26 -9
  3. package/dist/cache/cache-key.d.ts +20 -0
  4. package/dist/cache/cache-key.d.ts.map +1 -1
  5. package/dist/cache/cache-key.js +9 -0
  6. package/dist/cache/cache-key.js.map +1 -1
  7. package/dist/core/agent.d.ts +120 -29
  8. package/dist/core/agent.d.ts.map +1 -1
  9. package/dist/core/agent.js +584 -177
  10. package/dist/core/agent.js.map +1 -1
  11. package/dist/core/mcp-handler.d.ts +63 -5
  12. package/dist/core/mcp-handler.d.ts.map +1 -1
  13. package/dist/core/mcp-handler.js +184 -4
  14. package/dist/core/mcp-handler.js.map +1 -1
  15. package/dist/core/workflow-context.d.ts +6 -2
  16. package/dist/core/workflow-context.d.ts.map +1 -1
  17. package/dist/core/workflow-context.js +99 -4
  18. package/dist/core/workflow-context.js.map +1 -1
  19. package/dist/core/workflow.d.ts +315 -13
  20. package/dist/core/workflow.d.ts.map +1 -1
  21. package/dist/core/workflow.js +552 -30
  22. package/dist/core/workflow.js.map +1 -1
  23. package/dist/debugger/event-replayer.d.ts +422 -0
  24. package/dist/debugger/event-replayer.d.ts.map +1 -0
  25. package/dist/debugger/event-replayer.js +639 -0
  26. package/dist/debugger/event-replayer.js.map +1 -0
  27. package/dist/debugger/tree-debugger.d.ts +170 -1
  28. package/dist/debugger/tree-debugger.d.ts.map +1 -1
  29. package/dist/debugger/tree-debugger.js +423 -1
  30. package/dist/debugger/tree-debugger.js.map +1 -1
  31. package/dist/decorators/step.d.ts.map +1 -1
  32. package/dist/decorators/step.js +129 -47
  33. package/dist/decorators/step.js.map +1 -1
  34. package/dist/harnesses/claude-code-harness.d.ts +391 -0
  35. package/dist/harnesses/claude-code-harness.d.ts.map +1 -0
  36. package/dist/harnesses/claude-code-harness.js +1076 -0
  37. package/dist/harnesses/claude-code-harness.js.map +1 -0
  38. package/dist/harnesses/harness-registry.d.ts +440 -0
  39. package/dist/harnesses/harness-registry.d.ts.map +1 -0
  40. package/dist/harnesses/harness-registry.js +543 -0
  41. package/dist/harnesses/harness-registry.js.map +1 -0
  42. package/dist/harnesses/index.d.ts +12 -0
  43. package/dist/harnesses/index.d.ts.map +1 -0
  44. package/dist/harnesses/index.js +11 -0
  45. package/dist/harnesses/index.js.map +1 -0
  46. package/dist/harnesses/pi-harness.d.ts +219 -0
  47. package/dist/harnesses/pi-harness.d.ts.map +1 -0
  48. package/dist/harnesses/pi-harness.js +676 -0
  49. package/dist/harnesses/pi-harness.js.map +1 -0
  50. package/dist/harnesses/pi-schema-converter.d.ts +24 -0
  51. package/dist/harnesses/pi-schema-converter.d.ts.map +1 -0
  52. package/dist/harnesses/pi-schema-converter.js +81 -0
  53. package/dist/harnesses/pi-schema-converter.js.map +1 -0
  54. package/dist/harnesses/register-defaults.d.ts +24 -0
  55. package/dist/harnesses/register-defaults.d.ts.map +1 -0
  56. package/dist/harnesses/register-defaults.js +40 -0
  57. package/dist/harnesses/register-defaults.js.map +1 -0
  58. package/dist/harnesses/session-store.d.ts +201 -0
  59. package/dist/harnesses/session-store.d.ts.map +1 -0
  60. package/dist/harnesses/session-store.js +254 -0
  61. package/dist/harnesses/session-store.js.map +1 -0
  62. package/dist/index.d.ts +12 -2
  63. package/dist/index.d.ts.map +1 -1
  64. package/dist/index.js +17 -0
  65. package/dist/index.js.map +1 -1
  66. package/dist/reflection/reflection.d.ts.map +1 -1
  67. package/dist/reflection/reflection.js +19 -4
  68. package/dist/reflection/reflection.js.map +1 -1
  69. package/dist/types/agent.d.ts +1253 -2
  70. package/dist/types/agent.d.ts.map +1 -1
  71. package/dist/types/agent.js +418 -1
  72. package/dist/types/agent.js.map +1 -1
  73. package/dist/types/decorators.d.ts +10 -1
  74. package/dist/types/decorators.d.ts.map +1 -1
  75. package/dist/types/events.d.ts +26 -0
  76. package/dist/types/events.d.ts.map +1 -1
  77. package/dist/types/harnesses.d.ts +474 -0
  78. package/dist/types/harnesses.d.ts.map +1 -0
  79. package/dist/types/harnesses.js +2 -0
  80. package/dist/types/harnesses.js.map +1 -0
  81. package/dist/types/index.d.ts +9 -1
  82. package/dist/types/index.d.ts.map +1 -1
  83. package/dist/types/index.js +6 -0
  84. package/dist/types/index.js.map +1 -1
  85. package/dist/types/providers.d.ts +691 -0
  86. package/dist/types/providers.d.ts.map +1 -0
  87. package/dist/types/providers.js +14 -0
  88. package/dist/types/providers.js.map +1 -0
  89. package/dist/types/restart.d.ts +132 -0
  90. package/dist/types/restart.d.ts.map +1 -0
  91. package/dist/types/restart.js +2 -0
  92. package/dist/types/restart.js.map +1 -0
  93. package/dist/types/streaming.d.ts +194 -0
  94. package/dist/types/streaming.d.ts.map +1 -0
  95. package/dist/types/streaming.js +67 -0
  96. package/dist/types/streaming.js.map +1 -0
  97. package/dist/types/workflow-context.d.ts +137 -1
  98. package/dist/types/workflow-context.d.ts.map +1 -1
  99. package/dist/utils/agent-validation.d.ts +88 -0
  100. package/dist/utils/agent-validation.d.ts.map +1 -0
  101. package/dist/utils/agent-validation.js +87 -0
  102. package/dist/utils/agent-validation.js.map +1 -0
  103. package/dist/utils/delay.d.ts +7 -0
  104. package/dist/utils/delay.d.ts.map +1 -0
  105. package/dist/utils/delay.js +9 -0
  106. package/dist/utils/delay.js.map +1 -0
  107. package/dist/utils/harness-config.d.ts +180 -0
  108. package/dist/utils/harness-config.d.ts.map +1 -0
  109. package/dist/utils/harness-config.js +311 -0
  110. package/dist/utils/harness-config.js.map +1 -0
  111. package/dist/utils/index.d.ts +9 -1
  112. package/dist/utils/index.d.ts.map +1 -1
  113. package/dist/utils/index.js +8 -1
  114. package/dist/utils/index.js.map +1 -1
  115. package/dist/utils/model-spec.d.ts +110 -0
  116. package/dist/utils/model-spec.d.ts.map +1 -0
  117. package/dist/utils/model-spec.js +149 -0
  118. package/dist/utils/model-spec.js.map +1 -0
  119. package/dist/utils/provider-config.d.ts +10 -0
  120. package/dist/utils/provider-config.d.ts.map +1 -0
  121. package/dist/utils/provider-config.js +10 -0
  122. package/dist/utils/provider-config.js.map +1 -0
  123. package/dist/utils/restart-analysis.d.ts +202 -0
  124. package/dist/utils/restart-analysis.d.ts.map +1 -0
  125. package/dist/utils/restart-analysis.js +426 -0
  126. package/dist/utils/restart-analysis.js.map +1 -0
  127. package/dist/utils/session-serialization.d.ts +118 -0
  128. package/dist/utils/session-serialization.d.ts.map +1 -0
  129. package/dist/utils/session-serialization.js +217 -0
  130. package/dist/utils/session-serialization.js.map +1 -0
  131. package/package.json +31 -5
  132. package/CHANGELOG.md +0 -188
  133. package/dist/__tests__/adversarial/attachChild-performance.test.d.ts +0 -16
  134. package/dist/__tests__/adversarial/attachChild-performance.test.d.ts.map +0 -1
  135. package/dist/__tests__/adversarial/attachChild-performance.test.js +0 -187
  136. package/dist/__tests__/adversarial/attachChild-performance.test.js.map +0 -1
  137. package/dist/__tests__/adversarial/circular-reference.test.d.ts +0 -13
  138. package/dist/__tests__/adversarial/circular-reference.test.d.ts.map +0 -1
  139. package/dist/__tests__/adversarial/circular-reference.test.js +0 -92
  140. package/dist/__tests__/adversarial/circular-reference.test.js.map +0 -1
  141. package/dist/__tests__/adversarial/complex-circular-reference.test.d.ts +0 -16
  142. package/dist/__tests__/adversarial/complex-circular-reference.test.d.ts.map +0 -1
  143. package/dist/__tests__/adversarial/complex-circular-reference.test.js +0 -127
  144. package/dist/__tests__/adversarial/complex-circular-reference.test.js.map +0 -1
  145. package/dist/__tests__/adversarial/concurrent-task-failures.test.d.ts +0 -21
  146. package/dist/__tests__/adversarial/concurrent-task-failures.test.d.ts.map +0 -1
  147. package/dist/__tests__/adversarial/concurrent-task-failures.test.js +0 -667
  148. package/dist/__tests__/adversarial/concurrent-task-failures.test.js.map +0 -1
  149. package/dist/__tests__/adversarial/deep-analysis.test.d.ts +0 -6
  150. package/dist/__tests__/adversarial/deep-analysis.test.d.ts.map +0 -1
  151. package/dist/__tests__/adversarial/deep-analysis.test.js +0 -877
  152. package/dist/__tests__/adversarial/deep-analysis.test.js.map +0 -1
  153. package/dist/__tests__/adversarial/deep-hierarchy-stress.test.d.ts +0 -13
  154. package/dist/__tests__/adversarial/deep-hierarchy-stress.test.d.ts.map +0 -1
  155. package/dist/__tests__/adversarial/deep-hierarchy-stress.test.js +0 -186
  156. package/dist/__tests__/adversarial/deep-hierarchy-stress.test.js.map +0 -1
  157. package/dist/__tests__/adversarial/e2e-prd-validation.test.d.ts +0 -6
  158. package/dist/__tests__/adversarial/e2e-prd-validation.test.d.ts.map +0 -1
  159. package/dist/__tests__/adversarial/e2e-prd-validation.test.js +0 -626
  160. package/dist/__tests__/adversarial/e2e-prd-validation.test.js.map +0 -1
  161. package/dist/__tests__/adversarial/edge-case.test.d.ts +0 -6
  162. package/dist/__tests__/adversarial/edge-case.test.d.ts.map +0 -1
  163. package/dist/__tests__/adversarial/edge-case.test.js +0 -857
  164. package/dist/__tests__/adversarial/edge-case.test.js.map +0 -1
  165. package/dist/__tests__/adversarial/error-merge-strategy.test.d.ts +0 -20
  166. package/dist/__tests__/adversarial/error-merge-strategy.test.d.ts.map +0 -1
  167. package/dist/__tests__/adversarial/error-merge-strategy.test.js +0 -907
  168. package/dist/__tests__/adversarial/error-merge-strategy.test.js.map +0 -1
  169. package/dist/__tests__/adversarial/incremental-performance.test.d.ts +0 -2
  170. package/dist/__tests__/adversarial/incremental-performance.test.d.ts.map +0 -1
  171. package/dist/__tests__/adversarial/incremental-performance.test.js +0 -113
  172. package/dist/__tests__/adversarial/incremental-performance.test.js.map +0 -1
  173. package/dist/__tests__/adversarial/node-map-update-benchmarks.test.d.ts +0 -22
  174. package/dist/__tests__/adversarial/node-map-update-benchmarks.test.d.ts.map +0 -1
  175. package/dist/__tests__/adversarial/node-map-update-benchmarks.test.js +0 -383
  176. package/dist/__tests__/adversarial/node-map-update-benchmarks.test.js.map +0 -1
  177. package/dist/__tests__/adversarial/observer-propagation.test.d.ts +0 -21
  178. package/dist/__tests__/adversarial/observer-propagation.test.d.ts.map +0 -1
  179. package/dist/__tests__/adversarial/observer-propagation.test.js +0 -404
  180. package/dist/__tests__/adversarial/observer-propagation.test.js.map +0 -1
  181. package/dist/__tests__/adversarial/parent-validation.test.d.ts +0 -13
  182. package/dist/__tests__/adversarial/parent-validation.test.d.ts.map +0 -1
  183. package/dist/__tests__/adversarial/parent-validation.test.js +0 -128
  184. package/dist/__tests__/adversarial/parent-validation.test.js.map +0 -1
  185. package/dist/__tests__/adversarial/prd-12-2-compliance.test.d.ts +0 -20
  186. package/dist/__tests__/adversarial/prd-12-2-compliance.test.d.ts.map +0 -1
  187. package/dist/__tests__/adversarial/prd-12-2-compliance.test.js +0 -482
  188. package/dist/__tests__/adversarial/prd-12-2-compliance.test.js.map +0 -1
  189. package/dist/__tests__/adversarial/prd-compliance.test.d.ts +0 -6
  190. package/dist/__tests__/adversarial/prd-compliance.test.d.ts.map +0 -1
  191. package/dist/__tests__/adversarial/prd-compliance.test.js +0 -886
  192. package/dist/__tests__/adversarial/prd-compliance.test.js.map +0 -1
  193. package/dist/__tests__/compatibility/backward-compatibility.test.d.ts +0 -22
  194. package/dist/__tests__/compatibility/backward-compatibility.test.d.ts.map +0 -1
  195. package/dist/__tests__/compatibility/backward-compatibility.test.js +0 -1843
  196. package/dist/__tests__/compatibility/backward-compatibility.test.js.map +0 -1
  197. package/dist/__tests__/helpers/index.d.ts +0 -10
  198. package/dist/__tests__/helpers/index.d.ts.map +0 -1
  199. package/dist/__tests__/helpers/index.js +0 -10
  200. package/dist/__tests__/helpers/index.js.map +0 -1
  201. package/dist/__tests__/helpers/tree-verification.d.ts +0 -90
  202. package/dist/__tests__/helpers/tree-verification.d.ts.map +0 -1
  203. package/dist/__tests__/helpers/tree-verification.js +0 -202
  204. package/dist/__tests__/helpers/tree-verification.js.map +0 -1
  205. package/dist/__tests__/integration/agent-workflow.test.d.ts +0 -2
  206. package/dist/__tests__/integration/agent-workflow.test.d.ts.map +0 -1
  207. package/dist/__tests__/integration/agent-workflow.test.js +0 -256
  208. package/dist/__tests__/integration/agent-workflow.test.js.map +0 -1
  209. package/dist/__tests__/integration/bidirectional-consistency.test.d.ts +0 -14
  210. package/dist/__tests__/integration/bidirectional-consistency.test.d.ts.map +0 -1
  211. package/dist/__tests__/integration/bidirectional-consistency.test.js +0 -668
  212. package/dist/__tests__/integration/bidirectional-consistency.test.js.map +0 -1
  213. package/dist/__tests__/integration/observer-logging.test.d.ts +0 -2
  214. package/dist/__tests__/integration/observer-logging.test.d.ts.map +0 -1
  215. package/dist/__tests__/integration/observer-logging.test.js +0 -517
  216. package/dist/__tests__/integration/observer-logging.test.js.map +0 -1
  217. package/dist/__tests__/integration/tree-mirroring.test.d.ts +0 -2
  218. package/dist/__tests__/integration/tree-mirroring.test.d.ts.map +0 -1
  219. package/dist/__tests__/integration/tree-mirroring.test.js +0 -117
  220. package/dist/__tests__/integration/tree-mirroring.test.js.map +0 -1
  221. package/dist/__tests__/integration/workflow-reparenting.test.d.ts +0 -12
  222. package/dist/__tests__/integration/workflow-reparenting.test.d.ts.map +0 -1
  223. package/dist/__tests__/integration/workflow-reparenting.test.js +0 -239
  224. package/dist/__tests__/integration/workflow-reparenting.test.js.map +0 -1
  225. package/dist/__tests__/unit/agent.test.d.ts +0 -2
  226. package/dist/__tests__/unit/agent.test.d.ts.map +0 -1
  227. package/dist/__tests__/unit/agent.test.js +0 -143
  228. package/dist/__tests__/unit/agent.test.js.map +0 -1
  229. package/dist/__tests__/unit/cache-key.test.d.ts +0 -5
  230. package/dist/__tests__/unit/cache-key.test.d.ts.map +0 -1
  231. package/dist/__tests__/unit/cache-key.test.js +0 -145
  232. package/dist/__tests__/unit/cache-key.test.js.map +0 -1
  233. package/dist/__tests__/unit/cache.test.d.ts +0 -5
  234. package/dist/__tests__/unit/cache.test.d.ts.map +0 -1
  235. package/dist/__tests__/unit/cache.test.js +0 -132
  236. package/dist/__tests__/unit/cache.test.js.map +0 -1
  237. package/dist/__tests__/unit/context.test.d.ts +0 -2
  238. package/dist/__tests__/unit/context.test.d.ts.map +0 -1
  239. package/dist/__tests__/unit/context.test.js +0 -220
  240. package/dist/__tests__/unit/context.test.js.map +0 -1
  241. package/dist/__tests__/unit/decorators.test.d.ts +0 -2
  242. package/dist/__tests__/unit/decorators.test.d.ts.map +0 -1
  243. package/dist/__tests__/unit/decorators.test.js +0 -162
  244. package/dist/__tests__/unit/decorators.test.js.map +0 -1
  245. package/dist/__tests__/unit/introspection-tools.test.d.ts +0 -5
  246. package/dist/__tests__/unit/introspection-tools.test.d.ts.map +0 -1
  247. package/dist/__tests__/unit/introspection-tools.test.js +0 -191
  248. package/dist/__tests__/unit/introspection-tools.test.js.map +0 -1
  249. package/dist/__tests__/unit/logger.test.d.ts +0 -2
  250. package/dist/__tests__/unit/logger.test.d.ts.map +0 -1
  251. package/dist/__tests__/unit/logger.test.js +0 -241
  252. package/dist/__tests__/unit/logger.test.js.map +0 -1
  253. package/dist/__tests__/unit/observable.test.d.ts +0 -2
  254. package/dist/__tests__/unit/observable.test.d.ts.map +0 -1
  255. package/dist/__tests__/unit/observable.test.js +0 -251
  256. package/dist/__tests__/unit/observable.test.js.map +0 -1
  257. package/dist/__tests__/unit/prompt.test.d.ts +0 -2
  258. package/dist/__tests__/unit/prompt.test.d.ts.map +0 -1
  259. package/dist/__tests__/unit/prompt.test.js +0 -113
  260. package/dist/__tests__/unit/prompt.test.js.map +0 -1
  261. package/dist/__tests__/unit/reflection.test.d.ts +0 -5
  262. package/dist/__tests__/unit/reflection.test.d.ts.map +0 -1
  263. package/dist/__tests__/unit/reflection.test.js +0 -160
  264. package/dist/__tests__/unit/reflection.test.js.map +0 -1
  265. package/dist/__tests__/unit/tree-debugger-incremental.test.d.ts +0 -2
  266. package/dist/__tests__/unit/tree-debugger-incremental.test.d.ts.map +0 -1
  267. package/dist/__tests__/unit/tree-debugger-incremental.test.js +0 -136
  268. package/dist/__tests__/unit/tree-debugger-incremental.test.js.map +0 -1
  269. package/dist/__tests__/unit/tree-debugger.test.d.ts +0 -2
  270. package/dist/__tests__/unit/tree-debugger.test.d.ts.map +0 -1
  271. package/dist/__tests__/unit/tree-debugger.test.js +0 -69
  272. package/dist/__tests__/unit/tree-debugger.test.js.map +0 -1
  273. package/dist/__tests__/unit/utils/workflow-error-utils.test.d.ts +0 -2
  274. package/dist/__tests__/unit/utils/workflow-error-utils.test.d.ts.map +0 -1
  275. package/dist/__tests__/unit/utils/workflow-error-utils.test.js +0 -154
  276. package/dist/__tests__/unit/utils/workflow-error-utils.test.js.map +0 -1
  277. package/dist/__tests__/unit/workflow-detachChild.test.d.ts +0 -2
  278. package/dist/__tests__/unit/workflow-detachChild.test.d.ts.map +0 -1
  279. package/dist/__tests__/unit/workflow-detachChild.test.js +0 -76
  280. package/dist/__tests__/unit/workflow-detachChild.test.js.map +0 -1
  281. package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.d.ts +0 -2
  282. package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.d.ts.map +0 -1
  283. package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.js +0 -122
  284. package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.js.map +0 -1
  285. package/dist/__tests__/unit/workflow-isDescendantOf.test.d.ts +0 -2
  286. package/dist/__tests__/unit/workflow-isDescendantOf.test.d.ts.map +0 -1
  287. package/dist/__tests__/unit/workflow-isDescendantOf.test.js +0 -140
  288. package/dist/__tests__/unit/workflow-isDescendantOf.test.js.map +0 -1
  289. package/dist/__tests__/unit/workflow.test.d.ts +0 -2
  290. package/dist/__tests__/unit/workflow.test.d.ts.map +0 -1
  291. package/dist/__tests__/unit/workflow.test.js +0 -330
  292. package/dist/__tests__/unit/workflow.test.js.map +0 -1
@@ -0,0 +1,639 @@
1
+ /**
2
+ * WorkflowEventReplayer - Reconstruct workflow tree from event history
3
+ *
4
+ * **Purpose**: Enables time-travel debugging by replaying workflow events
5
+ * to reconstruct workflow tree state at any point in execution history.
6
+ *
7
+ * **Phase 1 Scope**: Interface definition only. Implementation will be added
8
+ * in future PRPs (P2.M1.T1.S2 for structural events, P2.M1.T1.S3 for state events).
9
+ *
10
+ * **Architecture**:
11
+ * - Uses Map-based node tracking for O(1) lookups (pattern from WorkflowTreeDebugger)
12
+ * - Processes events sequentially using discriminated union pattern
13
+ * - Maintains tree invariants: single-parent rule, bidirectional references, no cycles
14
+ *
15
+ * **Event Categorization**:
16
+ * - **Structural Events** (modify tree structure): childAttached, childDetached, treeUpdated
17
+ * - **State Events** (update node properties): stateSnapshot, error
18
+ * - **Metadata Events** (logged but don't modify tree): agentPrompt*, toolInvocation, mcpEvent, reflection*, cache*, task*, step*
19
+ *
20
+ * @example
21
+ * ```typescript
22
+ * const replayer = new WorkflowEventReplayer();
23
+ * const tree = replayer.replay(eventStream);
24
+ * console.log(`Tree has ${tree.children.length} root children`);
25
+ * ```
26
+ */
27
+ export class WorkflowEventReplayer {
28
+ /** Node lookup map for O(1) access */
29
+ nodeMap = new Map();
30
+ /** Root node of reconstructed tree */
31
+ root = null;
32
+ /**
33
+ * Replay a sequence of workflow events to reconstruct the workflow tree.
34
+ *
35
+ * **Event Processing Strategy:**
36
+ * - Processes events sequentially in order
37
+ * - Uses try-catch per event to isolate errors
38
+ * - Logs errors and continues processing on failure
39
+ * - Throws only if root cannot be established
40
+ *
41
+ * **Phase 1 - Structural Events** (implemented in P2.M1.T1.S2):
42
+ * - `childAttached`: Add new child node to parent's children array
43
+ * - `childDetached`: Remove child and all descendants from tree
44
+ * - `treeUpdated`: Update root reference to new tree
45
+ *
46
+ * **Phase 2 - State Events** (implemented in P2.M1.T1.S3):
47
+ * - `stateSnapshot`: Update node's stateSnapshot field
48
+ * - `error`: Record error information on node
49
+ * - `stepStart`: Track step execution start
50
+ * - `stepEnd`: Track step execution completion with duration
51
+ * - `taskStart`: Track task execution start
52
+ * - `taskEnd`: Track task execution completion
53
+ *
54
+ * **Phase 3 - Metadata Events** (logged but don't modify tree):
55
+ * - `agentPromptStart/End`, `toolInvocation`, `mcpEvent`, etc.
56
+ *
57
+ * **Tree Invariants Maintained:**
58
+ * - Single-parent rule: Each node has at most one parent
59
+ * - Bidirectional references: parent.children and child.parent are consistent
60
+ * - No circular references: Tree is a Directed Acyclic Graph (DAG)
61
+ *
62
+ * @param events - Array of workflow events in chronological order
63
+ * @returns Root node of the reconstructed workflow tree
64
+ * @throws {Error} If events array is empty
65
+ * @throws {Error} If root cannot be established from events
66
+ *
67
+ * @example
68
+ * ```typescript
69
+ * const replayer = new WorkflowEventReplayer();
70
+ * const tree = replayer.replay(eventStream);
71
+ * console.log(`Tree has ${tree.children.length} root children`);
72
+ * ```
73
+ */
74
+ replay(events) {
75
+ // Validate input
76
+ if (!events || events.length === 0) {
77
+ throw new Error('Events array is empty or null');
78
+ }
79
+ // Initialize state
80
+ this.nodeMap.clear();
81
+ this.root = null;
82
+ // Process events sequentially
83
+ for (const event of events) {
84
+ try {
85
+ switch (event.type) {
86
+ // Structural events (P2.M1.T1.S2)
87
+ case 'childAttached':
88
+ this.handleChildAttached(event);
89
+ break;
90
+ case 'childDetached':
91
+ this.handleChildDetached(event);
92
+ break;
93
+ case 'treeUpdated':
94
+ this.handleTreeUpdated(event);
95
+ break;
96
+ // State events (P2.M1.T1.S3)
97
+ case 'stateSnapshot':
98
+ this.handleStateSnapshot(event);
99
+ break;
100
+ case 'error':
101
+ this.handleErrorEvent(event);
102
+ break;
103
+ case 'stepStart':
104
+ this.handleStepStart(event);
105
+ break;
106
+ case 'stepEnd':
107
+ this.handleStepEnd(event);
108
+ break;
109
+ case 'taskStart':
110
+ this.handleTaskStart(event);
111
+ break;
112
+ case 'taskEnd':
113
+ this.handleTaskEnd(event);
114
+ break;
115
+ default:
116
+ // Other metadata events - skip for now
117
+ break;
118
+ }
119
+ }
120
+ catch (error) {
121
+ // Log error but continue processing subsequent events
122
+ console.error(`Error processing event type '${event.type}':`, error);
123
+ }
124
+ }
125
+ // Verify root was established
126
+ if (!this.root) {
127
+ throw new Error('No root node established from event stream');
128
+ }
129
+ return this.root;
130
+ }
131
+ /**
132
+ * Handle childAttached event - add subtree to tree.
133
+ *
134
+ * **Strategy:**
135
+ * 1. Deep clone event.child to avoid mutating original
136
+ * 2. Find parent node via nodeMap.get(event.parentId)
137
+ * 3. Validate: parent exists, single-parent rule, no circular references
138
+ * 4. Set child.parent = parent
139
+ * 5. Add child to parent.children array
140
+ * 6. Add child and all descendants to nodeMap via buildNodeMap()
141
+ * 7. Establish root if this is the first attachment
142
+ *
143
+ * **Invariants:**
144
+ * - Parent must exist in nodeMap (throw if not)
145
+ * - Child must not already have a different parent (single-parent rule)
146
+ * - No circular references (child must not be ancestor of parent)
147
+ * - Bidirectional links: child.parent = parent AND parent.children includes child
148
+ *
149
+ * **Deep Cloning:** Uses structuredClone() for safe deep copy
150
+ *
151
+ * @param event - ChildAttachedEvent with parentId and child node
152
+ * @throws {Error} If parent node not found
153
+ * @throws {Error} If child already has a parent
154
+ * @throws {Error} If attaching would create circular reference
155
+ *
156
+ * @example
157
+ * ```typescript
158
+ * // Event structure
159
+ * { type: 'childAttached', parentId: 'workflow-123', child: { id: 'workflow-456', ... } }
160
+ * // Result: workflow-456 is added as child of workflow-123
161
+ * ```
162
+ */
163
+ handleChildAttached(event) {
164
+ // Deep clone child to prevent mutation of event data
165
+ const child = structuredClone(event.child);
166
+ // Find parent
167
+ const parent = this.nodeMap.get(event.parentId);
168
+ if (!parent) {
169
+ throw new Error(`Parent node '${event.parentId}' not found in nodeMap during childAttached event`);
170
+ }
171
+ // Validation 1: Check if child already has a different parent (single-parent rule)
172
+ if (child.parent !== null && child.parent !== parent) {
173
+ throw new Error(`Child '${child.name}' already has a parent. A node can only have one parent.`);
174
+ }
175
+ // Validation 2: Check for circular references
176
+ if (this.isNodeDescendantOf(parent, child)) {
177
+ throw new Error(`Cannot attach '${child.name}' as child of '${parent.name}' - would create circular reference`);
178
+ }
179
+ // Set bidirectional parent-child links
180
+ child.parent = parent;
181
+ parent.children.push(child);
182
+ // Add child and all descendants to nodeMap
183
+ this.buildNodeMap(child);
184
+ // Establish root if this is the first attachment and parent has no parent
185
+ if (this.root === null && parent.parent === null) {
186
+ this.root = parent;
187
+ }
188
+ }
189
+ /**
190
+ * Handle childDetached event - remove subtree from tree.
191
+ *
192
+ * **Strategy:**
193
+ * 1. Find child node via nodeMap.get(event.childId)
194
+ * 2. Find parent node via nodeMap.get(event.parentId)
195
+ * 3. Validate: parent and child exist, child is direct child of parent
196
+ * 4. Remove child from parent.children array
197
+ * 5. Clear child.parent reference
198
+ * 6. Remove child and all descendants from nodeMap via removeSubtreeNodes()
199
+ *
200
+ * **Invariants:**
201
+ * - Both parent and child must exist in nodeMap
202
+ * - Child must be a direct child of parent (not just any descendant)
203
+ *
204
+ * **Error Handling:**
205
+ * - Logs warning and returns early if parent or child not found
206
+ * - Does not throw for missing nodes (replay continues)
207
+ *
208
+ * @param event - ChildDetachedEvent with parentId and childId
209
+ *
210
+ * @example
211
+ * ```typescript
212
+ * // Event structure
213
+ * { type: 'childDetached', parentId: 'workflow-123', childId: 'workflow-456' }
214
+ * // Result: workflow-456 and its descendants are removed from tree
215
+ * ```
216
+ */
217
+ handleChildDetached(event) {
218
+ // Find parent and child
219
+ const parent = this.nodeMap.get(event.parentId);
220
+ const child = this.nodeMap.get(event.childId);
221
+ if (!parent) {
222
+ console.warn(`Parent node '${event.parentId}' not found in nodeMap during childDetached event`);
223
+ return;
224
+ }
225
+ if (!child) {
226
+ console.warn(`Child node '${event.childId}' not found in nodeMap during childDetached event`);
227
+ return;
228
+ }
229
+ // Validate child is direct child of parent
230
+ const index = parent.children.indexOf(child);
231
+ if (index === -1) {
232
+ console.warn(`Child '${child.name}' is not a direct child of parent '${parent.name}' during childDetached event`);
233
+ return;
234
+ }
235
+ // Remove from parent's children array
236
+ parent.children.splice(index, 1);
237
+ // Clear child's parent reference
238
+ child.parent = null;
239
+ // Remove child and all descendants from nodeMap
240
+ this.removeSubtreeNodes(event.childId);
241
+ }
242
+ /**
243
+ * Handle treeUpdated event - update root reference.
244
+ *
245
+ * **Strategy:**
246
+ * 1. Verify event.root is a valid WorkflowNode
247
+ * 2. Update this.root = event.root
248
+ * 3. Clear nodeMap
249
+ * 4. Rebuild nodeMap from new root via buildNodeMap()
250
+ *
251
+ * **Use Case:**
252
+ * - Represents a complete tree replacement (not incremental update)
253
+ * - Rare in practice; most updates use childAttached/childDetached
254
+ *
255
+ * @param event - TreeUpdatedEvent with new root node
256
+ * @throws {Error} If event.root is null or undefined
257
+ *
258
+ * @example
259
+ * ```typescript
260
+ * // Event structure
261
+ * { type: 'treeUpdated', root: { id: 'workflow-123', children: [], ... } }
262
+ * // Result: this.root points to new tree, nodeMap rebuilt
263
+ * ```
264
+ */
265
+ handleTreeUpdated(event) {
266
+ if (!event.root) {
267
+ throw new Error('treeUpdated event has null or undefined root');
268
+ }
269
+ this.root = event.root;
270
+ // Clear and rebuild nodeMap from new root
271
+ this.nodeMap.clear();
272
+ this.buildNodeMap(event.root);
273
+ }
274
+ /**
275
+ * Handle stateSnapshot event - update node's state snapshot.
276
+ *
277
+ * **Strategy:**
278
+ * 1. Find node via nodeMap.get(event.node.id)
279
+ * 2. Extract event.node.stateSnapshot (not the entire node!)
280
+ * 3. Assign to node.stateSnapshot (direct assignment, last write wins)
281
+ *
282
+ * **Invariants:**
283
+ * - Node must exist in nodeMap
284
+ * - stateSnapshot can be null (no snapshot captured)
285
+ *
286
+ * **Error Handling:**
287
+ * - Logs warning if node not found (graceful degradation)
288
+ * - Does not throw for missing nodes
289
+ *
290
+ * **Null Handling:**
291
+ * - Allows null stateSnapshot values (valid state)
292
+ * - Don't throw error for null snapshots
293
+ *
294
+ * **Gotcha:** Event contains full node, but we only extract stateSnapshot field
295
+ * to avoid circular reference issues.
296
+ *
297
+ * @param event - StateSnapshotEvent with updated node
298
+ *
299
+ * @example
300
+ * ```typescript
301
+ * // Event structure
302
+ * { type: 'stateSnapshot', node: { id: 'workflow-123', stateSnapshot: { count: 42 }, ... } }
303
+ * // Result: node.stateSnapshot = { count: 42 }
304
+ * ```
305
+ */
306
+ handleStateSnapshot(event) {
307
+ // Find node in map
308
+ const node = this.nodeMap.get(event.node.id);
309
+ if (!node) {
310
+ // Graceful degradation - log warning and continue
311
+ console.warn(`Node '${event.node.id}' not found in nodeMap during stateSnapshot event. ` +
312
+ `This may indicate out-of-order events or missing structural events.`);
313
+ return;
314
+ }
315
+ // Extract just the snapshot data, not the entire node
316
+ // Gotcha: event.node contains full node, but we only need stateSnapshot
317
+ node.stateSnapshot = event.node.stateSnapshot;
318
+ }
319
+ /**
320
+ * Handle error event - record error on node.
321
+ *
322
+ * **Strategy:**
323
+ * 1. Find node via nodeMap.get(event.node.id)
324
+ * 2. Append event to node.events array (accumulation pattern)
325
+ *
326
+ * **Invariants:**
327
+ * - Node must exist in nodeMap
328
+ * - Error includes rich context (state, logs, stack)
329
+ *
330
+ * **Error Handling:**
331
+ * - Logs warning if node not found (graceful degradation)
332
+ * - Does not throw for missing nodes
333
+ *
334
+ * **Accumulation Pattern:**
335
+ * - Multiple errors are accumulated (not overwritten)
336
+ * - All errors preserved in node.events[] array
337
+ * - To find all errors: node.events.filter(e => e.type === 'error')
338
+ *
339
+ * **Gotcha:** WorkflowNode has no dedicated errors[] field.
340
+ * All errors are stored in the events[] array.
341
+ *
342
+ * @param event - ErrorEvent with error details
343
+ *
344
+ * @example
345
+ * ```typescript
346
+ * // Event structure
347
+ * { type: 'error', node: {...}, error: { message: 'Failed', state: {...}, logs: [...] } }
348
+ * // Result: Error event appended to node.events[]
349
+ * ```
350
+ */
351
+ handleErrorEvent(event) {
352
+ // Find node in map
353
+ const node = this.nodeMap.get(event.node.id);
354
+ if (!node) {
355
+ // Graceful degradation - log warning and continue
356
+ console.warn(`Node '${event.node.id}' not found in nodeMap during error event. ` +
357
+ `This may indicate out-of-order events or missing structural events.`);
358
+ return;
359
+ }
360
+ // Accumulate error in events array (append-only pattern)
361
+ // Gotcha: No dedicated errors[] field - use node.events[]
362
+ node.events.push(event);
363
+ }
364
+ /**
365
+ * Handle stepStart event - track step execution start.
366
+ *
367
+ * **Strategy:**
368
+ * 1. Find node via nodeMap.get(event.node.id)
369
+ * 2. Append event to node.events array for tracking
370
+ *
371
+ * **Invariants:**
372
+ * - Step nodes are created via @Step decorator
373
+ * - Step node may not exist yet if childAttached event hasn't been processed
374
+ *
375
+ * **Error Handling:**
376
+ * - Returns silently if step node not found (childAttached will add it later)
377
+ * - Does not log warning (step nodes are expected to be added separately)
378
+ *
379
+ * **Use Case:**
380
+ * - Tracks step execution for debugging and performance analysis
381
+ * - Metadata only - doesn't modify tree structure
382
+ *
383
+ * @param event - StepStartEvent with step name
384
+ *
385
+ * @example
386
+ * ```typescript
387
+ * // Event structure
388
+ * { type: 'stepStart', node: { id: 'step-123', ... }, step: 'processData' }
389
+ * // Result: Event appended to node.events[]
390
+ * ```
391
+ */
392
+ handleStepStart(event) {
393
+ // Find node in map
394
+ const node = this.nodeMap.get(event.node.id);
395
+ if (!node) {
396
+ // Step node may not exist yet - childAttached will add it later
397
+ // Don't log warning (expected for step nodes)
398
+ return;
399
+ }
400
+ // Track step start in events array
401
+ node.events.push(event);
402
+ }
403
+ /**
404
+ * Handle stepEnd event - track step execution completion with duration.
405
+ *
406
+ * **Strategy:**
407
+ * 1. Find node via nodeMap.get(event.node.id)
408
+ * 2. Append event to node.events array for tracking
409
+ * 3. Duration info is in event.duration field
410
+ *
411
+ * **Invariants:**
412
+ * - Step nodes are created via @Step decorator
413
+ * - Step node may not exist yet if childAttached event hasn't been processed
414
+ *
415
+ * **Error Handling:**
416
+ * - Returns silently if step node not found (childAttached will add it later)
417
+ * - Does not log warning (step nodes are expected to be added separately)
418
+ *
419
+ * **Use Case:**
420
+ * - Tracks step execution time for performance analysis
421
+ * - Metadata only - doesn't modify tree structure
422
+ *
423
+ * **Timing Info:**
424
+ * - Duration is in milliseconds
425
+ * - Access via event.duration field
426
+ *
427
+ * @param event - StepEndEvent with step name and duration
428
+ *
429
+ * @example
430
+ * ```typescript
431
+ * // Event structure
432
+ * { type: 'stepEnd', node: { id: 'step-123', ... }, step: 'processData', duration: 1500 }
433
+ * // Result: Event appended to node.events[], duration accessible
434
+ * ```
435
+ */
436
+ handleStepEnd(event) {
437
+ // Find node in map
438
+ const node = this.nodeMap.get(event.node.id);
439
+ if (!node) {
440
+ // Step node may not exist yet - childAttached will add it later
441
+ // Don't log warning (expected for step nodes)
442
+ return;
443
+ }
444
+ // Track step end with duration in events array
445
+ node.events.push(event);
446
+ }
447
+ /**
448
+ * Handle taskStart event - track task execution start.
449
+ *
450
+ * **Strategy:**
451
+ * 1. Find node via nodeMap.get(event.node.id)
452
+ * 2. Append event to node.events array for tracking
453
+ *
454
+ * **Invariants:**
455
+ * - Task events reference parent node (not a separate task node)
456
+ * - Parent node should exist in nodeMap
457
+ *
458
+ * **Error Handling:**
459
+ * - Logs warning if node not found (graceful degradation)
460
+ * - Does not throw for missing nodes
461
+ *
462
+ * **Use Case:**
463
+ * - Tracks task execution for debugging
464
+ * - Metadata only - doesn't modify tree structure
465
+ *
466
+ * **Difference from Steps:**
467
+ * - Tasks don't create separate nodes
468
+ * - Task events reference parent node
469
+ * - No duration tracking in task events
470
+ *
471
+ * @param event - TaskStartEvent with task name
472
+ *
473
+ * @example
474
+ * ```typescript
475
+ * // Event structure
476
+ * { type: 'taskStart', node: { id: 'workflow-123', ... }, task: 'cleanup' }
477
+ * // Result: Event appended to node.events[]
478
+ * ```
479
+ */
480
+ handleTaskStart(event) {
481
+ // Find node in map
482
+ const node = this.nodeMap.get(event.node.id);
483
+ if (!node) {
484
+ // Graceful degradation - log warning and continue
485
+ console.warn(`Node '${event.node.id}' not found in nodeMap during taskStart event. ` +
486
+ `This may indicate out-of-order events or missing structural events.`);
487
+ return;
488
+ }
489
+ // Track task start in events array
490
+ node.events.push(event);
491
+ }
492
+ /**
493
+ * Handle taskEnd event - track task execution completion.
494
+ *
495
+ * **Strategy:**
496
+ * 1. Find node via nodeMap.get(event.node.id)
497
+ * 2. Append event to node.events array for tracking
498
+ *
499
+ * **Invariants:**
500
+ * - Task events reference parent node (not a separate task node)
501
+ * - Parent node should exist in nodeMap
502
+ *
503
+ * **Error Handling:**
504
+ * - Logs warning if node not found (graceful degradation)
505
+ * - Does not throw for missing nodes
506
+ *
507
+ * **Use Case:**
508
+ * - Tracks task execution for debugging
509
+ * - Metadata only - doesn't modify tree structure
510
+ *
511
+ * **Gotcha:** taskEnd event does NOT have a duration field (unlike stepEnd)
512
+ *
513
+ * @param event - TaskEndEvent with task name
514
+ *
515
+ * @example
516
+ * ```typescript
517
+ * // Event structure
518
+ * { type: 'taskEnd', node: { id: 'workflow-123', ... }, task: 'cleanup' }
519
+ * // Result: Event appended to node.events[]
520
+ * ```
521
+ */
522
+ handleTaskEnd(event) {
523
+ // Find node in map
524
+ const node = this.nodeMap.get(event.node.id);
525
+ if (!node) {
526
+ // Graceful degradation - log warning and continue
527
+ console.warn(`Node '${event.node.id}' not found in nodeMap during taskEnd event. ` +
528
+ `This may indicate out-of-order events or missing structural events.`);
529
+ return;
530
+ }
531
+ // Track task end in events array
532
+ // Gotcha: No duration field in taskEnd event
533
+ node.events.push(event);
534
+ }
535
+ /**
536
+ * Build node lookup map recursively (pattern from WorkflowTreeDebugger).
537
+ *
538
+ * **Strategy:**
539
+ * - Depth-first traversal of subtree
540
+ * - Add each node to nodeMap: nodeMap.set(node.id, node)
541
+ * - Recurse for all children
542
+ *
543
+ * **Complexity:** O(k) where k = number of nodes in subtree
544
+ *
545
+ * @param node - Root of subtree to add to nodeMap
546
+ *
547
+ * @example
548
+ * ```typescript
549
+ * // After attaching a child, add it and descendants to map
550
+ * this.buildNodeMap(event.child);
551
+ * // Result: child and all descendants are now in nodeMap
552
+ * ```
553
+ */
554
+ buildNodeMap(node) {
555
+ this.nodeMap.set(node.id, node);
556
+ for (const child of node.children) {
557
+ this.buildNodeMap(child);
558
+ }
559
+ }
560
+ /**
561
+ * Remove entire subtree from node map using BFS traversal.
562
+ *
563
+ * **Strategy:**
564
+ * - BFS traversal to collect all descendant IDs
565
+ * - Batch delete all collected keys from nodeMap
566
+ * - Iterative (not recursive) to avoid stack overflow on deep trees
567
+ *
568
+ * **Complexity:** O(k) where k = number of nodes in subtree
569
+ *
570
+ * @param nodeId - ID of root node of subtree to remove
571
+ *
572
+ * @example
573
+ * ```typescript
574
+ * // After detaching a child, remove it and descendants from map
575
+ * this.removeSubtreeNodes(event.childId);
576
+ * // Result: child and all descendants removed from nodeMap
577
+ * ```
578
+ */
579
+ removeSubtreeNodes(nodeId) {
580
+ const node = this.nodeMap.get(nodeId);
581
+ if (!node)
582
+ return; // Already removed or never existed
583
+ // BFS traversal to collect all descendant IDs
584
+ const toRemove = [];
585
+ const queue = [node];
586
+ while (queue.length > 0) {
587
+ const current = queue.shift();
588
+ toRemove.push(current.id);
589
+ // Add children to queue for BFS traversal
590
+ queue.push(...current.children);
591
+ }
592
+ // Batch delete all collected keys (atomic update)
593
+ for (const id of toRemove) {
594
+ this.nodeMap.delete(id);
595
+ }
596
+ }
597
+ /**
598
+ * Check if node is descendant of potential ancestor.
599
+ * Uses cycle detection to prevent infinite loops during traversal.
600
+ *
601
+ * **Strategy:**
602
+ * - Traverse parent chain upward from node
603
+ * - Track visited nodes to detect cycles
604
+ * - Return true if ancestor found in parent chain
605
+ *
606
+ * **Complexity:** O(d) where d = depth of hierarchy
607
+ *
608
+ * @param node - Node to start traversal from
609
+ * @param potentialAncestor - Potential ancestor to search for
610
+ * @returns true if ancestor found in parent chain
611
+ * @throws {Error} If circular reference detected
612
+ *
613
+ * @example
614
+ * ```typescript
615
+ * // Check if attaching would create cycle
616
+ * if (this.isNodeDescendantOf(parent, child)) {
617
+ * throw new Error('Would create circular reference');
618
+ * }
619
+ * ```
620
+ */
621
+ isNodeDescendantOf(node, potentialAncestor) {
622
+ const visited = new Set();
623
+ let current = node.parent;
624
+ while (current !== null) {
625
+ // Cycle detection
626
+ if (visited.has(current)) {
627
+ throw new Error('Circular parent-child relationship detected');
628
+ }
629
+ visited.add(current);
630
+ // Check if we found the ancestor
631
+ if (current === potentialAncestor) {
632
+ return true;
633
+ }
634
+ current = current.parent;
635
+ }
636
+ return false;
637
+ }
638
+ }
639
+ //# sourceMappingURL=event-replayer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"event-replayer.js","sourceRoot":"","sources":["../../src/debugger/event-replayer.ts"],"names":[],"mappings":"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"}