agent-relay 2.0.28 → 2.0.32

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 (894) hide show
  1. package/README.md +19 -0
  2. package/dist/index.cjs +85691 -0
  3. package/dist/src/bridge/index.d.ts.map +1 -0
  4. package/dist/src/bridge/index.js.map +1 -0
  5. package/dist/src/cli/commands/doctor.d.ts +2 -0
  6. package/dist/src/cli/commands/doctor.d.ts.map +1 -0
  7. package/dist/src/cli/commands/doctor.js +451 -0
  8. package/dist/src/cli/commands/doctor.js.map +1 -0
  9. package/dist/src/cli/index.d.ts.map +1 -0
  10. package/dist/src/cli/index.js +29 -1
  11. package/dist/src/cli/index.js.map +1 -0
  12. package/dist/src/config/relay-config.d.ts.map +1 -0
  13. package/dist/src/config/relay-config.js.map +1 -0
  14. package/dist/src/continuity/index.d.ts.map +1 -0
  15. package/dist/src/continuity/index.js.map +1 -0
  16. package/dist/src/daemon/index.d.ts.map +1 -0
  17. package/dist/src/daemon/index.js.map +1 -0
  18. package/dist/src/health-worker-manager.d.ts.map +1 -0
  19. package/dist/src/health-worker-manager.js.map +1 -0
  20. package/dist/src/health-worker.d.ts.map +1 -0
  21. package/dist/src/health-worker.js.map +1 -0
  22. package/dist/src/hooks/index.d.ts.map +1 -0
  23. package/dist/src/hooks/index.js.map +1 -0
  24. package/dist/src/index.d.ts.map +1 -0
  25. package/dist/src/index.js.map +1 -0
  26. package/dist/src/memory/index.d.ts.map +1 -0
  27. package/dist/src/memory/index.js.map +1 -0
  28. package/dist/src/policy/index.d.ts.map +1 -0
  29. package/dist/src/policy/index.js.map +1 -0
  30. package/dist/src/protocol/index.d.ts.map +1 -0
  31. package/dist/src/protocol/index.js.map +1 -0
  32. package/dist/src/resiliency/index.d.ts.map +1 -0
  33. package/dist/src/resiliency/index.js.map +1 -0
  34. package/dist/src/shared/cli-auth-config.d.ts.map +1 -0
  35. package/dist/src/shared/cli-auth-config.js.map +1 -0
  36. package/dist/src/state/index.d.ts.map +1 -0
  37. package/dist/src/state/index.js.map +1 -0
  38. package/dist/src/storage/index.d.ts.map +1 -0
  39. package/dist/src/storage/index.js.map +1 -0
  40. package/dist/src/trajectory/index.d.ts.map +1 -0
  41. package/dist/src/trajectory/index.js.map +1 -0
  42. package/dist/src/utils/index.d.ts.map +1 -0
  43. package/dist/src/utils/index.js.map +1 -0
  44. package/dist/src/wrapper/index.d.ts.map +1 -0
  45. package/dist/src/wrapper/index.js.map +1 -0
  46. package/package.json +83 -20
  47. package/packages/api-types/dist/index.d.ts.map +1 -0
  48. package/packages/api-types/dist/index.js.map +1 -0
  49. package/packages/api-types/dist/schemas/agent.d.ts.map +1 -0
  50. package/packages/api-types/dist/schemas/agent.js.map +1 -0
  51. package/packages/api-types/dist/schemas/api.d.ts.map +1 -0
  52. package/packages/api-types/dist/schemas/api.js.map +1 -0
  53. package/packages/api-types/dist/schemas/decision.d.ts.map +1 -0
  54. package/packages/api-types/dist/schemas/decision.js.map +1 -0
  55. package/packages/api-types/dist/schemas/fleet.d.ts.map +1 -0
  56. package/packages/api-types/dist/schemas/fleet.js.map +1 -0
  57. package/packages/api-types/dist/schemas/history.d.ts.map +1 -0
  58. package/packages/api-types/dist/schemas/history.js.map +1 -0
  59. package/packages/api-types/dist/schemas/index.d.ts.map +1 -0
  60. package/packages/api-types/dist/schemas/index.js.map +1 -0
  61. package/packages/api-types/dist/schemas/message.d.ts.map +1 -0
  62. package/packages/api-types/dist/schemas/message.js.map +1 -0
  63. package/packages/api-types/dist/schemas/session.d.ts.map +1 -0
  64. package/packages/api-types/dist/schemas/session.js.map +1 -0
  65. package/packages/api-types/dist/schemas/task.d.ts.map +1 -0
  66. package/packages/api-types/dist/schemas/task.js.map +1 -0
  67. package/packages/api-types/package.json +1 -1
  68. package/packages/api-types/src/index.ts +22 -0
  69. package/packages/api-types/src/schemas/agent.test.ts +164 -0
  70. package/packages/api-types/src/schemas/agent.ts +110 -0
  71. package/packages/api-types/src/schemas/api.test.ts +372 -0
  72. package/packages/api-types/src/schemas/api.ts +194 -0
  73. package/packages/api-types/src/schemas/decision.test.ts +324 -0
  74. package/packages/api-types/src/schemas/decision.ts +136 -0
  75. package/packages/api-types/src/schemas/fleet.test.ts +212 -0
  76. package/packages/api-types/src/schemas/fleet.ts +83 -0
  77. package/packages/api-types/src/schemas/history.test.ts +242 -0
  78. package/packages/api-types/src/schemas/history.ts +84 -0
  79. package/packages/api-types/src/schemas/index.ts +148 -0
  80. package/packages/api-types/src/schemas/message.test.ts +192 -0
  81. package/packages/api-types/src/schemas/message.ts +98 -0
  82. package/packages/api-types/src/schemas/session.test.ts +104 -0
  83. package/packages/api-types/src/schemas/session.ts +40 -0
  84. package/packages/api-types/src/schemas/task.test.ts +192 -0
  85. package/packages/api-types/src/schemas/task.ts +78 -0
  86. package/packages/api-types/tsconfig.json +19 -0
  87. package/packages/api-types/vitest.config.ts +9 -0
  88. package/packages/benchmark/README.md +200 -0
  89. package/packages/benchmark/datasets/coding-tasks.yaml +127 -0
  90. package/packages/benchmark/datasets/coordination-tasks.yaml +122 -0
  91. package/packages/benchmark/dist/benchmark.d.ts +47 -0
  92. package/packages/benchmark/dist/benchmark.d.ts.map +1 -0
  93. package/packages/benchmark/dist/benchmark.js +224 -0
  94. package/packages/benchmark/dist/benchmark.js.map +1 -0
  95. package/packages/benchmark/dist/cli.d.ts +8 -0
  96. package/packages/benchmark/dist/cli.d.ts.map +1 -0
  97. package/packages/benchmark/dist/cli.js +185 -0
  98. package/packages/benchmark/dist/cli.js.map +1 -0
  99. package/packages/benchmark/dist/harbor.d.ts +53 -0
  100. package/packages/benchmark/dist/harbor.d.ts.map +1 -0
  101. package/packages/benchmark/dist/harbor.js +127 -0
  102. package/packages/benchmark/dist/harbor.js.map +1 -0
  103. package/packages/benchmark/dist/index.d.ts +48 -0
  104. package/packages/benchmark/dist/index.d.ts.map +1 -0
  105. package/packages/benchmark/dist/index.js +50 -0
  106. package/packages/benchmark/dist/index.js.map +1 -0
  107. package/packages/benchmark/dist/runners/base.d.ts +63 -0
  108. package/packages/benchmark/dist/runners/base.d.ts.map +1 -0
  109. package/packages/benchmark/dist/runners/base.js +155 -0
  110. package/packages/benchmark/dist/runners/base.js.map +1 -0
  111. package/packages/benchmark/dist/runners/index.d.ts +10 -0
  112. package/packages/benchmark/dist/runners/index.d.ts.map +1 -0
  113. package/packages/benchmark/dist/runners/index.js +10 -0
  114. package/packages/benchmark/dist/runners/index.js.map +1 -0
  115. package/packages/benchmark/dist/runners/single.d.ts +19 -0
  116. package/packages/benchmark/dist/runners/single.d.ts.map +1 -0
  117. package/packages/benchmark/dist/runners/single.js +111 -0
  118. package/packages/benchmark/dist/runners/single.js.map +1 -0
  119. package/packages/benchmark/dist/runners/subagent.d.ts +32 -0
  120. package/packages/benchmark/dist/runners/subagent.d.ts.map +1 -0
  121. package/packages/benchmark/dist/runners/subagent.js +212 -0
  122. package/packages/benchmark/dist/runners/subagent.js.map +1 -0
  123. package/packages/benchmark/dist/runners/swarm.d.ts +36 -0
  124. package/packages/benchmark/dist/runners/swarm.d.ts.map +1 -0
  125. package/packages/benchmark/dist/runners/swarm.js +273 -0
  126. package/packages/benchmark/dist/runners/swarm.js.map +1 -0
  127. package/packages/benchmark/dist/types.d.ts +178 -0
  128. package/packages/benchmark/dist/types.d.ts.map +1 -0
  129. package/packages/benchmark/dist/types.js +16 -0
  130. package/packages/benchmark/dist/types.js.map +1 -0
  131. package/packages/benchmark/package.json +80 -0
  132. package/packages/benchmark/src/benchmark.ts +298 -0
  133. package/packages/benchmark/src/cli.ts +240 -0
  134. package/packages/benchmark/src/harbor.ts +170 -0
  135. package/packages/benchmark/src/index.ts +73 -0
  136. package/packages/benchmark/src/runners/base.ts +204 -0
  137. package/packages/benchmark/src/runners/index.ts +10 -0
  138. package/packages/benchmark/src/runners/single.ts +121 -0
  139. package/packages/benchmark/src/runners/subagent.ts +240 -0
  140. package/packages/benchmark/src/runners/swarm.ts +326 -0
  141. package/packages/benchmark/src/types.ts +205 -0
  142. package/packages/benchmark/tsconfig.json +20 -0
  143. package/packages/bridge/dist/index.d.ts.map +1 -0
  144. package/packages/bridge/dist/index.js.map +1 -0
  145. package/packages/bridge/dist/multi-project-client.d.ts.map +1 -0
  146. package/packages/bridge/dist/multi-project-client.js.map +1 -0
  147. package/packages/bridge/dist/shadow-cli.d.ts.map +1 -0
  148. package/packages/bridge/dist/shadow-cli.js.map +1 -0
  149. package/packages/bridge/dist/spawner.d.ts.map +1 -0
  150. package/packages/bridge/dist/spawner.js +15 -2
  151. package/packages/bridge/dist/spawner.js.map +1 -0
  152. package/packages/bridge/dist/types.d.ts.map +1 -0
  153. package/packages/bridge/dist/types.js.map +1 -0
  154. package/packages/bridge/dist/utils.d.ts.map +1 -0
  155. package/packages/bridge/dist/utils.js.map +1 -0
  156. package/packages/bridge/package.json +8 -8
  157. package/packages/bridge/src/index.ts +25 -0
  158. package/packages/bridge/src/multi-project-client.test.ts +340 -0
  159. package/packages/bridge/src/multi-project-client.ts +469 -0
  160. package/packages/bridge/src/shadow-cli.ts +95 -0
  161. package/packages/bridge/src/spawner-mcp.test.ts +505 -0
  162. package/packages/bridge/src/spawner.ts +1724 -0
  163. package/packages/bridge/src/types.ts +145 -0
  164. package/packages/bridge/src/utils.test.ts +98 -0
  165. package/packages/bridge/src/utils.ts +67 -0
  166. package/packages/bridge/tsconfig.json +29 -0
  167. package/packages/bridge/vitest.config.ts +9 -0
  168. package/packages/cli-tester/dist/index.d.ts.map +1 -0
  169. package/packages/cli-tester/dist/index.js.map +1 -0
  170. package/packages/cli-tester/dist/utils/credential-check.d.ts.map +1 -0
  171. package/packages/cli-tester/dist/utils/credential-check.js.map +1 -0
  172. package/packages/cli-tester/dist/utils/socket-client.d.ts.map +1 -0
  173. package/packages/cli-tester/dist/utils/socket-client.js.map +1 -0
  174. package/packages/cli-tester/docker/Dockerfile +61 -0
  175. package/packages/cli-tester/docker/docker-compose.yml +71 -0
  176. package/packages/cli-tester/package.json +1 -1
  177. package/packages/cli-tester/src/index.ts +40 -0
  178. package/packages/cli-tester/src/utils/credential-check.ts +284 -0
  179. package/packages/cli-tester/src/utils/socket-client.ts +211 -0
  180. package/packages/cli-tester/tests/credential-check.test.ts +56 -0
  181. package/packages/cli-tester/tsconfig.json +11 -0
  182. package/packages/config/dist/agent-config.d.ts.map +1 -0
  183. package/packages/config/dist/agent-config.js.map +1 -0
  184. package/packages/config/dist/bridge-config.d.ts.map +1 -0
  185. package/packages/config/dist/bridge-config.js.map +1 -0
  186. package/packages/config/dist/bridge-utils.d.ts.map +1 -0
  187. package/packages/config/dist/bridge-utils.js.map +1 -0
  188. package/packages/config/dist/cli-auth-config.d.ts.map +1 -0
  189. package/packages/config/dist/cli-auth-config.js.map +1 -0
  190. package/packages/config/dist/cloud-config.d.ts.map +1 -0
  191. package/packages/config/dist/cloud-config.js.map +1 -0
  192. package/packages/config/dist/index.d.ts.map +1 -0
  193. package/packages/config/dist/index.js.map +1 -0
  194. package/packages/config/dist/project-namespace.d.ts.map +1 -0
  195. package/packages/config/dist/project-namespace.js.map +1 -0
  196. package/packages/config/dist/relay-config.d.ts.map +1 -0
  197. package/packages/config/dist/relay-config.js.map +1 -0
  198. package/packages/config/dist/relay-file-writer.d.ts.map +1 -0
  199. package/packages/config/dist/relay-file-writer.js.map +1 -0
  200. package/packages/config/dist/schemas.d.ts.map +1 -0
  201. package/packages/config/dist/schemas.js.map +1 -0
  202. package/packages/config/dist/shadow-config.d.ts.map +1 -0
  203. package/packages/config/dist/shadow-config.js.map +1 -0
  204. package/packages/config/dist/teams-config.d.ts.map +1 -0
  205. package/packages/config/dist/teams-config.js.map +1 -0
  206. package/packages/config/dist/trajectory-config.d.ts.map +1 -0
  207. package/packages/config/dist/trajectory-config.js.map +1 -0
  208. package/packages/config/package.json +2 -2
  209. package/packages/config/src/agent-config.test.ts +245 -0
  210. package/packages/config/src/agent-config.ts +160 -0
  211. package/packages/config/src/bridge-config.test.ts +132 -0
  212. package/packages/config/src/bridge-config.ts +189 -0
  213. package/packages/config/src/bridge-utils.ts +59 -0
  214. package/packages/config/src/cli-auth-config.ts +548 -0
  215. package/packages/config/src/cloud-config.ts +208 -0
  216. package/packages/config/src/index.ts +12 -0
  217. package/packages/config/src/project-namespace.ts +344 -0
  218. package/packages/config/src/relay-config.test.ts +51 -0
  219. package/packages/config/src/relay-config.ts +36 -0
  220. package/packages/config/src/relay-file-writer.test.ts +351 -0
  221. package/packages/config/src/relay-file-writer.ts +508 -0
  222. package/packages/config/src/schemas.test.ts +59 -0
  223. package/packages/config/src/schemas.ts +201 -0
  224. package/packages/config/src/shadow-config.ts +205 -0
  225. package/packages/config/src/teams-config.ts +135 -0
  226. package/packages/config/src/trajectory-config.ts +222 -0
  227. package/packages/config/tsconfig.json +21 -0
  228. package/packages/config/vitest.config.ts +9 -0
  229. package/packages/continuity/dist/formatter.d.ts.map +1 -0
  230. package/packages/continuity/dist/formatter.js.map +1 -0
  231. package/packages/continuity/dist/handoff-store.d.ts.map +1 -0
  232. package/packages/continuity/dist/handoff-store.js.map +1 -0
  233. package/packages/continuity/dist/index.d.ts.map +1 -0
  234. package/packages/continuity/dist/index.js.map +1 -0
  235. package/packages/continuity/dist/ledger-store.d.ts.map +1 -0
  236. package/packages/continuity/dist/ledger-store.js.map +1 -0
  237. package/packages/continuity/dist/manager.d.ts.map +1 -0
  238. package/packages/continuity/dist/manager.js.map +1 -0
  239. package/packages/continuity/dist/parser.d.ts.map +1 -0
  240. package/packages/continuity/dist/parser.js.map +1 -0
  241. package/packages/continuity/dist/types.d.ts.map +1 -0
  242. package/packages/continuity/dist/types.js.map +1 -0
  243. package/packages/continuity/package.json +1 -1
  244. package/packages/continuity/src/formatter.ts +371 -0
  245. package/packages/continuity/src/handoff-store.ts +523 -0
  246. package/packages/continuity/src/index.ts +9 -0
  247. package/packages/continuity/src/ledger-store.ts +594 -0
  248. package/packages/continuity/src/manager.test.ts +291 -0
  249. package/packages/continuity/src/manager.ts +774 -0
  250. package/packages/continuity/src/parser.test.ts +292 -0
  251. package/packages/continuity/src/parser.ts +680 -0
  252. package/packages/continuity/src/types.ts +211 -0
  253. package/packages/continuity/tsconfig.json +21 -0
  254. package/packages/continuity/vitest.config.ts +9 -0
  255. package/packages/daemon/dist/agent-manager.d.ts.map +1 -0
  256. package/packages/daemon/dist/agent-manager.js.map +1 -0
  257. package/packages/daemon/dist/agent-registry.d.ts.map +1 -0
  258. package/packages/daemon/dist/agent-registry.js.map +1 -0
  259. package/packages/daemon/dist/agent-signing.d.ts.map +1 -0
  260. package/packages/daemon/dist/agent-signing.js.map +1 -0
  261. package/packages/daemon/dist/api.d.ts.map +1 -0
  262. package/packages/daemon/dist/api.js.map +1 -0
  263. package/packages/daemon/dist/auth.d.ts.map +1 -0
  264. package/packages/daemon/dist/auth.js.map +1 -0
  265. package/packages/daemon/dist/channel-membership-store.d.ts.map +1 -0
  266. package/packages/daemon/dist/channel-membership-store.js.map +1 -0
  267. package/packages/daemon/dist/cli-auth.d.ts.map +1 -0
  268. package/packages/daemon/dist/cli-auth.js.map +1 -0
  269. package/packages/daemon/dist/cloud-sync.d.ts.map +1 -0
  270. package/packages/daemon/dist/cloud-sync.js.map +1 -0
  271. package/packages/daemon/dist/connection.d.ts.map +1 -0
  272. package/packages/daemon/dist/connection.js.map +1 -0
  273. package/packages/daemon/dist/consensus-integration.d.ts.map +1 -0
  274. package/packages/daemon/dist/consensus-integration.js.map +1 -0
  275. package/packages/daemon/dist/consensus.d.ts.map +1 -0
  276. package/packages/daemon/dist/consensus.js.map +1 -0
  277. package/packages/daemon/dist/delivery-tracker.d.ts.map +1 -0
  278. package/packages/daemon/dist/delivery-tracker.js.map +1 -0
  279. package/packages/daemon/dist/enhanced-features.d.ts.map +1 -0
  280. package/packages/daemon/dist/enhanced-features.js.map +1 -0
  281. package/packages/daemon/dist/index.d.ts.map +1 -0
  282. package/packages/daemon/dist/index.js.map +1 -0
  283. package/packages/daemon/dist/migrations/index.d.ts.map +1 -0
  284. package/packages/daemon/dist/migrations/index.js.map +1 -0
  285. package/packages/daemon/dist/orchestrator.d.ts.map +1 -0
  286. package/packages/daemon/dist/orchestrator.js.map +1 -0
  287. package/packages/daemon/dist/rate-limiter.d.ts.map +1 -0
  288. package/packages/daemon/dist/rate-limiter.js.map +1 -0
  289. package/packages/daemon/dist/registry.d.ts.map +1 -0
  290. package/packages/daemon/dist/registry.js.map +1 -0
  291. package/packages/daemon/dist/relay-ledger.d.ts.map +1 -0
  292. package/packages/daemon/dist/relay-ledger.js.map +1 -0
  293. package/packages/daemon/dist/relay-watchdog.d.ts.map +1 -0
  294. package/packages/daemon/dist/relay-watchdog.js.map +1 -0
  295. package/packages/daemon/dist/repo-manager.d.ts.map +1 -0
  296. package/packages/daemon/dist/repo-manager.js.map +1 -0
  297. package/packages/daemon/dist/router.d.ts.map +1 -0
  298. package/packages/daemon/dist/router.js.map +1 -0
  299. package/packages/daemon/dist/server.d.ts +1 -0
  300. package/packages/daemon/dist/server.d.ts.map +1 -0
  301. package/packages/daemon/dist/server.js +46 -16
  302. package/packages/daemon/dist/server.js.map +1 -0
  303. package/packages/daemon/dist/spawn-manager.d.ts.map +1 -0
  304. package/packages/daemon/dist/spawn-manager.js.map +1 -0
  305. package/packages/daemon/dist/sync-queue.d.ts.map +1 -0
  306. package/packages/daemon/dist/sync-queue.js.map +1 -0
  307. package/packages/daemon/dist/types.d.ts.map +1 -0
  308. package/packages/daemon/dist/types.js.map +1 -0
  309. package/packages/daemon/dist/workspace-manager.d.ts.map +1 -0
  310. package/packages/daemon/dist/workspace-manager.js.map +1 -0
  311. package/packages/daemon/package.json +12 -12
  312. package/packages/daemon/src/agent-manager.ts +679 -0
  313. package/packages/daemon/src/agent-registry.ts +284 -0
  314. package/packages/daemon/src/agent-signing.ts +707 -0
  315. package/packages/daemon/src/api.ts +1012 -0
  316. package/packages/daemon/src/auth.ts +276 -0
  317. package/packages/daemon/src/channel-membership-store.ts +217 -0
  318. package/packages/daemon/src/cli-auth.ts +906 -0
  319. package/packages/daemon/src/cloud-sync.ts +902 -0
  320. package/packages/daemon/src/connection.ts +534 -0
  321. package/packages/daemon/src/consensus-integration.ts +510 -0
  322. package/packages/daemon/src/consensus.ts +848 -0
  323. package/packages/daemon/src/delivery-tracker.ts +145 -0
  324. package/packages/daemon/src/enhanced-features.ts +390 -0
  325. package/packages/daemon/src/index.ts +52 -0
  326. package/packages/daemon/src/migrations/0001_initial.sql +72 -0
  327. package/packages/daemon/src/migrations/index.test.ts +195 -0
  328. package/packages/daemon/src/migrations/index.ts +286 -0
  329. package/packages/daemon/src/orchestrator.test.ts +231 -0
  330. package/packages/daemon/src/orchestrator.ts +1376 -0
  331. package/packages/daemon/src/rate-limiter.ts +172 -0
  332. package/packages/daemon/src/registry.ts +8 -0
  333. package/packages/daemon/src/relay-ledger.test.ts +358 -0
  334. package/packages/daemon/src/relay-ledger.ts +713 -0
  335. package/packages/daemon/src/relay-watchdog.test.ts +881 -0
  336. package/packages/daemon/src/relay-watchdog.ts +785 -0
  337. package/packages/daemon/src/repo-manager.ts +468 -0
  338. package/packages/daemon/src/router.test.ts +149 -0
  339. package/packages/daemon/src/router.ts +1885 -0
  340. package/packages/daemon/src/server.ts +1871 -0
  341. package/packages/daemon/src/spawn-manager.ts +275 -0
  342. package/packages/daemon/src/sync-queue.ts +477 -0
  343. package/packages/daemon/src/types.ts +158 -0
  344. package/packages/daemon/src/workspace-manager.ts +371 -0
  345. package/packages/daemon/tsconfig.json +21 -0
  346. package/packages/hooks/dist/browser.d.ts.map +1 -0
  347. package/packages/hooks/dist/browser.js.map +1 -0
  348. package/packages/hooks/dist/emitter.d.ts.map +1 -0
  349. package/packages/hooks/dist/emitter.js.map +1 -0
  350. package/packages/hooks/dist/inbox-check/hook.d.ts.map +1 -0
  351. package/packages/hooks/dist/inbox-check/hook.js.map +1 -0
  352. package/packages/hooks/dist/inbox-check/index.d.ts.map +1 -0
  353. package/packages/hooks/dist/inbox-check/index.js.map +1 -0
  354. package/packages/hooks/dist/inbox-check/types.d.ts.map +1 -0
  355. package/packages/hooks/dist/inbox-check/types.js.map +1 -0
  356. package/packages/hooks/dist/inbox-check/utils.d.ts.map +1 -0
  357. package/packages/hooks/dist/inbox-check/utils.js.map +1 -0
  358. package/packages/hooks/dist/index.d.ts.map +1 -0
  359. package/packages/hooks/dist/index.js.map +1 -0
  360. package/packages/hooks/dist/registry.d.ts.map +1 -0
  361. package/packages/hooks/dist/registry.js.map +1 -0
  362. package/packages/hooks/dist/trajectory-hooks.d.ts.map +1 -0
  363. package/packages/hooks/dist/trajectory-hooks.js.map +1 -0
  364. package/packages/hooks/dist/types.d.ts.map +1 -0
  365. package/packages/hooks/dist/types.js.map +1 -0
  366. package/packages/hooks/package.json +4 -4
  367. package/packages/hooks/src/browser.ts +2 -0
  368. package/packages/hooks/src/emitter.ts +84 -0
  369. package/packages/hooks/src/inbox-check/hook.ts +114 -0
  370. package/packages/hooks/src/inbox-check/index.ts +8 -0
  371. package/packages/hooks/src/inbox-check/types.ts +39 -0
  372. package/packages/hooks/src/inbox-check/utils.test.ts +287 -0
  373. package/packages/hooks/src/inbox-check/utils.ts +125 -0
  374. package/packages/hooks/src/index.ts +11 -0
  375. package/packages/hooks/src/registry.ts +614 -0
  376. package/packages/hooks/src/shims.d.ts +3 -0
  377. package/packages/hooks/src/trajectory-hooks.ts +251 -0
  378. package/packages/hooks/src/types.ts +342 -0
  379. package/packages/hooks/tsconfig.json +21 -0
  380. package/packages/hooks/vitest.config.ts +9 -0
  381. package/packages/mcp/dist/bin.d.ts.map +1 -0
  382. package/packages/mcp/dist/bin.js.map +1 -0
  383. package/packages/mcp/dist/client.d.ts +9 -15
  384. package/packages/mcp/dist/client.d.ts.map +1 -0
  385. package/packages/mcp/dist/client.js +42 -74
  386. package/packages/mcp/dist/client.js.map +1 -0
  387. package/packages/mcp/dist/cloud.d.ts.map +1 -0
  388. package/packages/mcp/dist/cloud.js.map +1 -0
  389. package/packages/mcp/dist/errors.d.ts.map +1 -0
  390. package/packages/mcp/dist/errors.js.map +1 -0
  391. package/packages/mcp/dist/file-transport.d.ts.map +1 -0
  392. package/packages/mcp/dist/file-transport.js.map +1 -0
  393. package/packages/mcp/dist/hybrid-client.d.ts.map +1 -0
  394. package/packages/mcp/dist/hybrid-client.js.map +1 -0
  395. package/packages/mcp/dist/index.d.ts.map +1 -0
  396. package/packages/mcp/dist/index.js.map +1 -0
  397. package/packages/mcp/dist/install-cli.d.ts.map +1 -0
  398. package/packages/mcp/dist/install-cli.js.map +1 -0
  399. package/packages/mcp/dist/install.d.ts.map +1 -0
  400. package/packages/mcp/dist/install.js.map +1 -0
  401. package/packages/mcp/dist/prompts/index.d.ts.map +1 -0
  402. package/packages/mcp/dist/prompts/index.js.map +1 -0
  403. package/packages/mcp/dist/prompts/protocol.d.ts.map +1 -0
  404. package/packages/mcp/dist/prompts/protocol.js.map +1 -0
  405. package/packages/mcp/dist/resources/agents.d.ts.map +1 -0
  406. package/packages/mcp/dist/resources/agents.js.map +1 -0
  407. package/packages/mcp/dist/resources/inbox.d.ts.map +1 -0
  408. package/packages/mcp/dist/resources/inbox.js.map +1 -0
  409. package/packages/mcp/dist/resources/index.d.ts.map +1 -0
  410. package/packages/mcp/dist/resources/index.js.map +1 -0
  411. package/packages/mcp/dist/resources/project.d.ts.map +1 -0
  412. package/packages/mcp/dist/resources/project.js.map +1 -0
  413. package/packages/mcp/dist/server.d.ts.map +1 -0
  414. package/packages/mcp/dist/server.js.map +1 -0
  415. package/packages/mcp/dist/simple.d.ts +2 -5
  416. package/packages/mcp/dist/simple.d.ts.map +1 -0
  417. package/packages/mcp/dist/simple.js.map +1 -0
  418. package/packages/mcp/dist/tools/index.d.ts.map +1 -0
  419. package/packages/mcp/dist/tools/index.js.map +1 -0
  420. package/packages/mcp/dist/tools/relay-broadcast.d.ts.map +1 -0
  421. package/packages/mcp/dist/tools/relay-broadcast.js.map +1 -0
  422. package/packages/mcp/dist/tools/relay-channel.d.ts.map +1 -0
  423. package/packages/mcp/dist/tools/relay-channel.js.map +1 -0
  424. package/packages/mcp/dist/tools/relay-connected.d.ts.map +1 -0
  425. package/packages/mcp/dist/tools/relay-connected.js.map +1 -0
  426. package/packages/mcp/dist/tools/relay-consensus.d.ts.map +1 -0
  427. package/packages/mcp/dist/tools/relay-consensus.js.map +1 -0
  428. package/packages/mcp/dist/tools/relay-continuity.d.ts.map +1 -0
  429. package/packages/mcp/dist/tools/relay-continuity.js.map +1 -0
  430. package/packages/mcp/dist/tools/relay-health.d.ts.map +1 -0
  431. package/packages/mcp/dist/tools/relay-health.js.map +1 -0
  432. package/packages/mcp/dist/tools/relay-inbox.d.ts.map +1 -0
  433. package/packages/mcp/dist/tools/relay-inbox.js.map +1 -0
  434. package/packages/mcp/dist/tools/relay-logs.d.ts.map +1 -0
  435. package/packages/mcp/dist/tools/relay-logs.js.map +1 -0
  436. package/packages/mcp/dist/tools/relay-metrics.d.ts.map +1 -0
  437. package/packages/mcp/dist/tools/relay-metrics.js.map +1 -0
  438. package/packages/mcp/dist/tools/relay-release.d.ts.map +1 -0
  439. package/packages/mcp/dist/tools/relay-release.js.map +1 -0
  440. package/packages/mcp/dist/tools/relay-remove-agent.d.ts.map +1 -0
  441. package/packages/mcp/dist/tools/relay-remove-agent.js.map +1 -0
  442. package/packages/mcp/dist/tools/relay-send.d.ts.map +1 -0
  443. package/packages/mcp/dist/tools/relay-send.js +4 -2
  444. package/packages/mcp/dist/tools/relay-send.js.map +1 -0
  445. package/packages/mcp/dist/tools/relay-shadow.d.ts.map +1 -0
  446. package/packages/mcp/dist/tools/relay-shadow.js.map +1 -0
  447. package/packages/mcp/dist/tools/relay-spawn.d.ts.map +1 -0
  448. package/packages/mcp/dist/tools/relay-spawn.js.map +1 -0
  449. package/packages/mcp/dist/tools/relay-status.d.ts.map +1 -0
  450. package/packages/mcp/dist/tools/relay-status.js.map +1 -0
  451. package/packages/mcp/dist/tools/relay-subscribe.d.ts.map +1 -0
  452. package/packages/mcp/dist/tools/relay-subscribe.js.map +1 -0
  453. package/packages/mcp/dist/tools/relay-who.d.ts.map +1 -0
  454. package/packages/mcp/dist/tools/relay-who.js.map +1 -0
  455. package/packages/mcp/package.json +3 -3
  456. package/packages/mcp/src/bin.ts +149 -0
  457. package/packages/mcp/src/client.ts +400 -0
  458. package/packages/mcp/src/cloud.ts +523 -0
  459. package/packages/mcp/src/errors.ts +54 -0
  460. package/packages/mcp/src/file-transport.ts +268 -0
  461. package/packages/mcp/src/hybrid-client.ts +209 -0
  462. package/packages/mcp/src/index.ts +122 -0
  463. package/packages/mcp/src/install-cli.ts +210 -0
  464. package/packages/mcp/src/install.ts +745 -0
  465. package/packages/mcp/src/prompts/index.ts +1 -0
  466. package/packages/mcp/src/prompts/protocol.ts +164 -0
  467. package/packages/mcp/src/resources/agents.ts +21 -0
  468. package/packages/mcp/src/resources/inbox.ts +21 -0
  469. package/packages/mcp/src/resources/index.ts +3 -0
  470. package/packages/mcp/src/resources/project.ts +29 -0
  471. package/packages/mcp/src/server.ts +431 -0
  472. package/packages/mcp/src/simple.ts +214 -0
  473. package/packages/mcp/src/tools/index.ts +133 -0
  474. package/packages/mcp/src/tools/relay-broadcast.ts +32 -0
  475. package/packages/mcp/src/tools/relay-channel.ts +93 -0
  476. package/packages/mcp/src/tools/relay-connected.ts +52 -0
  477. package/packages/mcp/src/tools/relay-consensus.ts +92 -0
  478. package/packages/mcp/src/tools/relay-continuity.ts +127 -0
  479. package/packages/mcp/src/tools/relay-health.ts +148 -0
  480. package/packages/mcp/src/tools/relay-inbox.ts +70 -0
  481. package/packages/mcp/src/tools/relay-logs.ts +106 -0
  482. package/packages/mcp/src/tools/relay-metrics.ts +140 -0
  483. package/packages/mcp/src/tools/relay-release.ts +54 -0
  484. package/packages/mcp/src/tools/relay-remove-agent.ts +58 -0
  485. package/packages/mcp/src/tools/relay-send.ts +84 -0
  486. package/packages/mcp/src/tools/relay-shadow.ts +67 -0
  487. package/packages/mcp/src/tools/relay-spawn.ts +87 -0
  488. package/packages/mcp/src/tools/relay-status.ts +57 -0
  489. package/packages/mcp/src/tools/relay-subscribe.ts +61 -0
  490. package/packages/mcp/src/tools/relay-who.ts +59 -0
  491. package/packages/mcp/tests/client.test.ts +476 -0
  492. package/packages/mcp/tests/discover.test.ts +195 -0
  493. package/packages/mcp/tests/install.test.ts +123 -0
  494. package/packages/mcp/tests/prompts.test.ts +12 -0
  495. package/packages/mcp/tests/resources.test.ts +53 -0
  496. package/packages/mcp/tests/tools.test.ts +1242 -0
  497. package/packages/mcp/tsconfig.json +22 -0
  498. package/packages/mcp/vitest.config.ts +9 -0
  499. package/packages/memory/dist/adapters/index.d.ts.map +1 -0
  500. package/packages/memory/dist/adapters/index.js.map +1 -0
  501. package/packages/memory/dist/adapters/inmemory.d.ts.map +1 -0
  502. package/packages/memory/dist/adapters/inmemory.js.map +1 -0
  503. package/packages/memory/dist/adapters/supermemory.d.ts.map +1 -0
  504. package/packages/memory/dist/adapters/supermemory.js.map +1 -0
  505. package/packages/memory/dist/context-compaction.d.ts.map +1 -0
  506. package/packages/memory/dist/context-compaction.js.map +1 -0
  507. package/packages/memory/dist/factory.d.ts.map +1 -0
  508. package/packages/memory/dist/factory.js.map +1 -0
  509. package/packages/memory/dist/index.d.ts.map +1 -0
  510. package/packages/memory/dist/index.js.map +1 -0
  511. package/packages/memory/dist/memory-hooks.d.ts.map +1 -0
  512. package/packages/memory/dist/memory-hooks.js.map +1 -0
  513. package/packages/memory/dist/service.d.ts.map +1 -0
  514. package/packages/memory/dist/service.js.map +1 -0
  515. package/packages/memory/dist/types.d.ts.map +1 -0
  516. package/packages/memory/dist/types.js.map +1 -0
  517. package/packages/memory/package.json +2 -2
  518. package/packages/memory/src/adapters/index.ts +8 -0
  519. package/packages/memory/src/adapters/inmemory.ts +265 -0
  520. package/packages/memory/src/adapters/supermemory.ts +449 -0
  521. package/packages/memory/src/context-compaction.test.ts +660 -0
  522. package/packages/memory/src/context-compaction.ts +612 -0
  523. package/packages/memory/src/factory.ts +170 -0
  524. package/packages/memory/src/index.ts +33 -0
  525. package/packages/memory/src/memory-hooks.ts +410 -0
  526. package/packages/memory/src/service.ts +194 -0
  527. package/packages/memory/src/types.ts +211 -0
  528. package/packages/memory/tsconfig.json +21 -0
  529. package/packages/memory/vitest.config.ts +9 -0
  530. package/packages/policy/dist/agent-policy.d.ts.map +1 -0
  531. package/packages/policy/dist/agent-policy.js.map +1 -0
  532. package/packages/policy/dist/cloud-policy-fetcher.d.ts.map +1 -0
  533. package/packages/policy/dist/cloud-policy-fetcher.js.map +1 -0
  534. package/packages/policy/dist/index.d.ts.map +1 -0
  535. package/packages/policy/dist/index.js.map +1 -0
  536. package/packages/policy/package.json +2 -2
  537. package/packages/policy/src/agent-policy.ts +866 -0
  538. package/packages/policy/src/cloud-policy-fetcher.ts +78 -0
  539. package/packages/policy/src/index.ts +21 -0
  540. package/packages/policy/tsconfig.json +21 -0
  541. package/packages/policy/vitest.config.ts +9 -0
  542. package/packages/protocol/dist/channels.d.ts.map +1 -0
  543. package/packages/protocol/dist/channels.js.map +1 -0
  544. package/packages/protocol/dist/framing.d.ts.map +1 -0
  545. package/packages/protocol/dist/framing.js.map +1 -0
  546. package/packages/protocol/dist/id-generator.d.ts.map +1 -0
  547. package/packages/protocol/dist/id-generator.js.map +1 -0
  548. package/packages/protocol/dist/index.d.ts.map +1 -0
  549. package/packages/protocol/dist/index.js.map +1 -0
  550. package/packages/protocol/dist/relay-pty-schemas.d.ts +70 -2
  551. package/packages/protocol/dist/relay-pty-schemas.d.ts.map +1 -0
  552. package/packages/protocol/dist/relay-pty-schemas.js.map +1 -0
  553. package/packages/protocol/dist/types.d.ts +8 -0
  554. package/packages/protocol/dist/types.d.ts.map +1 -0
  555. package/packages/protocol/dist/types.js.map +1 -0
  556. package/packages/protocol/package.json +1 -1
  557. package/packages/protocol/src/channels.test.ts +330 -0
  558. package/packages/protocol/src/channels.ts +270 -0
  559. package/packages/protocol/src/framing.test.ts +164 -0
  560. package/packages/protocol/src/framing.ts +242 -0
  561. package/packages/protocol/src/id-generator.ts +69 -0
  562. package/packages/protocol/src/index.ts +4 -0
  563. package/packages/protocol/src/relay-pty-schemas.ts +400 -0
  564. package/packages/protocol/src/types.test.ts +271 -0
  565. package/packages/protocol/src/types.ts +846 -0
  566. package/packages/protocol/tsconfig.json +21 -0
  567. package/packages/protocol/vitest.config.ts +9 -0
  568. package/packages/resiliency/dist/cgroup-manager.d.ts.map +1 -0
  569. package/packages/resiliency/dist/cgroup-manager.js.map +1 -0
  570. package/packages/resiliency/dist/context-persistence.d.ts.map +1 -0
  571. package/packages/resiliency/dist/context-persistence.js.map +1 -0
  572. package/packages/resiliency/dist/crash-insights.d.ts.map +1 -0
  573. package/packages/resiliency/dist/crash-insights.js.map +1 -0
  574. package/packages/resiliency/dist/gossip-health.d.ts.map +1 -0
  575. package/packages/resiliency/dist/gossip-health.js.map +1 -0
  576. package/packages/resiliency/dist/health-monitor.d.ts.map +1 -0
  577. package/packages/resiliency/dist/health-monitor.js.map +1 -0
  578. package/packages/resiliency/dist/index.d.ts.map +1 -0
  579. package/packages/resiliency/dist/index.js.map +1 -0
  580. package/packages/resiliency/dist/leader-watchdog.d.ts.map +1 -0
  581. package/packages/resiliency/dist/leader-watchdog.js.map +1 -0
  582. package/packages/resiliency/dist/logger.d.ts.map +1 -0
  583. package/packages/resiliency/dist/logger.js.map +1 -0
  584. package/packages/resiliency/dist/memory-monitor.d.ts.map +1 -0
  585. package/packages/resiliency/dist/memory-monitor.js.map +1 -0
  586. package/packages/resiliency/dist/metrics.d.ts.map +1 -0
  587. package/packages/resiliency/dist/metrics.js.map +1 -0
  588. package/packages/resiliency/dist/provider-context.d.ts.map +1 -0
  589. package/packages/resiliency/dist/provider-context.js.map +1 -0
  590. package/packages/resiliency/dist/stateless-lead.d.ts.map +1 -0
  591. package/packages/resiliency/dist/stateless-lead.js.map +1 -0
  592. package/packages/resiliency/dist/supervisor.d.ts.map +1 -0
  593. package/packages/resiliency/dist/supervisor.js.map +1 -0
  594. package/packages/resiliency/package.json +1 -1
  595. package/packages/resiliency/src/cgroup-manager.ts +468 -0
  596. package/packages/resiliency/src/context-persistence.ts +538 -0
  597. package/packages/resiliency/src/crash-insights.test.ts +620 -0
  598. package/packages/resiliency/src/crash-insights.ts +660 -0
  599. package/packages/resiliency/src/gossip-health.ts +333 -0
  600. package/packages/resiliency/src/health-monitor.ts +371 -0
  601. package/packages/resiliency/src/index.ts +157 -0
  602. package/packages/resiliency/src/leader-watchdog.ts +260 -0
  603. package/packages/resiliency/src/logger.ts +320 -0
  604. package/packages/resiliency/src/memory-monitor.test.ts +637 -0
  605. package/packages/resiliency/src/memory-monitor.ts +740 -0
  606. package/packages/resiliency/src/metrics.ts +311 -0
  607. package/packages/resiliency/src/provider-context.ts +452 -0
  608. package/packages/resiliency/src/stateless-lead.ts +408 -0
  609. package/packages/resiliency/src/supervisor.ts +578 -0
  610. package/packages/resiliency/tsconfig.json +21 -0
  611. package/packages/resiliency/vitest.config.ts +9 -0
  612. package/packages/sdk/dist/client.d.ts.map +1 -0
  613. package/packages/sdk/dist/client.js.map +1 -0
  614. package/packages/sdk/dist/index.d.ts.map +1 -0
  615. package/packages/sdk/dist/index.js.map +1 -0
  616. package/packages/sdk/dist/logs.d.ts.map +1 -0
  617. package/packages/sdk/dist/logs.js.map +1 -0
  618. package/packages/sdk/dist/protocol/index.d.ts.map +1 -0
  619. package/packages/sdk/dist/protocol/index.js.map +1 -0
  620. package/packages/sdk/dist/standalone.d.ts.map +1 -0
  621. package/packages/sdk/dist/standalone.js.map +1 -0
  622. package/packages/sdk/examples/SWARM_CAPABILITIES.md +498 -0
  623. package/packages/sdk/examples/SWARM_PATTERNS.md +541 -0
  624. package/packages/sdk/package.json +2 -2
  625. package/packages/sdk/src/client.test.ts +568 -0
  626. package/packages/sdk/src/client.ts +1418 -0
  627. package/packages/sdk/src/index.ts +103 -0
  628. package/packages/sdk/src/logs.test.ts +98 -0
  629. package/packages/sdk/src/logs.ts +126 -0
  630. package/packages/sdk/src/protocol/framing.test.ts +164 -0
  631. package/packages/sdk/src/protocol/index.ts +8 -0
  632. package/packages/sdk/src/standalone.ts +176 -0
  633. package/packages/sdk/tsconfig.json +22 -0
  634. package/packages/sdk/vitest.config.ts +9 -0
  635. package/packages/spawner/.trajectories/index.json +5 -0
  636. package/packages/spawner/dist/index.d.ts.map +1 -0
  637. package/packages/spawner/dist/index.js.map +1 -0
  638. package/packages/spawner/dist/types.d.ts.map +1 -0
  639. package/packages/spawner/dist/types.js.map +1 -0
  640. package/packages/spawner/package.json +1 -1
  641. package/packages/spawner/src/index.ts +8 -0
  642. package/packages/spawner/src/types.test.ts +385 -0
  643. package/packages/spawner/src/types.ts +228 -0
  644. package/packages/spawner/tsconfig.json +19 -0
  645. package/packages/spawner/vitest.config.ts +9 -0
  646. package/packages/state/dist/agent-state.d.ts.map +1 -0
  647. package/packages/state/dist/agent-state.js.map +1 -0
  648. package/packages/state/dist/index.d.ts.map +1 -0
  649. package/packages/state/dist/index.js.map +1 -0
  650. package/packages/state/package.json +1 -1
  651. package/packages/state/src/agent-state.test.ts +335 -0
  652. package/packages/state/src/agent-state.ts +153 -0
  653. package/packages/state/src/index.ts +12 -0
  654. package/packages/state/tsconfig.json +21 -0
  655. package/packages/state/vitest.config.ts +9 -0
  656. package/packages/storage/dist/adapter.d.ts +28 -1
  657. package/packages/storage/dist/adapter.d.ts.map +1 -0
  658. package/packages/storage/dist/adapter.js +104 -10
  659. package/packages/storage/dist/adapter.js.map +1 -0
  660. package/packages/storage/dist/batched-sqlite-adapter.d.ts.map +1 -0
  661. package/packages/storage/dist/batched-sqlite-adapter.js.map +1 -0
  662. package/packages/storage/dist/dead-letter-queue.d.ts.map +1 -0
  663. package/packages/storage/dist/dead-letter-queue.js.map +1 -0
  664. package/packages/storage/dist/dlq-adapter.d.ts.map +1 -0
  665. package/packages/storage/dist/dlq-adapter.js.map +1 -0
  666. package/packages/storage/dist/index.d.ts +1 -0
  667. package/packages/storage/dist/index.d.ts.map +1 -0
  668. package/packages/storage/dist/index.js +1 -0
  669. package/packages/storage/dist/index.js.map +1 -0
  670. package/packages/storage/dist/jsonl-adapter.d.ts +77 -0
  671. package/packages/storage/dist/jsonl-adapter.d.ts.map +1 -0
  672. package/packages/storage/dist/jsonl-adapter.js +505 -0
  673. package/packages/storage/dist/jsonl-adapter.js.map +1 -0
  674. package/packages/storage/dist/sqlite-adapter.d.ts +6 -1
  675. package/packages/storage/dist/sqlite-adapter.d.ts.map +1 -0
  676. package/packages/storage/dist/sqlite-adapter.js +47 -0
  677. package/packages/storage/dist/sqlite-adapter.js.map +1 -0
  678. package/packages/storage/package.json +2 -2
  679. package/packages/storage/src/adapter.ts +438 -0
  680. package/packages/storage/src/batched-sqlite-adapter.test.ts +240 -0
  681. package/packages/storage/src/batched-sqlite-adapter.ts +239 -0
  682. package/packages/storage/src/dead-letter-queue.ts +643 -0
  683. package/packages/storage/src/dlq-adapter.test.ts +492 -0
  684. package/packages/storage/src/dlq-adapter.ts +954 -0
  685. package/packages/storage/src/index.ts +6 -0
  686. package/packages/storage/src/jsonl-adapter.test.ts +200 -0
  687. package/packages/storage/src/jsonl-adapter.ts +618 -0
  688. package/packages/storage/src/memory-adapter.test.ts +36 -0
  689. package/packages/storage/src/sqlite-adapter.test.ts +562 -0
  690. package/packages/storage/src/sqlite-adapter.ts +1058 -0
  691. package/packages/storage/tsconfig.json +21 -0
  692. package/packages/storage/vitest.config.ts +9 -0
  693. package/packages/telemetry/dist/client.d.ts.map +1 -0
  694. package/packages/telemetry/dist/client.js.map +1 -0
  695. package/packages/telemetry/dist/config.d.ts.map +1 -0
  696. package/packages/telemetry/dist/config.js.map +1 -0
  697. package/packages/telemetry/dist/events.d.ts.map +1 -0
  698. package/packages/telemetry/dist/events.js.map +1 -0
  699. package/packages/telemetry/dist/index.d.ts.map +1 -0
  700. package/packages/telemetry/dist/index.js.map +1 -0
  701. package/packages/telemetry/dist/machine-id.d.ts.map +1 -0
  702. package/packages/telemetry/dist/machine-id.js.map +1 -0
  703. package/packages/telemetry/dist/posthog-config.d.ts.map +1 -0
  704. package/packages/telemetry/dist/posthog-config.js.map +1 -0
  705. package/packages/telemetry/package.json +1 -1
  706. package/packages/telemetry/src/client.ts +158 -0
  707. package/packages/telemetry/src/config.ts +110 -0
  708. package/packages/telemetry/src/events.ts +137 -0
  709. package/packages/telemetry/src/index.ts +46 -0
  710. package/packages/telemetry/src/machine-id.ts +63 -0
  711. package/packages/telemetry/src/posthog-config.ts +39 -0
  712. package/packages/telemetry/tsconfig.json +21 -0
  713. package/packages/trajectory/dist/index.d.ts.map +1 -0
  714. package/packages/trajectory/dist/index.js.map +1 -0
  715. package/packages/trajectory/dist/integration.d.ts.map +1 -0
  716. package/packages/trajectory/dist/integration.js.map +1 -0
  717. package/packages/trajectory/package.json +2 -2
  718. package/packages/trajectory/src/index.ts +1 -0
  719. package/packages/trajectory/src/integration.ts +1268 -0
  720. package/packages/trajectory/tsconfig.json +21 -0
  721. package/packages/trajectory/vitest.config.ts +9 -0
  722. package/packages/user-directory/dist/index.d.ts.map +1 -0
  723. package/packages/user-directory/dist/index.js.map +1 -0
  724. package/packages/user-directory/dist/user-directory.d.ts.map +1 -0
  725. package/packages/user-directory/dist/user-directory.js.map +1 -0
  726. package/packages/user-directory/package.json +2 -2
  727. package/packages/user-directory/src/index.ts +12 -0
  728. package/packages/user-directory/src/user-directory.ts +393 -0
  729. package/packages/user-directory/tsconfig.json +21 -0
  730. package/packages/user-directory/vitest.config.ts +9 -0
  731. package/packages/utils/dist/cjs/client-helpers.js +127 -0
  732. package/packages/utils/dist/cjs/command-resolver.js +89 -0
  733. package/packages/utils/dist/cjs/error-tracking.js +106 -0
  734. package/packages/utils/dist/cjs/git-remote.js +120 -0
  735. package/packages/utils/dist/cjs/index.js +40 -0
  736. package/packages/utils/dist/cjs/logger.js +105 -0
  737. package/packages/utils/dist/cjs/model-mapping.js +54 -0
  738. package/packages/utils/dist/cjs/name-generator.js +179 -0
  739. package/packages/utils/dist/cjs/package.json +3 -0
  740. package/packages/utils/dist/cjs/precompiled-patterns.js +271 -0
  741. package/packages/utils/dist/cjs/relay-pty-path.js +143 -0
  742. package/packages/utils/dist/cjs/update-checker.js +185 -0
  743. package/packages/utils/dist/client-helpers.d.ts +73 -0
  744. package/packages/utils/dist/client-helpers.d.ts.map +1 -0
  745. package/packages/utils/dist/client-helpers.js +130 -0
  746. package/packages/utils/dist/client-helpers.js.map +1 -0
  747. package/packages/utils/dist/command-resolver.d.ts.map +1 -0
  748. package/packages/utils/dist/command-resolver.js.map +1 -0
  749. package/packages/utils/dist/error-tracking.d.ts.map +1 -0
  750. package/packages/utils/dist/error-tracking.js.map +1 -0
  751. package/packages/utils/dist/git-remote.d.ts.map +1 -0
  752. package/packages/utils/dist/git-remote.js.map +1 -0
  753. package/packages/utils/dist/index.d.ts +1 -0
  754. package/packages/utils/dist/index.d.ts.map +1 -0
  755. package/packages/utils/dist/index.js +1 -0
  756. package/packages/utils/dist/index.js.map +1 -0
  757. package/packages/utils/dist/logger.d.ts.map +1 -0
  758. package/packages/utils/dist/logger.js.map +1 -0
  759. package/packages/utils/dist/model-mapping.d.ts.map +1 -0
  760. package/packages/utils/dist/model-mapping.js.map +1 -0
  761. package/packages/utils/dist/name-generator.d.ts.map +1 -0
  762. package/packages/utils/dist/name-generator.js.map +1 -0
  763. package/packages/utils/dist/precompiled-patterns.d.ts.map +1 -0
  764. package/packages/utils/dist/precompiled-patterns.js.map +1 -0
  765. package/packages/utils/dist/relay-pty-path.d.ts +11 -5
  766. package/packages/utils/dist/relay-pty-path.d.ts.map +1 -0
  767. package/packages/utils/dist/relay-pty-path.js +60 -5
  768. package/packages/utils/dist/relay-pty-path.js.map +1 -0
  769. package/packages/utils/dist/update-checker.d.ts.map +1 -0
  770. package/packages/utils/dist/update-checker.js.map +1 -0
  771. package/packages/utils/package.json +37 -14
  772. package/packages/utils/scripts/build-cjs.mjs +24 -0
  773. package/packages/utils/src/client-helpers.ts +221 -0
  774. package/packages/utils/src/command-resolver.ts +82 -0
  775. package/packages/utils/src/error-tracking.ts +189 -0
  776. package/packages/utils/src/git-remote.ts +143 -0
  777. package/packages/utils/src/index.ts +10 -0
  778. package/packages/utils/src/logger.ts +107 -0
  779. package/packages/utils/src/model-mapping.test.ts +122 -0
  780. package/packages/utils/src/model-mapping.ts +58 -0
  781. package/packages/utils/src/name-generator.test.ts +259 -0
  782. package/packages/utils/src/name-generator.ts +56 -0
  783. package/packages/utils/src/precompiled-patterns.test.ts +452 -0
  784. package/packages/utils/src/precompiled-patterns.ts +395 -0
  785. package/packages/utils/src/relay-pty-path.ts +196 -0
  786. package/packages/utils/src/update-checker.test.ts +260 -0
  787. package/packages/utils/src/update-checker.ts +211 -0
  788. package/packages/utils/tsconfig.json +21 -0
  789. package/packages/utils/vitest.config.ts +9 -0
  790. package/packages/wrapper/dist/__fixtures__/claude-outputs.d.ts.map +1 -0
  791. package/packages/wrapper/dist/__fixtures__/claude-outputs.js.map +1 -0
  792. package/packages/wrapper/dist/__fixtures__/codex-outputs.d.ts.map +1 -0
  793. package/packages/wrapper/dist/__fixtures__/codex-outputs.js.map +1 -0
  794. package/packages/wrapper/dist/__fixtures__/gemini-outputs.d.ts.map +1 -0
  795. package/packages/wrapper/dist/__fixtures__/gemini-outputs.js.map +1 -0
  796. package/packages/wrapper/dist/__fixtures__/index.d.ts.map +1 -0
  797. package/packages/wrapper/dist/__fixtures__/index.js.map +1 -0
  798. package/packages/wrapper/dist/auth-detection.d.ts.map +1 -0
  799. package/packages/wrapper/dist/auth-detection.js.map +1 -0
  800. package/packages/wrapper/dist/base-wrapper.d.ts.map +1 -0
  801. package/packages/wrapper/dist/base-wrapper.js.map +1 -0
  802. package/packages/wrapper/dist/client.d.ts.map +1 -0
  803. package/packages/wrapper/dist/client.js.map +1 -0
  804. package/packages/wrapper/dist/id-generator.d.ts.map +1 -0
  805. package/packages/wrapper/dist/id-generator.js.map +1 -0
  806. package/packages/wrapper/dist/idle-detector.d.ts.map +1 -0
  807. package/packages/wrapper/dist/idle-detector.js.map +1 -0
  808. package/packages/wrapper/dist/inbox.d.ts.map +1 -0
  809. package/packages/wrapper/dist/inbox.js.map +1 -0
  810. package/packages/wrapper/dist/index.d.ts.map +1 -0
  811. package/packages/wrapper/dist/index.js.map +1 -0
  812. package/packages/wrapper/dist/parser.d.ts.map +1 -0
  813. package/packages/wrapper/dist/parser.js.map +1 -0
  814. package/packages/wrapper/dist/prompt-composer.d.ts.map +1 -0
  815. package/packages/wrapper/dist/prompt-composer.js.map +1 -0
  816. package/packages/wrapper/dist/relay-pty-orchestrator.d.ts +10 -0
  817. package/packages/wrapper/dist/relay-pty-orchestrator.d.ts.map +1 -0
  818. package/packages/wrapper/dist/relay-pty-orchestrator.js +69 -0
  819. package/packages/wrapper/dist/relay-pty-orchestrator.js.map +1 -0
  820. package/packages/wrapper/dist/shared.d.ts.map +1 -0
  821. package/packages/wrapper/dist/shared.js.map +1 -0
  822. package/packages/wrapper/dist/stuck-detector.d.ts.map +1 -0
  823. package/packages/wrapper/dist/stuck-detector.js.map +1 -0
  824. package/packages/wrapper/dist/tmux-resolver.d.ts.map +1 -0
  825. package/packages/wrapper/dist/tmux-resolver.js.map +1 -0
  826. package/packages/wrapper/dist/tmux-wrapper.d.ts.map +1 -0
  827. package/packages/wrapper/dist/tmux-wrapper.js.map +1 -0
  828. package/packages/wrapper/dist/trajectory-integration.d.ts.map +1 -0
  829. package/packages/wrapper/dist/trajectory-integration.js.map +1 -0
  830. package/packages/wrapper/dist/wrapper-types.d.ts.map +1 -0
  831. package/packages/wrapper/dist/wrapper-types.js.map +1 -0
  832. package/packages/wrapper/package.json +6 -9
  833. package/packages/wrapper/src/__fixtures__/claude-outputs.ts +471 -0
  834. package/packages/wrapper/src/__fixtures__/codex-outputs.ts +99 -0
  835. package/packages/wrapper/src/__fixtures__/gemini-outputs.ts +151 -0
  836. package/packages/wrapper/src/__fixtures__/index.ts +47 -0
  837. package/packages/wrapper/src/auth-detection.ts +244 -0
  838. package/packages/wrapper/src/base-wrapper.test.ts +589 -0
  839. package/packages/wrapper/src/base-wrapper.ts +810 -0
  840. package/packages/wrapper/src/client.test.ts +262 -0
  841. package/packages/wrapper/src/client.ts +984 -0
  842. package/packages/wrapper/src/id-generator.test.ts +71 -0
  843. package/packages/wrapper/src/id-generator.ts +69 -0
  844. package/packages/wrapper/src/idle-detector.test.ts +418 -0
  845. package/packages/wrapper/src/idle-detector.ts +384 -0
  846. package/packages/wrapper/src/inbox.test.ts +233 -0
  847. package/packages/wrapper/src/inbox.ts +89 -0
  848. package/packages/wrapper/src/index.ts +170 -0
  849. package/packages/wrapper/src/parser.regression.test.ts +251 -0
  850. package/packages/wrapper/src/parser.test.ts +1359 -0
  851. package/packages/wrapper/src/parser.ts +1477 -0
  852. package/packages/wrapper/src/prompt-composer.test.ts +219 -0
  853. package/packages/wrapper/src/prompt-composer.ts +231 -0
  854. package/packages/wrapper/src/relay-pty-orchestrator.test.ts +1204 -0
  855. package/packages/wrapper/src/relay-pty-orchestrator.ts +2626 -0
  856. package/packages/wrapper/src/shared.test.ts +322 -0
  857. package/packages/wrapper/src/shared.ts +495 -0
  858. package/packages/wrapper/src/stuck-detector.test.ts +303 -0
  859. package/packages/wrapper/src/stuck-detector.ts +511 -0
  860. package/packages/wrapper/src/tmux-resolver.test.ts +104 -0
  861. package/packages/wrapper/src/tmux-resolver.ts +207 -0
  862. package/packages/wrapper/src/tmux-wrapper.test.ts +316 -0
  863. package/packages/wrapper/src/tmux-wrapper.ts +2095 -0
  864. package/packages/wrapper/src/trajectory-detection.test.ts +151 -0
  865. package/packages/wrapper/src/trajectory-integration.ts +1261 -0
  866. package/packages/wrapper/src/wrapper-types.ts +45 -0
  867. package/packages/wrapper/tsconfig.json +19 -0
  868. package/packages/wrapper/vitest.config.ts +9 -0
  869. package/scripts/build-cjs.mjs +23 -0
  870. package/scripts/postinstall.js +132 -0
  871. package/.cursor/mcp.json +0 -11
  872. package/.gitattributes +0 -3
  873. package/.gitleaks.toml +0 -26
  874. package/.mcp.json +0 -11
  875. package/.nvmrc +0 -1
  876. package/ARCHITECTURE.md +0 -1245
  877. package/CHANGELOG.md +0 -231
  878. package/TESTING.md +0 -278
  879. package/TRAIL_GIT_AUTH_FIX.md +0 -113
  880. package/scripts/demos/README.md +0 -79
  881. package/scripts/demos/server-capacity.sh +0 -69
  882. package/scripts/demos/sprint-planning.sh +0 -73
  883. package/scripts/hooks/install.sh +0 -16
  884. package/scripts/hooks/pre-commit +0 -60
  885. package/scripts/post-publish-verify/README.md +0 -80
  886. package/scripts/post-publish-verify/run-verify.sh +0 -127
  887. package/scripts/post-publish-verify/verify-install.sh +0 -249
  888. package/scripts/stress-test-orchestrator-integration.mts +0 -1366
  889. package/scripts/stress-test-orchestrator.mjs +0 -584
  890. package/scripts/stress-test-relay-pty.sh +0 -452
  891. package/scripts/test-interactive-terminal.sh +0 -248
  892. package/specs/PRIMITIVES_ROADMAP.md +0 -2154
  893. package/tests/benchmarks/protocol.bench.ts +0 -310
  894. package/turbo.json +0 -37
