macro-agent 0.1.1 → 0.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (406) hide show
  1. package/.sudocode/issues.jsonl +28 -0
  2. package/.sudocode/specs.jsonl +4 -0
  3. package/CLAUDE.md +9 -3
  4. package/dist/agent/agent-manager.d.ts.map +1 -1
  5. package/dist/agent/agent-manager.js +111 -48
  6. package/dist/agent/agent-manager.js.map +1 -1
  7. package/dist/agent/types.d.ts +7 -0
  8. package/dist/agent/types.d.ts.map +1 -1
  9. package/dist/agent/types.js.map +1 -1
  10. package/dist/api/server.d.ts +5 -1
  11. package/dist/api/server.d.ts.map +1 -1
  12. package/dist/api/server.js +100 -3
  13. package/dist/api/server.js.map +1 -1
  14. package/dist/api/types.d.ts +1 -1
  15. package/dist/api/types.d.ts.map +1 -1
  16. package/dist/cli/acp.d.ts.map +1 -1
  17. package/dist/cli/acp.js +71 -1
  18. package/dist/cli/acp.js.map +1 -1
  19. package/dist/cli/index.js +5 -1
  20. package/dist/cli/index.js.map +1 -1
  21. package/dist/cli/mcp.js +27 -8
  22. package/dist/cli/mcp.js.map +1 -1
  23. package/dist/config/project-config.d.ts +13 -2
  24. package/dist/config/project-config.d.ts.map +1 -1
  25. package/dist/config/project-config.js +12 -2
  26. package/dist/config/project-config.js.map +1 -1
  27. package/dist/index.d.ts +1 -0
  28. package/dist/index.d.ts.map +1 -1
  29. package/dist/index.js +2 -0
  30. package/dist/index.js.map +1 -1
  31. package/dist/lifecycle/handlers/index.d.ts +7 -3
  32. package/dist/lifecycle/handlers/index.d.ts.map +1 -1
  33. package/dist/lifecycle/handlers/index.js +25 -8
  34. package/dist/lifecycle/handlers/index.js.map +1 -1
  35. package/dist/lifecycle/types.d.ts +2 -0
  36. package/dist/lifecycle/types.d.ts.map +1 -1
  37. package/dist/lifecycle/types.js.map +1 -1
  38. package/dist/map/adapter/extensions/index.d.ts +4 -1
  39. package/dist/map/adapter/extensions/index.d.ts.map +1 -1
  40. package/dist/map/adapter/extensions/index.js +27 -0
  41. package/dist/map/adapter/extensions/index.js.map +1 -1
  42. package/dist/map/adapter/extensions/streams.d.ts +95 -0
  43. package/dist/map/adapter/extensions/streams.d.ts.map +1 -0
  44. package/dist/map/adapter/extensions/streams.js +515 -0
  45. package/dist/map/adapter/extensions/streams.js.map +1 -0
  46. package/dist/map/adapter/index.d.ts +1 -1
  47. package/dist/map/adapter/index.d.ts.map +1 -1
  48. package/dist/map/adapter/index.js +3 -1
  49. package/dist/map/adapter/index.js.map +1 -1
  50. package/dist/map/adapter/types.d.ts +1 -1
  51. package/dist/map/adapter/types.d.ts.map +1 -1
  52. package/dist/mcp/mcp-server.d.ts +2 -0
  53. package/dist/mcp/mcp-server.d.ts.map +1 -1
  54. package/dist/mcp/mcp-server.js +12 -3
  55. package/dist/mcp/mcp-server.js.map +1 -1
  56. package/dist/mcp/tools/done.d.ts.map +1 -1
  57. package/dist/mcp/tools/done.js +18 -0
  58. package/dist/mcp/tools/done.js.map +1 -1
  59. package/dist/roles/builtin/coordinator.d.ts.map +1 -1
  60. package/dist/roles/builtin/coordinator.js +2 -1
  61. package/dist/roles/builtin/coordinator.js.map +1 -1
  62. package/dist/roles/builtin/integrator.d.ts.map +1 -1
  63. package/dist/roles/builtin/integrator.js +2 -1
  64. package/dist/roles/builtin/integrator.js.map +1 -1
  65. package/dist/roles/builtin/worker.d.ts.map +1 -1
  66. package/dist/roles/builtin/worker.js +3 -1
  67. package/dist/roles/builtin/worker.js.map +1 -1
  68. package/dist/roles/capabilities.d.ts +6 -0
  69. package/dist/roles/capabilities.d.ts.map +1 -1
  70. package/dist/roles/capabilities.js +10 -0
  71. package/dist/roles/capabilities.js.map +1 -1
  72. package/dist/roles/config-loader.d.ts +1 -1
  73. package/dist/roles/config-loader.d.ts.map +1 -1
  74. package/dist/roles/config-loader.js +3 -2
  75. package/dist/roles/config-loader.js.map +1 -1
  76. package/dist/roles/types.d.ts +3 -1
  77. package/dist/roles/types.d.ts.map +1 -1
  78. package/dist/server/combined-server.d.ts +8 -1
  79. package/dist/server/combined-server.d.ts.map +1 -1
  80. package/dist/server/combined-server.js +6 -2
  81. package/dist/server/combined-server.js.map +1 -1
  82. package/dist/store/event-store.d.ts.map +1 -1
  83. package/dist/store/event-store.js +12 -5
  84. package/dist/store/event-store.js.map +1 -1
  85. package/dist/store/instance.d.ts +1 -1
  86. package/dist/store/instance.d.ts.map +1 -1
  87. package/dist/store/instance.js +2 -2
  88. package/dist/store/instance.js.map +1 -1
  89. package/dist/store/types/agents.d.ts +5 -0
  90. package/dist/store/types/agents.d.ts.map +1 -1
  91. package/dist/task/backend/opentasks/daemon-manager.d.ts.map +1 -1
  92. package/dist/task/backend/opentasks/daemon-manager.js +1 -1
  93. package/dist/task/backend/opentasks/daemon-manager.js.map +1 -1
  94. package/dist/teams/index.d.ts +3 -1
  95. package/dist/teams/index.d.ts.map +1 -1
  96. package/dist/teams/index.js +2 -0
  97. package/dist/teams/index.js.map +1 -1
  98. package/dist/teams/seed-defaults.d.ts +20 -0
  99. package/dist/teams/seed-defaults.d.ts.map +1 -0
  100. package/dist/teams/seed-defaults.js +71 -0
  101. package/dist/teams/seed-defaults.js.map +1 -0
  102. package/dist/teams/team-loader.d.ts +6 -2
  103. package/dist/teams/team-loader.d.ts.map +1 -1
  104. package/dist/teams/team-loader.js +154 -162
  105. package/dist/teams/team-loader.js.map +1 -1
  106. package/dist/teams/team-manager.d.ts +112 -0
  107. package/dist/teams/team-manager.d.ts.map +1 -0
  108. package/dist/teams/team-manager.js +305 -0
  109. package/dist/teams/team-manager.js.map +1 -0
  110. package/dist/teams/team-runtime.d.ts +125 -19
  111. package/dist/teams/team-runtime.d.ts.map +1 -1
  112. package/dist/teams/team-runtime.js +527 -119
  113. package/dist/teams/team-runtime.js.map +1 -1
  114. package/dist/teams/types.d.ts +41 -151
  115. package/dist/teams/types.d.ts.map +1 -1
  116. package/dist/teams/types.js +2 -3
  117. package/dist/teams/types.js.map +1 -1
  118. package/docs/teams.md +73 -0
  119. package/package.json +2 -1
  120. package/references/minimem/.claude/settings.json +7 -0
  121. package/references/minimem/.sudocode/issues.jsonl +18 -0
  122. package/references/minimem/.sudocode/specs.jsonl +1 -0
  123. package/references/minimem/CLAUDE.md +310 -0
  124. package/references/minimem/README.md +562 -0
  125. package/references/minimem/claude-plugin/.claude-plugin/plugin.json +10 -0
  126. package/references/minimem/claude-plugin/.mcp.json +7 -0
  127. package/references/minimem/claude-plugin/README.md +158 -0
  128. package/references/minimem/claude-plugin/commands/recall.md +47 -0
  129. package/references/minimem/claude-plugin/commands/remember.md +41 -0
  130. package/references/minimem/claude-plugin/hooks/__tests__/hooks.test.ts +272 -0
  131. package/references/minimem/claude-plugin/hooks/hooks.json +27 -0
  132. package/references/minimem/claude-plugin/hooks/session-end.sh +86 -0
  133. package/references/minimem/claude-plugin/hooks/session-start.sh +85 -0
  134. package/references/minimem/claude-plugin/skills/memory/SKILL.md +108 -0
  135. package/references/minimem/media/banner.png +0 -0
  136. package/references/minimem/package-lock.json +5373 -0
  137. package/references/minimem/package.json +72 -0
  138. package/references/minimem/scripts/postbuild.js +35 -0
  139. package/references/minimem/src/__tests__/edge-cases.test.ts +371 -0
  140. package/references/minimem/src/__tests__/errors.test.ts +265 -0
  141. package/references/minimem/src/__tests__/helpers.ts +199 -0
  142. package/references/minimem/src/__tests__/internal.test.ts +407 -0
  143. package/references/minimem/src/__tests__/knowledge.test.ts +287 -0
  144. package/references/minimem/src/__tests__/minimem.integration.test.ts +1127 -0
  145. package/references/minimem/src/__tests__/session.test.ts +190 -0
  146. package/references/minimem/src/cli/__tests__/commands.test.ts +759 -0
  147. package/references/minimem/src/cli/commands/__tests__/conflicts.test.ts +141 -0
  148. package/references/minimem/src/cli/commands/append.ts +76 -0
  149. package/references/minimem/src/cli/commands/config.ts +262 -0
  150. package/references/minimem/src/cli/commands/conflicts.ts +413 -0
  151. package/references/minimem/src/cli/commands/daemon.ts +169 -0
  152. package/references/minimem/src/cli/commands/index.ts +12 -0
  153. package/references/minimem/src/cli/commands/init.ts +88 -0
  154. package/references/minimem/src/cli/commands/mcp.ts +177 -0
  155. package/references/minimem/src/cli/commands/push-pull.ts +213 -0
  156. package/references/minimem/src/cli/commands/search.ts +158 -0
  157. package/references/minimem/src/cli/commands/status.ts +84 -0
  158. package/references/minimem/src/cli/commands/sync-init.ts +290 -0
  159. package/references/minimem/src/cli/commands/sync.ts +70 -0
  160. package/references/minimem/src/cli/commands/upsert.ts +197 -0
  161. package/references/minimem/src/cli/config.ts +584 -0
  162. package/references/minimem/src/cli/index.ts +264 -0
  163. package/references/minimem/src/cli/shared.ts +161 -0
  164. package/references/minimem/src/cli/sync/__tests__/central.test.ts +152 -0
  165. package/references/minimem/src/cli/sync/__tests__/conflicts.test.ts +209 -0
  166. package/references/minimem/src/cli/sync/__tests__/daemon.test.ts +118 -0
  167. package/references/minimem/src/cli/sync/__tests__/detection.test.ts +207 -0
  168. package/references/minimem/src/cli/sync/__tests__/integration.test.ts +476 -0
  169. package/references/minimem/src/cli/sync/__tests__/registry.test.ts +363 -0
  170. package/references/minimem/src/cli/sync/__tests__/state.test.ts +255 -0
  171. package/references/minimem/src/cli/sync/__tests__/validation.test.ts +193 -0
  172. package/references/minimem/src/cli/sync/__tests__/watcher.test.ts +178 -0
  173. package/references/minimem/src/cli/sync/central.ts +292 -0
  174. package/references/minimem/src/cli/sync/conflicts.ts +204 -0
  175. package/references/minimem/src/cli/sync/daemon.ts +407 -0
  176. package/references/minimem/src/cli/sync/detection.ts +138 -0
  177. package/references/minimem/src/cli/sync/index.ts +107 -0
  178. package/references/minimem/src/cli/sync/operations.ts +373 -0
  179. package/references/minimem/src/cli/sync/registry.ts +279 -0
  180. package/references/minimem/src/cli/sync/state.ts +355 -0
  181. package/references/minimem/src/cli/sync/validation.ts +206 -0
  182. package/references/minimem/src/cli/sync/watcher.ts +234 -0
  183. package/references/minimem/src/cli/version.ts +34 -0
  184. package/references/minimem/src/core/index.ts +9 -0
  185. package/references/minimem/src/core/indexer.ts +628 -0
  186. package/references/minimem/src/core/searcher.ts +221 -0
  187. package/references/minimem/src/db/schema.ts +183 -0
  188. package/references/minimem/src/db/sqlite-vec.ts +24 -0
  189. package/references/minimem/src/embeddings/__tests__/embeddings.test.ts +431 -0
  190. package/references/minimem/src/embeddings/batch-gemini.ts +392 -0
  191. package/references/minimem/src/embeddings/batch-openai.ts +409 -0
  192. package/references/minimem/src/embeddings/embeddings.ts +434 -0
  193. package/references/minimem/src/index.ts +109 -0
  194. package/references/minimem/src/internal.ts +299 -0
  195. package/references/minimem/src/minimem.ts +1276 -0
  196. package/references/minimem/src/search/__tests__/hybrid.test.ts +247 -0
  197. package/references/minimem/src/search/graph.ts +234 -0
  198. package/references/minimem/src/search/hybrid.ts +151 -0
  199. package/references/minimem/src/search/search.ts +256 -0
  200. package/references/minimem/src/server/__tests__/mcp.test.ts +341 -0
  201. package/references/minimem/src/server/__tests__/tools.test.ts +364 -0
  202. package/references/minimem/src/server/mcp.ts +326 -0
  203. package/references/minimem/src/server/tools.ts +720 -0
  204. package/references/minimem/src/session.ts +460 -0
  205. package/references/minimem/tsconfig.json +19 -0
  206. package/references/minimem/tsup.config.ts +26 -0
  207. package/references/minimem/vitest.config.ts +24 -0
  208. package/references/openteams/.claude/settings.json +6 -0
  209. package/references/openteams/README.md +1 -0
  210. package/references/openteams/SKILL.md +341 -0
  211. package/references/openteams/design.md +411 -0
  212. package/references/openteams/examples/bmad-method/prompts/analyst/ROLE.md +16 -0
  213. package/references/openteams/examples/bmad-method/prompts/analyst/SOUL.md +5 -0
  214. package/references/openteams/examples/bmad-method/prompts/architect/ROLE.md +24 -0
  215. package/references/openteams/examples/bmad-method/prompts/architect/SOUL.md +5 -0
  216. package/references/openteams/examples/bmad-method/prompts/developer/ROLE.md +25 -0
  217. package/references/openteams/examples/bmad-method/prompts/developer/SOUL.md +5 -0
  218. package/references/openteams/examples/bmad-method/prompts/master/ROLE.md +21 -0
  219. package/references/openteams/examples/bmad-method/prompts/master/SOUL.md +5 -0
  220. package/references/openteams/examples/bmad-method/prompts/pm/ROLE.md +20 -0
  221. package/references/openteams/examples/bmad-method/prompts/pm/SOUL.md +5 -0
  222. package/references/openteams/examples/bmad-method/prompts/qa/ROLE.md +17 -0
  223. package/references/openteams/examples/bmad-method/prompts/qa/SOUL.md +5 -0
  224. package/references/openteams/examples/bmad-method/prompts/quick-flow-dev/ROLE.md +23 -0
  225. package/references/openteams/examples/bmad-method/prompts/quick-flow-dev/SOUL.md +5 -0
  226. package/references/openteams/examples/bmad-method/prompts/scrum-master/ROLE.md +27 -0
  227. package/references/openteams/examples/bmad-method/prompts/scrum-master/SOUL.md +5 -0
  228. package/references/openteams/examples/bmad-method/prompts/tech-writer/ROLE.md +21 -0
  229. package/references/openteams/examples/bmad-method/prompts/tech-writer/SOUL.md +5 -0
  230. package/references/openteams/examples/bmad-method/prompts/ux-designer/ROLE.md +16 -0
  231. package/references/openteams/examples/bmad-method/prompts/ux-designer/SOUL.md +5 -0
  232. package/references/openteams/examples/bmad-method/roles/analyst.yaml +9 -0
  233. package/references/openteams/examples/bmad-method/roles/architect.yaml +9 -0
  234. package/references/openteams/examples/bmad-method/roles/developer.yaml +8 -0
  235. package/references/openteams/examples/bmad-method/roles/master.yaml +8 -0
  236. package/references/openteams/examples/bmad-method/roles/pm.yaml +9 -0
  237. package/references/openteams/examples/bmad-method/roles/qa.yaml +8 -0
  238. package/references/openteams/examples/bmad-method/roles/quick-flow-dev.yaml +8 -0
  239. package/references/openteams/examples/bmad-method/roles/scrum-master.yaml +9 -0
  240. package/references/openteams/examples/bmad-method/roles/tech-writer.yaml +8 -0
  241. package/references/openteams/examples/bmad-method/roles/ux-designer.yaml +8 -0
  242. package/references/openteams/examples/bmad-method/team.yaml +161 -0
  243. package/references/openteams/examples/get-shit-done/prompts/codebase-mapper/ROLE.md +17 -0
  244. package/references/openteams/examples/get-shit-done/prompts/codebase-mapper/SOUL.md +5 -0
  245. package/references/openteams/examples/get-shit-done/prompts/debugger/ROLE.md +25 -0
  246. package/references/openteams/examples/get-shit-done/prompts/debugger/SOUL.md +5 -0
  247. package/references/openteams/examples/get-shit-done/prompts/executor/ROLE.md +34 -0
  248. package/references/openteams/examples/get-shit-done/prompts/executor/SOUL.md +5 -0
  249. package/references/openteams/examples/get-shit-done/prompts/integration-checker/ROLE.md +18 -0
  250. package/references/openteams/examples/get-shit-done/prompts/integration-checker/SOUL.md +3 -0
  251. package/references/openteams/examples/get-shit-done/prompts/orchestrator/ROLE.md +42 -0
  252. package/references/openteams/examples/get-shit-done/prompts/orchestrator/SOUL.md +5 -0
  253. package/references/openteams/examples/get-shit-done/prompts/phase-researcher/ROLE.md +15 -0
  254. package/references/openteams/examples/get-shit-done/prompts/phase-researcher/SOUL.md +3 -0
  255. package/references/openteams/examples/get-shit-done/prompts/plan-checker/ROLE.md +17 -0
  256. package/references/openteams/examples/get-shit-done/prompts/plan-checker/SOUL.md +3 -0
  257. package/references/openteams/examples/get-shit-done/prompts/planner/ROLE.md +28 -0
  258. package/references/openteams/examples/get-shit-done/prompts/planner/SOUL.md +5 -0
  259. package/references/openteams/examples/get-shit-done/prompts/project-researcher/ROLE.md +16 -0
  260. package/references/openteams/examples/get-shit-done/prompts/project-researcher/SOUL.md +3 -0
  261. package/references/openteams/examples/get-shit-done/prompts/research-synthesizer/ROLE.md +13 -0
  262. package/references/openteams/examples/get-shit-done/prompts/research-synthesizer/SOUL.md +3 -0
  263. package/references/openteams/examples/get-shit-done/prompts/roadmapper/ROLE.md +14 -0
  264. package/references/openteams/examples/get-shit-done/prompts/roadmapper/SOUL.md +3 -0
  265. package/references/openteams/examples/get-shit-done/prompts/verifier/ROLE.md +19 -0
  266. package/references/openteams/examples/get-shit-done/prompts/verifier/SOUL.md +5 -0
  267. package/references/openteams/examples/get-shit-done/roles/codebase-mapper.yaml +8 -0
  268. package/references/openteams/examples/get-shit-done/roles/debugger.yaml +8 -0
  269. package/references/openteams/examples/get-shit-done/roles/executor.yaml +8 -0
  270. package/references/openteams/examples/get-shit-done/roles/integration-checker.yaml +8 -0
  271. package/references/openteams/examples/get-shit-done/roles/orchestrator.yaml +9 -0
  272. package/references/openteams/examples/get-shit-done/roles/phase-researcher.yaml +7 -0
  273. package/references/openteams/examples/get-shit-done/roles/plan-checker.yaml +8 -0
  274. package/references/openteams/examples/get-shit-done/roles/planner.yaml +8 -0
  275. package/references/openteams/examples/get-shit-done/roles/project-researcher.yaml +8 -0
  276. package/references/openteams/examples/get-shit-done/roles/research-synthesizer.yaml +7 -0
  277. package/references/openteams/examples/get-shit-done/roles/roadmapper.yaml +7 -0
  278. package/references/openteams/examples/get-shit-done/roles/verifier.yaml +8 -0
  279. package/references/openteams/examples/get-shit-done/team.yaml +154 -0
  280. package/references/openteams/package-lock.json +2181 -0
  281. package/references/openteams/package.json +48 -0
  282. package/references/openteams/schema/role.schema.json +125 -0
  283. package/references/openteams/schema/team.schema.json +284 -0
  284. package/references/openteams/src/cli/agent.ts +104 -0
  285. package/references/openteams/src/cli/cli.test.ts +381 -0
  286. package/references/openteams/src/cli/generate.ts +220 -0
  287. package/references/openteams/src/cli/message.ts +241 -0
  288. package/references/openteams/src/cli/task.ts +154 -0
  289. package/references/openteams/src/cli/team.ts +104 -0
  290. package/references/openteams/src/cli/template.ts +207 -0
  291. package/references/openteams/src/cli.ts +45 -0
  292. package/references/openteams/src/db/database.test.ts +185 -0
  293. package/references/openteams/src/db/database.ts +240 -0
  294. package/references/openteams/src/generators/agent-prompt-generator.test.ts +332 -0
  295. package/references/openteams/src/generators/agent-prompt-generator.ts +521 -0
  296. package/references/openteams/src/generators/package-generator.test.ts +129 -0
  297. package/references/openteams/src/generators/package-generator.ts +102 -0
  298. package/references/openteams/src/generators/skill-generator.test.ts +246 -0
  299. package/references/openteams/src/generators/skill-generator.ts +374 -0
  300. package/references/openteams/src/index.ts +104 -0
  301. package/references/openteams/src/services/agent-service.test.ts +158 -0
  302. package/references/openteams/src/services/agent-service.ts +84 -0
  303. package/references/openteams/src/services/communication-service.test.ts +455 -0
  304. package/references/openteams/src/services/communication-service.ts +371 -0
  305. package/references/openteams/src/services/message-service.test.ts +342 -0
  306. package/references/openteams/src/services/message-service.ts +203 -0
  307. package/references/openteams/src/services/task-service.test.ts +434 -0
  308. package/references/openteams/src/services/task-service.ts +239 -0
  309. package/references/openteams/src/services/team-service.test.ts +181 -0
  310. package/references/openteams/src/services/team-service.ts +139 -0
  311. package/references/openteams/src/services/template-service.test.ts +306 -0
  312. package/references/openteams/src/services/template-service.ts +182 -0
  313. package/references/openteams/src/spawner/acp-factory.ts +96 -0
  314. package/references/openteams/src/spawner/interface.ts +31 -0
  315. package/references/openteams/src/spawner/mock.test.ts +93 -0
  316. package/references/openteams/src/spawner/mock.ts +59 -0
  317. package/references/openteams/src/template/loader.test.ts +1319 -0
  318. package/references/openteams/src/template/loader.ts +698 -0
  319. package/references/openteams/src/template/types.ts +200 -0
  320. package/references/openteams/src/types.ts +205 -0
  321. package/references/openteams/tsconfig.json +18 -0
  322. package/references/openteams/vitest.config.ts +9 -0
  323. package/references/skill-tree/.claude/settings.json +6 -0
  324. package/references/skill-tree/.sudocode/issues.jsonl +11 -0
  325. package/references/skill-tree/.sudocode/specs.jsonl +1 -0
  326. package/references/skill-tree/CLAUDE.md +150 -0
  327. package/references/skill-tree/README.md +324 -0
  328. package/references/skill-tree/docs/GAPS_v1.md +221 -0
  329. package/references/skill-tree/docs/INTEGRATION_PLAN.md +467 -0
  330. package/references/skill-tree/docs/TODOS.md +91 -0
  331. package/references/skill-tree/docs/anthropic_skill_guide.md +1364 -0
  332. package/references/skill-tree/docs/design/federated-skill-trees.md +524 -0
  333. package/references/skill-tree/docs/design/multi-agent-sync.md +759 -0
  334. package/references/skill-tree/docs/scraper/BRAINSTORM.md +583 -0
  335. package/references/skill-tree/docs/scraper/POC_PLAN.md +420 -0
  336. package/references/skill-tree/docs/scraper/README.md +170 -0
  337. package/references/skill-tree/examples/basic-usage.ts +190 -0
  338. package/references/skill-tree/package-lock.json +1509 -0
  339. package/references/skill-tree/package.json +66 -0
  340. package/references/skill-tree/scraper/README.md +123 -0
  341. package/references/skill-tree/scraper/docs/DESIGN.md +683 -0
  342. package/references/skill-tree/scraper/docs/PLAN.md +336 -0
  343. package/references/skill-tree/scraper/drizzle.config.ts +10 -0
  344. package/references/skill-tree/scraper/package-lock.json +6329 -0
  345. package/references/skill-tree/scraper/package.json +68 -0
  346. package/references/skill-tree/scraper/test/fixtures/invalid-skill/missing-description.md +7 -0
  347. package/references/skill-tree/scraper/test/fixtures/invalid-skill/missing-name.md +7 -0
  348. package/references/skill-tree/scraper/test/fixtures/minimal-skill/SKILL.md +27 -0
  349. package/references/skill-tree/scraper/test/fixtures/skill-json/SKILL.json +21 -0
  350. package/references/skill-tree/scraper/test/fixtures/skill-with-meta/SKILL.md +54 -0
  351. package/references/skill-tree/scraper/test/fixtures/skill-with-meta/_meta.json +24 -0
  352. package/references/skill-tree/scraper/test/fixtures/valid-skill/SKILL.md +93 -0
  353. package/references/skill-tree/scraper/test/fixtures/valid-skill/_meta.json +22 -0
  354. package/references/skill-tree/scraper/tsup.config.ts +14 -0
  355. package/references/skill-tree/scraper/vitest.config.ts +17 -0
  356. package/references/skill-tree/scripts/convert-to-vitest.ts +166 -0
  357. package/references/skill-tree/skills/skill-writer/SKILL.md +339 -0
  358. package/references/skill-tree/skills/skill-writer/references/examples.md +326 -0
  359. package/references/skill-tree/skills/skill-writer/references/patterns.md +210 -0
  360. package/references/skill-tree/skills/skill-writer/references/quality-checklist.md +123 -0
  361. package/references/skill-tree/test/run-all.ts +106 -0
  362. package/references/skill-tree/test/utils.ts +128 -0
  363. package/references/skill-tree/vitest.config.ts +16 -0
  364. package/src/agent/agent-manager.ts +143 -72
  365. package/src/agent/types.ts +9 -0
  366. package/src/api/__tests__/server.test.ts +203 -4
  367. package/src/api/server.ts +130 -5
  368. package/src/api/types.ts +3 -1
  369. package/src/cli/acp.ts +68 -1
  370. package/src/cli/index.ts +5 -1
  371. package/src/cli/mcp.ts +27 -13
  372. package/src/config/project-config.ts +27 -3
  373. package/src/index.ts +3 -0
  374. package/src/lifecycle/__tests__/handlers.test.ts +53 -0
  375. package/src/lifecycle/handlers/index.ts +25 -8
  376. package/src/lifecycle/types.ts +3 -0
  377. package/src/map/adapter/__tests__/stream-extensions.test.ts +494 -0
  378. package/src/map/adapter/extensions/index.ts +36 -0
  379. package/src/map/adapter/extensions/streams.ts +839 -0
  380. package/src/map/adapter/index.ts +5 -0
  381. package/src/map/adapter/types.ts +8 -1
  382. package/src/mcp/mcp-server.ts +14 -3
  383. package/src/mcp/tools/done.ts +19 -0
  384. package/src/roles/builtin/coordinator.ts +2 -0
  385. package/src/roles/builtin/integrator.ts +2 -0
  386. package/src/roles/builtin/worker.ts +3 -0
  387. package/src/roles/capabilities.ts +11 -0
  388. package/src/roles/config-loader.ts +3 -2
  389. package/src/roles/types.ts +7 -0
  390. package/src/server/combined-server.ts +15 -1
  391. package/src/store/__tests__/event-store-oob.test.ts +109 -0
  392. package/src/store/event-store.ts +13 -3
  393. package/src/store/instance.ts +2 -2
  394. package/src/store/types/agents.ts +5 -0
  395. package/src/task/backend/__tests__/memory-pull-mode.test.ts +153 -0
  396. package/src/task/backend/opentasks/daemon-manager.ts +4 -1
  397. package/src/teams/CLAUDE.md +180 -0
  398. package/src/teams/__tests__/e2e/workspace-isolation.e2e.test.ts +1263 -0
  399. package/src/teams/__tests__/team-manager.test.ts +814 -0
  400. package/src/teams/__tests__/team-system.test.ts +1291 -8
  401. package/src/teams/index.ts +21 -3
  402. package/src/teams/seed-defaults.ts +79 -0
  403. package/src/teams/team-loader.ts +200 -234
  404. package/src/teams/team-manager.ts +387 -0
  405. package/src/teams/team-runtime.ts +590 -121
  406. package/src/teams/types.ts +99 -200
