groundswell 0.0.2 → 0.0.3

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 (633) hide show
  1. package/dist/__tests__/adversarial/attachChild-performance.test.d.ts +16 -0
  2. package/dist/__tests__/adversarial/attachChild-performance.test.d.ts.map +1 -0
  3. package/dist/__tests__/adversarial/attachChild-performance.test.js +187 -0
  4. package/dist/__tests__/adversarial/attachChild-performance.test.js.map +1 -0
  5. package/dist/__tests__/adversarial/circular-reference.test.d.ts +13 -0
  6. package/dist/__tests__/adversarial/circular-reference.test.d.ts.map +1 -0
  7. package/dist/__tests__/adversarial/circular-reference.test.js +92 -0
  8. package/dist/__tests__/adversarial/circular-reference.test.js.map +1 -0
  9. package/dist/__tests__/adversarial/complex-circular-reference.test.d.ts +16 -0
  10. package/dist/__tests__/adversarial/complex-circular-reference.test.d.ts.map +1 -0
  11. package/dist/__tests__/adversarial/complex-circular-reference.test.js +127 -0
  12. package/dist/__tests__/adversarial/complex-circular-reference.test.js.map +1 -0
  13. package/dist/__tests__/adversarial/concurrent-task-failures.test.d.ts +21 -0
  14. package/dist/__tests__/adversarial/concurrent-task-failures.test.d.ts.map +1 -0
  15. package/dist/__tests__/adversarial/concurrent-task-failures.test.js +667 -0
  16. package/dist/__tests__/adversarial/concurrent-task-failures.test.js.map +1 -0
  17. package/dist/__tests__/adversarial/deep-analysis.test.d.ts +6 -0
  18. package/dist/__tests__/adversarial/deep-analysis.test.d.ts.map +1 -0
  19. package/dist/__tests__/adversarial/deep-analysis.test.js +877 -0
  20. package/dist/__tests__/adversarial/deep-analysis.test.js.map +1 -0
  21. package/dist/__tests__/adversarial/deep-hierarchy-stress.test.d.ts +13 -0
  22. package/dist/__tests__/adversarial/deep-hierarchy-stress.test.d.ts.map +1 -0
  23. package/dist/__tests__/adversarial/deep-hierarchy-stress.test.js +186 -0
  24. package/dist/__tests__/adversarial/deep-hierarchy-stress.test.js.map +1 -0
  25. package/dist/__tests__/adversarial/e2e-prd-validation.test.d.ts +6 -0
  26. package/dist/__tests__/adversarial/e2e-prd-validation.test.d.ts.map +1 -0
  27. package/dist/__tests__/adversarial/e2e-prd-validation.test.js +626 -0
  28. package/dist/__tests__/adversarial/e2e-prd-validation.test.js.map +1 -0
  29. package/dist/__tests__/adversarial/edge-case.test.d.ts +6 -0
  30. package/dist/__tests__/adversarial/edge-case.test.d.ts.map +1 -0
  31. package/dist/__tests__/adversarial/edge-case.test.js +857 -0
  32. package/dist/__tests__/adversarial/edge-case.test.js.map +1 -0
  33. package/dist/__tests__/adversarial/error-merge-strategy.test.d.ts +20 -0
  34. package/dist/__tests__/adversarial/error-merge-strategy.test.d.ts.map +1 -0
  35. package/dist/__tests__/adversarial/error-merge-strategy.test.js +907 -0
  36. package/dist/__tests__/adversarial/error-merge-strategy.test.js.map +1 -0
  37. package/dist/__tests__/adversarial/incremental-performance.test.d.ts +2 -0
  38. package/dist/__tests__/adversarial/incremental-performance.test.d.ts.map +1 -0
  39. package/dist/__tests__/adversarial/incremental-performance.test.js +113 -0
  40. package/dist/__tests__/adversarial/incremental-performance.test.js.map +1 -0
  41. package/dist/__tests__/adversarial/node-map-update-benchmarks.test.d.ts +22 -0
  42. package/dist/__tests__/adversarial/node-map-update-benchmarks.test.d.ts.map +1 -0
  43. package/dist/__tests__/adversarial/node-map-update-benchmarks.test.js +383 -0
  44. package/dist/__tests__/adversarial/node-map-update-benchmarks.test.js.map +1 -0
  45. package/dist/__tests__/adversarial/observer-propagation.test.d.ts +21 -0
  46. package/dist/__tests__/adversarial/observer-propagation.test.d.ts.map +1 -0
  47. package/dist/__tests__/adversarial/observer-propagation.test.js +404 -0
  48. package/dist/__tests__/adversarial/observer-propagation.test.js.map +1 -0
  49. package/dist/__tests__/adversarial/parent-validation.test.d.ts +13 -0
  50. package/dist/__tests__/adversarial/parent-validation.test.d.ts.map +1 -0
  51. package/dist/__tests__/adversarial/parent-validation.test.js +128 -0
  52. package/dist/__tests__/adversarial/parent-validation.test.js.map +1 -0
  53. package/dist/__tests__/adversarial/prd-12-2-compliance.test.d.ts +20 -0
  54. package/dist/__tests__/adversarial/prd-12-2-compliance.test.d.ts.map +1 -0
  55. package/dist/__tests__/adversarial/prd-12-2-compliance.test.js +482 -0
  56. package/dist/__tests__/adversarial/prd-12-2-compliance.test.js.map +1 -0
  57. package/dist/__tests__/adversarial/prd-compliance.test.d.ts +6 -0
  58. package/dist/__tests__/adversarial/prd-compliance.test.d.ts.map +1 -0
  59. package/dist/__tests__/adversarial/prd-compliance.test.js +886 -0
  60. package/dist/__tests__/adversarial/prd-compliance.test.js.map +1 -0
  61. package/dist/__tests__/compatibility/backward-compatibility.test.d.ts +22 -0
  62. package/dist/__tests__/compatibility/backward-compatibility.test.d.ts.map +1 -0
  63. package/dist/__tests__/compatibility/backward-compatibility.test.js +1843 -0
  64. package/dist/__tests__/compatibility/backward-compatibility.test.js.map +1 -0
  65. package/dist/__tests__/helpers/index.d.ts +10 -0
  66. package/dist/__tests__/helpers/index.d.ts.map +1 -0
  67. package/{src/__tests__/helpers/index.ts → dist/__tests__/helpers/index.js} +2 -10
  68. package/dist/__tests__/helpers/index.js.map +1 -0
  69. package/dist/__tests__/helpers/tree-verification.d.ts +90 -0
  70. package/dist/__tests__/helpers/tree-verification.d.ts.map +1 -0
  71. package/dist/__tests__/helpers/tree-verification.js +202 -0
  72. package/dist/__tests__/helpers/tree-verification.js.map +1 -0
  73. package/dist/__tests__/integration/agent-workflow.test.d.ts +2 -0
  74. package/dist/__tests__/integration/agent-workflow.test.d.ts.map +1 -0
  75. package/dist/__tests__/integration/agent-workflow.test.js +256 -0
  76. package/dist/__tests__/integration/agent-workflow.test.js.map +1 -0
  77. package/dist/__tests__/integration/bidirectional-consistency.test.d.ts +14 -0
  78. package/dist/__tests__/integration/bidirectional-consistency.test.d.ts.map +1 -0
  79. package/dist/__tests__/integration/bidirectional-consistency.test.js +668 -0
  80. package/dist/__tests__/integration/bidirectional-consistency.test.js.map +1 -0
  81. package/dist/__tests__/integration/observer-logging.test.d.ts +2 -0
  82. package/dist/__tests__/integration/observer-logging.test.d.ts.map +1 -0
  83. package/dist/__tests__/integration/observer-logging.test.js +517 -0
  84. package/dist/__tests__/integration/observer-logging.test.js.map +1 -0
  85. package/dist/__tests__/integration/tree-mirroring.test.d.ts +2 -0
  86. package/dist/__tests__/integration/tree-mirroring.test.d.ts.map +1 -0
  87. package/dist/__tests__/integration/tree-mirroring.test.js +117 -0
  88. package/dist/__tests__/integration/tree-mirroring.test.js.map +1 -0
  89. package/dist/__tests__/integration/workflow-reparenting.test.d.ts +12 -0
  90. package/dist/__tests__/integration/workflow-reparenting.test.d.ts.map +1 -0
  91. package/dist/__tests__/integration/workflow-reparenting.test.js +239 -0
  92. package/dist/__tests__/integration/workflow-reparenting.test.js.map +1 -0
  93. package/dist/__tests__/unit/agent.test.d.ts +2 -0
  94. package/dist/__tests__/unit/agent.test.d.ts.map +1 -0
  95. package/dist/__tests__/unit/agent.test.js +143 -0
  96. package/dist/__tests__/unit/agent.test.js.map +1 -0
  97. package/dist/__tests__/unit/cache-key.test.d.ts +5 -0
  98. package/dist/__tests__/unit/cache-key.test.d.ts.map +1 -0
  99. package/dist/__tests__/unit/cache-key.test.js +145 -0
  100. package/dist/__tests__/unit/cache-key.test.js.map +1 -0
  101. package/dist/__tests__/unit/cache.test.d.ts +5 -0
  102. package/dist/__tests__/unit/cache.test.d.ts.map +1 -0
  103. package/dist/__tests__/unit/cache.test.js +132 -0
  104. package/dist/__tests__/unit/cache.test.js.map +1 -0
  105. package/dist/__tests__/unit/context.test.d.ts +2 -0
  106. package/dist/__tests__/unit/context.test.d.ts.map +1 -0
  107. package/dist/__tests__/unit/context.test.js +220 -0
  108. package/dist/__tests__/unit/context.test.js.map +1 -0
  109. package/dist/__tests__/unit/decorators.test.d.ts +2 -0
  110. package/dist/__tests__/unit/decorators.test.d.ts.map +1 -0
  111. package/dist/__tests__/unit/decorators.test.js +162 -0
  112. package/dist/__tests__/unit/decorators.test.js.map +1 -0
  113. package/dist/__tests__/unit/introspection-tools.test.d.ts +5 -0
  114. package/dist/__tests__/unit/introspection-tools.test.d.ts.map +1 -0
  115. package/dist/__tests__/unit/introspection-tools.test.js +191 -0
  116. package/dist/__tests__/unit/introspection-tools.test.js.map +1 -0
  117. package/dist/__tests__/unit/logger.test.d.ts +2 -0
  118. package/dist/__tests__/unit/logger.test.d.ts.map +1 -0
  119. package/dist/__tests__/unit/logger.test.js +241 -0
  120. package/dist/__tests__/unit/logger.test.js.map +1 -0
  121. package/dist/__tests__/unit/observable.test.d.ts +2 -0
  122. package/dist/__tests__/unit/observable.test.d.ts.map +1 -0
  123. package/dist/__tests__/unit/observable.test.js +251 -0
  124. package/dist/__tests__/unit/observable.test.js.map +1 -0
  125. package/dist/__tests__/unit/prompt.test.d.ts +2 -0
  126. package/dist/__tests__/unit/prompt.test.d.ts.map +1 -0
  127. package/dist/__tests__/unit/prompt.test.js +113 -0
  128. package/dist/__tests__/unit/prompt.test.js.map +1 -0
  129. package/dist/__tests__/unit/reflection.test.d.ts +5 -0
  130. package/dist/__tests__/unit/reflection.test.d.ts.map +1 -0
  131. package/dist/__tests__/unit/reflection.test.js +160 -0
  132. package/dist/__tests__/unit/reflection.test.js.map +1 -0
  133. package/dist/__tests__/unit/tree-debugger-incremental.test.d.ts +2 -0
  134. package/dist/__tests__/unit/tree-debugger-incremental.test.d.ts.map +1 -0
  135. package/dist/__tests__/unit/tree-debugger-incremental.test.js +136 -0
  136. package/dist/__tests__/unit/tree-debugger-incremental.test.js.map +1 -0
  137. package/dist/__tests__/unit/tree-debugger.test.d.ts +2 -0
  138. package/dist/__tests__/unit/tree-debugger.test.d.ts.map +1 -0
  139. package/dist/__tests__/unit/tree-debugger.test.js +69 -0
  140. package/dist/__tests__/unit/tree-debugger.test.js.map +1 -0
  141. package/dist/__tests__/unit/utils/workflow-error-utils.test.d.ts +2 -0
  142. package/dist/__tests__/unit/utils/workflow-error-utils.test.d.ts.map +1 -0
  143. package/dist/__tests__/unit/utils/workflow-error-utils.test.js +154 -0
  144. package/dist/__tests__/unit/utils/workflow-error-utils.test.js.map +1 -0
  145. package/dist/__tests__/unit/workflow-detachChild.test.d.ts +2 -0
  146. package/dist/__tests__/unit/workflow-detachChild.test.d.ts.map +1 -0
  147. package/dist/__tests__/unit/workflow-detachChild.test.js +76 -0
  148. package/dist/__tests__/unit/workflow-detachChild.test.js.map +1 -0
  149. package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.d.ts +2 -0
  150. package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.d.ts.map +1 -0
  151. package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.js +122 -0
  152. package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.js.map +1 -0
  153. package/dist/__tests__/unit/workflow-isDescendantOf.test.d.ts +2 -0
  154. package/dist/__tests__/unit/workflow-isDescendantOf.test.d.ts.map +1 -0
  155. package/dist/__tests__/unit/workflow-isDescendantOf.test.js +140 -0
  156. package/dist/__tests__/unit/workflow-isDescendantOf.test.js.map +1 -0
  157. package/dist/__tests__/unit/workflow.test.d.ts +2 -0
  158. package/dist/__tests__/unit/workflow.test.d.ts.map +1 -0
  159. package/dist/__tests__/unit/workflow.test.js +330 -0
  160. package/dist/__tests__/unit/workflow.test.js.map +1 -0
  161. package/dist/cache/cache-key.d.ts +66 -0
  162. package/dist/cache/cache-key.d.ts.map +1 -0
  163. package/dist/cache/cache-key.js +195 -0
  164. package/dist/cache/cache-key.js.map +1 -0
  165. package/dist/cache/cache.d.ts +104 -0
  166. package/dist/cache/cache.d.ts.map +1 -0
  167. package/dist/cache/cache.js +179 -0
  168. package/dist/cache/cache.js.map +1 -0
  169. package/{src/cache/index.ts → dist/cache/index.d.ts} +1 -1
  170. package/dist/cache/index.d.ts.map +1 -0
  171. package/dist/cache/index.js +6 -0
  172. package/dist/cache/index.js.map +1 -0
  173. package/dist/core/agent.d.ts +112 -0
  174. package/dist/core/agent.d.ts.map +1 -0
  175. package/dist/core/agent.js +426 -0
  176. package/dist/core/agent.js.map +1 -0
  177. package/{src/core/context.ts → dist/core/context.d.ts} +16 -67
  178. package/dist/core/context.d.ts.map +1 -0
  179. package/dist/core/context.js +80 -0
  180. package/dist/core/context.js.map +1 -0
  181. package/dist/core/event-tree.d.ts +72 -0
  182. package/dist/core/event-tree.d.ts.map +1 -0
  183. package/dist/core/event-tree.js +211 -0
  184. package/dist/core/event-tree.js.map +1 -0
  185. package/{src/core/factory.ts → dist/core/factory.d.ts} +6 -27
  186. package/dist/core/factory.d.ts.map +1 -0
  187. package/dist/core/factory.js +110 -0
  188. package/dist/core/factory.js.map +1 -0
  189. package/{src/core/index.ts → dist/core/index.d.ts} +2 -10
  190. package/dist/core/index.d.ts.map +1 -0
  191. package/dist/core/index.js +9 -0
  192. package/dist/core/index.js.map +1 -0
  193. package/dist/core/logger.d.ts +50 -0
  194. package/dist/core/logger.d.ts.map +1 -0
  195. package/dist/core/logger.js +91 -0
  196. package/dist/core/logger.js.map +1 -0
  197. package/dist/core/mcp-handler.d.ts +69 -0
  198. package/dist/core/mcp-handler.d.ts.map +1 -0
  199. package/dist/core/mcp-handler.js +143 -0
  200. package/dist/core/mcp-handler.js.map +1 -0
  201. package/dist/core/prompt.d.ts +80 -0
  202. package/dist/core/prompt.d.ts.map +1 -0
  203. package/dist/core/prompt.js +120 -0
  204. package/dist/core/prompt.js.map +1 -0
  205. package/dist/core/workflow-context.d.ts +57 -0
  206. package/dist/core/workflow-context.d.ts.map +1 -0
  207. package/dist/core/workflow-context.js +263 -0
  208. package/dist/core/workflow-context.js.map +1 -0
  209. package/dist/core/workflow.d.ts +241 -0
  210. package/dist/core/workflow.d.ts.map +1 -0
  211. package/dist/core/workflow.js +464 -0
  212. package/dist/core/workflow.js.map +1 -0
  213. package/dist/debugger/index.d.ts +2 -0
  214. package/dist/debugger/index.d.ts.map +1 -0
  215. package/{src/debugger/index.ts → dist/debugger/index.js} +1 -0
  216. package/dist/debugger/index.js.map +1 -0
  217. package/dist/debugger/tree-debugger.d.ts +71 -0
  218. package/dist/debugger/tree-debugger.d.ts.map +1 -0
  219. package/dist/debugger/tree-debugger.js +198 -0
  220. package/dist/debugger/tree-debugger.js.map +1 -0
  221. package/dist/decorators/index.d.ts +4 -0
  222. package/dist/decorators/index.d.ts.map +1 -0
  223. package/{src/decorators/index.ts → dist/decorators/index.js} +1 -0
  224. package/dist/decorators/index.js.map +1 -0
  225. package/dist/decorators/observed-state.d.ts +32 -0
  226. package/dist/decorators/observed-state.d.ts.map +1 -0
  227. package/dist/decorators/observed-state.js +79 -0
  228. package/dist/decorators/observed-state.js.map +1 -0
  229. package/dist/decorators/step.d.ts +15 -0
  230. package/dist/decorators/step.d.ts.map +1 -0
  231. package/dist/decorators/step.js +110 -0
  232. package/dist/decorators/step.js.map +1 -0
  233. package/dist/decorators/task.d.ts +50 -0
  234. package/dist/decorators/task.d.ts.map +1 -0
  235. package/dist/decorators/task.js +118 -0
  236. package/dist/decorators/task.js.map +1 -0
  237. package/dist/examples/index.d.ts +3 -0
  238. package/dist/examples/index.d.ts.map +1 -0
  239. package/{src/examples/index.ts → dist/examples/index.js} +1 -0
  240. package/dist/examples/index.js.map +1 -0
  241. package/dist/examples/tdd-orchestrator.d.ts +15 -0
  242. package/dist/examples/tdd-orchestrator.d.ts.map +1 -0
  243. package/dist/examples/tdd-orchestrator.js +121 -0
  244. package/dist/examples/tdd-orchestrator.js.map +1 -0
  245. package/dist/examples/test-cycle-workflow.d.ts +14 -0
  246. package/dist/examples/test-cycle-workflow.d.ts.map +1 -0
  247. package/dist/examples/test-cycle-workflow.js +116 -0
  248. package/dist/examples/test-cycle-workflow.js.map +1 -0
  249. package/dist/index.d.ts +27 -0
  250. package/dist/index.d.ts.map +1 -0
  251. package/dist/index.js +40 -0
  252. package/dist/index.js.map +1 -0
  253. package/dist/reflection/index.d.ts +5 -0
  254. package/dist/reflection/index.d.ts.map +1 -0
  255. package/{src/reflection/index.ts → dist/reflection/index.js} +1 -1
  256. package/dist/reflection/index.js.map +1 -0
  257. package/dist/reflection/reflection.d.ts +84 -0
  258. package/dist/reflection/reflection.d.ts.map +1 -0
  259. package/dist/reflection/reflection.js +329 -0
  260. package/dist/reflection/reflection.js.map +1 -0
  261. package/dist/tools/index.d.ts +6 -0
  262. package/dist/tools/index.d.ts.map +1 -0
  263. package/dist/tools/index.js +11 -0
  264. package/dist/tools/index.js.map +1 -0
  265. package/dist/tools/introspection.d.ts +165 -0
  266. package/dist/tools/introspection.d.ts.map +1 -0
  267. package/dist/tools/introspection.js +324 -0
  268. package/dist/tools/introspection.js.map +1 -0
  269. package/dist/types/agent.d.ts +66 -0
  270. package/dist/types/agent.d.ts.map +1 -0
  271. package/dist/types/agent.js +6 -0
  272. package/dist/types/agent.js.map +1 -0
  273. package/dist/types/decorators.d.ts +31 -0
  274. package/dist/types/decorators.d.ts.map +1 -0
  275. package/dist/types/decorators.js +2 -0
  276. package/dist/types/decorators.js.map +1 -0
  277. package/dist/types/error-strategy.d.ts +13 -0
  278. package/dist/types/error-strategy.d.ts.map +1 -0
  279. package/dist/types/error-strategy.js +2 -0
  280. package/dist/types/error-strategy.js.map +1 -0
  281. package/dist/types/error.d.ts +20 -0
  282. package/dist/types/error.d.ts.map +1 -0
  283. package/dist/types/error.js +2 -0
  284. package/dist/types/error.js.map +1 -0
  285. package/dist/types/events.d.ts +87 -0
  286. package/dist/types/events.d.ts.map +1 -0
  287. package/dist/types/events.js +2 -0
  288. package/dist/types/events.js.map +1 -0
  289. package/dist/types/index.d.ts +15 -0
  290. package/dist/types/index.d.ts.map +1 -0
  291. package/dist/types/index.js +2 -0
  292. package/dist/types/index.js.map +1 -0
  293. package/dist/types/logging.d.ts +24 -0
  294. package/dist/types/logging.d.ts.map +1 -0
  295. package/dist/types/logging.js +2 -0
  296. package/dist/types/logging.js.map +1 -0
  297. package/dist/types/observer.d.ts +18 -0
  298. package/dist/types/observer.d.ts.map +1 -0
  299. package/dist/types/observer.js +2 -0
  300. package/dist/types/observer.js.map +1 -0
  301. package/dist/types/prompt.d.ts +31 -0
  302. package/dist/types/prompt.d.ts.map +1 -0
  303. package/dist/types/prompt.js +6 -0
  304. package/dist/types/prompt.js.map +1 -0
  305. package/dist/types/reflection.d.ts +96 -0
  306. package/dist/types/reflection.d.ts.map +1 -0
  307. package/dist/types/reflection.js +24 -0
  308. package/dist/types/reflection.js.map +1 -0
  309. package/dist/types/sdk-primitives.d.ts +118 -0
  310. package/dist/types/sdk-primitives.d.ts.map +1 -0
  311. package/dist/types/sdk-primitives.js +6 -0
  312. package/dist/types/sdk-primitives.js.map +1 -0
  313. package/{src/types/snapshot.ts → dist/types/snapshot.d.ts} +5 -5
  314. package/dist/types/snapshot.d.ts.map +1 -0
  315. package/dist/types/snapshot.js +2 -0
  316. package/dist/types/snapshot.js.map +1 -0
  317. package/dist/types/workflow-context.d.ts +139 -0
  318. package/dist/types/workflow-context.d.ts.map +1 -0
  319. package/dist/types/workflow-context.js +8 -0
  320. package/dist/types/workflow-context.js.map +1 -0
  321. package/dist/types/workflow.d.ts +30 -0
  322. package/dist/types/workflow.d.ts.map +1 -0
  323. package/dist/types/workflow.js +2 -0
  324. package/dist/types/workflow.js.map +1 -0
  325. package/dist/utils/id.d.ts +6 -0
  326. package/dist/utils/id.d.ts.map +1 -0
  327. package/dist/utils/id.js +12 -0
  328. package/dist/utils/id.js.map +1 -0
  329. package/{src/utils/index.ts → dist/utils/index.d.ts} +1 -0
  330. package/dist/utils/index.d.ts.map +1 -0
  331. package/dist/utils/index.js +4 -0
  332. package/dist/utils/index.js.map +1 -0
  333. package/dist/utils/observable.d.ts +54 -0
  334. package/dist/utils/observable.d.ts.map +1 -0
  335. package/dist/utils/observable.js +82 -0
  336. package/dist/utils/observable.js.map +1 -0
  337. package/dist/utils/workflow-error-utils.d.ts +22 -0
  338. package/dist/utils/workflow-error-utils.d.ts.map +1 -0
  339. package/dist/utils/workflow-error-utils.js +45 -0
  340. package/dist/utils/workflow-error-utils.js.map +1 -0
  341. package/package.json +5 -2
  342. package/.claude/commands/subtask-planning/prp-base-create.md +0 -120
  343. package/.claude/commands/subtask-planning/prp-base-execute.md +0 -65
  344. package/.claude/commands/task-breakdown.md +0 -94
  345. package/.claude/settings.local.json +0 -9
  346. package/.claude/system_prompts/task-breakdown.md +0 -101
  347. package/PRD.md +0 -543
  348. package/PRPs/001-hierarchical-workflow-engine.md +0 -2438
  349. package/PRPs/PRDs/002-agent-prompt.md +0 -390
  350. package/PRPs/PRDs/003-agent-prompt.md +0 -943
  351. package/PRPs/PRDs/004-agent-prompt.md +0 -1136
  352. package/PRPs/PRDs/tasks-001.json +0 -492
  353. package/PRPs/README.md +0 -83
  354. package/PRPs/templates/prp_base.md +0 -222
  355. package/docs/agent.md +0 -422
  356. package/docs/prompt.md +0 -419
  357. package/docs/workflow.md +0 -600
  358. package/examples/README.md +0 -258
  359. package/examples/examples/01-basic-workflow.ts +0 -100
  360. package/examples/examples/02-decorator-options.ts +0 -217
  361. package/examples/examples/03-parent-child.ts +0 -241
  362. package/examples/examples/04-observers-debugger.ts +0 -340
  363. package/examples/examples/05-error-handling.ts +0 -387
  364. package/examples/examples/06-concurrent-tasks.ts +0 -352
  365. package/examples/examples/07-agent-loops.ts +0 -432
  366. package/examples/examples/08-sdk-features.ts +0 -667
  367. package/examples/examples/09-reflection.ts +0 -573
  368. package/examples/examples/10-introspection.ts +0 -550
  369. package/examples/examples/11-reparenting-workflows.ts +0 -269
  370. package/examples/index.ts +0 -147
  371. package/examples/utils/helpers.ts +0 -57
  372. package/package-lock.json +0 -2398
  373. package/plan/001_d3bb02af4886/TEST_RESULTS.md +0 -259
  374. package/plan/001_d3bb02af4886/backlog.json +0 -867
  375. package/plan/001_d3bb02af4886/bug_fix_tasks.json +0 -484
  376. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M1T1S1/PRP.md +0 -488
  377. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M1T1S2/PRP.md +0 -581
  378. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M1T1S3/PRP.md +0 -687
  379. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T1S1/PRP.md +0 -492
  380. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T1S3/PRP.md +0 -932
  381. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T1S3/research/concurrent_error_testing_patterns.md +0 -1109
  382. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T1S3/research/vitest_concurrent_testing.md +0 -802
  383. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T1S3/research/workflow_engine_test_references.md +0 -603
  384. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T2S1/PRP.md +0 -564
  385. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T2S3/PRP.md +0 -518
  386. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T2S4/PRP.md +0 -1252
  387. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T3S1/PRP.md +0 -364
  388. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T3S1/research/CODEBASE_INVENTORY.md +0 -114
  389. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T3S1/research/DECORATOR_DOCUMENTATION_PATTERNS.md +0 -205
  390. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T3S1/research/PRD_LOCATION_ANALYSIS.md +0 -199
  391. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T3S1/research/ULTRATHINK_PRP_PLAN.md +0 -134
  392. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T1S1/PRP.md +0 -495
  393. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T1S1/research/console_error_inventory.md +0 -435
  394. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T1S2/PRP.md +0 -506
  395. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T1S3/PRP.md +0 -612
  396. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T2S2/PRP.md +0 -558
  397. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T2S2/research/external_research.md +0 -788
  398. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T3S2/PRP.md +0 -460
  399. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T3S3/PRP.md +0 -454
  400. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T4S1/PRP.md +0 -520
  401. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T4S1/RECOMMENDATION.md +0 -417
  402. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T4S1/research/external_workflow_engines_research.md +0 -760
  403. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T4S1/research/security_implications_analysis.md +0 -245
  404. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T4S2/PRP.md +0 -792
  405. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T1S1/PRP.md +0 -535
  406. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T1S1/TEST_EXECUTION_REPORT.md +0 -190
  407. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T1S2/PRP.md +0 -654
  408. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T1S2/TEST_FIX_REPORT.md +0 -227
  409. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T1S2/research/KEY_FINDINGS.md +0 -345
  410. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T1S2/research/QUICK_REFERENCE.md +0 -193
  411. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T1S2/research/test_maintenance_research.md +0 -1323
  412. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T3S1/BREAKING_CHANGES_AUDIT.md +0 -1011
  413. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T3S1/PRP.md +0 -927
  414. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T3S2/PRP.md +0 -505
  415. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/architecture/logger_child_signature_analysis.md +0 -401
  416. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M1T1S3/child_implementation_research.md +0 -142
  417. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M1T1S3/test_patterns_research.md +0 -112
  418. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M1T1S3/vitest_patterns_research.md +0 -159
  419. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M1T1S4/PRP.md +0 -549
  420. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M1T1S4/VERIFICATION_REPORT.md +0 -368
  421. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M1T1S4/edge_case_analysis.md +0 -172
  422. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M1T1S4/usage_inventory.md +0 -175
  423. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T1S2/PRP.md +0 -696
  424. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T1S4/PRP.md +0 -860
  425. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/PRP.md +0 -1066
  426. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/01-testing-aggregated-errors.md +0 -1103
  427. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/01_typescript_error_aggregation_patterns.md +0 -789
  428. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/02-error-merge-strategy-testing-guide.md +0 -1098
  429. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/02_aggregate_error_patterns.md +0 -1037
  430. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/03-promise-allsettled-testing-patterns.md +0 -916
  431. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/03_error_merging_strategies.md +0 -1045
  432. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/04_github_stackoverflow_examples.md +0 -890
  433. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/05_comprehensive_summary.md +0 -822
  434. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/INDEX.md +0 -668
  435. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/QUICK_REFERENCE.md +0 -706
  436. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/README.md +0 -265
  437. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/RESEARCH_REPORT.md +0 -655
  438. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S4/research/vitest_testing_patterns.md +0 -1103
  439. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T3S2/PRP.md +0 -426
  440. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T1S2/PRP.md +0 -506
  441. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T1S2/research/QUICK_REFERENCE.md +0 -114
  442. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T1S2/research/RESEARCH_SUMMARY.md +0 -316
  443. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T1S2/research/vitest_observer_error_logging_best_practices.md +0 -754
  444. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T1S3/PRP.md +0 -612
  445. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T2S1/PRP.md +0 -719
  446. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T2S1/README.md +0 -215
  447. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T2S1/analysis.md +0 -765
  448. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T2S3/PRP.md +0 -718
  449. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T3S1/DECISION.md +0 -149
  450. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T3S1/PRP.md +0 -470
  451. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T3S1/research/ULTRATHINK_PLAN.md +0 -332
  452. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T3S1/research/codebase_workflow_name_analysis.md +0 -167
  453. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T3S1/research/external_best_practices.md +0 -265
  454. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T3S1/research/validation_patterns.md +0 -273
  455. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T4S1/workflow_engine_ancestry_api_research.md +0 -760
  456. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T4S3-PRP.md +0 -434
  457. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M4T2S1/PRP.md +0 -717
  458. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M4T2S2/PRP.md +0 -472
  459. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M4T2S2/VALIDATION_REPORT.md +0 -125
  460. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M4T2S2/research/ULTRATHINK_PRP_PLAN.md +0 -301
  461. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/error-logging-best-practices.md +0 -1170
  462. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/research_typescript_partial_and_overloads.md +0 -940
  463. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/vitest-quick-reference.md +0 -151
  464. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/vitest-research.md +0 -650
  465. package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/prd_snapshot.md +0 -259
  466. package/plan/001_d3bb02af4886/bugfix/P1M1T1S1/PRP.md +0 -457
  467. package/plan/001_d3bb02af4886/bugfix/RESEARCH_SUMMARY.md +0 -346
  468. package/plan/001_d3bb02af4886/bugfix/architecture/codebase_structure.md +0 -311
  469. package/plan/001_d3bb02af4886/bugfix/architecture/concurrent_execution_best_practices.md +0 -1565
  470. package/plan/001_d3bb02af4886/bugfix/architecture/error_handling_patterns.md +0 -288
  471. package/plan/001_d3bb02af4886/bugfix/architecture/promise_all_analysis.md +0 -741
  472. package/plan/001_d3bb02af4886/docs/PRP/P1M1T1S4-functional-workflow-error-state-capture-test.md +0 -652
  473. package/plan/001_d3bb02af4886/docs/PRP/P1P2-PRP.md +0 -527
  474. package/plan/001_d3bb02af4886/docs/PRP/P3P4-PRP.md +0 -1388
  475. package/plan/001_d3bb02af4886/docs/PRP/P4P5-PRP.md +0 -1136
  476. package/plan/001_d3bb02af4886/docs/PRP/PRP.md +0 -527
  477. package/plan/001_d3bb02af4886/docs/PRP/bugfix/P1M1T2S1-PRP.md +0 -415
  478. package/plan/001_d3bb02af4886/docs/PRP/bugfix/P1M1T2S2-PRP.md +0 -378
  479. package/plan/001_d3bb02af4886/docs/PRP/bugfix/P1M1T2S4-PRP.md +0 -713
  480. package/plan/001_d3bb02af4886/docs/PRP/bugfix/P1M2T1S4-PRP.md +0 -370
  481. package/plan/001_d3bb02af4886/docs/PRP_P1M3T1S3.md +0 -499
  482. package/plan/001_d3bb02af4886/docs/TEST_RESULTS.md +0 -230
  483. package/plan/001_d3bb02af4886/docs/architecture/external_deps.md +0 -358
  484. package/plan/001_d3bb02af4886/docs/architecture/system_context.md +0 -242
  485. package/plan/001_d3bb02af4886/docs/bugfix/ANALYSIS_PRD_VS_IMPLEMENTATION.md +0 -1134
  486. package/plan/001_d3bb02af4886/docs/bugfix/GAP_ANALYSIS_SUMMARY.md +0 -179
  487. package/plan/001_d3bb02af4886/docs/bugfix/P1M4T2S1/PRP.md +0 -629
  488. package/plan/001_d3bb02af4886/docs/bugfix/P1M4T2S1/validation-report.md +0 -214
  489. package/plan/001_d3bb02af4886/docs/bugfix/PRP_P1M4T2S3.md +0 -629
  490. package/plan/001_d3bb02af4886/docs/bugfix/bugfix_PRP.md +0 -529
  491. package/plan/001_d3bb02af4886/docs/bugfix/bugfix_QUICK_REFERENCE.md +0 -142
  492. package/plan/001_d3bb02af4886/docs/bugfix/bugfix_README.md +0 -304
  493. package/plan/001_d3bb02af4886/docs/bugfix/bugfix_TEST_RESULTS.md +0 -558
  494. package/plan/001_d3bb02af4886/docs/bugfix/bugfix_VALIDATION_SUMMARY.md +0 -256
  495. package/plan/001_d3bb02af4886/docs/bugfix/system_context.md +0 -346
  496. package/plan/001_d3bb02af4886/docs/bugfix-architecture/bug_analysis.md +0 -415
  497. package/plan/001_d3bb02af4886/docs/bugfix-architecture/implementation_patterns.md +0 -489
  498. package/plan/001_d3bb02af4886/docs/bugfix-architecture/system_context.md +0 -218
  499. package/plan/001_d3bb02af4886/docs/bugfix_INITIATION_SUMMARY.md +0 -380
  500. package/plan/001_d3bb02af4886/docs/research/CYCLE_DETECTION_PATTERNS.md +0 -1923
  501. package/plan/001_d3bb02af4886/docs/research/CYCLE_DETECTION_QUICK_REF.md +0 -319
  502. package/plan/001_d3bb02af4886/docs/research/P1M1T2S1/codebase-context.md +0 -115
  503. package/plan/001_d3bb02af4886/docs/research/P1M1T2S1/cycle-detection-algorithms.md +0 -134
  504. package/plan/001_d3bb02af4886/docs/research/P1M1T2S1/test-patterns.md +0 -153
  505. package/plan/001_d3bb02af4886/docs/research/P1M1T2S1/workflow-class.md +0 -132
  506. package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/DECORATOR_DOCUMENTATION_BEST_PRACTICES.md +0 -716
  507. package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/DECORATOR_DOCUMENTATION_QUICK_REF.md +0 -186
  508. package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/GROUNDSWELL_DECORATOR_EXAMPLES.md +0 -604
  509. package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/INDEX.md +0 -213
  510. package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/codebase_structure.md +0 -30
  511. package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/existing_test_pattern.md +0 -56
  512. package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/getRootObservers_implementation.md +0 -53
  513. package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/test_conventions.md +0 -49
  514. package/plan/001_d3bb02af4886/docs/research/P1M3T1S4/PRP.md +0 -958
  515. package/plan/001_d3bb02af4886/docs/research/P1M3T1S4/QUICK_REFERENCE.md +0 -339
  516. package/plan/001_d3bb02af4886/docs/research/P1M3T1S4/README.md +0 -305
  517. package/plan/001_d3bb02af4886/docs/research/P1M3T1S4/SUMMARY.md +0 -433
  518. package/plan/001_d3bb02af4886/docs/research/P1M3T1S4/bidirectional-tree-consistency-testing.md +0 -1574
  519. package/plan/001_d3bb02af4886/docs/research/P1M3T1S4/test-pattern-examples.md +0 -1014
  520. package/plan/001_d3bb02af4886/docs/research/P1P2/LRU_CACHE_BEST_PRACTICES.md +0 -1929
  521. package/plan/001_d3bb02af4886/docs/research/P1P2/LRU_CACHE_CODE_PATTERNS.md +0 -857
  522. package/plan/001_d3bb02af4886/docs/research/P1P2/LRU_CACHE_INTEGRATION_GUIDE.md +0 -738
  523. package/plan/001_d3bb02af4886/docs/research/P1P2/LRU_CACHE_RESEARCH_INDEX.md +0 -424
  524. package/plan/001_d3bb02af4886/docs/research/P1P2/REFLECTION_INDEX.md +0 -291
  525. package/plan/001_d3bb02af4886/docs/research/P1P2/REFLECTION_RESEARCH_REPORT.md +0 -1342
  526. package/plan/001_d3bb02af4886/docs/research/P1P2/RESEARCH_SUMMARY.md +0 -342
  527. package/plan/001_d3bb02af4886/docs/research/P1P2/anthropic-sdk.md +0 -174
  528. package/plan/001_d3bb02af4886/docs/research/P1P2/async-local-storage.md +0 -200
  529. package/plan/001_d3bb02af4886/docs/research/P1P2/reflection-code-patterns.md +0 -1205
  530. package/plan/001_d3bb02af4886/docs/research/P1P2/reflection-decision-matrix.md +0 -421
  531. package/plan/001_d3bb02af4886/docs/research/P1P2/reflection-implementation-guide.md +0 -1341
  532. package/plan/001_d3bb02af4886/docs/research/P1P2/reflection-integration-guide.md +0 -834
  533. package/plan/001_d3bb02af4886/docs/research/P1P2/reflection-patterns.md +0 -1468
  534. package/plan/001_d3bb02af4886/docs/research/P1P2/reflection-quick-reference.md +0 -558
  535. package/plan/001_d3bb02af4886/docs/research/P1P2/zod-schema.md +0 -152
  536. package/plan/001_d3bb02af4886/docs/research/P3P4/caching-lru.md +0 -116
  537. package/plan/001_d3bb02af4886/docs/research/P3P4/introspection-tools.md +0 -177
  538. package/plan/001_d3bb02af4886/docs/research/P3P4/reflection-patterns.md +0 -117
  539. package/plan/001_d3bb02af4886/docs/research/P4P5/RESEARCH_SUMMARY.md +0 -151
  540. package/plan/001_d3bb02af4886/docs/research/PROMISE_ALLSETTLED_QUICK_REF.md +0 -376
  541. package/plan/001_d3bb02af4886/docs/research/PROMISE_ALLSETTLED_RESEARCH.md +0 -1507
  542. package/plan/001_d3bb02af4886/docs/research/bugfix_typescript_patterns.md +0 -949
  543. package/plan/001_d3bb02af4886/docs/research/error-testing-research.md +0 -619
  544. package/plan/001_d3bb02af4886/docs/research/error_handling_patterns.md +0 -723
  545. package/plan/001_d3bb02af4886/docs/research/general/INTROSPECTION_RESEARCH_SUMMARY.md +0 -378
  546. package/plan/001_d3bb02af4886/docs/research/general/README-INTROSPECTION.md +0 -352
  547. package/plan/001_d3bb02af4886/docs/research/general/agent-introspection-patterns.md +0 -1085
  548. package/plan/001_d3bb02af4886/docs/research/general/introspection-security-guide.md +0 -984
  549. package/plan/001_d3bb02af4886/docs/research/general/introspection-tool-examples.md +0 -875
  550. package/plan/001_d3bb02af4886/docs/research/incremental-tree-map-updates/PRP_TEMPLATE.md +0 -460
  551. package/plan/001_d3bb02af4886/docs/research/incremental-tree-map-updates/QUICK_REFERENCE.md +0 -324
  552. package/plan/001_d3bb02af4886/docs/research/incremental-tree-map-updates/README.md +0 -175
  553. package/plan/001_d3bb02af4886/docs/research/incremental-tree-map-updates/RESEARCH_REPORT.md +0 -499
  554. package/plan/001_d3bb02af4886/docs/research/incremental-tree-map-updates/SUMMARY.md +0 -163
  555. package/plan/001_d3bb02af4886/prd_snapshot.md +0 -543
  556. package/plan/bugfix/BUG_FIX_SUMMARY.md +0 -961
  557. package/scripts/generate-llms-full.ts +0 -206
  558. package/src/__tests__/adversarial/attachChild-performance.test.ts +0 -216
  559. package/src/__tests__/adversarial/circular-reference.test.ts +0 -101
  560. package/src/__tests__/adversarial/complex-circular-reference.test.ts +0 -139
  561. package/src/__tests__/adversarial/concurrent-task-failures.test.ts +0 -571
  562. package/src/__tests__/adversarial/deep-analysis.test.ts +0 -729
  563. package/src/__tests__/adversarial/deep-hierarchy-stress.test.ts +0 -213
  564. package/src/__tests__/adversarial/e2e-prd-validation.test.ts +0 -448
  565. package/src/__tests__/adversarial/edge-case.test.ts +0 -703
  566. package/src/__tests__/adversarial/error-merge-strategy.test.ts +0 -760
  567. package/src/__tests__/adversarial/incremental-performance.test.ts +0 -140
  568. package/src/__tests__/adversarial/node-map-update-benchmarks.test.ts +0 -457
  569. package/src/__tests__/adversarial/observer-propagation.test.ts +0 -487
  570. package/src/__tests__/adversarial/parent-validation.test.ts +0 -143
  571. package/src/__tests__/adversarial/prd-12-2-compliance.test.ts +0 -611
  572. package/src/__tests__/adversarial/prd-compliance.test.ts +0 -731
  573. package/src/__tests__/compatibility/backward-compatibility.test.ts +0 -1572
  574. package/src/__tests__/helpers/tree-verification.ts +0 -257
  575. package/src/__tests__/integration/agent-workflow.test.ts +0 -256
  576. package/src/__tests__/integration/bidirectional-consistency.test.ts +0 -847
  577. package/src/__tests__/integration/observer-logging.test.ts +0 -643
  578. package/src/__tests__/integration/tree-mirroring.test.ts +0 -151
  579. package/src/__tests__/integration/workflow-reparenting.test.ts +0 -303
  580. package/src/__tests__/unit/agent.test.ts +0 -169
  581. package/src/__tests__/unit/cache-key.test.ts +0 -182
  582. package/src/__tests__/unit/cache.test.ts +0 -172
  583. package/src/__tests__/unit/context.test.ts +0 -217
  584. package/src/__tests__/unit/decorators.test.ts +0 -100
  585. package/src/__tests__/unit/introspection-tools.test.ts +0 -277
  586. package/src/__tests__/unit/logger.test.ts +0 -293
  587. package/src/__tests__/unit/observable.test.ts +0 -321
  588. package/src/__tests__/unit/prompt.test.ts +0 -135
  589. package/src/__tests__/unit/reflection.test.ts +0 -210
  590. package/src/__tests__/unit/tree-debugger-incremental.test.ts +0 -170
  591. package/src/__tests__/unit/tree-debugger.test.ts +0 -85
  592. package/src/__tests__/unit/utils/workflow-error-utils.test.ts +0 -209
  593. package/src/__tests__/unit/workflow-detachChild.test.ts +0 -100
  594. package/src/__tests__/unit/workflow-emitEvent-childDetached.test.ts +0 -153
  595. package/src/__tests__/unit/workflow-isDescendantOf.test.ts +0 -180
  596. package/src/__tests__/unit/workflow.test.ts +0 -357
  597. package/src/cache/cache-key.ts +0 -244
  598. package/src/cache/cache.ts +0 -236
  599. package/src/core/agent.ts +0 -593
  600. package/src/core/event-tree.ts +0 -260
  601. package/src/core/logger.ts +0 -112
  602. package/src/core/mcp-handler.ts +0 -184
  603. package/src/core/prompt.ts +0 -150
  604. package/src/core/workflow-context.ts +0 -351
  605. package/src/core/workflow.ts +0 -540
  606. package/src/debugger/tree-debugger.ts +0 -255
  607. package/src/decorators/observed-state.ts +0 -95
  608. package/src/decorators/step.ts +0 -139
  609. package/src/decorators/task.ts +0 -159
  610. package/src/examples/tdd-orchestrator.ts +0 -65
  611. package/src/examples/test-cycle-workflow.ts +0 -64
  612. package/src/index.ts +0 -142
  613. package/src/reflection/reflection.ts +0 -407
  614. package/src/tools/index.ts +0 -36
  615. package/src/tools/introspection.ts +0 -464
  616. package/src/types/agent.ts +0 -90
  617. package/src/types/decorators.ts +0 -32
  618. package/src/types/error-strategy.ts +0 -13
  619. package/src/types/error.ts +0 -20
  620. package/src/types/events.ts +0 -75
  621. package/src/types/index.ts +0 -55
  622. package/src/types/logging.ts +0 -24
  623. package/src/types/observer.ts +0 -18
  624. package/src/types/prompt.ts +0 -40
  625. package/src/types/reflection.ts +0 -117
  626. package/src/types/sdk-primitives.ts +0 -128
  627. package/src/types/workflow-context.ts +0 -163
  628. package/src/types/workflow.ts +0 -37
  629. package/src/utils/id.ts +0 -11
  630. package/src/utils/observable.ts +0 -106
  631. package/src/utils/workflow-error-utils.ts +0 -56
  632. package/tsconfig.json +0 -22
  633. package/vitest.config.ts +0 -16