@@ -0,0 +1,1242 @@
1
+ import { describe, it, expect, vi, beforeEach } from 'vitest';
2
+ import type { RelayClient } from '../src/client.js';
3
+ import {
4
+ handleRelaySend,
5
+ relaySendSchema,
6
+ handleRelayInbox,
7
+ relayInboxSchema,
8
+ handleRelayWho,
9
+ relayWhoSchema,
10
+ handleRelaySpawn,
11
+ handleRelayRelease,
12
+ handleRelayStatus,
13
+ handleRelayBroadcast,
14
+ relayBroadcastSchema,
15
+ handleRelaySubscribe,
16
+ relaySubscribeSchema,
17
+ handleRelayUnsubscribe,
18
+ relayUnsubscribeSchema,
19
+ handleRelayChannelJoin,
20
+ relayChannelJoinSchema,
21
+ handleRelayChannelLeave,
22
+ relayChannelLeaveSchema,
23
+ handleRelayChannelMessage,
24
+ relayChannelMessageSchema,
25
+ handleRelayShadowBind,
26
+ relayShadowBindSchema,
27
+ handleRelayShadowUnbind,
28
+ relayShadowUnbindSchema,
29
+ handleRelayProposal,
30
+ relayProposalSchema,
31
+ handleRelayVote,
32
+ relayVoteSchema,
33
+ } from '../src/tools/index.js';
34
+
35
+ /**
36
+ * Creates a mock RelayClient with all methods stubbed.
37
+ * Only specify the methods you need for each test.
38
+ */
39
+ function createMockClient(overrides: Partial<Record<keyof RelayClient, ReturnType<typeof vi.fn>>> = {}): RelayClient {
40
+ return {
41
+ send: vi.fn(),
42
+ sendAndWait: vi.fn(),
43
+ spawn: vi.fn(),
44
+ release: vi.fn(),
45
+ getStatus: vi.fn(),
46
+ getInbox: vi.fn(),
47
+ listAgents: vi.fn(),
48
+ broadcast: vi.fn(),
49
+ subscribe: vi.fn(),
50
+ unsubscribe: vi.fn(),
51
+ joinChannel: vi.fn(),
52
+ leaveChannel: vi.fn(),
53
+ sendChannelMessage: vi.fn(),
54
+ bindAsShadow: vi.fn(),
55
+ unbindAsShadow: vi.fn(),
56
+ createProposal: vi.fn(),
57
+ vote: vi.fn(),
58
+ ...overrides,
59
+ };
60
+ }
61
+
62
+ describe('relay_send', () => {
63
+ let mockClient: RelayClient;
64
+
65
+ beforeEach(() => {
66
+ vi.clearAllMocks();
67
+ mockClient = createMockClient();
68
+ });
69
+
70
+ it('sends a direct message', async () => {
71
+ vi.mocked(mockClient.send).mockResolvedValue(undefined);
72
+
73
+ const input = relaySendSchema.parse({
74
+ to: 'Alice',
75
+ message: 'Hello',
76
+ });
77
+ const result = await handleRelaySend(mockClient, input);
78
+
79
+ expect(result).toBe('Message sent to Alice');
80
+ expect(mockClient.send).toHaveBeenCalledWith('Alice', 'Hello', { thread: undefined });
81
+ });
82
+
83
+ it('sends to a channel', async () => {
84
+ vi.mocked(mockClient.send).mockResolvedValue(undefined);
85
+
86
+ const input = relaySendSchema.parse({
87
+ to: '#general',
88
+ message: 'Team update',
89
+ });
90
+ const result = await handleRelaySend(mockClient, input);
91
+
92
+ expect(result).toBe('Message sent to #general');
93
+ expect(mockClient.send).toHaveBeenCalledWith('#general', 'Team update', { thread: undefined });
94
+ });
95
+
96
+ it('awaits response when requested', async () => {
97
+ vi.mocked(mockClient.sendAndWait).mockResolvedValue({
98
+ ack_id: 'msg-123',
99
+ seq: 1,
100
+ correlationId: 'corr-456',
101
+ response: 'Done!',
102
+ responseData: undefined,
103
+ });
104
+
105
+ const result = await handleRelaySend(mockClient, {
106
+ to: 'Worker',
107
+ message: 'Process this',
108
+ await_response: true,
109
+ timeout_ms: 5000,
110
+ thread: 'task-123',
111
+ });
112
+
113
+ expect(result).toBe('Response from Worker: Done!');
114
+ expect(mockClient.sendAndWait).toHaveBeenCalledWith('Worker', 'Process this', {
115
+ thread: 'task-123',
116
+ timeoutMs: 5000,
117
+ });
118
+ });
119
+ });
120
+
121
+ describe('relay_inbox', () => {
122
+ let mockClient: RelayClient;
123
+
124
+ beforeEach(() => {
125
+ vi.clearAllMocks();
126
+ mockClient = createMockClient();
127
+ });
128
+
129
+ it('returns no messages message when inbox empty', async () => {
130
+ vi.mocked(mockClient.getInbox).mockResolvedValue([]);
131
+
132
+ const input = relayInboxSchema.parse({});
133
+ const result = await handleRelayInbox(mockClient, input);
134
+
135
+ expect(result).toBe('No messages in inbox.');
136
+ // After parsing, limit and unread_only have defaults
137
+ expect(mockClient.getInbox).toHaveBeenCalledWith({ limit: 10, unread_only: true });
138
+ });
139
+
140
+ it('formats messages with channel and thread', async () => {
141
+ vi.mocked(mockClient.getInbox).mockResolvedValue([
142
+ {
143
+ id: '123',
144
+ from: 'Lead',
145
+ content: 'Update',
146
+ channel: '#general',
147
+ thread: 'thr-1',
148
+ },
149
+ {
150
+ id: '124',
151
+ from: 'Worker',
152
+ content: 'Done',
153
+ },
154
+ ]);
155
+
156
+ const input = relayInboxSchema.parse({
157
+ limit: 5,
158
+ unread_only: true,
159
+ from: 'Lead',
160
+ });
161
+ const result = await handleRelayInbox(mockClient, input);
162
+
163
+ expect(mockClient.getInbox).toHaveBeenCalledWith({
164
+ limit: 5,
165
+ unread_only: true,
166
+ from: 'Lead',
167
+ });
168
+ expect(result).toContain('2 message(s):');
169
+ expect(result).toContain('[123] From Lead [#general] (thread: thr-1):\nUpdate');
170
+ expect(result).toContain('[124] From Worker:\nDone');
171
+ });
172
+ });
173
+
174
+ describe('relay_who', () => {
175
+ let mockClient: RelayClient;
176
+
177
+ beforeEach(() => {
178
+ vi.clearAllMocks();
179
+ mockClient = createMockClient();
180
+ });
181
+
182
+ it('returns message when no agents online', async () => {
183
+ vi.mocked(mockClient.listAgents).mockResolvedValue([]);
184
+
185
+ const input = relayWhoSchema.parse({});
186
+ const result = await handleRelayWho(mockClient, input);
187
+
188
+ expect(result).toBe('No agents online.');
189
+ // After parsing, include_idle has a default of true
190
+ expect(mockClient.listAgents).toHaveBeenCalledWith({ include_idle: true });
191
+ });
192
+
193
+ it('lists agents with status and parent info', async () => {
194
+ vi.mocked(mockClient.listAgents).mockResolvedValue([
195
+ { name: 'Alice', cli: 'claude', idle: false },
196
+ { name: 'Bob', cli: 'codex', idle: true },
197
+ { name: 'Worker1', cli: 'claude', idle: false, parent: 'Alice' },
198
+ ]);
199
+
200
+ const input = relayWhoSchema.parse({ include_idle: true, project: 'proj' });
201
+ const result = await handleRelayWho(mockClient, input);
202
+
203
+ expect(mockClient.listAgents).toHaveBeenCalledWith({ include_idle: true, project: 'proj' });
204
+ expect(result).toContain('3 agent(s) online:');
205
+ expect(result).toContain('- Alice (claude) - active');
206
+ expect(result).toContain('- Bob (codex) - idle');
207
+ expect(result).toContain('- Worker1 (claude) - active [worker of: Alice]');
208
+ });
209
+ });
210
+
211
+ describe('relay_spawn', () => {
212
+ let mockClient: RelayClient;
213
+
214
+ beforeEach(() => {
215
+ vi.clearAllMocks();
216
+ mockClient = createMockClient();
217
+ });
218
+
219
+ it('returns success message when worker spawns', async () => {
220
+ vi.mocked(mockClient.spawn).mockResolvedValue({ success: true });
221
+
222
+ const result = await handleRelaySpawn(mockClient, {
223
+ name: 'TestRunner',
224
+ cli: 'claude',
225
+ task: 'Run tests',
226
+ model: 'claude-3',
227
+ cwd: '/tmp',
228
+ });
229
+
230
+ expect(result).toContain('spawned successfully');
231
+ expect(mockClient.spawn).toHaveBeenCalledWith({
232
+ name: 'TestRunner',
233
+ cli: 'claude',
234
+ task: 'Run tests',
235
+ model: 'claude-3',
236
+ cwd: '/tmp',
237
+ });
238
+ });
239
+
240
+ it('returns failure message when spawn fails', async () => {
241
+ vi.mocked(mockClient.spawn).mockResolvedValue({ success: false, error: 'Busy' });
242
+
243
+ const result = await handleRelaySpawn(mockClient, {
244
+ name: 'Worker',
245
+ cli: 'codex',
246
+ task: 'Do thing',
247
+ });
248
+
249
+ expect(result).toContain('Failed to spawn worker');
250
+ expect(result).toContain('Busy');
251
+ });
252
+ });
253
+
254
+ describe('relay_release', () => {
255
+ let mockClient: RelayClient;
256
+
257
+ beforeEach(() => {
258
+ vi.clearAllMocks();
259
+ mockClient = createMockClient();
260
+ });
261
+
262
+ it('returns success message when worker released', async () => {
263
+ vi.mocked(mockClient.release).mockResolvedValue({ success: true });
264
+
265
+ const result = await handleRelayRelease(mockClient, {
266
+ name: 'Worker1',
267
+ reason: 'done',
268
+ });
269
+
270
+ expect(result).toBe('Worker "Worker1" released.');
271
+ expect(mockClient.release).toHaveBeenCalledWith('Worker1', 'done');
272
+ });
273
+
274
+ it('returns failure message when release fails', async () => {
275
+ vi.mocked(mockClient.release).mockResolvedValue({ success: false, error: 'not found' });
276
+
277
+ const result = await handleRelayRelease(mockClient, {
278
+ name: 'Worker2',
279
+ });
280
+
281
+ expect(result).toBe('Failed to release worker: not found');
282
+ });
283
+ });
284
+
285
+ describe('relay_status', () => {
286
+ let mockClient: RelayClient;
287
+
288
+ beforeEach(() => {
289
+ vi.clearAllMocks();
290
+ mockClient = createMockClient();
291
+ });
292
+
293
+ it('formats status output', async () => {
294
+ vi.mocked(mockClient.getStatus).mockResolvedValue({
295
+ connected: true,
296
+ agentName: 'AgentA',
297
+ project: 'proj',
298
+ socketPath: '/tmp/socket',
299
+ daemonVersion: '0.1.0',
300
+ uptime: '1h',
301
+ });
302
+
303
+ const result = await handleRelayStatus(mockClient, {});
304
+
305
+ expect(result).toContain('Connected: Yes');
306
+ expect(result).toContain('Agent Name: AgentA');
307
+ expect(result).toContain('Project: proj');
308
+ expect(result).toContain('Socket: /tmp/socket');
309
+ expect(result).toContain('Daemon Version: 0.1.0');
310
+ expect(result).toContain('Uptime: 1h');
311
+ });
312
+
313
+ it('handles disconnected status', async () => {
314
+ vi.mocked(mockClient.getStatus).mockResolvedValue({
315
+ connected: false,
316
+ agentName: 'AgentA',
317
+ project: 'proj',
318
+ socketPath: '/tmp/socket',
319
+ });
320
+
321
+ const result = await handleRelayStatus(mockClient, {});
322
+
323
+ expect(result).toContain('Connected: No');
324
+ });
325
+ });
326
+
327
+ // ============================================================================
328
+ // Multi-Agent Scenarios (SDK parity tests)
329
+ // ============================================================================
330
+
331
+ describe('multi-agent scenarios', () => {
332
+ let mockClient: RelayClient;
333
+
334
+ beforeEach(() => {
335
+ vi.clearAllMocks();
336
+ mockClient = createMockClient();
337
+ });
338
+
339
+ it('spawns multiple workers sequentially', async () => {
340
+ vi.mocked(mockClient.spawn).mockResolvedValue({ success: true });
341
+
342
+ // Spawn Worker1
343
+ const result1 = await handleRelaySpawn(mockClient, {
344
+ name: 'Worker1',
345
+ cli: 'claude',
346
+ task: 'Task 1',
347
+ });
348
+ expect(result1).toContain('spawned successfully');
349
+
350
+ // Spawn Worker2
351
+ const result2 = await handleRelaySpawn(mockClient, {
352
+ name: 'Worker2',
353
+ cli: 'claude',
354
+ task: 'Task 2',
355
+ });
356
+ expect(result2).toContain('spawned successfully');
357
+
358
+ // Spawn Worker3
359
+ const result3 = await handleRelaySpawn(mockClient, {
360
+ name: 'Worker3',
361
+ cli: 'claude',
362
+ task: 'Task 3',
363
+ });
364
+ expect(result3).toContain('spawned successfully');
365
+
366
+ expect(mockClient.spawn).toHaveBeenCalledTimes(3);
367
+ });
368
+
369
+ it('lists multiple agents with different statuses', async () => {
370
+ vi.mocked(mockClient.listAgents).mockResolvedValue([
371
+ { name: 'Orchestrator', cli: 'sdk', idle: false },
372
+ { name: 'Worker1', cli: 'claude', idle: false, parent: 'Orchestrator' },
373
+ { name: 'Worker2', cli: 'claude', idle: true, parent: 'Orchestrator' },
374
+ { name: 'Worker3', cli: 'codex', idle: false, parent: 'Orchestrator' },
375
+ ]);
376
+
377
+ const input = relayWhoSchema.parse({ include_idle: true });
378
+ const result = await handleRelayWho(mockClient, input);
379
+
380
+ expect(result).toContain('4 agent(s) online:');
381
+ expect(result).toContain('Orchestrator');
382
+ expect(result).toContain('Worker1');
383
+ expect(result).toContain('Worker2');
384
+ expect(result).toContain('Worker3');
385
+ });
386
+
387
+ it('releases multiple workers', async () => {
388
+ vi.mocked(mockClient.release)
389
+ .mockResolvedValueOnce({ success: true })
390
+ .mockResolvedValueOnce({ success: true })
391
+ .mockResolvedValueOnce({ success: false, error: 'already exited' });
392
+
393
+ const result1 = await handleRelayRelease(mockClient, { name: 'Worker1' });
394
+ expect(result1).toBe('Worker "Worker1" released.');
395
+
396
+ const result2 = await handleRelayRelease(mockClient, { name: 'Worker2' });
397
+ expect(result2).toBe('Worker "Worker2" released.');
398
+
399
+ const result3 = await handleRelayRelease(mockClient, { name: 'Worker3' });
400
+ expect(result3).toBe('Failed to release worker: already exited');
401
+
402
+ expect(mockClient.release).toHaveBeenCalledTimes(3);
403
+ });
404
+
405
+ it('handles release of non-existent agent gracefully', async () => {
406
+ vi.mocked(mockClient.release).mockResolvedValue({
407
+ success: false,
408
+ error: 'Agent not found: NonExistentAgent',
409
+ });
410
+
411
+ const result = await handleRelayRelease(mockClient, {
412
+ name: 'NonExistentAgent',
413
+ });
414
+
415
+ expect(result).toBe('Failed to release worker: Agent not found: NonExistentAgent');
416
+ });
417
+ });
418
+
419
+ // ============================================================================
420
+ // Message Threading Scenarios
421
+ // ============================================================================
422
+
423
+ describe('message threading', () => {
424
+ let mockClient: RelayClient;
425
+
426
+ beforeEach(() => {
427
+ vi.clearAllMocks();
428
+ mockClient = createMockClient();
429
+ });
430
+
431
+ it('sends message with thread ID', async () => {
432
+ vi.mocked(mockClient.send).mockResolvedValue(undefined);
433
+
434
+ const input = relaySendSchema.parse({
435
+ to: 'Worker',
436
+ message: 'Continue task',
437
+ thread: 'task-thread-123',
438
+ });
439
+ await handleRelaySend(mockClient, input);
440
+
441
+ expect(mockClient.send).toHaveBeenCalledWith('Worker', 'Continue task', {
442
+ thread: 'task-thread-123',
443
+ });
444
+ });
445
+
446
+ it('filters inbox by thread', async () => {
447
+ vi.mocked(mockClient.getInbox).mockResolvedValue([
448
+ { id: '1', from: 'Worker', content: 'Done step 1', thread: 'task-123' },
449
+ { id: '2', from: 'Worker', content: 'Done step 2', thread: 'task-123' },
450
+ ]);
451
+
452
+ const input = relayInboxSchema.parse({ limit: 10 });
453
+ const result = await handleRelayInbox(mockClient, input);
454
+
455
+ expect(result).toContain('2 message(s):');
456
+ expect(result).toContain('(thread: task-123)');
457
+ });
458
+ });
459
+
460
+ // ============================================================================
461
+ // Broadcast-like Scenarios (send to multiple agents)
462
+ // ============================================================================
463
+
464
+ describe('broadcast scenarios', () => {
465
+ let mockClient: RelayClient;
466
+
467
+ beforeEach(() => {
468
+ vi.clearAllMocks();
469
+ mockClient = createMockClient();
470
+ });
471
+
472
+ it('sends messages to multiple agents', async () => {
473
+ vi.mocked(mockClient.send).mockResolvedValue(undefined);
474
+ const agents = ['Alice', 'Bob', 'Charlie'];
475
+
476
+ for (const agent of agents) {
477
+ const input = relaySendSchema.parse({
478
+ to: agent,
479
+ message: 'Broadcast message to all',
480
+ });
481
+ await handleRelaySend(mockClient, input);
482
+ }
483
+
484
+ expect(mockClient.send).toHaveBeenCalledTimes(3);
485
+ expect(mockClient.send).toHaveBeenCalledWith('Alice', 'Broadcast message to all', { thread: undefined });
486
+ expect(mockClient.send).toHaveBeenCalledWith('Bob', 'Broadcast message to all', { thread: undefined });
487
+ expect(mockClient.send).toHaveBeenCalledWith('Charlie', 'Broadcast message to all', { thread: undefined });
488
+ });
489
+
490
+ it('receives messages from multiple senders', async () => {
491
+ vi.mocked(mockClient.getInbox).mockResolvedValue([
492
+ { id: '1', from: 'Alice', content: 'Hello from Alice' },
493
+ { id: '2', from: 'Bob', content: 'Hello from Bob' },
494
+ { id: '3', from: 'Charlie', content: 'Hello from Charlie' },
495
+ ]);
496
+
497
+ const input = relayInboxSchema.parse({ limit: 10 });
498
+ const result = await handleRelayInbox(mockClient, input);
499
+
500
+ expect(result).toContain('3 message(s):');
501
+ expect(result).toContain('From Alice');
502
+ expect(result).toContain('From Bob');
503
+ expect(result).toContain('From Charlie');
504
+ });
505
+ });
506
+
507
+ // ============================================================================
508
+ // Negotiation-like Workflow Scenarios
509
+ // ============================================================================
510
+
511
+ describe('negotiation workflow', () => {
512
+ let mockClient: RelayClient;
513
+
514
+ beforeEach(() => {
515
+ vi.clearAllMocks();
516
+ mockClient = createMockClient();
517
+ });
518
+
519
+ it('coordinates multi-round communication', async () => {
520
+ vi.mocked(mockClient.spawn).mockResolvedValue({ success: true });
521
+ vi.mocked(mockClient.send).mockResolvedValue(undefined);
522
+ vi.mocked(mockClient.sendAndWait)
523
+ .mockResolvedValueOnce({ from: 'Frontend', content: 'Frontend priorities: Design System, Accessibility' })
524
+ .mockResolvedValueOnce({ from: 'Backend', content: 'Backend priorities: Microservices, Caching' })
525
+ .mockResolvedValueOnce({ from: 'Infra', content: 'Infra priorities: Kubernetes, Multi-Region' });
526
+
527
+ // Spawn agents
528
+ const teams = ['Frontend', 'Backend', 'Infra'];
529
+ for (const team of teams) {
530
+ await handleRelaySpawn(mockClient, {
531
+ name: team,
532
+ cli: 'claude',
533
+ task: `You are the ${team} team lead`,
534
+ });
535
+ }
536
+ expect(mockClient.spawn).toHaveBeenCalledTimes(3);
537
+
538
+ // Request introductions (with await_response)
539
+ for (const team of teams) {
540
+ await handleRelaySend(mockClient, {
541
+ to: team,
542
+ message: 'Please introduce yourself',
543
+ await_response: true,
544
+ timeout_ms: 30000,
545
+ });
546
+ }
547
+ expect(mockClient.sendAndWait).toHaveBeenCalledTimes(3);
548
+ });
549
+
550
+ it('handles voting responses', async () => {
551
+ vi.mocked(mockClient.getInbox).mockResolvedValue([
552
+ { id: '1', from: 'Frontend', content: 'I VOTE: Frontend=$35000, Backend=$35000, Infra=$30000' },
553
+ { id: '2', from: 'Backend', content: 'I VOTE: Frontend=$30000, Backend=$40000, Infra=$30000' },
554
+ { id: '3', from: 'Infra', content: 'I VOTE: Frontend=$33000, Backend=$35000, Infra=$32000' },
555
+ ]);
556
+
557
+ const input = relayInboxSchema.parse({ limit: 10 });
558
+ const result = await handleRelayInbox(mockClient, input);
559
+
560
+ expect(result).toContain('3 message(s):');
561
+ expect(result).toContain('I VOTE:');
562
+ expect(result).toContain('Frontend');
563
+ expect(result).toContain('Backend');
564
+ expect(result).toContain('Infra');
565
+ });
566
+ });
567
+
568
+ // ============================================================================
569
+ // Broadcast Tool Tests
570
+ // ============================================================================
571
+
572
+ describe('relay_broadcast', () => {
573
+ let mockClient: RelayClient;
574
+
575
+ beforeEach(() => {
576
+ vi.clearAllMocks();
577
+ mockClient = createMockClient();
578
+ });
579
+
580
+ it('broadcasts a message to all agents', async () => {
581
+ vi.mocked(mockClient.broadcast).mockResolvedValue(undefined);
582
+
583
+ const input = relayBroadcastSchema.parse({
584
+ message: 'Hello everyone!',
585
+ });
586
+ const result = await handleRelayBroadcast(mockClient, input);
587
+
588
+ expect(result).toBe('Message broadcast to all agents');
589
+ expect(mockClient.broadcast).toHaveBeenCalledWith('Hello everyone!', { kind: undefined });
590
+ });
591
+
592
+ it('broadcasts with message kind', async () => {
593
+ vi.mocked(mockClient.broadcast).mockResolvedValue(undefined);
594
+
595
+ const input = relayBroadcastSchema.parse({
596
+ message: 'System update',
597
+ kind: 'action',
598
+ });
599
+ const result = await handleRelayBroadcast(mockClient, input);
600
+
601
+ expect(result).toBe('Message broadcast to all agents');
602
+ expect(mockClient.broadcast).toHaveBeenCalledWith('System update', { kind: 'action' });
603
+ });
604
+
605
+ it('supports different message kinds', async () => {
606
+ vi.mocked(mockClient.broadcast).mockResolvedValue(undefined);
607
+
608
+ const kinds = ['message', 'action', 'state', 'thinking'] as const;
609
+ for (const kind of kinds) {
610
+ const input = relayBroadcastSchema.parse({
611
+ message: `Test ${kind}`,
612
+ kind,
613
+ });
614
+ await handleRelayBroadcast(mockClient, input);
615
+ }
616
+
617
+ expect(mockClient.broadcast).toHaveBeenCalledTimes(4);
618
+ });
619
+ });
620
+
621
+ // ============================================================================
622
+ // Subscribe/Unsubscribe Tool Tests
623
+ // ============================================================================
624
+
625
+ describe('relay_subscribe', () => {
626
+ let mockClient: RelayClient;
627
+
628
+ beforeEach(() => {
629
+ vi.clearAllMocks();
630
+ mockClient = createMockClient();
631
+ });
632
+
633
+ it('subscribes to a topic', async () => {
634
+ vi.mocked(mockClient.subscribe).mockResolvedValue({ success: true });
635
+
636
+ const input = relaySubscribeSchema.parse({
637
+ topic: 'updates',
638
+ });
639
+ const result = await handleRelaySubscribe(mockClient, input);
640
+
641
+ expect(result).toBe('Subscribed to topic "updates"');
642
+ expect(mockClient.subscribe).toHaveBeenCalledWith('updates');
643
+ });
644
+
645
+ it('returns error when subscription fails', async () => {
646
+ vi.mocked(mockClient.subscribe).mockResolvedValue({
647
+ success: false,
648
+ error: 'Topic does not exist',
649
+ });
650
+
651
+ const input = relaySubscribeSchema.parse({
652
+ topic: 'nonexistent',
653
+ });
654
+ const result = await handleRelaySubscribe(mockClient, input);
655
+
656
+ expect(result).toBe('Failed to subscribe: Topic does not exist');
657
+ });
658
+ });
659
+
660
+ describe('relay_unsubscribe', () => {
661
+ let mockClient: RelayClient;
662
+
663
+ beforeEach(() => {
664
+ vi.clearAllMocks();
665
+ mockClient = createMockClient();
666
+ });
667
+
668
+ it('unsubscribes from a topic', async () => {
669
+ vi.mocked(mockClient.unsubscribe).mockResolvedValue({ success: true });
670
+
671
+ const input = relayUnsubscribeSchema.parse({
672
+ topic: 'updates',
673
+ });
674
+ const result = await handleRelayUnsubscribe(mockClient, input);
675
+
676
+ expect(result).toBe('Unsubscribed from topic "updates"');
677
+ expect(mockClient.unsubscribe).toHaveBeenCalledWith('updates');
678
+ });
679
+
680
+ it('returns error when unsubscribe fails', async () => {
681
+ vi.mocked(mockClient.unsubscribe).mockResolvedValue({
682
+ success: false,
683
+ error: 'Not subscribed to topic',
684
+ });
685
+
686
+ const input = relayUnsubscribeSchema.parse({
687
+ topic: 'random',
688
+ });
689
+ const result = await handleRelayUnsubscribe(mockClient, input);
690
+
691
+ expect(result).toBe('Failed to unsubscribe: Not subscribed to topic');
692
+ });
693
+ });
694
+
695
+ // ============================================================================
696
+ // Channel Tool Tests
697
+ // ============================================================================
698
+
699
+ describe('relay_channel_join', () => {
700
+ let mockClient: RelayClient;
701
+
702
+ beforeEach(() => {
703
+ vi.clearAllMocks();
704
+ mockClient = createMockClient();
705
+ });
706
+
707
+ it('joins a channel', async () => {
708
+ vi.mocked(mockClient.joinChannel).mockResolvedValue({ success: true });
709
+
710
+ const input = relayChannelJoinSchema.parse({
711
+ channel: '#general',
712
+ });
713
+ const result = await handleRelayChannelJoin(mockClient, input);
714
+
715
+ expect(result).toBe('Joined channel "#general"');
716
+ expect(mockClient.joinChannel).toHaveBeenCalledWith('#general', undefined);
717
+ });
718
+
719
+ it('joins a channel with display name', async () => {
720
+ vi.mocked(mockClient.joinChannel).mockResolvedValue({ success: true });
721
+
722
+ const input = relayChannelJoinSchema.parse({
723
+ channel: '#dev-team',
724
+ display_name: 'Alice (Lead)',
725
+ });
726
+ const result = await handleRelayChannelJoin(mockClient, input);
727
+
728
+ expect(result).toBe('Joined channel "#dev-team"');
729
+ expect(mockClient.joinChannel).toHaveBeenCalledWith('#dev-team', 'Alice (Lead)');
730
+ });
731
+
732
+ it('returns error when join fails', async () => {
733
+ vi.mocked(mockClient.joinChannel).mockResolvedValue({
734
+ success: false,
735
+ error: 'Channel is private',
736
+ });
737
+
738
+ const input = relayChannelJoinSchema.parse({
739
+ channel: '#secret',
740
+ });
741
+ const result = await handleRelayChannelJoin(mockClient, input);
742
+
743
+ expect(result).toBe('Failed to join channel: Channel is private');
744
+ });
745
+ });
746
+
747
+ describe('relay_channel_leave', () => {
748
+ let mockClient: RelayClient;
749
+
750
+ beforeEach(() => {
751
+ vi.clearAllMocks();
752
+ mockClient = createMockClient();
753
+ });
754
+
755
+ it('leaves a channel', async () => {
756
+ vi.mocked(mockClient.leaveChannel).mockResolvedValue({ success: true });
757
+
758
+ const input = relayChannelLeaveSchema.parse({
759
+ channel: '#general',
760
+ });
761
+ const result = await handleRelayChannelLeave(mockClient, input);
762
+
763
+ expect(result).toBe('Left channel "#general"');
764
+ expect(mockClient.leaveChannel).toHaveBeenCalledWith('#general', undefined);
765
+ });
766
+
767
+ it('leaves a channel with reason', async () => {
768
+ vi.mocked(mockClient.leaveChannel).mockResolvedValue({ success: true });
769
+
770
+ const input = relayChannelLeaveSchema.parse({
771
+ channel: '#dev-team',
772
+ reason: 'Task completed',
773
+ });
774
+ const result = await handleRelayChannelLeave(mockClient, input);
775
+
776
+ expect(result).toBe('Left channel "#dev-team"');
777
+ expect(mockClient.leaveChannel).toHaveBeenCalledWith('#dev-team', 'Task completed');
778
+ });
779
+
780
+ it('returns error when leave fails', async () => {
781
+ vi.mocked(mockClient.leaveChannel).mockResolvedValue({
782
+ success: false,
783
+ error: 'Not a member of channel',
784
+ });
785
+
786
+ const input = relayChannelLeaveSchema.parse({
787
+ channel: '#random',
788
+ });
789
+ const result = await handleRelayChannelLeave(mockClient, input);
790
+
791
+ expect(result).toBe('Failed to leave channel: Not a member of channel');
792
+ });
793
+ });
794
+
795
+ describe('relay_channel_message', () => {
796
+ let mockClient: RelayClient;
797
+
798
+ beforeEach(() => {
799
+ vi.clearAllMocks();
800
+ mockClient = createMockClient();
801
+ });
802
+
803
+ it('sends a message to a channel', async () => {
804
+ vi.mocked(mockClient.sendChannelMessage).mockResolvedValue(undefined);
805
+
806
+ const input = relayChannelMessageSchema.parse({
807
+ channel: '#general',
808
+ message: 'Hello channel!',
809
+ });
810
+ const result = await handleRelayChannelMessage(mockClient, input);
811
+
812
+ expect(result).toBe('Message sent to channel "#general"');
813
+ expect(mockClient.sendChannelMessage).toHaveBeenCalledWith('#general', 'Hello channel!', { thread: undefined });
814
+ });
815
+
816
+ it('sends a threaded message to a channel', async () => {
817
+ vi.mocked(mockClient.sendChannelMessage).mockResolvedValue(undefined);
818
+
819
+ const input = relayChannelMessageSchema.parse({
820
+ channel: '#dev-team',
821
+ message: 'Follow-up on this',
822
+ thread: 'thread-123',
823
+ });
824
+ const result = await handleRelayChannelMessage(mockClient, input);
825
+
826
+ expect(result).toBe('Message sent to channel "#dev-team"');
827
+ expect(mockClient.sendChannelMessage).toHaveBeenCalledWith('#dev-team', 'Follow-up on this', { thread: 'thread-123' });
828
+ });
829
+ });
830
+
831
+ // ============================================================================
832
+ // Shadow Agent Tool Tests
833
+ // ============================================================================
834
+
835
+ describe('relay_shadow_bind', () => {
836
+ let mockClient: RelayClient;
837
+
838
+ beforeEach(() => {
839
+ vi.clearAllMocks();
840
+ mockClient = createMockClient();
841
+ });
842
+
843
+ it('binds as a shadow agent', async () => {
844
+ vi.mocked(mockClient.bindAsShadow).mockResolvedValue({ success: true });
845
+
846
+ const input = relayShadowBindSchema.parse({
847
+ primary_agent: 'Alice',
848
+ });
849
+ const result = await handleRelayShadowBind(mockClient, input);
850
+
851
+ expect(result).toBe('Now shadowing agent "Alice"');
852
+ expect(mockClient.bindAsShadow).toHaveBeenCalledWith('Alice', { speakOn: undefined });
853
+ });
854
+
855
+ it('binds with speak_on events', async () => {
856
+ vi.mocked(mockClient.bindAsShadow).mockResolvedValue({ success: true });
857
+
858
+ const input = relayShadowBindSchema.parse({
859
+ primary_agent: 'Alice',
860
+ speak_on: ['SESSION_END', 'CODE_WRITTEN'],
861
+ });
862
+ const result = await handleRelayShadowBind(mockClient, input);
863
+
864
+ expect(result).toBe('Now shadowing agent "Alice"');
865
+ expect(mockClient.bindAsShadow).toHaveBeenCalledWith('Alice', {
866
+ speakOn: ['SESSION_END', 'CODE_WRITTEN'],
867
+ });
868
+ });
869
+
870
+ it('returns error when bind fails', async () => {
871
+ vi.mocked(mockClient.bindAsShadow).mockResolvedValue({
872
+ success: false,
873
+ error: 'Agent not found',
874
+ });
875
+
876
+ const input = relayShadowBindSchema.parse({
877
+ primary_agent: 'Unknown',
878
+ });
879
+ const result = await handleRelayShadowBind(mockClient, input);
880
+
881
+ expect(result).toBe('Failed to bind as shadow: Agent not found');
882
+ });
883
+ });
884
+
885
+ describe('relay_shadow_unbind', () => {
886
+ let mockClient: RelayClient;
887
+
888
+ beforeEach(() => {
889
+ vi.clearAllMocks();
890
+ mockClient = createMockClient();
891
+ });
892
+
893
+ it('unbinds from shadowing', async () => {
894
+ vi.mocked(mockClient.unbindAsShadow).mockResolvedValue({ success: true });
895
+
896
+ const input = relayShadowUnbindSchema.parse({
897
+ primary_agent: 'Alice',
898
+ });
899
+ const result = await handleRelayShadowUnbind(mockClient, input);
900
+
901
+ expect(result).toBe('Stopped shadowing agent "Alice"');
902
+ expect(mockClient.unbindAsShadow).toHaveBeenCalledWith('Alice');
903
+ });
904
+
905
+ it('returns error when unbind fails', async () => {
906
+ vi.mocked(mockClient.unbindAsShadow).mockResolvedValue({
907
+ success: false,
908
+ error: 'Not shadowing this agent',
909
+ });
910
+
911
+ const input = relayShadowUnbindSchema.parse({
912
+ primary_agent: 'Bob',
913
+ });
914
+ const result = await handleRelayShadowUnbind(mockClient, input);
915
+
916
+ expect(result).toBe('Failed to unbind from shadow: Not shadowing this agent');
917
+ });
918
+ });
919
+
920
+ // ============================================================================
921
+ // Consensus/Voting Tool Tests
922
+ // ============================================================================
923
+
924
+ describe('relay_proposal', () => {
925
+ let mockClient: RelayClient;
926
+
927
+ beforeEach(() => {
928
+ vi.clearAllMocks();
929
+ mockClient = createMockClient();
930
+ });
931
+
932
+ it('creates a proposal', async () => {
933
+ vi.mocked(mockClient.createProposal).mockResolvedValue({ success: true });
934
+
935
+ const input = relayProposalSchema.parse({
936
+ id: 'budget-2024',
937
+ description: 'Vote on Q1 budget allocation',
938
+ options: ['Option A: $50k', 'Option B: $75k', 'Option C: $100k'],
939
+ });
940
+ const result = await handleRelayProposal(mockClient, input);
941
+
942
+ expect(result).toBe('Proposal "budget-2024" created successfully. Options: Option A: $50k, Option B: $75k, Option C: $100k');
943
+ expect(mockClient.createProposal).toHaveBeenCalledWith({
944
+ id: 'budget-2024',
945
+ description: 'Vote on Q1 budget allocation',
946
+ options: ['Option A: $50k', 'Option B: $75k', 'Option C: $100k'],
947
+ votingMethod: undefined,
948
+ deadline: undefined,
949
+ });
950
+ });
951
+
952
+ it('creates a proposal with voting method', async () => {
953
+ vi.mocked(mockClient.createProposal).mockResolvedValue({ success: true });
954
+
955
+ const input = relayProposalSchema.parse({
956
+ id: 'critical-decision',
957
+ description: 'Requires unanimous agreement',
958
+ options: ['approve', 'reject'],
959
+ voting_method: 'unanimous',
960
+ });
961
+ const result = await handleRelayProposal(mockClient, input);
962
+
963
+ expect(result).toContain('created successfully');
964
+ expect(mockClient.createProposal).toHaveBeenCalledWith({
965
+ id: 'critical-decision',
966
+ description: 'Requires unanimous agreement',
967
+ options: ['approve', 'reject'],
968
+ votingMethod: 'unanimous',
969
+ deadline: undefined,
970
+ });
971
+ });
972
+
973
+ it('creates a proposal with deadline', async () => {
974
+ vi.mocked(mockClient.createProposal).mockResolvedValue({ success: true });
975
+ const deadline = Date.now() + 3600000; // 1 hour from now
976
+
977
+ const input = relayProposalSchema.parse({
978
+ id: 'timed-vote',
979
+ description: 'Vote must be completed within 1 hour',
980
+ options: ['yes', 'no'],
981
+ deadline,
982
+ });
983
+ const result = await handleRelayProposal(mockClient, input);
984
+
985
+ expect(result).toContain('created successfully');
986
+ expect(mockClient.createProposal).toHaveBeenCalledWith({
987
+ id: 'timed-vote',
988
+ description: 'Vote must be completed within 1 hour',
989
+ options: ['yes', 'no'],
990
+ votingMethod: undefined,
991
+ deadline,
992
+ });
993
+ });
994
+
995
+ it('returns error when proposal creation fails', async () => {
996
+ vi.mocked(mockClient.createProposal).mockResolvedValue({
997
+ success: false,
998
+ error: 'Proposal ID already exists',
999
+ });
1000
+
1001
+ const input = relayProposalSchema.parse({
1002
+ id: 'duplicate',
1003
+ description: 'Test',
1004
+ options: ['a', 'b'],
1005
+ });
1006
+ const result = await handleRelayProposal(mockClient, input);
1007
+
1008
+ expect(result).toBe('Failed to create proposal: Proposal ID already exists');
1009
+ });
1010
+ });
1011
+
1012
+ describe('relay_vote', () => {
1013
+ let mockClient: RelayClient;
1014
+
1015
+ beforeEach(() => {
1016
+ vi.clearAllMocks();
1017
+ mockClient = createMockClient();
1018
+ });
1019
+
1020
+ it('casts a vote on a proposal', async () => {
1021
+ vi.mocked(mockClient.vote).mockResolvedValue({ success: true });
1022
+
1023
+ const input = relayVoteSchema.parse({
1024
+ proposal_id: 'budget-2024',
1025
+ vote: 'Option B: $75k',
1026
+ });
1027
+ const result = await handleRelayVote(mockClient, input);
1028
+
1029
+ expect(result).toBe('Vote "Option B: $75k" cast on proposal "budget-2024"');
1030
+ expect(mockClient.vote).toHaveBeenCalledWith({
1031
+ proposalId: 'budget-2024',
1032
+ vote: 'Option B: $75k',
1033
+ reason: undefined,
1034
+ });
1035
+ });
1036
+
1037
+ it('casts a vote with reason', async () => {
1038
+ vi.mocked(mockClient.vote).mockResolvedValue({ success: true });
1039
+
1040
+ const input = relayVoteSchema.parse({
1041
+ proposal_id: 'critical-decision',
1042
+ vote: 'approve',
1043
+ reason: 'This aligns with our Q2 goals',
1044
+ });
1045
+ const result = await handleRelayVote(mockClient, input);
1046
+
1047
+ expect(result).toBe('Vote "approve" cast on proposal "critical-decision"');
1048
+ expect(mockClient.vote).toHaveBeenCalledWith({
1049
+ proposalId: 'critical-decision',
1050
+ vote: 'approve',
1051
+ reason: 'This aligns with our Q2 goals',
1052
+ });
1053
+ });
1054
+
1055
+ it('returns error when vote fails', async () => {
1056
+ vi.mocked(mockClient.vote).mockResolvedValue({
1057
+ success: false,
1058
+ error: 'Voting period has ended',
1059
+ });
1060
+
1061
+ const input = relayVoteSchema.parse({
1062
+ proposal_id: 'expired-vote',
1063
+ vote: 'yes',
1064
+ });
1065
+ const result = await handleRelayVote(mockClient, input);
1066
+
1067
+ expect(result).toBe('Failed to vote: Voting period has ended');
1068
+ });
1069
+
1070
+ it('supports standard vote options', async () => {
1071
+ vi.mocked(mockClient.vote).mockResolvedValue({ success: true });
1072
+
1073
+ const standardVotes = ['approve', 'reject', 'abstain'];
1074
+ for (const voteOption of standardVotes) {
1075
+ const input = relayVoteSchema.parse({
1076
+ proposal_id: 'test-proposal',
1077
+ vote: voteOption,
1078
+ });
1079
+ await handleRelayVote(mockClient, input);
1080
+ }
1081
+
1082
+ expect(mockClient.vote).toHaveBeenCalledTimes(3);
1083
+ });
1084
+ });
1085
+
1086
+ // ============================================================================
1087
+ // Complete SDK/MCP Parity Integration Tests
1088
+ // ============================================================================
1089
+
1090
+ describe('SDK/MCP parity scenarios', () => {
1091
+ let mockClient: RelayClient;
1092
+
1093
+ beforeEach(() => {
1094
+ vi.clearAllMocks();
1095
+ mockClient = createMockClient();
1096
+ });
1097
+
1098
+ it('full orchestration workflow with all tool types', async () => {
1099
+ // Setup mocks
1100
+ vi.mocked(mockClient.spawn).mockResolvedValue({ success: true });
1101
+ vi.mocked(mockClient.joinChannel).mockResolvedValue({ success: true });
1102
+ vi.mocked(mockClient.sendChannelMessage).mockResolvedValue(undefined);
1103
+ vi.mocked(mockClient.broadcast).mockResolvedValue(undefined);
1104
+ vi.mocked(mockClient.createProposal).mockResolvedValue({ success: true });
1105
+ vi.mocked(mockClient.vote).mockResolvedValue({ success: true });
1106
+ vi.mocked(mockClient.leaveChannel).mockResolvedValue({ success: true });
1107
+ vi.mocked(mockClient.release).mockResolvedValue({ success: true });
1108
+
1109
+ // 1. Spawn workers
1110
+ await handleRelaySpawn(mockClient, { name: 'Worker1', cli: 'claude', task: 'Frontend' });
1111
+ await handleRelaySpawn(mockClient, { name: 'Worker2', cli: 'claude', task: 'Backend' });
1112
+ expect(mockClient.spawn).toHaveBeenCalledTimes(2);
1113
+
1114
+ // 2. Join a coordination channel
1115
+ await handleRelayChannelJoin(mockClient, { channel: '#coordination' });
1116
+ expect(mockClient.joinChannel).toHaveBeenCalledWith('#coordination', undefined);
1117
+
1118
+ // 3. Broadcast kickoff message
1119
+ await handleRelayBroadcast(mockClient, { message: 'Project started!' });
1120
+ expect(mockClient.broadcast).toHaveBeenCalled();
1121
+
1122
+ // 4. Create a proposal for decision making
1123
+ await handleRelayProposal(mockClient, {
1124
+ id: 'arch-decision',
1125
+ description: 'Choose architecture',
1126
+ options: ['Monolith', 'Microservices'],
1127
+ });
1128
+ expect(mockClient.createProposal).toHaveBeenCalled();
1129
+
1130
+ // 5. Cast votes
1131
+ await handleRelayVote(mockClient, { proposal_id: 'arch-decision', vote: 'Microservices' });
1132
+ expect(mockClient.vote).toHaveBeenCalled();
1133
+
1134
+ // 6. Send channel update
1135
+ await handleRelayChannelMessage(mockClient, { channel: '#coordination', message: 'Decision made!' });
1136
+ expect(mockClient.sendChannelMessage).toHaveBeenCalled();
1137
+
1138
+ // 7. Cleanup - leave channel and release workers
1139
+ await handleRelayChannelLeave(mockClient, { channel: '#coordination' });
1140
+ await handleRelayRelease(mockClient, { name: 'Worker1' });
1141
+ await handleRelayRelease(mockClient, { name: 'Worker2' });
1142
+ expect(mockClient.release).toHaveBeenCalledTimes(2);
1143
+ });
1144
+
1145
+ it('shadow agent monitoring workflow', async () => {
1146
+ vi.mocked(mockClient.spawn).mockResolvedValue({ success: true });
1147
+ vi.mocked(mockClient.bindAsShadow).mockResolvedValue({ success: true });
1148
+ vi.mocked(mockClient.send).mockResolvedValue(undefined);
1149
+ vi.mocked(mockClient.unbindAsShadow).mockResolvedValue({ success: true });
1150
+ vi.mocked(mockClient.release).mockResolvedValue({ success: true });
1151
+
1152
+ // 1. Spawn primary worker
1153
+ await handleRelaySpawn(mockClient, { name: 'PrimaryWorker', cli: 'claude', task: 'Main task' });
1154
+
1155
+ // 2. Spawn monitor/shadow
1156
+ await handleRelaySpawn(mockClient, { name: 'Monitor', cli: 'claude', task: 'Monitor primary' });
1157
+
1158
+ // 3. Bind monitor as shadow
1159
+ await handleRelayShadowBind(mockClient, {
1160
+ primary_agent: 'PrimaryWorker',
1161
+ speak_on: ['SESSION_END', 'CODE_WRITTEN'],
1162
+ });
1163
+ expect(mockClient.bindAsShadow).toHaveBeenCalledWith('PrimaryWorker', {
1164
+ speakOn: ['SESSION_END', 'CODE_WRITTEN'],
1165
+ });
1166
+
1167
+ // 4. Primary does work, shadow observes (simulated by sending message)
1168
+ await handleRelaySend(mockClient, { to: 'PrimaryWorker', message: 'Do the task' });
1169
+
1170
+ // 5. Unbind shadow when done
1171
+ await handleRelayShadowUnbind(mockClient, { primary_agent: 'PrimaryWorker' });
1172
+ expect(mockClient.unbindAsShadow).toHaveBeenCalledWith('PrimaryWorker');
1173
+
1174
+ // 6. Release both agents
1175
+ await handleRelayRelease(mockClient, { name: 'PrimaryWorker' });
1176
+ await handleRelayRelease(mockClient, { name: 'Monitor' });
1177
+ expect(mockClient.release).toHaveBeenCalledTimes(2);
1178
+ });
1179
+
1180
+ it('pub/sub topic workflow', async () => {
1181
+ vi.mocked(mockClient.spawn).mockResolvedValue({ success: true });
1182
+ vi.mocked(mockClient.subscribe).mockResolvedValue({ success: true });
1183
+ vi.mocked(mockClient.broadcast).mockResolvedValue(undefined);
1184
+ vi.mocked(mockClient.unsubscribe).mockResolvedValue({ success: true });
1185
+ vi.mocked(mockClient.release).mockResolvedValue({ success: true });
1186
+
1187
+ // 1. Spawn multiple workers
1188
+ const workers = ['Worker1', 'Worker2', 'Worker3'];
1189
+ for (const name of workers) {
1190
+ await handleRelaySpawn(mockClient, { name, cli: 'claude', task: 'Subscribe test' });
1191
+ }
1192
+ expect(mockClient.spawn).toHaveBeenCalledTimes(3);
1193
+
1194
+ // 2. Subscribe all workers to a topic
1195
+ for (const _ of workers) {
1196
+ await handleRelaySubscribe(mockClient, { topic: 'updates' });
1197
+ }
1198
+ expect(mockClient.subscribe).toHaveBeenCalledTimes(3);
1199
+
1200
+ // 3. Broadcast to topic (simulated)
1201
+ await handleRelayBroadcast(mockClient, { message: 'Update for all subscribers' });
1202
+ expect(mockClient.broadcast).toHaveBeenCalled();
1203
+
1204
+ // 4. Unsubscribe workers
1205
+ for (const _ of workers) {
1206
+ await handleRelayUnsubscribe(mockClient, { topic: 'updates' });
1207
+ }
1208
+ expect(mockClient.unsubscribe).toHaveBeenCalledTimes(3);
1209
+
1210
+ // 5. Release workers
1211
+ for (const name of workers) {
1212
+ await handleRelayRelease(mockClient, { name });
1213
+ }
1214
+ expect(mockClient.release).toHaveBeenCalledTimes(3);
1215
+ });
1216
+
1217
+ it('multi-channel coordination workflow', async () => {
1218
+ vi.mocked(mockClient.joinChannel).mockResolvedValue({ success: true });
1219
+ vi.mocked(mockClient.sendChannelMessage).mockResolvedValue(undefined);
1220
+ vi.mocked(mockClient.leaveChannel).mockResolvedValue({ success: true });
1221
+
1222
+ const channels = ['#frontend', '#backend', '#devops'];
1223
+
1224
+ // 1. Join multiple channels
1225
+ for (const channel of channels) {
1226
+ await handleRelayChannelJoin(mockClient, { channel });
1227
+ }
1228
+ expect(mockClient.joinChannel).toHaveBeenCalledTimes(3);
1229
+
1230
+ // 2. Send messages to each channel
1231
+ for (const channel of channels) {
1232
+ await handleRelayChannelMessage(mockClient, { channel, message: `Update for ${channel}` });
1233
+ }
1234
+ expect(mockClient.sendChannelMessage).toHaveBeenCalledTimes(3);
1235
+
1236
+ // 3. Leave all channels
1237
+ for (const channel of channels) {
1238
+ await handleRelayChannelLeave(mockClient, { channel, reason: 'Task complete' });
1239
+ }
1240
+ expect(mockClient.leaveChannel).toHaveBeenCalledTimes(3);
1241
+ });
1242
+ });