@@ -0,0 +1,494 @@
1
+ /**
2
+ * Tests for Stream/Checkpoint/DiffStack/MergeQueue Extension Methods
3
+ *
4
+ * Tests the handlers using mock services.
5
+ */
6
+
7
+ import { describe, it, expect, beforeEach, vi } from "vitest";
8
+ import {
9
+ registerStreamExtensions,
10
+ unregisterStreamExtensions,
11
+ STREAM_EXTENSION_METHODS,
12
+ type StreamExtensionServices,
13
+ } from "../extensions/streams.js";
14
+ import type { MAPAdapter, ExtensionHandler, ExtensionContext } from "../interface.js";
15
+ import type { Stream, StreamNode, Checkpoint, DiffStack, DiffStackWithCheckpoints } from "git-cascade";
16
+ import type { MergeRequest } from "../../../workspace/merge-queue/types.js";
17
+
18
+ // =============================================================================
19
+ // Mock Setup
20
+ // =============================================================================
21
+
22
+ function createMockAdapter(): MAPAdapter & {
23
+ handlers: Map<string, ExtensionHandler>;
24
+ } {
25
+ const handlers = new Map<string, ExtensionHandler>();
26
+
27
+ return {
28
+ handlers,
29
+ registerExtension: vi.fn((method: string, handler: ExtensionHandler) => {
30
+ handlers.set(method, handler);
31
+ }),
32
+ unregisterExtension: vi.fn((method: string) => {
33
+ handlers.delete(method);
34
+ }),
35
+ hasExtension: vi.fn((method: string) => handlers.has(method)),
36
+ getExtensions: vi.fn(() => Array.from(handlers.keys())),
37
+ start: vi.fn(),
38
+ stop: vi.fn(),
39
+ isRunning: vi.fn().mockReturnValue(true),
40
+ acceptConnection: vi.fn(),
41
+ disconnectParticipant: vi.fn(),
42
+ getParticipant: vi.fn(),
43
+ getParticipants: vi.fn().mockReturnValue([]),
44
+ createSubscription: vi.fn(),
45
+ removeSubscription: vi.fn(),
46
+ pauseSubscription: vi.fn(),
47
+ resumeSubscription: vi.fn(),
48
+ getSubscriptions: vi.fn().mockReturnValue([]),
49
+ sendMessage: vi.fn(),
50
+ listAgents: vi.fn().mockReturnValue([]),
51
+ getAgent: vi.fn(),
52
+ listScopes: vi.fn().mockReturnValue([]),
53
+ getScope: vi.fn(),
54
+ emitEvent: vi.fn(),
55
+ onEvent: vi.fn().mockReturnValue(() => {}),
56
+ config: {},
57
+ } as unknown as MAPAdapter & { handlers: Map<string, ExtensionHandler> };
58
+ }
59
+
60
+ function createMockContext(participantId = "test-participant"): ExtensionContext {
61
+ return {
62
+ participantId,
63
+ capabilities: { canQuery: true, canMessage: true, canManageTasks: true } as any,
64
+ sessionId: "test-session",
65
+ };
66
+ }
67
+
68
+ // Sample data
69
+ const mockStream: Stream = {
70
+ id: "stream-1",
71
+ name: "main-integration",
72
+ agentId: "agent-1",
73
+ baseCommit: "abc123",
74
+ parentStream: null,
75
+ branchPointCommit: null,
76
+ status: "active",
77
+ createdAt: 1000,
78
+ updatedAt: 2000,
79
+ mergedInto: null,
80
+ enableStackedReview: false,
81
+ metadata: {},
82
+ existingBranch: null,
83
+ isLocalMode: false,
84
+ };
85
+
86
+ const mockChildStream: Stream = {
87
+ ...mockStream,
88
+ id: "stream-2",
89
+ name: "feature-branch",
90
+ parentStream: "stream-1",
91
+ };
92
+
93
+ const mockCheckpoint: Checkpoint = {
94
+ id: "cp-1",
95
+ streamId: "stream-1",
96
+ commitSha: "abcdef1234567890",
97
+ parentCommit: "0000000000000000",
98
+ originalCommit: null,
99
+ changeId: "change-1",
100
+ message: "Added login feature",
101
+ createdAt: 3000,
102
+ createdBy: "agent-1",
103
+ };
104
+
105
+ const mockDiffStack: DiffStack = {
106
+ id: "ds-1",
107
+ name: "login-stack",
108
+ description: "Login feature stack",
109
+ targetBranch: "main",
110
+ reviewStatus: "pending",
111
+ reviewedBy: null,
112
+ reviewedAt: null,
113
+ reviewNotes: null,
114
+ queuePosition: null,
115
+ createdAt: 4000,
116
+ createdBy: "agent-1",
117
+ };
118
+
119
+ const mockDiffStackWithCps: DiffStackWithCheckpoints = {
120
+ ...mockDiffStack,
121
+ checkpoints: [{ ...mockCheckpoint, position: 0 }] as any,
122
+ };
123
+
124
+ const mockMergeRequest: MergeRequest = {
125
+ id: "mr-1",
126
+ streamId: "stream-1",
127
+ taskId: "task-1",
128
+ workerBranch: "worker/agent-1/task-1",
129
+ workerAgentId: "agent-1",
130
+ status: "pending",
131
+ priority: 0,
132
+ position: 1,
133
+ submittedAt: 5000,
134
+ startedAt: null,
135
+ completedAt: null,
136
+ mergeCommit: null,
137
+ conflictFiles: null,
138
+ resolverTaskId: null,
139
+ metadata: null,
140
+ };
141
+
142
+ function createMockServices(): StreamExtensionServices {
143
+ return {
144
+ getStream: vi.fn((id: string) => (id === "stream-1" ? mockStream : id === "stream-2" ? mockChildStream : null)),
145
+ listStreams: vi.fn(() => [mockStream, mockChildStream]),
146
+ getStreamBranchName: vi.fn((id: string) => `stream/${id}`),
147
+ getStreamHierarchy: vi.fn(() => [
148
+ {
149
+ stream: mockStream,
150
+ children: [{ stream: mockChildStream, children: [], tasks: [] }],
151
+ tasks: [],
152
+ } as StreamNode,
153
+ ]),
154
+ getCheckpoint: vi.fn((id: string) => (id === "cp-1" ? mockCheckpoint : null)),
155
+ getCheckpointsForStream: vi.fn((streamId: string) =>
156
+ streamId === "stream-1" ? [mockCheckpoint] : [],
157
+ ),
158
+ forkFromCheckpoint: vi.fn(() => "stream-3"),
159
+ getDiffStack: vi.fn((id: string) => (id === "ds-1" ? mockDiffStack : null)),
160
+ getDiffStackWithCheckpoints: vi.fn((id: string) =>
161
+ id === "ds-1" ? mockDiffStackWithCps : null,
162
+ ),
163
+ listDiffStacks: vi.fn(() => [mockDiffStack]),
164
+ createDiffStack: vi.fn(() => mockDiffStack),
165
+ addCheckpointToStack: vi.fn(),
166
+ getMergeQueueRequests: vi.fn(() => [mockMergeRequest]),
167
+ getMergeQueueDepth: vi.fn(() => 1),
168
+ getMergeRequest: vi.fn((id: string) => (id === "mr-1" ? mockMergeRequest : null)),
169
+ createPR: vi.fn(async () => ({ prUrl: "https://github.com/test/repo/pull/1", prNumber: 1 })),
170
+ };
171
+ }
172
+
173
+ // =============================================================================
174
+ // Tests
175
+ // =============================================================================
176
+
177
+ describe("Stream Extensions", () => {
178
+ let adapter: ReturnType<typeof createMockAdapter>;
179
+ let services: ReturnType<typeof createMockServices>;
180
+ let context: ExtensionContext;
181
+
182
+ beforeEach(() => {
183
+ adapter = createMockAdapter();
184
+ services = createMockServices();
185
+ context = createMockContext();
186
+ registerStreamExtensions(adapter, services);
187
+ });
188
+
189
+ describe("registration", () => {
190
+ it("registers all extension methods", () => {
191
+ for (const method of STREAM_EXTENSION_METHODS) {
192
+ expect(adapter.handlers.has(method)).toBe(true);
193
+ }
194
+ });
195
+
196
+ it("registers exactly 13 methods", () => {
197
+ expect(adapter.handlers.size).toBe(13);
198
+ });
199
+
200
+ it("unregisters all methods", () => {
201
+ unregisterStreamExtensions(adapter);
202
+ expect(adapter.unregisterExtension).toHaveBeenCalledTimes(13);
203
+ });
204
+ });
205
+
206
+ describe("_macro/streams/list", () => {
207
+ it("returns all streams", async () => {
208
+ const handler = adapter.handlers.get("_macro/streams/list")!;
209
+ const result = (await handler(context, {})) as any;
210
+
211
+ expect(result.streams).toHaveLength(2);
212
+ expect(result.streams[0].id).toBe("stream-1");
213
+ expect(result.streams[0].branchName).toBe("stream/stream-1");
214
+ expect(result.streams[0].checkpointCount).toBe(1);
215
+ });
216
+
217
+ it("filters by status", async () => {
218
+ const handler = adapter.handlers.get("_macro/streams/list")!;
219
+ await handler(context, { filter: { status: "active" } });
220
+
221
+ expect(services.listStreams).toHaveBeenCalledWith({ agentId: undefined, status: "active" });
222
+ });
223
+
224
+ it("filters by parentStream", async () => {
225
+ const handler = adapter.handlers.get("_macro/streams/list")!;
226
+ const result = (await handler(context, { filter: { parentStream: "stream-1" } })) as any;
227
+
228
+ // Only stream-2 has parentStream === "stream-1"
229
+ expect(result.streams).toHaveLength(1);
230
+ expect(result.streams[0].id).toBe("stream-2");
231
+ });
232
+ });
233
+
234
+ describe("_macro/streams/get", () => {
235
+ it("returns stream info", async () => {
236
+ const handler = adapter.handlers.get("_macro/streams/get")!;
237
+ const result = (await handler(context, { streamId: "stream-1" })) as any;
238
+
239
+ expect(result.stream.id).toBe("stream-1");
240
+ expect(result.stream.name).toBe("main-integration");
241
+ expect(result.stream.status).toBe("active");
242
+ });
243
+
244
+ it("throws on missing streamId", async () => {
245
+ const handler = adapter.handlers.get("_macro/streams/get")!;
246
+ await expect(handler(context, {})).rejects.toThrow("streamId is required");
247
+ });
248
+
249
+ it("throws on stream not found", async () => {
250
+ const handler = adapter.handlers.get("_macro/streams/get")!;
251
+ await expect(handler(context, { streamId: "nonexistent" })).rejects.toThrow(
252
+ "Stream not found",
253
+ );
254
+ });
255
+
256
+ it("includes children when requested", async () => {
257
+ const handler = adapter.handlers.get("_macro/streams/get")!;
258
+ const result = (await handler(context, {
259
+ streamId: "stream-1",
260
+ includeChildren: true,
261
+ })) as any;
262
+
263
+ expect(result.stream.id).toBe("stream-1");
264
+ expect(result.children).toBeDefined();
265
+ });
266
+ });
267
+
268
+ describe("_macro/streams/hierarchy", () => {
269
+ it("returns stream tree", async () => {
270
+ const handler = adapter.handlers.get("_macro/streams/hierarchy")!;
271
+ const result = (await handler(context, {})) as any;
272
+
273
+ expect(result.roots).toHaveLength(1);
274
+ expect(result.roots[0].stream.id).toBe("stream-1");
275
+ expect(result.roots[0].children).toHaveLength(1);
276
+ expect(result.roots[0].children[0].stream.id).toBe("stream-2");
277
+ });
278
+ });
279
+
280
+ describe("_macro/streams/createPR", () => {
281
+ it("creates PR for stream", async () => {
282
+ const handler = adapter.handlers.get("_macro/streams/createPR")!;
283
+ const result = (await handler(context, {
284
+ streamId: "stream-1",
285
+ title: "My PR",
286
+ draft: true,
287
+ })) as any;
288
+
289
+ expect(result.prUrl).toBe("https://github.com/test/repo/pull/1");
290
+ expect(services.createPR).toHaveBeenCalledWith({
291
+ branch: "stream/stream-1",
292
+ targetBranch: "main",
293
+ title: "My PR",
294
+ body: undefined,
295
+ draft: true,
296
+ });
297
+ });
298
+
299
+ it("throws on missing streamId", async () => {
300
+ const handler = adapter.handlers.get("_macro/streams/createPR")!;
301
+ await expect(handler(context, {})).rejects.toThrow("streamId is required");
302
+ });
303
+ });
304
+
305
+ describe("_macro/checkpoints/list", () => {
306
+ it("returns checkpoints for stream", async () => {
307
+ const handler = adapter.handlers.get("_macro/checkpoints/list")!;
308
+ const result = (await handler(context, { streamId: "stream-1" })) as any;
309
+
310
+ expect(result.checkpoints).toHaveLength(1);
311
+ expect(result.checkpoints[0].id).toBe("cp-1");
312
+ expect(result.checkpoints[0].commitShaShort).toBe("abcdef12");
313
+ });
314
+
315
+ it("throws on missing streamId", async () => {
316
+ const handler = adapter.handlers.get("_macro/checkpoints/list")!;
317
+ await expect(handler(context, {})).rejects.toThrow("streamId is required");
318
+ });
319
+
320
+ it("throws on stream not found", async () => {
321
+ const handler = adapter.handlers.get("_macro/checkpoints/list")!;
322
+ await expect(handler(context, { streamId: "nonexistent" })).rejects.toThrow(
323
+ "Stream not found",
324
+ );
325
+ });
326
+ });
327
+
328
+ describe("_macro/checkpoints/get", () => {
329
+ it("returns checkpoint info", async () => {
330
+ const handler = adapter.handlers.get("_macro/checkpoints/get")!;
331
+ const result = (await handler(context, { checkpointId: "cp-1" })) as any;
332
+
333
+ expect(result.checkpoint.id).toBe("cp-1");
334
+ expect(result.checkpoint.message).toBe("Added login feature");
335
+ });
336
+
337
+ it("throws on checkpoint not found", async () => {
338
+ const handler = adapter.handlers.get("_macro/checkpoints/get")!;
339
+ await expect(handler(context, { checkpointId: "nonexistent" })).rejects.toThrow(
340
+ "Checkpoint not found",
341
+ );
342
+ });
343
+ });
344
+
345
+ describe("_macro/checkpoints/select", () => {
346
+ it("forks from checkpoint", async () => {
347
+ const handler = adapter.handlers.get("_macro/checkpoints/select")!;
348
+ const result = (await handler(context, {
349
+ streamId: "stream-1",
350
+ checkpointId: "cp-1",
351
+ })) as any;
352
+
353
+ expect(result.success).toBe(true);
354
+ expect(result.newStreamId).toBe("stream-3");
355
+ expect(result.commitSha).toBe("abcdef1234567890");
356
+ expect(services.forkFromCheckpoint).toHaveBeenCalledWith({
357
+ checkpointId: "cp-1",
358
+ name: "fork-from-cp-1",
359
+ agentId: "external:test-participant",
360
+ });
361
+ });
362
+
363
+ it("throws when checkpoint does not belong to stream", async () => {
364
+ // cp-1 belongs to stream-1, not stream-2
365
+ const handler = adapter.handlers.get("_macro/checkpoints/select")!;
366
+ await expect(
367
+ handler(context, { streamId: "stream-2", checkpointId: "cp-1" }),
368
+ ).rejects.toThrow("does not belong to stream");
369
+ });
370
+ });
371
+
372
+ describe("_macro/diffStacks/list", () => {
373
+ it("returns diff stacks", async () => {
374
+ const handler = adapter.handlers.get("_macro/diffStacks/list")!;
375
+ const result = (await handler(context, {})) as any;
376
+
377
+ expect(result.diffStacks).toHaveLength(1);
378
+ expect(result.diffStacks[0].id).toBe("ds-1");
379
+ expect(result.diffStacks[0].name).toBe("login-stack");
380
+ });
381
+ });
382
+
383
+ describe("_macro/diffStacks/get", () => {
384
+ it("returns diff stack with checkpoints", async () => {
385
+ const handler = adapter.handlers.get("_macro/diffStacks/get")!;
386
+ const result = (await handler(context, { diffStackId: "ds-1" })) as any;
387
+
388
+ expect(result.diffStack.id).toBe("ds-1");
389
+ expect(result.checkpoints).toHaveLength(1);
390
+ expect(result.checkpoints[0].id).toBe("cp-1");
391
+ });
392
+
393
+ it("throws on not found", async () => {
394
+ const handler = adapter.handlers.get("_macro/diffStacks/get")!;
395
+ await expect(handler(context, { diffStackId: "nonexistent" })).rejects.toThrow(
396
+ "DiffStack not found",
397
+ );
398
+ });
399
+ });
400
+
401
+ describe("_macro/diffStacks/create", () => {
402
+ it("creates diff stack with checkpoints", async () => {
403
+ const handler = adapter.handlers.get("_macro/diffStacks/create")!;
404
+ const result = (await handler(context, {
405
+ name: "new-stack",
406
+ streamId: "stream-1",
407
+ checkpointIds: ["cp-1"],
408
+ targetBranch: "main",
409
+ description: "Test stack",
410
+ })) as any;
411
+
412
+ expect(result.diffStack.id).toBe("ds-1");
413
+ expect(services.createDiffStack).toHaveBeenCalledWith({
414
+ name: "new-stack",
415
+ targetBranch: "main",
416
+ description: "Test stack",
417
+ createdBy: "external:test-participant",
418
+ });
419
+ expect(services.addCheckpointToStack).toHaveBeenCalledWith({
420
+ stackId: "ds-1",
421
+ checkpointId: "cp-1",
422
+ position: 0,
423
+ });
424
+ });
425
+
426
+ it("throws on empty checkpointIds", async () => {
427
+ const handler = adapter.handlers.get("_macro/diffStacks/create")!;
428
+ await expect(
429
+ handler(context, {
430
+ name: "stack",
431
+ checkpointIds: [],
432
+ targetBranch: "main",
433
+ }),
434
+ ).rejects.toThrow("checkpointIds is required");
435
+ });
436
+ });
437
+
438
+ describe("_macro/diffStacks/createPR", () => {
439
+ it("creates PR from diff stack", async () => {
440
+ const handler = adapter.handlers.get("_macro/diffStacks/createPR")!;
441
+ const result = (await handler(context, {
442
+ diffStackId: "ds-1",
443
+ title: "PR from stack",
444
+ draft: false,
445
+ })) as any;
446
+
447
+ expect(result.prUrl).toBe("https://github.com/test/repo/pull/1");
448
+ expect(services.createPR).toHaveBeenCalledWith({
449
+ branch: "stream/stream-1",
450
+ targetBranch: "main",
451
+ title: "PR from stack",
452
+ body: undefined,
453
+ draft: false,
454
+ });
455
+ });
456
+ });
457
+
458
+ describe("_macro/mergeQueue/status", () => {
459
+ it("returns merge queue status", async () => {
460
+ const handler = adapter.handlers.get("_macro/mergeQueue/status")!;
461
+ const result = (await handler(context, {})) as any;
462
+
463
+ expect(result.queueDepth).toBe(1);
464
+ expect(result.requests).toHaveLength(1);
465
+ expect(result.requests[0].id).toBe("mr-1");
466
+ expect(result.requests[0].status).toBe("pending");
467
+ });
468
+
469
+ it("filters by streamId", async () => {
470
+ const handler = adapter.handlers.get("_macro/mergeQueue/status")!;
471
+ await handler(context, { streamId: "stream-1" });
472
+
473
+ expect(services.getMergeQueueRequests).toHaveBeenCalledWith("stream-1");
474
+ expect(services.getMergeQueueDepth).toHaveBeenCalledWith("stream-1");
475
+ });
476
+ });
477
+
478
+ describe("_macro/mergeQueue/get", () => {
479
+ it("returns merge request", async () => {
480
+ const handler = adapter.handlers.get("_macro/mergeQueue/get")!;
481
+ const result = (await handler(context, { requestId: "mr-1" })) as any;
482
+
483
+ expect(result.request.id).toBe("mr-1");
484
+ expect(result.request.workerAgentId).toBe("agent-1");
485
+ });
486
+
487
+ it("throws on not found", async () => {
488
+ const handler = adapter.handlers.get("_macro/mergeQueue/get")!;
489
+ await expect(handler(context, { requestId: "nonexistent" })).rejects.toThrow(
490
+ "Merge request not found",
491
+ );
492
+ });
493
+ });
494
+ });
@@ -75,6 +75,14 @@ export {
75
75
  type AgentLifecycleExtensionServices,
76
76
  } from "./agent-lifecycle.js";
