@cleocode/core 2026.3.56 → 2026.3.58

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 (893) hide show
  1. package/dist/adapters/adapter-registry.js +64 -0
  2. package/dist/adapters/adapter-registry.js.map +1 -0
  3. package/dist/adapters/discovery.js +83 -0
  4. package/dist/adapters/discovery.js.map +1 -0
  5. package/dist/adapters/index.js +9 -0
  6. package/dist/adapters/index.js.map +1 -0
  7. package/dist/adapters/manager.js +260 -0
  8. package/dist/adapters/manager.js.map +1 -0
  9. package/dist/admin/export-tasks.js +171 -0
  10. package/dist/admin/export-tasks.js.map +1 -0
  11. package/dist/admin/export.js +103 -0
  12. package/dist/admin/export.js.map +1 -0
  13. package/dist/admin/help.js +106 -0
  14. package/dist/admin/help.js.map +1 -0
  15. package/dist/admin/import-tasks.js +182 -0
  16. package/dist/admin/import-tasks.js.map +1 -0
  17. package/dist/admin/import.js +129 -0
  18. package/dist/admin/import.js.map +1 -0
  19. package/dist/admin/index.js +13 -0
  20. package/dist/admin/index.js.map +1 -0
  21. package/dist/adrs/find.js +134 -0
  22. package/dist/adrs/find.js.map +1 -0
  23. package/dist/adrs/index.js +15 -0
  24. package/dist/adrs/index.js.map +1 -0
  25. package/dist/adrs/link-pipeline.js +160 -0
  26. package/dist/adrs/link-pipeline.js.map +1 -0
  27. package/dist/adrs/list.js +43 -0
  28. package/dist/adrs/list.js.map +1 -0
  29. package/dist/adrs/parse.js +51 -0
  30. package/dist/adrs/parse.js.map +1 -0
  31. package/dist/adrs/show.js +22 -0
  32. package/dist/adrs/show.js.map +1 -0
  33. package/dist/adrs/sync.js +188 -0
  34. package/dist/adrs/sync.js.map +1 -0
  35. package/dist/adrs/types.js +9 -0
  36. package/dist/adrs/types.js.map +1 -0
  37. package/dist/adrs/validate.js +57 -0
  38. package/dist/adrs/validate.js.map +1 -0
  39. package/dist/agents/agent-schema.d.ts.map +1 -1
  40. package/dist/agents/agent-schema.js +80 -0
  41. package/dist/agents/agent-schema.js.map +1 -0
  42. package/dist/agents/capacity.js +116 -0
  43. package/dist/agents/capacity.js.map +1 -0
  44. package/dist/agents/execution-learning.d.ts +223 -0
  45. package/dist/agents/execution-learning.d.ts.map +1 -0
  46. package/dist/agents/index.d.ts +1 -0
  47. package/dist/agents/index.d.ts.map +1 -1
  48. package/dist/agents/index.js +21 -0
  49. package/dist/agents/index.js.map +1 -0
  50. package/dist/agents/registry.js +314 -0
  51. package/dist/agents/registry.js.map +1 -0
  52. package/dist/agents/retry.js +176 -0
  53. package/dist/agents/retry.js.map +1 -0
  54. package/dist/audit-prune.js +94 -0
  55. package/dist/audit-prune.js.map +1 -0
  56. package/dist/audit.js +68 -0
  57. package/dist/audit.js.map +1 -0
  58. package/dist/backfill/index.d.ts +56 -0
  59. package/dist/backfill/index.d.ts.map +1 -0
  60. package/dist/bootstrap.d.ts +1 -1
  61. package/dist/bootstrap.js +260 -0
  62. package/dist/bootstrap.js.map +1 -0
  63. package/dist/caamp/adapter.js +434 -0
  64. package/dist/caamp/adapter.js.map +1 -0
  65. package/dist/caamp/capability-check.js +38 -0
  66. package/dist/caamp/capability-check.js.map +1 -0
  67. package/dist/caamp/index.js +23 -0
  68. package/dist/caamp/index.js.map +1 -0
  69. package/dist/caamp-init.js +16 -0
  70. package/dist/caamp-init.js.map +1 -0
  71. package/dist/cleo.js +267 -0
  72. package/dist/cleo.js.map +1 -0
  73. package/dist/codebase-map/analyzers/architecture.js +130 -0
  74. package/dist/codebase-map/analyzers/architecture.js.map +1 -0
  75. package/dist/codebase-map/analyzers/concerns.js +122 -0
  76. package/dist/codebase-map/analyzers/concerns.js.map +1 -0
  77. package/dist/codebase-map/analyzers/conventions.js +149 -0
  78. package/dist/codebase-map/analyzers/conventions.js.map +1 -0
  79. package/dist/codebase-map/analyzers/integrations.js +108 -0
  80. package/dist/codebase-map/analyzers/integrations.js.map +1 -0
  81. package/dist/codebase-map/analyzers/stack.js +117 -0
  82. package/dist/codebase-map/analyzers/stack.js.map +1 -0
  83. package/dist/codebase-map/analyzers/structure.js +137 -0
  84. package/dist/codebase-map/analyzers/structure.js.map +1 -0
  85. package/dist/codebase-map/analyzers/testing.js +118 -0
  86. package/dist/codebase-map/analyzers/testing.js.map +1 -0
  87. package/dist/codebase-map/index.js +57 -0
  88. package/dist/codebase-map/index.js.map +1 -0
  89. package/dist/codebase-map/store.js +122 -0
  90. package/dist/codebase-map/store.js.map +1 -0
  91. package/dist/codebase-map/summary.js +152 -0
  92. package/dist/codebase-map/summary.js.map +1 -0
  93. package/dist/compliance/index.js +288 -0
  94. package/dist/compliance/index.js.map +1 -0
  95. package/dist/compliance/protocol-enforcement.js +332 -0
  96. package/dist/compliance/protocol-enforcement.js.map +1 -0
  97. package/dist/compliance/protocol-rules.js +786 -0
  98. package/dist/compliance/protocol-rules.js.map +1 -0
  99. package/dist/compliance/protocol-types.js +80 -0
  100. package/dist/compliance/protocol-types.js.map +1 -0
  101. package/dist/compliance/store.js +53 -0
  102. package/dist/compliance/store.js.map +1 -0
  103. package/dist/config/build-config.js +29 -0
  104. package/dist/config/build-config.js.map +1 -0
  105. package/dist/config.d.ts +47 -0
  106. package/dist/config.d.ts.map +1 -1
  107. package/dist/config.js +287 -0
  108. package/dist/config.js.map +1 -0
  109. package/dist/constants.js +18 -0
  110. package/dist/constants.js.map +1 -0
  111. package/dist/context/index.js +137 -0
  112. package/dist/context/index.js.map +1 -0
  113. package/dist/engine-result.js +12 -0
  114. package/dist/engine-result.js.map +1 -0
  115. package/dist/error-catalog.js +404 -0
  116. package/dist/error-catalog.js.map +1 -0
  117. package/dist/error-registry.js +393 -0
  118. package/dist/error-registry.js.map +1 -0
  119. package/dist/errors.js +167 -0
  120. package/dist/errors.js.map +1 -0
  121. package/dist/hooks/handlers/error-hooks.js +43 -0
  122. package/dist/hooks/handlers/error-hooks.js.map +1 -0
  123. package/dist/hooks/handlers/file-hooks.js +80 -0
  124. package/dist/hooks/handlers/file-hooks.js.map +1 -0
  125. package/dist/hooks/handlers/index.js +19 -0
  126. package/dist/hooks/handlers/index.js.map +1 -0
  127. package/dist/hooks/handlers/mcp-hooks.js +80 -0
  128. package/dist/hooks/handlers/mcp-hooks.js.map +1 -0
  129. package/dist/hooks/handlers/session-hooks.js +73 -0
  130. package/dist/hooks/handlers/session-hooks.js.map +1 -0
  131. package/dist/hooks/handlers/task-hooks.js +63 -0
  132. package/dist/hooks/handlers/task-hooks.js.map +1 -0
  133. package/dist/hooks/index.js +13 -0
  134. package/dist/hooks/index.js.map +1 -0
  135. package/dist/hooks/payload-schemas.js +163 -0
  136. package/dist/hooks/payload-schemas.js.map +1 -0
  137. package/dist/hooks/provider-hooks.js +34 -0
  138. package/dist/hooks/provider-hooks.js.map +1 -0
  139. package/dist/hooks/registry.js +176 -0
  140. package/dist/hooks/registry.js.map +1 -0
  141. package/dist/hooks/types.js +62 -0
  142. package/dist/hooks/types.js.map +1 -0
  143. package/dist/hooks.js +136 -0
  144. package/dist/hooks.js.map +1 -0
  145. package/dist/index.d.ts +1 -1
  146. package/dist/index.d.ts.map +1 -1
  147. package/dist/index.js +6567 -5024
  148. package/dist/index.js.map +4 -4
  149. package/dist/init.js +711 -0
  150. package/dist/init.js.map +1 -0
  151. package/dist/inject/index.js +82 -0
  152. package/dist/inject/index.js.map +1 -0
  153. package/dist/injection.js +343 -0
  154. package/dist/injection.js.map +1 -0
  155. package/dist/intelligence/adaptive-validation.d.ts +151 -0
  156. package/dist/intelligence/adaptive-validation.d.ts.map +1 -0
  157. package/dist/intelligence/impact.js +499 -0
  158. package/dist/intelligence/impact.js.map +1 -0
  159. package/dist/intelligence/index.d.ts +5 -0
  160. package/dist/intelligence/index.d.ts.map +1 -1
  161. package/dist/intelligence/index.js +17 -0
  162. package/dist/intelligence/index.js.map +1 -0
  163. package/dist/intelligence/patterns.js +492 -0
  164. package/dist/intelligence/patterns.js.map +1 -0
  165. package/dist/intelligence/prediction.js +499 -0
  166. package/dist/intelligence/prediction.js.map +1 -0
  167. package/dist/intelligence/types.js +13 -0
  168. package/dist/intelligence/types.js.map +1 -0
  169. package/dist/internal.d.ts +5 -2
  170. package/dist/internal.d.ts.map +1 -1
  171. package/dist/internal.js +258 -0
  172. package/dist/internal.js.map +1 -0
  173. package/dist/issue/create.js +121 -0
  174. package/dist/issue/create.js.map +1 -0
  175. package/dist/issue/diagnostics.js +59 -0
  176. package/dist/issue/diagnostics.js.map +1 -0
  177. package/dist/issue/index.js +10 -0
  178. package/dist/issue/index.js.map +1 -0
  179. package/dist/issue/template-parser.js +267 -0
  180. package/dist/issue/template-parser.js.map +1 -0
  181. package/dist/json-schema-validator.js +76 -0
  182. package/dist/json-schema-validator.js.map +1 -0
  183. package/dist/lifecycle/chain-composition.js +152 -0
  184. package/dist/lifecycle/chain-composition.js.map +1 -0
  185. package/dist/lifecycle/chain-store.js +246 -0
  186. package/dist/lifecycle/chain-store.js.map +1 -0
  187. package/dist/lifecycle/consolidate-rcasd.js +352 -0
  188. package/dist/lifecycle/consolidate-rcasd.js.map +1 -0
  189. package/dist/lifecycle/default-chain.js +167 -0
  190. package/dist/lifecycle/default-chain.js.map +1 -0
  191. package/dist/lifecycle/evidence.js +180 -0
  192. package/dist/lifecycle/evidence.js.map +1 -0
  193. package/dist/lifecycle/frontmatter.js +363 -0
  194. package/dist/lifecycle/frontmatter.js.map +1 -0
  195. package/dist/lifecycle/index.js +753 -0
  196. package/dist/lifecycle/index.js.map +1 -0
  197. package/dist/lifecycle/pipeline.js +656 -0
  198. package/dist/lifecycle/pipeline.js.map +1 -0
  199. package/dist/lifecycle/rcasd-index.js +326 -0
  200. package/dist/lifecycle/rcasd-index.js.map +1 -0
  201. package/dist/lifecycle/rcasd-paths.js +220 -0
  202. package/dist/lifecycle/rcasd-paths.js.map +1 -0
  203. package/dist/lifecycle/resume.js +864 -0
  204. package/dist/lifecycle/resume.js.map +1 -0
  205. package/dist/lifecycle/stage-artifacts.js +94 -0
  206. package/dist/lifecycle/stage-artifacts.js.map +1 -0
  207. package/dist/lifecycle/stages.js +534 -0
  208. package/dist/lifecycle/stages.js.map +1 -0
  209. package/dist/lifecycle/state-machine.js +516 -0
  210. package/dist/lifecycle/state-machine.js.map +1 -0
  211. package/dist/lifecycle/tessera-engine.js +249 -0
  212. package/dist/lifecycle/tessera-engine.js.map +1 -0
  213. package/dist/logger.js +140 -0
  214. package/dist/logger.js.map +1 -0
  215. package/dist/mcp/index.js +146 -0
  216. package/dist/mcp/index.js.map +1 -0
  217. package/dist/memory/auto-extract.js +143 -0
  218. package/dist/memory/auto-extract.js.map +1 -0
  219. package/dist/memory/brain-embedding.js +49 -0
  220. package/dist/memory/brain-embedding.js.map +1 -0
  221. package/dist/memory/brain-lifecycle.js +298 -0
  222. package/dist/memory/brain-lifecycle.js.map +1 -0
  223. package/dist/memory/brain-links.js +148 -0
  224. package/dist/memory/brain-links.js.map +1 -0
  225. package/dist/memory/brain-migration.js +149 -0
  226. package/dist/memory/brain-migration.js.map +1 -0
  227. package/dist/memory/brain-reasoning.js +215 -0
  228. package/dist/memory/brain-reasoning.js.map +1 -0
  229. package/dist/memory/brain-retrieval.js +474 -0
  230. package/dist/memory/brain-retrieval.js.map +1 -0
  231. package/dist/memory/brain-row-types.js +10 -0
  232. package/dist/memory/brain-row-types.js.map +1 -0
  233. package/dist/memory/brain-search.js +519 -0
  234. package/dist/memory/brain-search.js.map +1 -0
  235. package/dist/memory/brain-similarity.js +145 -0
  236. package/dist/memory/brain-similarity.js.map +1 -0
  237. package/dist/memory/claude-mem-migration.js +277 -0
  238. package/dist/memory/claude-mem-migration.js.map +1 -0
  239. package/dist/memory/decisions.js +148 -0
  240. package/dist/memory/decisions.js.map +1 -0
  241. package/dist/memory/engine-compat.js +1030 -0
  242. package/dist/memory/engine-compat.js.map +1 -0
  243. package/dist/memory/index.js +773 -0
  244. package/dist/memory/index.js.map +1 -0
  245. package/dist/memory/learnings.js +121 -0
  246. package/dist/memory/learnings.js.map +1 -0
  247. package/dist/memory/memory-bridge.js +289 -0
  248. package/dist/memory/memory-bridge.js.map +1 -0
  249. package/dist/memory/patterns.js +122 -0
  250. package/dist/memory/patterns.js.map +1 -0
  251. package/dist/memory/pipeline-manifest-sqlite.js +975 -0
  252. package/dist/memory/pipeline-manifest-sqlite.js.map +1 -0
  253. package/dist/memory/session-memory.js +226 -0
  254. package/dist/memory/session-memory.js.map +1 -0
  255. package/dist/metrics/ab-test.js +260 -0
  256. package/dist/metrics/ab-test.js.map +1 -0
  257. package/dist/metrics/aggregation.js +363 -0
  258. package/dist/metrics/aggregation.js.map +1 -0
  259. package/dist/metrics/common.js +64 -0
  260. package/dist/metrics/common.js.map +1 -0
  261. package/dist/metrics/enums.js +78 -0
  262. package/dist/metrics/enums.js.map +1 -0
  263. package/dist/metrics/index.js +19 -0
  264. package/dist/metrics/index.js.map +1 -0
  265. package/dist/metrics/model-provider-registry.js +88 -0
  266. package/dist/metrics/model-provider-registry.js.map +1 -0
  267. package/dist/metrics/otel-integration.js +263 -0
  268. package/dist/metrics/otel-integration.js.map +1 -0
  269. package/dist/metrics/provider-detection.js +103 -0
  270. package/dist/metrics/provider-detection.js.map +1 -0
  271. package/dist/metrics/token-estimation.js +253 -0
  272. package/dist/metrics/token-estimation.js.map +1 -0
  273. package/dist/metrics/token-service.js +450 -0
  274. package/dist/metrics/token-service.js.map +1 -0
  275. package/dist/migration/agent-outputs.js +316 -0
  276. package/dist/migration/agent-outputs.js.map +1 -0
  277. package/dist/migration/checksum.js +92 -0
  278. package/dist/migration/checksum.js.map +1 -0
  279. package/dist/migration/index.js +282 -0
  280. package/dist/migration/index.js.map +1 -0
  281. package/dist/migration/logger.js +360 -0
  282. package/dist/migration/logger.js.map +1 -0
  283. package/dist/migration/preflight.js +9 -0
  284. package/dist/migration/preflight.js.map +1 -0
  285. package/dist/migration/state.js +421 -0
  286. package/dist/migration/state.js.map +1 -0
  287. package/dist/migration/validate.js +241 -0
  288. package/dist/migration/validate.js.map +1 -0
  289. package/dist/nexus/deps.js +375 -0
  290. package/dist/nexus/deps.js.map +1 -0
  291. package/dist/nexus/discover.js +288 -0
  292. package/dist/nexus/discover.js.map +1 -0
  293. package/dist/nexus/hash.js +10 -0
  294. package/dist/nexus/hash.js.map +1 -0
  295. package/dist/nexus/index.js +38 -0
  296. package/dist/nexus/index.js.map +1 -0
  297. package/dist/nexus/migrate-json-to-sqlite.js +115 -0
  298. package/dist/nexus/migrate-json-to-sqlite.js.map +1 -0
  299. package/dist/nexus/permissions.js +105 -0
  300. package/dist/nexus/permissions.js.map +1 -0
  301. package/dist/nexus/query.js +175 -0
  302. package/dist/nexus/query.js.map +1 -0
  303. package/dist/nexus/registry.js +584 -0
  304. package/dist/nexus/registry.js.map +1 -0
  305. package/dist/nexus/sharing/index.js +179 -0
  306. package/dist/nexus/sharing/index.js.map +1 -0
  307. package/dist/nexus/transfer-types.js +8 -0
  308. package/dist/nexus/transfer-types.js.map +1 -0
  309. package/dist/nexus/transfer.js +263 -0
  310. package/dist/nexus/transfer.js.map +1 -0
  311. package/dist/observability/index.js +103 -0
  312. package/dist/observability/index.js.map +1 -0
  313. package/dist/observability/log-filter.js +63 -0
  314. package/dist/observability/log-filter.js.map +1 -0
  315. package/dist/observability/log-parser.js +99 -0
  316. package/dist/observability/log-parser.js.map +1 -0
  317. package/dist/observability/log-reader.js +139 -0
  318. package/dist/observability/log-reader.js.map +1 -0
  319. package/dist/observability/types.js +19 -0
  320. package/dist/observability/types.js.map +1 -0
  321. package/dist/orchestration/analyze.js +107 -0
  322. package/dist/orchestration/analyze.js.map +1 -0
  323. package/dist/orchestration/bootstrap.js +132 -0
  324. package/dist/orchestration/bootstrap.js.map +1 -0
  325. package/dist/orchestration/context.js +56 -0
  326. package/dist/orchestration/context.js.map +1 -0
  327. package/dist/orchestration/critical-path.js +100 -0
  328. package/dist/orchestration/critical-path.js.map +1 -0
  329. package/dist/orchestration/index.js +286 -0
  330. package/dist/orchestration/index.js.map +1 -0
  331. package/dist/orchestration/parallel.js +89 -0
  332. package/dist/orchestration/parallel.js.map +1 -0
  333. package/dist/orchestration/protocol-validators.js +524 -0
  334. package/dist/orchestration/protocol-validators.js.map +1 -0
  335. package/dist/orchestration/skill-ops.js +98 -0
  336. package/dist/orchestration/skill-ops.js.map +1 -0
  337. package/dist/orchestration/status.js +107 -0
  338. package/dist/orchestration/status.js.map +1 -0
  339. package/dist/orchestration/unblock.js +103 -0
  340. package/dist/orchestration/unblock.js.map +1 -0
  341. package/dist/orchestration/validate-spawn.js +67 -0
  342. package/dist/orchestration/validate-spawn.js.map +1 -0
  343. package/dist/orchestration/waves.js +86 -0
  344. package/dist/orchestration/waves.js.map +1 -0
  345. package/dist/otel/index.js +163 -0
  346. package/dist/otel/index.js.map +1 -0
  347. package/dist/output.js +132 -0
  348. package/dist/output.js.map +1 -0
  349. package/dist/pagination.js +61 -0
  350. package/dist/pagination.js.map +1 -0
  351. package/dist/paths.js +337 -0
  352. package/dist/paths.js.map +1 -0
  353. package/dist/phases/deps.js +369 -0
  354. package/dist/phases/deps.js.map +1 -0
  355. package/dist/phases/index.js +349 -0
  356. package/dist/phases/index.js.map +1 -0
  357. package/dist/pipeline/index.js +10 -0
  358. package/dist/pipeline/index.js.map +1 -0
  359. package/dist/pipeline/phase.js +45 -0
  360. package/dist/pipeline/phase.js.map +1 -0
  361. package/dist/platform.js +211 -0
  362. package/dist/platform.js.map +1 -0
  363. package/dist/project-info.js +84 -0
  364. package/dist/project-info.js.map +1 -0
  365. package/dist/reconciliation/index.js +10 -0
  366. package/dist/reconciliation/index.js.map +1 -0
  367. package/dist/reconciliation/link-store.js +129 -0
  368. package/dist/reconciliation/link-store.js.map +1 -0
  369. package/dist/reconciliation/reconciliation-engine.js +298 -0
  370. package/dist/reconciliation/reconciliation-engine.js.map +1 -0
  371. package/dist/release/artifacts.js +427 -0
  372. package/dist/release/artifacts.js.map +1 -0
  373. package/dist/release/changelog-writer.js +151 -0
  374. package/dist/release/changelog-writer.js.map +1 -0
  375. package/dist/release/channel.js +144 -0
  376. package/dist/release/channel.js.map +1 -0
  377. package/dist/release/ci.js +166 -0
  378. package/dist/release/ci.js.map +1 -0
  379. package/dist/release/github-pr.js +225 -0
  380. package/dist/release/github-pr.js.map +1 -0
  381. package/dist/release/guards.js +116 -0
  382. package/dist/release/guards.js.map +1 -0
  383. package/dist/release/index.js +22 -0
  384. package/dist/release/index.js.map +1 -0
  385. package/dist/release/release-config.js +158 -0
  386. package/dist/release/release-config.js.map +1 -0
  387. package/dist/release/release-manifest.js +1019 -0
  388. package/dist/release/release-manifest.js.map +1 -0
  389. package/dist/release/version-bump.js +255 -0
  390. package/dist/release/version-bump.js.map +1 -0
  391. package/dist/remote/index.js +257 -0
  392. package/dist/remote/index.js.map +1 -0
  393. package/dist/repair.js +89 -0
  394. package/dist/repair.js.map +1 -0
  395. package/dist/research/index.js +2 -0
  396. package/dist/research/index.js.map +1 -0
  397. package/dist/roadmap/index.js +59 -0
  398. package/dist/roadmap/index.js.map +1 -0
  399. package/dist/routing/capability-matrix.js +1550 -0
  400. package/dist/routing/capability-matrix.js.map +1 -0
  401. package/dist/routing/index.js +9 -0
  402. package/dist/routing/index.js.map +1 -0
  403. package/dist/scaffold.js +1158 -0
  404. package/dist/scaffold.js.map +1 -0
  405. package/dist/schema-management.js +295 -0
  406. package/dist/schema-management.js.map +1 -0
  407. package/dist/security/index.js +9 -0
  408. package/dist/security/index.js.map +1 -0
  409. package/dist/security/input-sanitization.js +321 -0
  410. package/dist/security/input-sanitization.js.map +1 -0
  411. package/dist/sequence/index.js +295 -0
  412. package/dist/sequence/index.js.map +1 -0
  413. package/dist/sessions/assumptions.js +54 -0
  414. package/dist/sessions/assumptions.js.map +1 -0
  415. package/dist/sessions/briefing.js +377 -0
  416. package/dist/sessions/briefing.js.map +1 -0
  417. package/dist/sessions/context-alert.js +222 -0
  418. package/dist/sessions/context-alert.js.map +1 -0
  419. package/dist/sessions/context-inject.js +61 -0
  420. package/dist/sessions/context-inject.js.map +1 -0
  421. package/dist/sessions/context-monitor.js +98 -0
  422. package/dist/sessions/context-monitor.js.map +1 -0
  423. package/dist/sessions/decisions.js +65 -0
  424. package/dist/sessions/decisions.js.map +1 -0
  425. package/dist/sessions/find.js +63 -0
  426. package/dist/sessions/find.js.map +1 -0
  427. package/dist/sessions/handoff.js +328 -0
  428. package/dist/sessions/handoff.js.map +1 -0
  429. package/dist/sessions/hitl-warnings.js +254 -0
  430. package/dist/sessions/hitl-warnings.js.map +1 -0
  431. package/dist/sessions/index.js +318 -0
  432. package/dist/sessions/index.js.map +1 -0
  433. package/dist/sessions/session-archive.js +40 -0
  434. package/dist/sessions/session-archive.js.map +1 -0
  435. package/dist/sessions/session-cleanup.js +59 -0
  436. package/dist/sessions/session-cleanup.js.map +1 -0
  437. package/dist/sessions/session-drift.js +134 -0
  438. package/dist/sessions/session-drift.js.map +1 -0
  439. package/dist/sessions/session-enforcement.d.ts.map +1 -1
  440. package/dist/sessions/session-enforcement.js +140 -0
  441. package/dist/sessions/session-enforcement.js.map +1 -0
  442. package/dist/sessions/session-grade.js +253 -0
  443. package/dist/sessions/session-grade.js.map +1 -0
  444. package/dist/sessions/session-history.js +42 -0
  445. package/dist/sessions/session-history.js.map +1 -0
  446. package/dist/sessions/session-id.js +81 -0
  447. package/dist/sessions/session-id.js.map +1 -0
  448. package/dist/sessions/session-memory-bridge.js +52 -0
  449. package/dist/sessions/session-memory-bridge.js.map +1 -0
  450. package/dist/sessions/session-show.js +24 -0
  451. package/dist/sessions/session-show.js.map +1 -0
  452. package/dist/sessions/session-stats.js +69 -0
  453. package/dist/sessions/session-stats.js.map +1 -0
  454. package/dist/sessions/session-suspend.js +39 -0
  455. package/dist/sessions/session-suspend.js.map +1 -0
  456. package/dist/sessions/session-switch.js +51 -0
  457. package/dist/sessions/session-switch.js.map +1 -0
  458. package/dist/sessions/session-view.js +76 -0
  459. package/dist/sessions/session-view.js.map +1 -0
  460. package/dist/sessions/statusline-setup.js +85 -0
  461. package/dist/sessions/statusline-setup.js.map +1 -0
  462. package/dist/sessions/types.js +8 -0
  463. package/dist/sessions/types.js.map +1 -0
  464. package/dist/signaldock/claude-code-transport.js +107 -0
  465. package/dist/signaldock/claude-code-transport.js.map +1 -0
  466. package/dist/signaldock/factory.js +25 -0
  467. package/dist/signaldock/factory.js.map +1 -0
  468. package/dist/signaldock/index.js +9 -0
  469. package/dist/signaldock/index.js.map +1 -0
  470. package/dist/signaldock/signaldock-transport.js +122 -0
  471. package/dist/signaldock/signaldock-transport.js.map +1 -0
  472. package/dist/signaldock/transport.js +11 -0
  473. package/dist/signaldock/transport.js.map +1 -0
  474. package/dist/signaldock/types.js +11 -0
  475. package/dist/signaldock/types.js.map +1 -0
  476. package/dist/skills/agents/config.js +94 -0
  477. package/dist/skills/agents/config.js.map +1 -0
  478. package/dist/skills/agents/install.js +116 -0
  479. package/dist/skills/agents/install.js.map +1 -0
  480. package/dist/skills/agents/registry.js +161 -0
  481. package/dist/skills/agents/registry.js.map +1 -0
  482. package/dist/skills/discovery.js +333 -0
  483. package/dist/skills/discovery.js.map +1 -0
  484. package/dist/skills/dispatch.js +347 -0
  485. package/dist/skills/dispatch.js.map +1 -0
  486. package/dist/skills/dynamic-skill-generator.js +100 -0
  487. package/dist/skills/dynamic-skill-generator.js.map +1 -0
  488. package/dist/skills/index.js +44 -0
  489. package/dist/skills/index.js.map +1 -0
  490. package/dist/skills/injection/subagent.js +195 -0
  491. package/dist/skills/injection/subagent.js.map +1 -0
  492. package/dist/skills/injection/token.js +260 -0
  493. package/dist/skills/injection/token.js.map +1 -0
  494. package/dist/skills/install.js +40 -0
  495. package/dist/skills/install.js.map +1 -0
  496. package/dist/skills/manifests/contribution.js +175 -0
  497. package/dist/skills/manifests/contribution.js.map +1 -0
  498. package/dist/skills/manifests/research.js +281 -0
  499. package/dist/skills/manifests/research.js.map +1 -0
  500. package/dist/skills/manifests/resolver.js +146 -0
  501. package/dist/skills/manifests/resolver.js.map +1 -0
  502. package/dist/skills/marketplace.js +90 -0
  503. package/dist/skills/marketplace.js.map +1 -0
  504. package/dist/skills/orchestrator/spawn.js +178 -0
  505. package/dist/skills/orchestrator/spawn.js.map +1 -0
  506. package/dist/skills/orchestrator/startup.js +451 -0
  507. package/dist/skills/orchestrator/startup.js.map +1 -0
  508. package/dist/skills/orchestrator/validator.js +301 -0
  509. package/dist/skills/orchestrator/validator.js.map +1 -0
  510. package/dist/skills/precedence-integration.js +73 -0
  511. package/dist/skills/precedence-integration.js.map +1 -0
  512. package/dist/skills/precedence-types.js +16 -0
  513. package/dist/skills/precedence-types.js.map +1 -0
  514. package/dist/skills/routing-table.js +63 -0
  515. package/dist/skills/routing-table.js.map +1 -0
  516. package/dist/skills/skill-paths.js +220 -0
  517. package/dist/skills/skill-paths.js.map +1 -0
  518. package/dist/skills/test-utility.js +55 -0
  519. package/dist/skills/test-utility.js.map +1 -0
  520. package/dist/skills/types.js +118 -0
  521. package/dist/skills/types.js.map +1 -0
  522. package/dist/skills/validation.js +183 -0
  523. package/dist/skills/validation.js.map +1 -0
  524. package/dist/skills/version.js +57 -0
  525. package/dist/skills/version.js.map +1 -0
  526. package/dist/snapshot/index.js +188 -0
  527. package/dist/snapshot/index.js.map +1 -0
  528. package/dist/spawn/adapter-registry.js +246 -0
  529. package/dist/spawn/adapter-registry.js.map +1 -0
  530. package/dist/spawn/index.js +10 -0
  531. package/dist/spawn/index.js.map +1 -0
  532. package/dist/stats/index.d.ts +1 -0
  533. package/dist/stats/index.d.ts.map +1 -1
  534. package/dist/stats/index.js +339 -0
  535. package/dist/stats/index.js.map +1 -0
  536. package/dist/stats/workflow-telemetry.d.ts +74 -0
  537. package/dist/stats/workflow-telemetry.d.ts.map +1 -0
  538. package/dist/sticky/archive.js +47 -0
  539. package/dist/sticky/archive.js.map +1 -0
  540. package/dist/sticky/convert.js +235 -0
  541. package/dist/sticky/convert.js.map +1 -0
  542. package/dist/sticky/create.js +48 -0
  543. package/dist/sticky/create.js.map +1 -0
  544. package/dist/sticky/id.js +35 -0
  545. package/dist/sticky/id.js.map +1 -0
  546. package/dist/sticky/index.js +16 -0
  547. package/dist/sticky/index.js.map +1 -0
  548. package/dist/sticky/list.js +44 -0
  549. package/dist/sticky/list.js.map +1 -0
  550. package/dist/sticky/purge.js +45 -0
  551. package/dist/sticky/purge.js.map +1 -0
  552. package/dist/sticky/show.js +42 -0
  553. package/dist/sticky/show.js.map +1 -0
  554. package/dist/sticky/types.js +10 -0
  555. package/dist/sticky/types.js.map +1 -0
  556. package/dist/store/atomic.js +167 -0
  557. package/dist/store/atomic.js.map +1 -0
  558. package/dist/store/backup.js +94 -0
  559. package/dist/store/backup.js.map +1 -0
  560. package/dist/store/brain-accessor.js +397 -0
  561. package/dist/store/brain-accessor.js.map +1 -0
  562. package/dist/store/brain-schema.d.ts.map +1 -1
  563. package/dist/store/brain-schema.js +212 -0
  564. package/dist/store/brain-schema.js.map +1 -0
  565. package/dist/store/brain-sqlite.js +271 -0
  566. package/dist/store/brain-sqlite.js.map +1 -0
  567. package/dist/store/cache.js +168 -0
  568. package/dist/store/cache.js.map +1 -0
  569. package/dist/store/chain-schema.js +51 -0
  570. package/dist/store/chain-schema.js.map +1 -0
  571. package/dist/store/converters.d.ts.map +1 -1
  572. package/dist/store/converters.js +120 -0
  573. package/dist/store/converters.js.map +1 -0
  574. package/dist/store/cross-db-cleanup.d.ts +58 -0
  575. package/dist/store/cross-db-cleanup.d.ts.map +1 -0
  576. package/dist/store/data-accessor.js +26 -0
  577. package/dist/store/data-accessor.js.map +1 -0
  578. package/dist/store/data-safety-central.js +269 -0
  579. package/dist/store/data-safety-central.js.map +1 -0
  580. package/dist/store/data-safety.js +274 -0
  581. package/dist/store/data-safety.js.map +1 -0
  582. package/dist/store/db-helpers.d.ts.map +1 -1
  583. package/dist/store/db-helpers.js +221 -0
  584. package/dist/store/db-helpers.js.map +1 -0
  585. package/dist/store/export.js +155 -0
  586. package/dist/store/export.js.map +1 -0
  587. package/dist/store/file-utils.js +270 -0
  588. package/dist/store/file-utils.js.map +1 -0
  589. package/dist/store/git-checkpoint.js +365 -0
  590. package/dist/store/git-checkpoint.js.map +1 -0
  591. package/dist/store/import-logging.js +139 -0
  592. package/dist/store/import-logging.js.map +1 -0
  593. package/dist/store/import-remap.js +145 -0
  594. package/dist/store/import-remap.js.map +1 -0
  595. package/dist/store/import-sort.js +121 -0
  596. package/dist/store/import-sort.js.map +1 -0
  597. package/dist/store/index.js +28 -0
  598. package/dist/store/index.js.map +1 -0
  599. package/dist/store/json.js +208 -0
  600. package/dist/store/json.js.map +1 -0
  601. package/dist/store/lifecycle-store.js +249 -0
  602. package/dist/store/lifecycle-store.js.map +1 -0
  603. package/dist/store/lock.js +70 -0
  604. package/dist/store/lock.js.map +1 -0
  605. package/dist/store/migration-sqlite.d.ts.map +1 -1
  606. package/dist/store/migration-sqlite.js +671 -0
  607. package/dist/store/migration-sqlite.js.map +1 -0
  608. package/dist/store/nexus-schema.js +62 -0
  609. package/dist/store/nexus-schema.js.map +1 -0
  610. package/dist/store/nexus-sqlite.js +217 -0
  611. package/dist/store/nexus-sqlite.js.map +1 -0
  612. package/dist/store/nexus-validation-schemas.js +40 -0
  613. package/dist/store/nexus-validation-schemas.js.map +1 -0
  614. package/dist/store/parsers.js +37 -0
  615. package/dist/store/parsers.js.map +1 -0
  616. package/dist/store/project-detect.js +457 -0
  617. package/dist/store/project-detect.js.map +1 -0
  618. package/dist/store/provider.js +101 -0
  619. package/dist/store/provider.js.map +1 -0
  620. package/dist/store/safety-data-accessor.js +243 -0
  621. package/dist/store/safety-data-accessor.js.map +1 -0
  622. package/dist/store/schema.js +7 -0
  623. package/dist/store/schema.js.map +1 -0
  624. package/dist/store/session-store.js +219 -0
  625. package/dist/store/session-store.js.map +1 -0
  626. package/dist/store/sqlite-backup.js +105 -0
  627. package/dist/store/sqlite-backup.js.map +1 -0
  628. package/dist/store/sqlite-data-accessor.d.ts.map +1 -1
  629. package/dist/store/sqlite-data-accessor.js +742 -0
  630. package/dist/store/sqlite-data-accessor.js.map +1 -0
  631. package/dist/store/sqlite.d.ts.map +1 -1
  632. package/dist/store/sqlite.js +489 -0
  633. package/dist/store/sqlite.js.map +1 -0
  634. package/dist/store/status-registry.js +8 -0
  635. package/dist/store/status-registry.js.map +1 -0
  636. package/dist/store/task-store.d.ts.map +1 -1
  637. package/dist/store/task-store.js +344 -0
  638. package/dist/store/task-store.js.map +1 -0
  639. package/dist/store/tasks-schema.d.ts +18 -3
  640. package/dist/store/tasks-schema.d.ts.map +1 -1
  641. package/dist/store/tasks-schema.js +574 -0
  642. package/dist/store/tasks-schema.js.map +1 -0
  643. package/dist/store/typed-query.js +15 -0
  644. package/dist/store/typed-query.js.map +1 -0
  645. package/dist/store/validation-schemas.d.ts +32 -0
  646. package/dist/store/validation-schemas.d.ts.map +1 -1
  647. package/dist/store/validation-schemas.js +278 -0
  648. package/dist/store/validation-schemas.js.map +1 -0
  649. package/dist/system/archive-analytics.js +277 -0
  650. package/dist/system/archive-analytics.js.map +1 -0
  651. package/dist/system/archive-stats.js +64 -0
  652. package/dist/system/archive-stats.js.map +1 -0
  653. package/dist/system/audit.js +145 -0
  654. package/dist/system/audit.js.map +1 -0
  655. package/dist/system/backup.js +99 -0
  656. package/dist/system/backup.js.map +1 -0
  657. package/dist/system/cleanup.js +134 -0
  658. package/dist/system/cleanup.js.map +1 -0
  659. package/dist/system/health.js +1054 -0
  660. package/dist/system/health.js.map +1 -0
  661. package/dist/system/index.js +18 -0
  662. package/dist/system/index.js.map +1 -0
  663. package/dist/system/inject-generate.js +122 -0
  664. package/dist/system/inject-generate.js.map +1 -0
  665. package/dist/system/labels.js +38 -0
  666. package/dist/system/labels.js.map +1 -0
  667. package/dist/system/metrics.js +61 -0
  668. package/dist/system/metrics.js.map +1 -0
  669. package/dist/system/migrate.js +43 -0
  670. package/dist/system/migrate.js.map +1 -0
  671. package/dist/system/platform-paths.js +80 -0
  672. package/dist/system/platform-paths.js.map +1 -0
  673. package/dist/system/runtime.js +161 -0
  674. package/dist/system/runtime.js.map +1 -0
  675. package/dist/system/safestop.js +99 -0
  676. package/dist/system/safestop.js.map +1 -0
  677. package/dist/system/storage-preflight.js +123 -0
  678. package/dist/system/storage-preflight.js.map +1 -0
  679. package/dist/task-work/index.js +155 -0
  680. package/dist/task-work/index.js.map +1 -0
  681. package/dist/tasks/add.d.ts +10 -1
  682. package/dist/tasks/add.d.ts.map +1 -1
  683. package/dist/tasks/add.js +510 -0
  684. package/dist/tasks/add.js.map +1 -0
  685. package/dist/tasks/analyze.js +85 -0
  686. package/dist/tasks/analyze.js.map +1 -0
  687. package/dist/tasks/archive.js +90 -0
  688. package/dist/tasks/archive.js.map +1 -0
  689. package/dist/tasks/atomicity.js +83 -0
  690. package/dist/tasks/atomicity.js.map +1 -0
  691. package/dist/tasks/cancel-ops.js +83 -0
  692. package/dist/tasks/cancel-ops.js.map +1 -0
  693. package/dist/tasks/complete.d.ts.map +1 -1
  694. package/dist/tasks/complete.js +224 -0
  695. package/dist/tasks/complete.js.map +1 -0
  696. package/dist/tasks/crossref-extract.js +73 -0
  697. package/dist/tasks/crossref-extract.js.map +1 -0
  698. package/dist/tasks/delete-preview.js +192 -0
  699. package/dist/tasks/delete-preview.js.map +1 -0
  700. package/dist/tasks/delete.js +120 -0
  701. package/dist/tasks/delete.js.map +1 -0
  702. package/dist/tasks/deletion-strategy.js +200 -0
  703. package/dist/tasks/deletion-strategy.js.map +1 -0
  704. package/dist/tasks/dependency-check.js +278 -0
  705. package/dist/tasks/dependency-check.js.map +1 -0
  706. package/dist/tasks/deps-ready.js +32 -0
  707. package/dist/tasks/deps-ready.js.map +1 -0
  708. package/dist/tasks/enforcement.d.ts +22 -0
  709. package/dist/tasks/enforcement.d.ts.map +1 -0
  710. package/dist/tasks/enforcement.js +82 -0
  711. package/dist/tasks/enforcement.js.map +1 -0
  712. package/dist/tasks/epic-enforcement.d.ts +138 -0
  713. package/dist/tasks/epic-enforcement.d.ts.map +1 -0
  714. package/dist/tasks/find.js +148 -0
  715. package/dist/tasks/find.js.map +1 -0
  716. package/dist/tasks/graph-cache.js +127 -0
  717. package/dist/tasks/graph-cache.js.map +1 -0
  718. package/dist/tasks/graph-ops.js +171 -0
  719. package/dist/tasks/graph-ops.js.map +1 -0
  720. package/dist/tasks/graph-rag.js +328 -0
  721. package/dist/tasks/graph-rag.js.map +1 -0
  722. package/dist/tasks/hierarchy-policy.js +149 -0
  723. package/dist/tasks/hierarchy-policy.js.map +1 -0
  724. package/dist/tasks/hierarchy.js +185 -0
  725. package/dist/tasks/hierarchy.js.map +1 -0
  726. package/dist/tasks/id-generator.js +65 -0
  727. package/dist/tasks/id-generator.js.map +1 -0
  728. package/dist/tasks/index.d.ts +1 -1
  729. package/dist/tasks/index.d.ts.map +1 -1
  730. package/dist/tasks/index.js +14 -0
  731. package/dist/tasks/index.js.map +1 -0
  732. package/dist/tasks/labels.js +52 -0
  733. package/dist/tasks/labels.js.map +1 -0
  734. package/dist/tasks/list.js +68 -0
  735. package/dist/tasks/list.js.map +1 -0
  736. package/dist/tasks/phase-tracking.js +133 -0
  737. package/dist/tasks/phase-tracking.js.map +1 -0
  738. package/dist/tasks/pipeline-stage.d.ts +112 -0
  739. package/dist/tasks/pipeline-stage.d.ts.map +1 -0
  740. package/dist/tasks/plan.js +268 -0
  741. package/dist/tasks/plan.js.map +1 -0
  742. package/dist/tasks/relates.js +89 -0
  743. package/dist/tasks/relates.js.map +1 -0
  744. package/dist/tasks/reparent.d.ts +38 -0
  745. package/dist/tasks/reparent.d.ts.map +1 -0
  746. package/dist/tasks/show.js +78 -0
  747. package/dist/tasks/show.js.map +1 -0
  748. package/dist/tasks/size-weighting.js +86 -0
  749. package/dist/tasks/size-weighting.js.map +1 -0
  750. package/dist/tasks/staleness.js +86 -0
  751. package/dist/tasks/staleness.js.map +1 -0
  752. package/dist/tasks/task-ops.js +1340 -0
  753. package/dist/tasks/task-ops.js.map +1 -0
  754. package/dist/tasks/update.d.ts +2 -0
  755. package/dist/tasks/update.d.ts.map +1 -1
  756. package/dist/tasks/update.js +243 -0
  757. package/dist/tasks/update.js.map +1 -0
  758. package/dist/templates/index.js +10 -0
  759. package/dist/templates/index.js.map +1 -0
  760. package/dist/templates/parser.js +254 -0
  761. package/dist/templates/parser.js.map +1 -0
  762. package/dist/ui/aliases.js +153 -0
  763. package/dist/ui/aliases.js.map +1 -0
  764. package/dist/ui/changelog.js +184 -0
  765. package/dist/ui/changelog.js.map +1 -0
  766. package/dist/ui/command-registry.js +168 -0
  767. package/dist/ui/command-registry.js.map +1 -0
  768. package/dist/ui/flags.js +94 -0
  769. package/dist/ui/flags.js.map +1 -0
  770. package/dist/ui/index.js +24 -0
  771. package/dist/ui/index.js.map +1 -0
  772. package/dist/ui/injection-legacy.d.ts +26 -0
  773. package/dist/ui/injection-legacy.d.ts.map +1 -0
  774. package/dist/ui/injection-legacy.js +42 -0
  775. package/dist/ui/injection-legacy.js.map +1 -0
  776. package/dist/upgrade.js +901 -0
  777. package/dist/upgrade.js.map +1 -0
  778. package/dist/validation/chain-validation.js +146 -0
  779. package/dist/validation/chain-validation.js.map +1 -0
  780. package/dist/validation/compliance.js +155 -0
  781. package/dist/validation/compliance.js.map +1 -0
  782. package/dist/validation/docs-sync.js +212 -0
  783. package/dist/validation/docs-sync.js.map +1 -0
  784. package/dist/validation/doctor/checks.js +1069 -0
  785. package/dist/validation/doctor/checks.js.map +1 -0
  786. package/dist/validation/doctor/index.js +9 -0
  787. package/dist/validation/doctor/index.js.map +1 -0
  788. package/dist/validation/doctor/project-cache.js +160 -0
  789. package/dist/validation/doctor/project-cache.js.map +1 -0
  790. package/dist/validation/doctor/utils.js +155 -0
  791. package/dist/validation/doctor/utils.js.map +1 -0
  792. package/dist/validation/engine.js +902 -0
  793. package/dist/validation/engine.js.map +1 -0
  794. package/dist/validation/gap-check.js +175 -0
  795. package/dist/validation/gap-check.js.map +1 -0
  796. package/dist/validation/index.js +40 -0
  797. package/dist/validation/index.js.map +1 -0
  798. package/dist/validation/manifest.js +237 -0
  799. package/dist/validation/manifest.js.map +1 -0
  800. package/dist/validation/operation-gate-validators.js +724 -0
  801. package/dist/validation/operation-gate-validators.js.map +1 -0
  802. package/dist/validation/operation-verification-gates.js +532 -0
  803. package/dist/validation/operation-verification-gates.js.map +1 -0
  804. package/dist/validation/param-utils.js +139 -0
  805. package/dist/validation/param-utils.js.map +1 -0
  806. package/dist/validation/protocol-common.js +300 -0
  807. package/dist/validation/protocol-common.js.map +1 -0
  808. package/dist/validation/protocols/consensus.js +71 -0
  809. package/dist/validation/protocols/consensus.js.map +1 -0
  810. package/dist/validation/protocols/contribution.js +59 -0
  811. package/dist/validation/protocols/contribution.js.map +1 -0
  812. package/dist/validation/protocols/decomposition.js +59 -0
  813. package/dist/validation/protocols/decomposition.js.map +1 -0
  814. package/dist/validation/protocols/implementation.js +59 -0
  815. package/dist/validation/protocols/implementation.js.map +1 -0
  816. package/dist/validation/protocols/release-protocol.js +60 -0
  817. package/dist/validation/protocols/release-protocol.js.map +1 -0
  818. package/dist/validation/protocols/research.js +77 -0
  819. package/dist/validation/protocols/research.js.map +1 -0
  820. package/dist/validation/protocols/specification.js +84 -0
  821. package/dist/validation/protocols/specification.js.map +1 -0
  822. package/dist/validation/protocols/testing-protocol.js +70 -0
  823. package/dist/validation/protocols/testing-protocol.js.map +1 -0
  824. package/dist/validation/protocols/validation-protocol.js +70 -0
  825. package/dist/validation/protocols/validation-protocol.js.map +1 -0
  826. package/dist/validation/schema-integrity.js +170 -0
  827. package/dist/validation/schema-integrity.js.map +1 -0
  828. package/dist/validation/schema-validator.js +176 -0
  829. package/dist/validation/schema-validator.js.map +1 -0
  830. package/dist/validation/validate-ops.js +937 -0
  831. package/dist/validation/validate-ops.js.map +1 -0
  832. package/dist/validation/validation-rules.js +226 -0
  833. package/dist/validation/validation-rules.js.map +1 -0
  834. package/dist/validation/verification.js +321 -0
  835. package/dist/validation/verification.js.map +1 -0
  836. package/migrations/drizzle-brain/20260321000001_t033-brain-indexes/migration.sql +12 -0
  837. package/migrations/drizzle-brain/20260321000001_t033-brain-indexes/snapshot.json +1232 -0
  838. package/migrations/drizzle-tasks/20260321000000_t033-connection-health/migration.sql +518 -0
  839. package/migrations/drizzle-tasks/20260321000000_t033-connection-health/snapshot.json +4312 -0
  840. package/migrations/drizzle-tasks/20260321000002_t060-pipeline-stage-binding/migration.sql +82 -0
  841. package/migrations/drizzle-tasks/20260321000002_t060-pipeline-stage-binding/snapshot.json +9 -0
  842. package/package.json +5 -5
  843. package/schemas/config.schema.json +47 -2
  844. package/src/__tests__/injection-mvi-tiers.test.ts +5 -5
  845. package/src/agents/__tests__/execution-learning.test.ts +684 -0
  846. package/src/agents/__tests__/registry.test.ts +30 -2
  847. package/src/agents/agent-schema.ts +5 -0
  848. package/src/agents/execution-learning.ts +675 -0
  849. package/src/agents/index.ts +13 -0
  850. package/src/backfill/index.ts +282 -0
  851. package/src/bootstrap.ts +1 -1
  852. package/src/config.ts +126 -0
  853. package/src/index.ts +7 -1
  854. package/src/intelligence/__tests__/adaptive-validation.test.ts +694 -0
  855. package/src/intelligence/adaptive-validation.ts +764 -0
  856. package/src/intelligence/index.ts +16 -0
  857. package/src/internal.ts +19 -0
  858. package/src/lifecycle/__tests__/chain-store.test.ts +7 -0
  859. package/src/lifecycle/__tests__/tessera-engine.test.ts +52 -0
  860. package/src/sessions/__tests__/session-edge-cases.test.ts +24 -1
  861. package/src/sessions/session-enforcement.ts +13 -2
  862. package/src/stats/index.ts +7 -0
  863. package/src/stats/workflow-telemetry.ts +487 -0
  864. package/src/store/__tests__/migration-safety.test.ts +3 -0
  865. package/src/store/__tests__/session-store.test.ts +96 -1
  866. package/src/store/__tests__/task-store.test.ts +22 -1
  867. package/src/store/__tests__/test-db-helper.ts +25 -2
  868. package/src/store/brain-schema.ts +4 -1
  869. package/src/store/converters.ts +2 -0
  870. package/src/store/cross-db-cleanup.ts +157 -0
  871. package/src/store/db-helpers.ts +2 -0
  872. package/src/store/migration-sqlite.ts +6 -0
  873. package/src/store/sqlite-data-accessor.ts +20 -28
  874. package/src/store/sqlite.ts +14 -2
  875. package/src/store/task-store.ts +6 -0
  876. package/src/store/tasks-schema.ts +59 -20
  877. package/src/tasks/__tests__/add.test.ts +16 -0
  878. package/src/tasks/__tests__/complete-unblocks.test.ts +10 -1
  879. package/src/tasks/__tests__/complete.test.ts +11 -2
  880. package/src/tasks/__tests__/epic-enforcement.test.ts +904 -0
  881. package/src/tasks/__tests__/minimal-test.test.ts +28 -0
  882. package/src/tasks/__tests__/pipeline-stage.test.ts +403 -0
  883. package/src/tasks/__tests__/update.test.ts +40 -6
  884. package/src/tasks/add.ts +128 -2
  885. package/src/tasks/complete.ts +24 -17
  886. package/src/tasks/enforcement.ts +124 -0
  887. package/src/tasks/epic-enforcement.ts +303 -0
  888. package/src/tasks/index.ts +1 -0
  889. package/src/tasks/pipeline-stage.ts +224 -0
  890. package/src/tasks/update.ts +62 -0
  891. package/templates/CLEO-INJECTION.md +1 -1
  892. package/templates/config.template.json +34 -0
  893. package/templates/global-config.template.json +26 -0