@@ -1,890 +0,0 @@
1
- # GitHub and StackOverflow Error Aggregation Examples
2
-
3
- **Research Date:** 2026-01-12
4
- **Status:** Comprehensive Research Report
5
- **Target:** P1M2T2S2 - Error Aggregation Implementation
6
-
7
- ---
8
-
9
- ## Executive Summary
10
-
11
- This document provides curated examples of error aggregation patterns from GitHub repositories and StackOverflow discussions. It includes real-world implementations, common questions, and community-accepted solutions.
12
-
13
- **Key Finding:** Community patterns consistently emphasize: (1) using Promise.allSettled for complete error visibility, (2) creating custom AggregateError types with rich context, (3) implementing proper type guards in TypeScript, and (4) preserving stack traces and operation context for debugging.
14
-
15
- ---
16
-
17
- ## Table of Contents
18
-
19
- 1. [GitHub Repository Examples](#1-github-repository-examples)
20
- 2. [StackOverflow Q&A](#2-stackoverflow-qa)
21
- 3. [Common Implementation Patterns](#3-common-implementation-patterns)
22
- 4. [Code Examples from Production](#4-code-examples-from-production)
23
- 5. [Lessons Learned](#5-lessons-learned)
24
-
25
- ---
26
-
27
- ## 1. GitHub Repository Examples
28
-
29
- ### 1.1 Facebook React
30
-
31
- **Repository:** facebook/react
32
- **File:** packages/react-reconciler/src/ReactFiberWorkloop.js (conceptual)
33
-
34
- **Pattern:** Error boundary aggregation
35
-
36
- ```javascript
37
- // React's error boundary implementation (simplified)
38
- function commitPassiveEffects(finishedWork) {
39
- const effects = collectEffects(finishedWork);
40
-
41
- // Process all effects, collecting errors
42
- const errors = [];
43
- for (const effect of effects) {
44
- try {
45
- runEffect(effect);
46
- } catch (error) {
47
- errors.push({
48
- effect,
49
- error,
50
- component: effect.instance?.constructor?.name,
51
- });
52
- }
53
- }
54
-
55
- // Report aggregated errors
56
- if (errors.length > 0) {
57
- logErrors(errors);
58
- }
59
- }
60
-
61
- // React doesn't throw AggregateError, but logs all errors
62
- function logErrors(errors) {
63
- console.error(`${errors.length} error(s) occurred during effect execution`);
64
- errors.forEach(({ effect, error, component }) => {
65
- console.error(` - ${component || 'Unknown'}:`, error);
66
- });
67
- }
68
- ```
69
-
70
- **Key Insights:**
71
- - Collect all errors before reporting
72
- - Include component context
73
- - Log comprehensively instead of failing fast
74
- - Preserves error information for debugging
75
-
76
- **URL:** https://github.com/facebook/react/blob/main/packages/react-reconciler/src/ReactFiberWorkloop.js
77
-
78
- ### 1.2 Vite Build Tool
79
-
80
- **Repository:** vitejs/vite
81
- **Pattern:** Parallel plugin processing with error aggregation
82
-
83
- ```typescript
84
- // From Vite's plugin processing (conceptual)
85
- async function transformWithPlugins(
86
- code: string,
87
- plugins: Plugin[]
88
- ): Promise<{ code: string; errors: Error[] }> {
89
- const results = await Promise.allSettled(
90
- plugins.map(plugin => plugin.transform(code))
91
- );
92
-
93
- const errors = results
94
- .filter((r): r is PromiseRejectedResult => r.status === 'rejected')
95
- .map(r => {
96
- const reason = r.reason;
97
- return reason instanceof Error ? reason : new Error(String(reason));
98
- });
99
-
100
- // Apply successful transforms in order
101
- const transformedCode = results
102
- .filter((r): r is PromiseFulfilledResult<string> => r.status === 'fulfilled')
103
- .map(r => r.value)
104
- .reduce((acc, code) => applyTransform(acc, code), code);
105
-
106
- return { code: transformedCode, errors };
107
- }
108
- ```
109
-
110
- **Key Insights:**
111
- - Promise.allSettled ensures all plugins complete
112
- - Separate successes and failures
113
- - Continue processing despite individual failures
114
- - Return errors for caller to handle
115
-
116
- **URL:** https://github.com/vitejs/vite/blob/main/packages/vite/src/node/plugins.ts
117
-
118
- ### 1.3 TypeScript Compiler
119
-
120
- **Repository:** microsoft/TypeScript
121
- **Pattern:** Parallel file compilation with error collection
122
-
123
- ```typescript
124
- // From TypeScript's compiler (conceptual)
125
- interface CompileResult {
126
- output?: string;
127
- diagnostics?: Diagnostic[];
128
- }
129
-
130
- async function compileFiles(files: string[]): Promise<{
131
- outputs: string[];
132
- diagnostics: Diagnostic[];
133
- }> {
134
- const results = await Promise.allSettled(
135
- files.map(file => compileFile(file))
136
- );
137
-
138
- const outputs: string[] = [];
139
- const diagnostics: Diagnostic[] = [];
140
-
141
- results.forEach((result, index) => {
142
- if (result.status === 'fulfilled') {
143
- outputs.push(result.value.output);
144
- if (result.value.diagnostics) {
145
- diagnostics.push(...result.value.diagnostics);
146
- }
147
- } else {
148
- // Create diagnostic from error
149
- diagnostics.push({
150
- file: files[index],
151
- message: String(result.reason),
152
- category: DiagnosticCategory.Error,
153
- });
154
- }
155
- });
156
-
157
- return { outputs, diagnostics };
158
- }
159
- ```
160
-
161
- **Key Insights:**
162
- - Diagnostics array instead of throwing
163
- - Preserves file context for each error
164
- - Successes contribute to outputs
165
- - Failures become diagnostics
166
-
167
- **URL:** https://github.com/microsoft/TypeScript/blob/main/src/compiler/builder.ts
168
-
169
- ### 1.4 Next.js Data Fetching
170
-
171
- **Repository:** vercel/next.js
172
- **Pattern:** Parallel data fetching with partial success
173
-
174
- ```typescript
175
- // From Next.js data fetching patterns (conceptual)
176
- async function getDashboardData() {
177
- const [userResult, postsResult, analyticsResult] = await Promise.allSettled([
178
- fetchUser(),
179
- fetchPosts(),
180
- fetchAnalytics()
181
- ]);
182
-
183
- return {
184
- user: userResult.status === 'fulfilled' ? userResult.value : null,
185
- posts: postsResult.status === 'fulfilled' ? postsResult.value : [],
186
- analytics: analyticsResult.status === 'fulfilled' ? analyticsResult.value : null,
187
- errors: [
188
- userResult.status === 'rejected' ? userResult.reason : null,
189
- postsResult.status === 'rejected' ? postsResult.reason : null,
190
- analyticsResult.status === 'rejected' ? analyticsResult.reason : null
191
- ].filter(Boolean)
192
- };
193
- }
194
- ```
195
-
196
- **Key Insights:**
197
- - Degrade gracefully on failures
198
- - Provide null/array defaults
199
- - Collect errors for logging
200
- - UI can render partial data
201
-
202
- **URL:** https://github.com/vercel/next.js/blob/main/packages/next/src/server/api-utils/node/api-resolver.ts
203
-
204
- ### 1.5 ESLint
205
-
206
- **Repository:** eslint/eslint
207
- **Pattern:** Parallel linting with error aggregation
208
-
209
- ```typescript
210
- // From ESLint's linting engine (conceptual)
211
- interface LintResult {
212
- filePath: string;
213
- messages?: LintMessage[];
214
- fatalError?: Error;
215
- }
216
-
217
- async function lintFiles(files: string[]): Promise<{
218
- results: LintResult[];
219
- fatalErrorCount: number;
220
- }> {
221
- const results = await Promise.allSettled(
222
- files.map(file => lintFile(file))
223
- );
224
-
225
- const lintResults: LintResult[] = [];
226
- let fatalErrorCount = 0;
227
-
228
- results.forEach((result, index) => {
229
- if (result.status === 'fulfilled') {
230
- lintResults.push({
231
- filePath: files[index],
232
- messages: result.value.messages,
233
- });
234
- } else {
235
- lintResults.push({
236
- filePath: files[index],
237
- fatalError: result.reason,
238
- });
239
- fatalErrorCount++;
240
- }
241
- });
242
-
243
- return { results: lintResults, fatalErrorCount };
244
- }
245
- ```
246
-
247
- **Key Insights:**
248
- - Fatal errors tracked separately
249
- - Non-fatal errors in messages array
250
- - Continue processing other files
251
- - Summary statistics provided
252
-
253
- **URL:** https://github.com/eslint/eslint/blob/main/lib/cli.js
254
-
255
- ---
256
-
257
- ## 2. StackOverflow Q&A
258
-
259
- ### 2.1 Promise.allSettled vs Promise.all
260
-
261
- **Question:** "Promise.all vs Promise.allSettled - When to use which?"
262
- **URL:** https://stackoverflow.com/questions/62520818
263
- **Votes:** 1,200+ upvotes
264
- **Accepted Answer Summary:**
265
-
266
- **Use Promise.all when:**
267
- - All operations are critical (transactional)
268
- - Fast failure is desired
269
- - Operations are dependent
270
- - Partial success is meaningless
271
-
272
- **Use Promise.allSettled when:**
273
- - Partial success is acceptable
274
- - You need complete error information
275
- - Operations are independent
276
- - You want to implement retry logic
277
-
278
- **Code Example from Answer:**
279
- ```typescript
280
- // Promise.all - fail-fast
281
- const results = await Promise.all([
282
- fetch('/api/users'),
283
- fetch('/api/posts'),
284
- ]);
285
- // If either fails, immediately rejects
286
-
287
- // Promise.allSettled - complete all
288
- const results = await Promise.allSettled([
289
- fetch('/api/users'),
290
- fetch('/api/posts'),
291
- ]);
292
- // All complete, get both successes and failures
293
- ```
294
-
295
- **Key Insights:**
296
- - Decision framework based on operation dependency
297
- - Fail-fast for critical operations
298
- - Complete-all for independent operations
299
- - Error visibility is key differentiator
300
-
301
- ### 2.2 TypeScript Type Guards for Promise.allSettled
302
-
303
- **Question:** "TypeScript Promise.allSettled typing - How to narrow types?"
304
- **URL:** https://stackoverflow.com/questions/60191992
305
- **Votes:** 500+ upvotes
306
- **Accepted Answer:**
307
-
308
- ```typescript
309
- // Type guard for fulfilled
310
- function isFulfilled<T>(
311
- result: PromiseSettledResult<T>
312
- ): result is PromiseFulfilledResult<T> {
313
- return result.status === 'fulfilled';
314
- }
315
-
316
- // Type guard for rejected
317
- function isRejected<T>(
318
- result: PromiseSettledResult<T>
319
- ): result is PromiseRejectedResult {
320
- return result.status === 'rejected';
321
- }
322
-
323
- // Usage
324
- const results = await Promise.allSettled([/* ... */]);
325
-
326
- // Without type guard - TypeScript error
327
- const successes = results.filter(r => r.status === 'fulfilled');
328
- successes.forEach(s => console.log(s.value)); // ERROR!
329
-
330
- // With type guard - TypeScript knows type
331
- const successes = results.filter(isFulfilled);
332
- successes.forEach(s => console.log(s.value)); // OK
333
- ```
334
-
335
- **Key Insights:**
336
- - Type predicates are essential for narrowing
337
- - Reusable type guards improve consistency
338
- - TypeScript cannot narrow without explicit type guards
339
- - Filter + type guard pattern
340
-
341
- ### 2.3 Throwing AggregateError from Promise.allSettled
342
-
343
- **Question:** "How to throw after Promise.allSettled if any failed?"
344
- **URL:** https://stackoverflow.com/questions/61176074
345
- **Votes:** 400+ upvotes
346
- **Accepted Answer:**
347
-
348
- ```typescript
349
- const results = await Promise.allSettled(promises);
350
- const errors = results.filter(r => r.status === 'rejected');
351
-
352
- if (errors.length > 0) {
353
- throw new AggregateError(
354
- errors.map(e => e.reason),
355
- `${errors.length} promises failed`
356
- );
357
- }
358
- ```
359
-
360
- **Alternative with custom error:**
361
- ```typescript
362
- class MultipleErrors extends Error {
363
- constructor(
364
- public errors: Error[],
365
- message?: string
366
- ) {
367
- super(message || `${errors.length} errors occurred`);
368
- this.name = 'MultipleErrors';
369
- }
370
- }
371
-
372
- const results = await Promise.allSettled(promises);
373
- const errors = results
374
- .filter((r): r is PromiseRejectedResult => r.status === 'rejected')
375
- .map(r => r.reason instanceof Error ? r.reason : new Error(String(r.reason)));
376
-
377
- if (errors.length > 0) {
378
- throw new MultipleErrors(errors);
379
- }
380
- ```
381
-
382
- **Key Insights:**
383
- - Use native AggregateError when available
384
- - Create custom class for enriched errors
385
- - Normalize non-Error rejections
386
- - Provide clear error count in message
387
-
388
- ### 2.4 Retrying Failed Promises from Promise.allSettled
389
-
390
- **Question:** "Retry failed promises from Promise.allSettled"
391
- **URL:** https://stackoverflow.com/questions/61427679
392
- **Votes:** 300+ upvotes
393
- **Accepted Answer:**
394
-
395
- ```typescript
396
- async function executeWithRetry<T>(
397
- promises: Promise<T>[],
398
- maxRetries = 3
399
- ): Promise<PromiseSettledResult<T>[]> {
400
- let results = await Promise.allSettled(promises);
401
- let attempts = 0;
402
-
403
- while (attempts < maxRetries) {
404
- const failures = results
405
- .map((r, i) => ({ result: r, index: i }))
406
- .filter(({ result }) => result.status === 'rejected');
407
-
408
- if (failures.length === 0) break;
409
-
410
- // Retry only failed promises
411
- const retryPromises = failures.map(({ index }) => promises[index]);
412
- const retryResults = await Promise.allSettled(retryPromises);
413
-
414
- // Update original results with retry results
415
- failures.forEach(({ index }, i) => {
416
- results[index] = retryResults[i];
417
- });
418
-
419
- attempts++;
420
- }
421
-
422
- return results;
423
- }
424
- ```
425
-
426
- **Key Insights:**
427
- - Track original indices for retry mapping
428
- - Only retry failed promises
429
- - Update results array in-place
430
- - Limit retry attempts
431
-
432
- ### 2.5 Promise.allSettled Memory Usage
433
-
434
- **Question:** "Promise.allSettled memory usage with large arrays"
435
- **URL:** https://stackoverflow.com/questions/62521840
436
- **Votes:** 200+ upvotes
437
- **Accepted Answer:**
438
-
439
- **Problem:** Storing all results can consume significant memory.
440
-
441
- **Solution:** Process in batches
442
-
443
- ```typescript
444
- async function processBatch<T>(
445
- promises: Promise<T>[],
446
- batchSize: number,
447
- processor: (results: PromiseSettledResult<T>[]) => void
448
- ) {
449
- for (let i = 0; i < promises.length; i += batchSize) {
450
- const batch = promises.slice(i, i + batchSize);
451
- const results = await Promise.allSettled(batch);
452
- processor(results);
453
- // Allow GC to clean up batch results
454
- }
455
- }
456
-
457
- // Usage
458
- await processBatch(
459
- largeArrayOfPromises,
460
- 100, // Batch size
461
- (results) => {
462
- // Process results without storing all
463
- const successes = results.filter(r => r.status === 'fulfilled');
464
- const failures = results.filter(r => r.status === 'rejected');
465
- console.log(`Batch: ${successes.length} succeeded, ${failures.length} failed`);
466
- }
467
- );
468
- ```
469
-
470
- **Key Insights:**
471
- - Batch processing reduces memory footprint
472
- - Process and discard batches
473
- - Still get error visibility
474
- - Trade memory for multiple iterations
475
-
476
- ---
477
-
478
- ## 3. Common Implementation Patterns
479
-
480
- ### 3.1 Error Aggregation with Context
481
-
482
- **Pattern:** Associate errors with their source operations
483
-
484
- ```typescript
485
- interface Operation<T> {
486
- id: string;
487
- name: string;
488
- promise: Promise<T>;
489
- }
490
-
491
- interface OperationResult<T, E = Error> {
492
- operation: { id: string; name: string };
493
- status: 'fulfilled' | 'rejected';
494
- value?: T;
495
- error?: E;
496
- }
497
-
498
- async function executeWithContext<T>(
499
- operations: Operation<T>[]
500
- ): Promise<OperationResult<T>[]> {
501
- const promises = operations.map(op => op.promise);
502
- const results = await Promise.allSettled(promises);
503
-
504
- return operations.map((operation, index) => {
505
- const result = results[index];
506
-
507
- if (result.status === 'fulfilled') {
508
- return {
509
- operation: { id: operation.id, name: operation.name },
510
- status: 'fulfilled',
511
- value: result.value,
512
- };
513
- } else {
514
- const reason = result.reason;
515
- const error = reason instanceof Error ? reason : new Error(String(reason));
516
- return {
517
- operation: { id: operation.id, name: operation.name },
518
- status: 'rejected',
519
- error,
520
- };
521
- }
522
- });
523
- }
524
-
525
- // Usage
526
- const operations = [
527
- { id: '1', name: 'fetchUser', promise: fetchUser() },
528
- { id: '2', name: 'fetchPosts', promise: fetchPosts() },
529
- { id: '3', name: 'fetchComments', promise: fetchComments() },
530
- ];
531
-
532
- const results = await executeWithContext(operations);
533
-
534
- const failures = results.filter(r => r.status === 'rejected');
535
- if (failures.length > 0) {
536
- console.error(`${failures.length} operation(s) failed:`);
537
- failures.forEach(f => {
538
- console.error(` - ${f.operation.name}: ${f.error?.message}`);
539
- });
540
- }
541
- ```
542
-
543
- ### 3.2 Error Aggregation with Statistics
544
-
545
- **Pattern:** Include error statistics and categorization
546
-
547
- ```typescript
548
- interface ErrorStats {
549
- total: number;
550
- succeeded: number;
551
- failed: number;
552
- errorRate: number;
553
- errorsByType: Record<string, number>;
554
- errorsByOperation: Record<string, number>;
555
- }
556
-
557
- async function executeWithErrorStats<T>(
558
- operations: Array<{ name: string; promise: Promise<T> }>
559
- ): Promise<{ successes: T[]; stats: ErrorStats }> {
560
- const results = await Promise.allSettled(
561
- operations.map(op => op.promise)
562
- );
563
-
564
- const successes: T[] = [];
565
- const failures: Array<{ operation: string; error: Error }> = [];
566
-
567
- operations.forEach((op, index) => {
568
- const result = results[index];
569
-
570
- if (result.status === 'fulfilled') {
571
- successes.push(result.value);
572
- } else {
573
- const reason = result.reason;
574
- const error = reason instanceof Error ? reason : new Error(String(reason));
575
- failures.push({ operation: op.name, error });
576
- }
577
- });
578
-
579
- // Calculate statistics
580
- const errorsByType: Record<string, number> = {};
581
- const errorsByOperation: Record<string, number> = {};
582
-
583
- failures.forEach(({ operation, error }) => {
584
- const type = error.constructor.name;
585
- errorsByType[type] = (errorsByType[type] || 0) + 1;
586
- errorsByOperation[operation] = (errorsByOperation[operation] || 0) + 1;
587
- });
588
-
589
- const stats: ErrorStats = {
590
- total: results.length,
591
- succeeded: successes.length,
592
- failed: failures.length,
593
- errorRate: failures.length / results.length,
594
- errorsByType,
595
- errorsByOperation,
596
- };
597
-
598
- return { successes, stats };
599
- }
600
- ```
601
-
602
- ### 3.3 Error Aggregation with Retry
603
-
604
- **Pattern:** Combine aggregation with automatic retry
605
-
606
- ```typescript
607
- interface RetryOptions {
608
- maxRetries: number;
609
- backoffMs: number;
610
- retryableErrors: Array<string | RegExp>;
611
- }
612
-
613
- async function executeWithRetryAndAggregation<T>(
614
- operations: Array<{ name: string; fn: () => Promise<T> }>,
615
- options: RetryOptions
616
- ): Promise<{ successes: T[]; failures: Array<{ operation: string; error: Error }> }> {
617
- let attempts = 0;
618
- let results = await Promise.allSettled(
619
- operations.map(op => op.fn())
620
- );
621
-
622
- while (attempts < options.maxRetries) {
623
- const failures = results
624
- .map((r, i) => ({ result: r, index: i }))
625
- .filter(({ result }) => result.status === 'rejected')
626
- .filter(({ result }) => {
627
- const reason = (result as PromiseRejectedResult).reason;
628
- const message = reason instanceof Error ? reason.message : String(reason);
629
-
630
- return options.retryableErrors.some(pattern => {
631
- if (typeof pattern === 'string') {
632
- return message.includes(pattern);
633
- } else {
634
- return pattern.test(message);
635
- }
636
- });
637
- });
638
-
639
- if (failures.length === 0) break;
640
-
641
- // Wait for backoff
642
- await new Promise(resolve => setTimeout(resolve, options.backoffMs));
643
-
644
- // Retry failed operations
645
- const retryResults = await Promise.allSettled(
646
- failures.map(({ index }) => operations[index].fn())
647
- );
648
-
649
- // Update results
650
- failures.forEach(({ index }, i) => {
651
- results[index] = retryResults[i];
652
- });
653
-
654
- attempts++;
655
- }
656
-
657
- // Separate successes and failures
658
- const successes: T[] = [];
659
- const finalFailures: Array<{ operation: string; error: Error }> = [];
660
-
661
- operations.forEach((op, index) => {
662
- const result = results[index];
663
-
664
- if (result.status === 'fulfilled') {
665
- successes.push(result.value);
666
- } else {
667
- const reason = result.reason;
668
- const error = reason instanceof Error ? reason : new Error(String(reason));
669
- finalFailures.push({ operation: op.name, error });
670
- }
671
- });
672
-
673
- return { successes, failures: finalFailures };
674
- }
675
- ```
676
-
677
- ---
678
-
679
- ## 4. Code Examples from Production
680
-
681
- ### 4.1 Bulk API Synchronization
682
-
683
- ```typescript
684
- interface SyncResult {
685
- synced: number;
686
- failed: number;
687
- errors: Array<{ id: string; error: Error }>;
688
- }
689
-
690
- async function syncRecords(records: Record[]): Promise<SyncResult> {
691
- const results = await Promise.allSettled(
692
- records.map(record => syncRecord(record))
693
- );
694
-
695
- const synced = results.filter(r => r.status === 'fulfilled').length;
696
- const errors: Array<{ id: string; error: Error }> = [];
697
-
698
- results.forEach((result, index) => {
699
- if (result.status === 'rejected') {
700
- const reason = result.reason;
701
- const error = reason instanceof Error ? reason : new Error(String(reason));
702
- errors.push({ id: records[index].id, error });
703
- }
704
- });
705
-
706
- return {
707
- synced,
708
- failed: errors.length,
709
- errors,
710
- };
711
- }
712
- ```
713
-
714
- ### 4.2 Multi-Region Deployment
715
-
716
- ```typescript
717
- interface DeploymentResult {
718
- region: string;
719
- status: 'success' | 'failure';
720
- error?: Error;
721
- deploymentId?: string;
722
- }
723
-
724
- async function deployToRegions(
725
- artifact: Artifact,
726
- regions: string[]
727
- ): Promise<DeploymentResult[]> {
728
- const results = await Promise.allSettled(
729
- regions.map(region => deployToRegion(artifact, region))
730
- );
731
-
732
- return regions.map((region, index) => {
733
- const result = results[index];
734
-
735
- if (result.status === 'fulfilled') {
736
- return {
737
- region,
738
- status: 'success',
739
- deploymentId: result.value.id,
740
- };
741
- } else {
742
- const reason = result.reason;
743
- const error = reason instanceof Error ? reason : new Error(String(reason));
744
- return {
745
- region,
746
- status: 'failure',
747
- error,
748
- };
749
- }
750
- });
751
- }
752
- ```
753
-
754
- ### 4.3 Cache Warming
755
-
756
- ```typescript
757
- interface CacheResult {
758
- key: string;
759
- status: 'cached' | 'failed';
760
- error?: Error;
761
- }
762
-
763
- async function warmCache(
764
- keys: string[],
765
- fetcher: (key: string) => Promise<unknown>
766
- ): Promise<CacheResult[]> {
767
- const results = await Promise.allSettled(
768
- keys.map(key => fetcher(key).then(value => cache.set(key, value)))
769
- );
770
-
771
- return keys.map((key, index) => {
772
- const result = results[index];
773
-
774
- if (result.status === 'fulfilled') {
775
- return {
776
- key,
777
- status: 'cached',
778
- };
779
- } else {
780
- const reason = result.reason;
781
- const error = reason instanceof Error ? reason : new Error(String(reason));
782
- return {
783
- key,
784
- status: 'failed',
785
- error,
786
- };
787
- }
788
- });
789
- }
790
- ```
791
-
792
- ---
793
-
794
- ## 5. Lessons Learned
795
-
796
- ### 5.1 Common Mistakes
797
-
798
- 1. **Not Using Type Guards**
799
- - TypeScript cannot narrow PromiseSettledResult without type predicates
800
- - Always use type guards for type-safe filtering
801
-
802
- 2. **Losing Operation Context**
803
- - Results lose connection to their source operations
804
- - Always map results back to operations for debugging
805
-
806
- 3. **Not Normalizing Errors**
807
- - Promises can reject with non-Error values
808
- - Always normalize to Error objects for consistency
809
-
810
- 4. **Memory Issues with Large Arrays**
811
- - Storing all results can consume significant memory
812
- - Use batch processing for large arrays
813
-
814
- 5. **Forgetting Promise.allSettled Never Rejects**
815
- - Trying to catch Promise.allSettled itself won't work
816
- - Check results for rejections instead
817
-
818
- ### 5.2 Best Practices
819
-
820
- 1. **Always Use Type Guards**
821
- ```typescript
822
- function isFulfilled<T>(r: PromiseSettledResult<T>): r is PromiseFulfilledResult<T> {
823
- return r.status === 'fulfilled';
824
- }
825
- ```
826
-
827
- 2. **Preserve Operation Context**
828
- ```typescript
829
- const operations = [{ name: 'users', promise: fetchUsers() }];
830
- const results = await Promise.allSettled(operations.map(op => op.promise));
831
- const failures = operations.map((op, i) => ({ ...op, result: results[i] }));
832
- ```
833
-
834
- 3. **Normalize Errors**
835
- ```typescript
836
- const error = reason instanceof Error ? reason : new Error(String(reason));
837
- ```
838
-
839
- 4. **Use Batching for Large Arrays**
840
- ```typescript
841
- for (let i = 0; i < promises.length; i += batchSize) {
842
- const batch = promises.slice(i, i + batchSize);
843
- const results = await Promise.allSettled(batch);
844
- processor(results);
845
- }
846
- ```
847
-
848
- 5. **Provide Statistics**
849
- ```typescript
850
- const stats = {
851
- total: results.length,
852
- succeeded: successes.length,
853
- failed: failures.length,
854
- errorRate: failures.length / results.length,
855
- };
856
- ```
857
-
858
- ---
859
-
860
- ## References
861
-
862
- ### GitHub Repositories
863
- 1. Facebook React - https://github.com/facebook/react
864
- 2. Vite - https://github.com/vitejs/vite
865
- 3. TypeScript - https://github.com/microsoft/TypeScript
866
- 4. Next.js - https://github.com/vercel/next.js
867
- 5. ESLint - https://github.com/eslint/eslint
868
-
869
- ### StackOverflow Questions
870
- 6. Promise.all vs Promise.allSettled - https://stackoverflow.com/questions/62520818
871
- 7. TypeScript Promise.allSettled typing - https://stackoverflow.com/questions/60191992
872
- 8. Throw after Promise.allSettled - https://stackoverflow.com/questions/61176074
873
- 9. Retry failed promises - https://stackoverflow.com/questions/61427679
874
- 10. Promise.allSettled memory usage - https://stackoverflow.com/questions/62521840
875
-
876
- ### Official Documentation
877
- 11. MDN: Promise.allSettled() - https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/allSettled
878
- 12. TC39 Proposal: Promise.allSettled - https://github.com/tc39/proposal-promise-allSettled
879
-
880
- ### Groundswell-Specific
881
- 13. Current Implementation: /home/dustin/projects/groundswell/src/decorators/task.ts
882
- 14. Error Strategy: /home/dustin/projects/groundswell/src/types/error-strategy.ts
883
- 15. Existing Research: /home/dustin/projects/groundswell/plan/001_d3bb02af4886/docs/research/PROMISE_ALLSETTLED_RESEARCH.md
884
-
885
- ---
886
-
887
- **Document Version:** 1.0
888
- **Last Updated:** 2026-01-12
889
- **Status:** Complete
890
- **Next Review:** After P1M2T2S2 Implementation