77
77
 
78
+ // Stream/checkpoint/diffStack/mergeQueue extensions
79
+ export {
80
+ registerStreamExtensions,
81
+ unregisterStreamExtensions,
82
+ STREAM_EXTENSION_METHODS,
83
+ type StreamExtensionServices,
84
+ } from "./streams.js";
85
+
78
86
  import type { MAPAdapter } from "../interface.js";
79
87
  import type { TaskExtensionServices } from "./task.js";
80
88
  import type { WakeExtensionServices } from "./wake.js";
@@ -85,6 +93,7 @@ import type { AgentDetectionExtensionServices } from "./agent-detection.js";
85
93
  import type { UpdateMetadataExtensionServices } from "./update-metadata.js";
86
94
  import type { MCPBridgeServices } from "./mcp-bridge.js";
87
95
  import type { AgentLifecycleExtensionServices } from "./agent-lifecycle.js";
96
+ import type { StreamExtensionServices } from "./streams.js";
88
97
  import { registerTaskExtensions } from "./task.js";
89
98
  import { registerWakeExtension } from "./wake.js";
90
99
  import { registerWorkspaceExtension } from "./workspace.js";
@@ -94,6 +103,7 @@ import { registerAgentDetectionExtensions } from "./agent-detection.js";
94
103
  import { registerUpdateMetadataExtension } from "./update-metadata.js";