@@ -0,0 +1,904 @@
1
+ /**
2
+ * Tests for epic lifecycle pipeline enforcement (T062).
3
+ *
4
+ * Covers:
5
+ * - validateEpicCreation: min-5 AC, description required, mode gating
6
+ * - validateChildStageCeiling: child stage must not exceed epic's stage
7
+ * - validateEpicStageAdvancement: epic blocked by in-flight children
8
+ * - findEpicAncestor: correct ancestor traversal
9
+ * - Integration via addTask / updateTask
10
+ *
11
+ * @task T062
12
+ * @epic T056
13
+ */
14
+
15
+ import { writeFile } from 'node:fs/promises';
16
+ import { join } from 'node:path';
17
+ import { afterAll, afterEach, beforeAll, beforeEach, describe, expect, it } from 'vitest';
18
+ import { createTestDb, type TestDbEnv } from '../../store/__tests__/test-db-helper.js';
19
+
20
+ // Epic enforcement tests NEED enforcement active — temporarily clear VITEST
21
+ const savedVitest = process.env.VITEST;
22
+ beforeAll(() => { delete process.env.VITEST; });
23
+ afterAll(() => { if (savedVitest) process.env.VITEST = savedVitest; });
24
+ import type { DataAccessor } from '../../store/data-accessor.js';
25
+ import { addTask } from '../add.js';
26
+ import {
27
+ EPIC_MIN_AC,
28
+ findEpicAncestor,
29
+ getLifecycleMode,
30
+ validateChildStageCeiling,
31
+ validateEpicCreation,
32
+ validateEpicStageAdvancement,
33
+ } from '../epic-enforcement.js';
34
+ import { updateTask } from '../update.js';
35
+
36
+ // ---------------------------------------------------------------------------
37
+ // Config helpers
38
+ // ---------------------------------------------------------------------------
39
+
40
+ /** Config that disables session and acceptance enforcement for test isolation. */
41
+ function makeConfig(lifecycleMode: 'strict' | 'advisory' | 'off' = 'strict'): string {
42
+ return JSON.stringify({
43
+ lifecycle: { mode: lifecycleMode },
44
+ enforcement: {
45
+ session: { requiredForMutate: false },
46
+ acceptance: { mode: 'off' },
47
+ },
48
+ verification: { enabled: false },
49
+ });
50
+ }
51
+
52
+ // ---------------------------------------------------------------------------
53
+ // Unit: EPIC_MIN_AC
54
+ // ---------------------------------------------------------------------------
55
+
56
+ describe('EPIC_MIN_AC constant', () => {
57
+ it('is 5', () => {
58
+ expect(EPIC_MIN_AC).toBe(5);
59
+ });
60
+ });
61
+
62
+ // ---------------------------------------------------------------------------
63
+ // Unit: getLifecycleMode
64
+ // ---------------------------------------------------------------------------
65
+
66
+ describe('getLifecycleMode', () => {
67
+ let env: TestDbEnv;
68
+
69
+ beforeEach(async () => {
70
+ env = await createTestDb();
71
+ });
72
+
73
+ afterEach(async () => {
74
+ await env.cleanup();
75
+ });
76
+
77
+ it('returns strict by default when no config', async () => {
78
+ const mode = await getLifecycleMode(env.tempDir);
79
+ expect(mode).toBe('strict');
80
+ });
81
+
82
+ it('returns advisory from config', async () => {
83
+ await writeFile(join(env.cleoDir, 'config.json'), makeConfig('advisory'));
84
+ const mode = await getLifecycleMode(env.tempDir);
85
+ expect(mode).toBe('advisory');
86
+ });
87
+
88
+ it('returns off from config', async () => {
89
+ await writeFile(join(env.cleoDir, 'config.json'), makeConfig('off'));
90
+ const mode = await getLifecycleMode(env.tempDir);
91
+ expect(mode).toBe('off');
92
+ });
93
+ });
94
+
95
+ // ---------------------------------------------------------------------------
96
+ // Unit: validateEpicCreation
97
+ // ---------------------------------------------------------------------------
98
+
99
+ describe('validateEpicCreation (strict mode)', () => {
100
+ let env: TestDbEnv;
101
+
102
+ beforeEach(async () => {
103
+ env = await createTestDb();
104
+ await writeFile(join(env.cleoDir, 'config.json'), makeConfig('strict'));
105
+ });
106
+
107
+ afterEach(async () => {
108
+ await env.cleanup();
109
+ });
110
+
111
+ it('accepts when 5 AC items and description are present', async () => {
112
+ const result = await validateEpicCreation(
113
+ {
114
+ acceptance: ['ac1', 'ac2', 'ac3', 'ac4', 'ac5'],
115
+ description: 'Some completion criteria',
116
+ },
117
+ env.tempDir,
118
+ );
119
+ expect(result.valid).toBe(true);
120
+ expect(result.warning).toBeUndefined();
121
+ });
122
+
123
+ it('throws when fewer than 5 AC items', async () => {
124
+ await expect(
125
+ validateEpicCreation(
126
+ {
127
+ acceptance: ['ac1', 'ac2', 'ac3', 'ac4'],
128
+ description: 'Some completion criteria',
129
+ },
130
+ env.tempDir,
131
+ ),
132
+ ).rejects.toThrow(/5 acceptance criteria/);
133
+ });
134
+
135
+ it('throws when description is empty', async () => {
136
+ await expect(
137
+ validateEpicCreation(
138
+ {
139
+ acceptance: ['ac1', 'ac2', 'ac3', 'ac4', 'ac5'],
140
+ description: '',
141
+ },
142
+ env.tempDir,
143
+ ),
144
+ ).rejects.toThrow(/non-empty description/);
145
+ });
146
+
147
+ it('throws when both AC count and description are insufficient', async () => {
148
+ await expect(
149
+ validateEpicCreation({ acceptance: [], description: ' ' }, env.tempDir),
150
+ ).rejects.toThrow();
151
+ });
152
+ });
153
+
154
+ describe('validateEpicCreation (advisory mode)', () => {
155
+ let env: TestDbEnv;
156
+
157
+ beforeEach(async () => {
158
+ env = await createTestDb();
159
+ await writeFile(join(env.cleoDir, 'config.json'), makeConfig('advisory'));
160
+ });
161
+
162
+ afterEach(async () => {
163
+ await env.cleanup();
164
+ });
165
+
166
+ it('does not throw on violation, returns warning', async () => {
167
+ const result = await validateEpicCreation(
168
+ { acceptance: ['ac1'], description: 'OK' },
169
+ env.tempDir,
170
+ );
171
+ expect(result.valid).toBe(true);
172
+ expect(result.warning).toMatch(/5 acceptance criteria/);
173
+ });
174
+ });
175
+
176
+ describe('validateEpicCreation (off mode)', () => {
177
+ let env: TestDbEnv;
178
+
179
+ beforeEach(async () => {
180
+ env = await createTestDb();
181
+ await writeFile(join(env.cleoDir, 'config.json'), makeConfig('off'));
182
+ });
183
+
184
+ afterEach(async () => {
185
+ await env.cleanup();
186
+ });
187
+
188
+ it('skips all checks and returns valid', async () => {
189
+ const result = await validateEpicCreation({ acceptance: [], description: '' }, env.tempDir);
190
+ expect(result.valid).toBe(true);
191
+ expect(result.warning).toBeUndefined();
192
+ });
193
+ });
194
+
195
+ // ---------------------------------------------------------------------------
196
+ // Unit: validateChildStageCeiling
197
+ // ---------------------------------------------------------------------------
198
+
199
+ describe('validateChildStageCeiling (strict)', () => {
200
+ let env: TestDbEnv;
201
+ let accessor: DataAccessor;
202
+
203
+ beforeEach(async () => {
204
+ env = await createTestDb();
205
+ accessor = env.accessor;
206
+ await writeFile(join(env.cleoDir, 'config.json'), makeConfig('strict'));
207
+ });
208
+
209
+ afterEach(async () => {
210
+ await env.cleanup();
211
+ });
212
+
213
+ async function seedEpicAtStage(stage: string): Promise<string> {
214
+ const now = new Date().toISOString();
215
+ await accessor.upsertSingleTask({
216
+ id: 'T001',
217
+ title: 'Epic',
218
+ description: 'Epic description',
219
+ status: 'pending',
220
+ priority: 'medium',
221
+ type: 'epic',
222
+ pipelineStage: stage,
223
+ createdAt: now,
224
+ updatedAt: now,
225
+ });
226
+ return 'T001';
227
+ }
228
+
229
+ it('allows child stage equal to epic stage', async () => {
230
+ const epicId = await seedEpicAtStage('specification');
231
+ const result = await validateChildStageCeiling(
232
+ { childStage: 'specification', epicId },
233
+ accessor,
234
+ env.tempDir,
235
+ );
236
+ expect(result.valid).toBe(true);
237
+ });
238
+
239
+ it('allows child stage below epic stage', async () => {
240
+ const epicId = await seedEpicAtStage('implementation');
241
+ const result = await validateChildStageCeiling(
242
+ { childStage: 'research', epicId },
243
+ accessor,
244
+ env.tempDir,
245
+ );
246
+ expect(result.valid).toBe(true);
247
+ });
248
+
249
+ it('throws when child stage exceeds epic stage', async () => {
250
+ const epicId = await seedEpicAtStage('research');
251
+ await expect(
252
+ validateChildStageCeiling({ childStage: 'implementation', epicId }, accessor, env.tempDir),
253
+ ).rejects.toThrow(/cannot be at pipeline stage/);
254
+ });
255
+
256
+ it('skips check when epic ID does not exist', async () => {
257
+ const result = await validateChildStageCeiling(
258
+ { childStage: 'testing', epicId: 'T999' },
259
+ accessor,
260
+ env.tempDir,
261
+ );
262
+ expect(result.valid).toBe(true);
263
+ });
264
+ });
265
+
266
+ describe('validateChildStageCeiling (advisory)', () => {
267
+ let env: TestDbEnv;
268
+ let accessor: DataAccessor;
269
+
270
+ beforeEach(async () => {
271
+ env = await createTestDb();
272
+ accessor = env.accessor;
273
+ await writeFile(join(env.cleoDir, 'config.json'), makeConfig('advisory'));
274
+ });
275
+
276
+ afterEach(async () => {
277
+ await env.cleanup();
278
+ });
279
+
280
+ it('returns warning instead of throwing', async () => {
281
+ const now = new Date().toISOString();
282
+ await accessor.upsertSingleTask({
283
+ id: 'T001',
284
+ title: 'Epic',
285
+ description: 'desc',
286
+ status: 'pending',
287
+ priority: 'medium',
288
+ type: 'epic',
289
+ pipelineStage: 'research',
290
+ createdAt: now,
291
+ updatedAt: now,
292
+ });
293
+ const result = await validateChildStageCeiling(
294
+ { childStage: 'testing', epicId: 'T001' },
295
+ accessor,
296
+ env.tempDir,
297
+ );
298
+ expect(result.valid).toBe(true);
299
+ expect(result.warning).toMatch(/cannot be at pipeline stage/);
300
+ });
301
+ });
302
+
303
+ // ---------------------------------------------------------------------------
304
+ // Unit: validateEpicStageAdvancement
305
+ // ---------------------------------------------------------------------------
306
+
307
+ describe('validateEpicStageAdvancement (strict)', () => {
308
+ let env: TestDbEnv;
309
+ let accessor: DataAccessor;
310
+
311
+ beforeEach(async () => {
312
+ env = await createTestDb();
313
+ accessor = env.accessor;
314
+ await writeFile(join(env.cleoDir, 'config.json'), makeConfig('strict'));
315
+ });
316
+
317
+ afterEach(async () => {
318
+ await env.cleanup();
319
+ });
320
+
321
+ it('allows advancement when no children exist', async () => {
322
+ const result = await validateEpicStageAdvancement(
323
+ { epicId: 'T001', currentStage: 'research', newStage: 'implementation' },
324
+ accessor,
325
+ env.tempDir,
326
+ );
327
+ expect(result.valid).toBe(true);
328
+ });
329
+
330
+ it('allows advancement when all children are done', async () => {
331
+ const now = new Date().toISOString();
332
+ // Seed epic
333
+ await accessor.upsertSingleTask({
334
+ id: 'T001',
335
+ title: 'Epic',
336
+ description: 'Epic',
337
+ status: 'pending',
338
+ priority: 'medium',
339
+ type: 'epic',
340
+ pipelineStage: 'research',
341
+ createdAt: now,
342
+ updatedAt: now,
343
+ });
344
+ // Seed done child at research
345
+ await accessor.upsertSingleTask({
346
+ id: 'T002',
347
+ title: 'Child',
348
+ description: 'Child',
349
+ status: 'done',
350
+ priority: 'medium',
351
+ type: 'task',
352
+ parentId: 'T001',
353
+ pipelineStage: 'research',
354
+ createdAt: now,
355
+ updatedAt: now,
356
+ });
357
+
358
+ const result = await validateEpicStageAdvancement(
359
+ { epicId: 'T001', currentStage: 'research', newStage: 'implementation' },
360
+ accessor,
361
+ env.tempDir,
362
+ );
363
+ expect(result.valid).toBe(true);
364
+ });
365
+
366
+ it('throws when child is in-flight at current stage', async () => {
367
+ const now = new Date().toISOString();
368
+ await accessor.upsertSingleTask({
369
+ id: 'T001',
370
+ title: 'Epic',
371
+ description: 'Epic',
372
+ status: 'pending',
373
+ priority: 'medium',
374
+ type: 'epic',
375
+ pipelineStage: 'research',
376
+ createdAt: now,
377
+ updatedAt: now,
378
+ });
379
+ await accessor.upsertSingleTask({
380
+ id: 'T002',
381
+ title: 'Child',
382
+ description: 'Child',
383
+ status: 'in-progress',
384
+ priority: 'medium',
385
+ type: 'task',
386
+ parentId: 'T001',
387
+ pipelineStage: 'research',
388
+ createdAt: now,
389
+ updatedAt: now,
390
+ });
391
+
392
+ await expect(
393
+ validateEpicStageAdvancement(
394
+ { epicId: 'T001', currentStage: 'research', newStage: 'implementation' },
395
+ accessor,
396
+ env.tempDir,
397
+ ),
398
+ ).rejects.toThrow(/cannot advance/);
399
+ });
400
+
401
+ it('ignores children at a different (later) stage', async () => {
402
+ const now = new Date().toISOString();
403
+ await accessor.upsertSingleTask({
404
+ id: 'T001',
405
+ title: 'Epic',
406
+ description: 'Epic',
407
+ status: 'pending',
408
+ priority: 'medium',
409
+ type: 'epic',
410
+ pipelineStage: 'research',
411
+ createdAt: now,
412
+ updatedAt: now,
413
+ });
414
+ // Child is at implementation (not at current stage 'research')
415
+ await accessor.upsertSingleTask({
416
+ id: 'T002',
417
+ title: 'Child',
418
+ description: 'Child',
419
+ status: 'in-progress',
420
+ priority: 'medium',
421
+ type: 'task',
422
+ parentId: 'T001',
423
+ pipelineStage: 'implementation',
424
+ createdAt: now,
425
+ updatedAt: now,
426
+ });
427
+
428
+ const result = await validateEpicStageAdvancement(
429
+ { epicId: 'T001', currentStage: 'research', newStage: 'implementation' },
430
+ accessor,
431
+ env.tempDir,
432
+ );
433
+ expect(result.valid).toBe(true);
434
+ });
435
+
436
+ it('ignores cancelled children at current stage', async () => {
437
+ const now = new Date().toISOString();
438
+ await accessor.upsertSingleTask({
439
+ id: 'T001',
440
+ title: 'Epic',
441
+ description: 'Epic',
442
+ status: 'pending',
443
+ priority: 'medium',
444
+ type: 'epic',
445
+ pipelineStage: 'research',
446
+ createdAt: now,
447
+ updatedAt: now,
448
+ });
449
+ await accessor.upsertSingleTask({
450
+ id: 'T002',
451
+ title: 'Child',
452
+ description: 'Child',
453
+ status: 'cancelled',
454
+ priority: 'medium',
455
+ type: 'task',
456
+ parentId: 'T001',
457
+ pipelineStage: 'research',
458
+ createdAt: now,
459
+ updatedAt: now,
460
+ });
461
+
462
+ const result = await validateEpicStageAdvancement(
463
+ { epicId: 'T001', currentStage: 'research', newStage: 'implementation' },
464
+ accessor,
465
+ env.tempDir,
466
+ );
467
+ expect(result.valid).toBe(true);
468
+ });
469
+
470
+ it('is no-op for same-stage (no advancement)', async () => {
471
+ const result = await validateEpicStageAdvancement(
472
+ { epicId: 'T001', currentStage: 'research', newStage: 'research' },
473
+ accessor,
474
+ env.tempDir,
475
+ );
476
+ expect(result.valid).toBe(true);
477
+ });
478
+ });
479
+
480
+ describe('validateEpicStageAdvancement (advisory)', () => {
481
+ let env: TestDbEnv;
482
+ let accessor: DataAccessor;
483
+
484
+ beforeEach(async () => {
485
+ env = await createTestDb();
486
+ accessor = env.accessor;
487
+ await writeFile(join(env.cleoDir, 'config.json'), makeConfig('advisory'));
488
+ });
489
+
490
+ afterEach(async () => {
491
+ await env.cleanup();
492
+ });
493
+
494
+ it('returns warning instead of throwing when blocked', async () => {
495
+ const now = new Date().toISOString();
496
+ await accessor.upsertSingleTask({
497
+ id: 'T001',
498
+ title: 'Epic',
499
+ description: 'Epic',
500
+ status: 'pending',
501
+ priority: 'medium',
502
+ type: 'epic',
503
+ pipelineStage: 'research',
504
+ createdAt: now,
505
+ updatedAt: now,
506
+ });
507
+ await accessor.upsertSingleTask({
508
+ id: 'T002',
509
+ title: 'Child',
510
+ description: 'Child',
511
+ status: 'pending',
512
+ priority: 'medium',
513
+ type: 'task',
514
+ parentId: 'T001',
515
+ pipelineStage: 'research',
516
+ createdAt: now,
517
+ updatedAt: now,
518
+ });
519
+
520
+ const result = await validateEpicStageAdvancement(
521
+ { epicId: 'T001', currentStage: 'research', newStage: 'implementation' },
522
+ accessor,
523
+ env.tempDir,
524
+ );
525
+ expect(result.valid).toBe(true);
526
+ expect(result.warning).toMatch(/cannot advance/);
527
+ });
528
+ });
529
+
530
+ // ---------------------------------------------------------------------------
531
+ // Unit: findEpicAncestor
532
+ // ---------------------------------------------------------------------------
533
+
534
+ describe('findEpicAncestor', () => {
535
+ let env: TestDbEnv;
536
+ let accessor: DataAccessor;
537
+
538
+ beforeEach(async () => {
539
+ env = await createTestDb();
540
+ accessor = env.accessor;
541
+ });
542
+
543
+ afterEach(async () => {
544
+ await env.cleanup();
545
+ });
546
+
547
+ it('returns null when task has no ancestors', async () => {
548
+ const result = await findEpicAncestor('T999', accessor);
549
+ expect(result).toBeNull();
550
+ });
551
+
552
+ it('finds a direct epic parent', async () => {
553
+ const now = new Date().toISOString();
554
+ await accessor.upsertSingleTask({
555
+ id: 'T001',
556
+ title: 'Epic',
557
+ description: 'Epic',
558
+ status: 'pending',
559
+ priority: 'medium',
560
+ type: 'epic',
561
+ pipelineStage: 'research',
562
+ createdAt: now,
563
+ updatedAt: now,
564
+ });
565
+ await accessor.upsertSingleTask({
566
+ id: 'T002',
567
+ title: 'Child',
568
+ description: 'Child',
569
+ status: 'pending',
570
+ priority: 'medium',
571
+ type: 'task',
572
+ parentId: 'T001',
573
+ pipelineStage: 'research',
574
+ createdAt: now,
575
+ updatedAt: now,
576
+ });
577
+
578
+ // findEpicAncestor takes the task whose ancestors to walk.
579
+ // For T002's parent T001, we pass T001 to check its ancestors, OR
580
+ // we pass T002 to check ancestors of T002 (which includes T001).
581
+ const epic = await findEpicAncestor('T001', accessor);
582
+ // T001 has no ancestors (root level), so no epic ancestor
583
+ expect(epic).toBeNull();
584
+
585
+ // For T002's parent: we already know T001 is the epic, so we pass parentId=T001
586
+ // and check if T001 itself is an epic — that's handled in add.ts separately.
587
+ // findEpicAncestor walks ancestors of the supplied ID.
588
+ const fromChild = await findEpicAncestor('T002', accessor);
589
+ // T002's ancestor is T001 (epic) — should be found
590
+ expect(fromChild?.id).toBe('T001');
591
+ });
592
+
593
+ it('returns null when no epic in ancestor chain', async () => {
594
+ const now = new Date().toISOString();
595
+ await accessor.upsertSingleTask({
596
+ id: 'T001',
597
+ title: 'Parent task',
598
+ description: 'desc',
599
+ status: 'pending',
600
+ priority: 'medium',
601
+ type: 'task',
602
+ pipelineStage: 'research',
603
+ createdAt: now,
604
+ updatedAt: now,
605
+ });
606
+ await accessor.upsertSingleTask({
607
+ id: 'T002',
608
+ title: 'Child subtask',
609
+ description: 'desc',
610
+ status: 'pending',
611
+ priority: 'medium',
612
+ type: 'subtask',
613
+ parentId: 'T001',
614
+ pipelineStage: 'research',
615
+ createdAt: now,
616
+ updatedAt: now,
617
+ });
618
+
619
+ const epic = await findEpicAncestor('T002', accessor);
620
+ expect(epic).toBeNull();
621
+ });
622
+ });
623
+
624
+ // ---------------------------------------------------------------------------
625
+ // Integration: addTask epic creation enforcement
626
+ // ---------------------------------------------------------------------------
627
+
628
+ describe('addTask epic creation enforcement (strict)', () => {
629
+ let env: TestDbEnv;
630
+ let accessor: DataAccessor;
631
+
632
+ beforeEach(async () => {
633
+ env = await createTestDb();
634
+ accessor = env.accessor;
635
+ await writeFile(join(env.cleoDir, 'config.json'), makeConfig('strict'));
636
+ });
637
+
638
+ afterEach(async () => {
639
+ await env.cleanup();
640
+ });
641
+
642
+ it('creates an epic when 5 AC and description are provided', async () => {
643
+ const result = await addTask(
644
+ {
645
+ title: 'My epic',
646
+ description: 'Completion criteria: all features shipped',
647
+ type: 'epic',
648
+ acceptance: ['ac1', 'ac2', 'ac3', 'ac4', 'ac5'],
649
+ },
650
+ env.tempDir,
651
+ accessor,
652
+ );
653
+ expect(result.task.type).toBe('epic');
654
+ expect(result.task.acceptance?.length).toBe(5);
655
+ });
656
+
657
+ it('blocks epic creation with fewer than 5 AC', async () => {
658
+ await expect(
659
+ addTask(
660
+ {
661
+ title: 'Bad epic',
662
+ description: 'Completion criteria here',
663
+ type: 'epic',
664
+ acceptance: ['ac1', 'ac2', 'ac3'],
665
+ },
666
+ env.tempDir,
667
+ accessor,
668
+ ),
669
+ ).rejects.toThrow(/5 acceptance criteria/);
670
+ });
671
+ });
672
+
673
+ describe('addTask child stage ceiling (strict)', () => {
674
+ let env: TestDbEnv;
675
+ let accessor: DataAccessor;
676
+
677
+ beforeEach(async () => {
678
+ env = await createTestDb();
679
+ accessor = env.accessor;
680
+ await writeFile(join(env.cleoDir, 'config.json'), makeConfig('strict'));
681
+ });
682
+
683
+ afterEach(async () => {
684
+ await env.cleanup();
685
+ });
686
+
687
+ it('allows child at same stage as epic', async () => {
688
+ // Create epic at research
689
+ const epicResult = await addTask(
690
+ {
691
+ title: 'Epic',
692
+ description: 'Epic desc',
693
+ type: 'epic',
694
+ acceptance: ['ac1', 'ac2', 'ac3', 'ac4', 'ac5'],
695
+ pipelineStage: 'research',
696
+ },
697
+ env.tempDir,
698
+ accessor,
699
+ );
700
+ const epicId = epicResult.task.id;
701
+
702
+ const childResult = await addTask(
703
+ {
704
+ title: 'Child',
705
+ description: 'Child task',
706
+ parentId: epicId,
707
+ pipelineStage: 'research',
708
+ },
709
+ env.tempDir,
710
+ accessor,
711
+ );
712
+ expect(childResult.task.pipelineStage).toBe('research');
713
+ });
714
+
715
+ it('blocks child at stage beyond epic stage', async () => {
716
+ const epicResult = await addTask(
717
+ {
718
+ title: 'Epic',
719
+ description: 'Epic desc',
720
+ type: 'epic',
721
+ acceptance: ['ac1', 'ac2', 'ac3', 'ac4', 'ac5'],
722
+ pipelineStage: 'research',
723
+ },
724
+ env.tempDir,
725
+ accessor,
726
+ );
727
+ const epicId = epicResult.task.id;
728
+
729
+ await expect(
730
+ addTask(
731
+ {
732
+ title: 'Child',
733
+ description: 'Child task',
734
+ parentId: epicId,
735
+ pipelineStage: 'implementation',
736
+ },
737
+ env.tempDir,
738
+ accessor,
739
+ ),
740
+ ).rejects.toThrow(/cannot be at pipeline stage/);
741
+ });
742
+ });
743
+
744
+ // ---------------------------------------------------------------------------
745
+ // Integration: updateTask epic stage advancement gate
746
+ // ---------------------------------------------------------------------------
747
+
748
+ describe('updateTask epic stage advancement gate (strict)', () => {
749
+ let env: TestDbEnv;
750
+ let accessor: DataAccessor;
751
+
752
+ beforeEach(async () => {
753
+ env = await createTestDb();
754
+ accessor = env.accessor;
755
+ await writeFile(join(env.cleoDir, 'config.json'), makeConfig('strict'));
756
+ });
757
+
758
+ afterEach(async () => {
759
+ await env.cleanup();
760
+ });
761
+
762
+ it('allows advancing epic stage when no in-flight children at current stage', async () => {
763
+ // Create epic at research with 5 AC
764
+ const epicResult = await addTask(
765
+ {
766
+ title: 'Epic',
767
+ description: 'Epic desc',
768
+ type: 'epic',
769
+ acceptance: ['ac1', 'ac2', 'ac3', 'ac4', 'ac5'],
770
+ pipelineStage: 'research',
771
+ },
772
+ env.tempDir,
773
+ accessor,
774
+ );
775
+ const epicId = epicResult.task.id;
776
+
777
+ // Advance epic to implementation — no children
778
+ const updateResult = await updateTask(
779
+ { taskId: epicId, pipelineStage: 'implementation' },
780
+ env.tempDir,
781
+ accessor,
782
+ );
783
+ expect(updateResult.task.pipelineStage).toBe('implementation');
784
+ });
785
+
786
+ it('blocks advancing epic when child is in-flight at current stage', async () => {
787
+ // Create epic at research
788
+ const epicResult = await addTask(
789
+ {
790
+ title: 'Epic',
791
+ description: 'Epic desc',
792
+ type: 'epic',
793
+ acceptance: ['ac1', 'ac2', 'ac3', 'ac4', 'ac5'],
794
+ pipelineStage: 'research',
795
+ },
796
+ env.tempDir,
797
+ accessor,
798
+ );
799
+ const epicId = epicResult.task.id;
800
+
801
+ // Create in-flight child at research stage
802
+ await addTask(
803
+ {
804
+ title: 'Child',
805
+ description: 'Child task',
806
+ parentId: epicId,
807
+ pipelineStage: 'research',
808
+ },
809
+ env.tempDir,
810
+ accessor,
811
+ );
812
+
813
+ // Attempt to advance epic — should be blocked
814
+ await expect(
815
+ updateTask({ taskId: epicId, pipelineStage: 'implementation' }, env.tempDir, accessor),
816
+ ).rejects.toThrow(/cannot advance/);
817
+ });
818
+ });
819
+
820
+ describe('updateTask child stage ceiling on update (strict)', () => {
821
+ let env: TestDbEnv;
822
+ let accessor: DataAccessor;
823
+
824
+ beforeEach(async () => {
825
+ env = await createTestDb();
826
+ accessor = env.accessor;
827
+ await writeFile(join(env.cleoDir, 'config.json'), makeConfig('strict'));
828
+ });
829
+
830
+ afterEach(async () => {
831
+ await env.cleanup();
832
+ });
833
+
834
+ it('blocks updating child to a stage beyond epic', async () => {
835
+ // Create epic at research
836
+ const epicResult = await addTask(
837
+ {
838
+ title: 'Epic',
839
+ description: 'Epic desc',
840
+ type: 'epic',
841
+ acceptance: ['ac1', 'ac2', 'ac3', 'ac4', 'ac5'],
842
+ pipelineStage: 'research',
843
+ },
844
+ env.tempDir,
845
+ accessor,
846
+ );
847
+ const epicId = epicResult.task.id;
848
+
849
+ // Create child at research
850
+ const childResult = await addTask(
851
+ {
852
+ title: 'Child',
853
+ description: 'Child task',
854
+ parentId: epicId,
855
+ pipelineStage: 'research',
856
+ },
857
+ env.tempDir,
858
+ accessor,
859
+ );
860
+ const childId = childResult.task.id;
861
+
862
+ // Attempt to update child to implementation (beyond epic's research)
863
+ await expect(
864
+ updateTask({ taskId: childId, pipelineStage: 'implementation' }, env.tempDir, accessor),
865
+ ).rejects.toThrow(/cannot be at pipeline stage/);
866
+ });
867
+
868
+ it('allows updating child to a stage equal to epic', async () => {
869
+ // Create epic at implementation
870
+ const epicResult = await addTask(
871
+ {
872
+ title: 'Epic',
873
+ description: 'Epic desc',
874
+ type: 'epic',
875
+ acceptance: ['ac1', 'ac2', 'ac3', 'ac4', 'ac5'],
876
+ pipelineStage: 'implementation',
877
+ },
878
+ env.tempDir,
879
+ accessor,
880
+ );
881
+ const epicId = epicResult.task.id;
882
+
883
+ // Create child at research
884
+ const childResult = await addTask(
885
+ {
886
+ title: 'Child',
887
+ description: 'Child task',
888
+ parentId: epicId,
889
+ pipelineStage: 'research',
890
+ },
891
+ env.tempDir,
892
+ accessor,
893
+ );
894
+ const childId = childResult.task.id;
895
+
896
+ // Update child to implementation (same as epic)
897
+ const updateResult = await updateTask(
898
+ { taskId: childId, pipelineStage: 'implementation' },
899
+ env.tempDir,
900
+ accessor,
901
+ );
902
+ expect(updateResult.task.pipelineStage).toBe('implementation');
903
+ });
904
+ });