95
104
  import { registerMCPBridgeExtensions, unregisterMCPBridgeExtensions, MCP_BRIDGE_METHODS } from "./mcp-bridge.js";
96
105
  import { registerAgentLifecycleExtensions, unregisterAgentLifecycleExtensions, AGENT_LIFECYCLE_METHODS } from "./agent-lifecycle.js";
106
+ import { registerStreamExtensions, unregisterStreamExtensions, STREAM_EXTENSION_METHODS } from "./streams.js";
97
107
 
98
108
  // =============================================================================
99
109
  // Combined Registration
@@ -112,6 +122,7 @@ export interface MacroExtensionServices {
112
122
  updateMetadata?: UpdateMetadataExtensionServices;
113
123
  mcpBridge?: MCPBridgeServices;
114
124
  agentLifecycle?: AgentLifecycleExtensionServices;
125
+ streams?: StreamExtensionServices;
115
126
  }
116
127
 
117
128
  /**
@@ -184,6 +195,10 @@ export function registerMacroExtensions(
184
195
  if (services.agentLifecycle) {
185
196
  registerAgentLifecycleExtensions(adapter, services.agentLifecycle);
186
197
  }
198
+
199
+ if (services.streams) {
200
+ registerStreamExtensions(adapter, services.streams);
201
+ }
187
202
  }
188
203
 
189
204
  /**
@@ -216,6 +231,8 @@ export function unregisterMacroExtensions(adapter: MAPAdapter): void {
216
231
  unregisterMCPBridgeExtensions(adapter);
217
232
  // Also unregister agent lifecycle extensions
218
233
  unregisterAgentLifecycleExtensions(adapter);
234
+ // Also unregister stream/checkpoint/diffStack/mergeQueue extensions
235
+ unregisterStreamExtensions(adapter);
219
236
  }
220
237
 
221
238
  // =============================================================================
@@ -252,6 +269,8 @@ export const MACRO_EXTENSION_METHODS = [
252
269
  ...MCP_BRIDGE_METHODS,
253
270
  // Agent lifecycle extensions
254
271
  ...AGENT_LIFECYCLE_METHODS,
272
+ // Stream/checkpoint/diffStack/mergeQueue extensions
273
+ ...STREAM_EXTENSION_METHODS,
255
274
  ] as const;
256
275
 
257
276
  /**
@@ -277,4 +296,21 @@ export const EXTENSION_CAPABILITIES: Record<string, string> = {
277
296
  "_macro/forkAgent": "canManageLifecycle",
278
297
  "_macro/setPermissionMode": "canManageLifecycle",
279
298
  "_macro/respondToPermission": "canManageLifecycle",
299
+ // Stream extensions
300
+ "_macro/streams/list": "canQuery",
301
+ "_macro/streams/get": "canQuery",
302
+ "_macro/streams/hierarchy": "canQuery",
303
+ "_macro/streams/createPR": "canManageTasks",
304
+ // Checkpoint extensions
305
+ "_macro/checkpoints/list": "canQuery",
306
+ "_macro/checkpoints/get": "canQuery",
307
+ "_macro/checkpoints/select": "canManageTasks",
308
+ // DiffStack extensions
309
+ "_macro/diffStacks/list": "canQuery",
310
+ "_macro/diffStacks/get": "canQuery",
311
+ "_macro/diffStacks/create": "canManageTasks",
312
+ "_macro/diffStacks/createPR": "canManageTasks",
313
+ // MergeQueue extensions
314
+ "_macro/mergeQueue/status": "canQuery",
315
+ "_macro/mergeQueue/get": "canQuery",
280
316
  };