opentasks 0.0.6 → 0.0.7

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 (660) hide show
  1. package/README.md +68 -0
  2. package/dist/__tests__/cli-tools.test.d.ts +8 -0
  3. package/dist/__tests__/cli-tools.test.d.ts.map +1 -0
  4. package/dist/__tests__/cli-tools.test.js +546 -0
  5. package/dist/__tests__/cli-tools.test.js.map +1 -0
  6. package/dist/__tests__/cli.test.d.ts +5 -0
  7. package/dist/__tests__/cli.test.d.ts.map +1 -0
  8. package/dist/__tests__/cli.test.js +77 -0
  9. package/dist/__tests__/cli.test.js.map +1 -0
  10. package/dist/__tests__/p1-p3-gaps.test.d.ts +2 -0
  11. package/dist/__tests__/p1-p3-gaps.test.d.ts.map +1 -0
  12. package/dist/__tests__/p1-p3-gaps.test.js +463 -0
  13. package/dist/__tests__/p1-p3-gaps.test.js.map +1 -0
  14. package/dist/cli.d.ts +1 -0
  15. package/dist/cli.d.ts.map +1 -1
  16. package/dist/cli.js +64 -0
  17. package/dist/cli.js.map +1 -1
  18. package/dist/client/__tests__/client-crud.test.d.ts +7 -0
  19. package/dist/client/__tests__/client-crud.test.d.ts.map +1 -0
  20. package/dist/client/__tests__/client-crud.test.js +404 -0
  21. package/dist/client/__tests__/client-crud.test.js.map +1 -0
  22. package/dist/client/__tests__/client.test.d.ts +5 -0
  23. package/dist/client/__tests__/client.test.d.ts.map +1 -0
  24. package/dist/client/__tests__/client.test.js +518 -0
  25. package/dist/client/__tests__/client.test.js.map +1 -0
  26. package/dist/client/client.d.ts +47 -1
  27. package/dist/client/client.d.ts.map +1 -1
  28. package/dist/client/client.js +71 -0
  29. package/dist/client/client.js.map +1 -1
  30. package/dist/client/index.d.ts +1 -1
  31. package/dist/client/index.d.ts.map +1 -1
  32. package/dist/config/__tests__/defaults.test.d.ts +2 -0
  33. package/dist/config/__tests__/defaults.test.d.ts.map +1 -0
  34. package/dist/config/__tests__/defaults.test.js +57 -0
  35. package/dist/config/__tests__/defaults.test.js.map +1 -0
  36. package/dist/config/__tests__/env.test.d.ts +2 -0
  37. package/dist/config/__tests__/env.test.d.ts.map +1 -0
  38. package/dist/config/__tests__/env.test.js +136 -0
  39. package/dist/config/__tests__/env.test.js.map +1 -0
  40. package/dist/config/__tests__/index.test.d.ts +2 -0
  41. package/dist/config/__tests__/index.test.d.ts.map +1 -0
  42. package/dist/config/__tests__/index.test.js +113 -0
  43. package/dist/config/__tests__/index.test.js.map +1 -0
  44. package/dist/config/__tests__/loader.test.d.ts +2 -0
  45. package/dist/config/__tests__/loader.test.d.ts.map +1 -0
  46. package/dist/config/__tests__/loader.test.js +128 -0
  47. package/dist/config/__tests__/loader.test.js.map +1 -0
  48. package/dist/config/__tests__/merge.test.d.ts +2 -0
  49. package/dist/config/__tests__/merge.test.d.ts.map +1 -0
  50. package/dist/config/__tests__/merge.test.js +79 -0
  51. package/dist/config/__tests__/merge.test.js.map +1 -0
  52. package/dist/config/__tests__/schema.test.d.ts +2 -0
  53. package/dist/config/__tests__/schema.test.d.ts.map +1 -0
  54. package/dist/config/__tests__/schema.test.js +300 -0
  55. package/dist/config/__tests__/schema.test.js.map +1 -0
  56. package/dist/config/schema.d.ts +178 -4
  57. package/dist/config/schema.d.ts.map +1 -1
  58. package/dist/config/schema.js +109 -7
  59. package/dist/config/schema.js.map +1 -1
  60. package/dist/context-files/context-files.d.ts +72 -0
  61. package/dist/context-files/context-files.d.ts.map +1 -0
  62. package/dist/context-files/context-files.js +145 -0
  63. package/dist/context-files/context-files.js.map +1 -0
  64. package/dist/context-files/index.d.ts +16 -0
  65. package/dist/context-files/index.d.ts.map +1 -0
  66. package/dist/context-files/index.js +14 -0
  67. package/dist/context-files/index.js.map +1 -0
  68. package/dist/context-files/resolver.d.ts +43 -0
  69. package/dist/context-files/resolver.d.ts.map +1 -0
  70. package/dist/context-files/resolver.js +127 -0
  71. package/dist/context-files/resolver.js.map +1 -0
  72. package/dist/context-files/types.d.ts +94 -0
  73. package/dist/context-files/types.d.ts.map +1 -0
  74. package/dist/context-files/types.js +10 -0
  75. package/dist/context-files/types.js.map +1 -0
  76. package/dist/context-files/watcher-integration.d.ts +47 -0
  77. package/dist/context-files/watcher-integration.d.ts.map +1 -0
  78. package/dist/context-files/watcher-integration.js +47 -0
  79. package/dist/context-files/watcher-integration.js.map +1 -0
  80. package/dist/core/__tests__/conditional-redirects.test.d.ts +2 -0
  81. package/dist/core/__tests__/conditional-redirects.test.d.ts.map +1 -0
  82. package/dist/core/__tests__/conditional-redirects.test.js +83 -0
  83. package/dist/core/__tests__/conditional-redirects.test.js.map +1 -0
  84. package/dist/core/__tests__/connections.test.d.ts +2 -0
  85. package/dist/core/__tests__/connections.test.d.ts.map +1 -0
  86. package/dist/core/__tests__/connections.test.js +158 -0
  87. package/dist/core/__tests__/connections.test.js.map +1 -0
  88. package/dist/core/__tests__/hash.test.d.ts +2 -0
  89. package/dist/core/__tests__/hash.test.d.ts.map +1 -0
  90. package/dist/core/__tests__/hash.test.js +139 -0
  91. package/dist/core/__tests__/hash.test.js.map +1 -0
  92. package/dist/core/__tests__/id.test.d.ts +2 -0
  93. package/dist/core/__tests__/id.test.d.ts.map +1 -0
  94. package/dist/core/__tests__/id.test.js +142 -0
  95. package/dist/core/__tests__/id.test.js.map +1 -0
  96. package/dist/core/__tests__/location.test.d.ts +2 -0
  97. package/dist/core/__tests__/location.test.d.ts.map +1 -0
  98. package/dist/core/__tests__/location.test.js +77 -0
  99. package/dist/core/__tests__/location.test.js.map +1 -0
  100. package/dist/core/__tests__/merge-driver.test.d.ts +2 -0
  101. package/dist/core/__tests__/merge-driver.test.d.ts.map +1 -0
  102. package/dist/core/__tests__/merge-driver.test.js +218 -0
  103. package/dist/core/__tests__/merge-driver.test.js.map +1 -0
  104. package/dist/core/__tests__/redirects.test.d.ts +2 -0
  105. package/dist/core/__tests__/redirects.test.d.ts.map +1 -0
  106. package/dist/core/__tests__/redirects.test.js +123 -0
  107. package/dist/core/__tests__/redirects.test.js.map +1 -0
  108. package/dist/core/__tests__/resolve-location-target.test.d.ts +8 -0
  109. package/dist/core/__tests__/resolve-location-target.test.d.ts.map +1 -0
  110. package/dist/core/__tests__/resolve-location-target.test.js +303 -0
  111. package/dist/core/__tests__/resolve-location-target.test.js.map +1 -0
  112. package/dist/core/__tests__/uri.test.d.ts +2 -0
  113. package/dist/core/__tests__/uri.test.d.ts.map +1 -0
  114. package/dist/core/__tests__/uri.test.js +159 -0
  115. package/dist/core/__tests__/uri.test.js.map +1 -0
  116. package/dist/core/__tests__/worktree.test.d.ts +2 -0
  117. package/dist/core/__tests__/worktree.test.d.ts.map +1 -0
  118. package/dist/core/__tests__/worktree.test.js +120 -0
  119. package/dist/core/__tests__/worktree.test.js.map +1 -0
  120. package/dist/core/merge-driver.d.ts +5 -0
  121. package/dist/core/merge-driver.d.ts.map +1 -1
  122. package/dist/core/merge-driver.js +35 -0
  123. package/dist/core/merge-driver.js.map +1 -1
  124. package/dist/daemon/__tests__/flush.test.d.ts +5 -0
  125. package/dist/daemon/__tests__/flush.test.d.ts.map +1 -0
  126. package/dist/daemon/__tests__/flush.test.js +213 -0
  127. package/dist/daemon/__tests__/flush.test.js.map +1 -0
  128. package/dist/daemon/__tests__/integration.test.d.ts +7 -0
  129. package/dist/daemon/__tests__/integration.test.d.ts.map +1 -0
  130. package/dist/daemon/__tests__/integration.test.js +276 -0
  131. package/dist/daemon/__tests__/integration.test.js.map +1 -0
  132. package/dist/daemon/__tests__/ipc.test.d.ts +5 -0
  133. package/dist/daemon/__tests__/ipc.test.d.ts.map +1 -0
  134. package/dist/daemon/__tests__/ipc.test.js +314 -0
  135. package/dist/daemon/__tests__/ipc.test.js.map +1 -0
  136. package/dist/daemon/__tests__/lifecycle.test.d.ts +5 -0
  137. package/dist/daemon/__tests__/lifecycle.test.d.ts.map +1 -0
  138. package/dist/daemon/__tests__/lifecycle.test.js +301 -0
  139. package/dist/daemon/__tests__/lifecycle.test.js.map +1 -0
  140. package/dist/daemon/__tests__/lock.test.d.ts +5 -0
  141. package/dist/daemon/__tests__/lock.test.d.ts.map +1 -0
  142. package/dist/daemon/__tests__/lock.test.js +192 -0
  143. package/dist/daemon/__tests__/lock.test.js.map +1 -0
  144. package/dist/daemon/__tests__/methods/graph.test.d.ts +5 -0
  145. package/dist/daemon/__tests__/methods/graph.test.d.ts.map +1 -0
  146. package/dist/daemon/__tests__/methods/graph.test.js +309 -0
  147. package/dist/daemon/__tests__/methods/graph.test.js.map +1 -0
  148. package/dist/daemon/__tests__/methods/provider.test.d.ts +7 -0
  149. package/dist/daemon/__tests__/methods/provider.test.d.ts.map +1 -0
  150. package/dist/daemon/__tests__/methods/provider.test.js +181 -0
  151. package/dist/daemon/__tests__/methods/provider.test.js.map +1 -0
  152. package/dist/daemon/__tests__/methods/tools.test.d.ts +5 -0
  153. package/dist/daemon/__tests__/methods/tools.test.d.ts.map +1 -0
  154. package/dist/daemon/__tests__/methods/tools.test.js +587 -0
  155. package/dist/daemon/__tests__/methods/tools.test.js.map +1 -0
  156. package/dist/daemon/__tests__/multi-location.test.d.ts +8 -0
  157. package/dist/daemon/__tests__/multi-location.test.d.ts.map +1 -0
  158. package/dist/daemon/__tests__/multi-location.test.js +669 -0
  159. package/dist/daemon/__tests__/multi-location.test.js.map +1 -0
  160. package/dist/daemon/__tests__/registry.test.d.ts +5 -0
  161. package/dist/daemon/__tests__/registry.test.d.ts.map +1 -0
  162. package/dist/daemon/__tests__/registry.test.js +208 -0
  163. package/dist/daemon/__tests__/registry.test.js.map +1 -0
  164. package/dist/daemon/__tests__/watcher.test.d.ts +5 -0
  165. package/dist/daemon/__tests__/watcher.test.d.ts.map +1 -0
  166. package/dist/daemon/__tests__/watcher.test.js +234 -0
  167. package/dist/daemon/__tests__/watcher.test.js.map +1 -0
  168. package/dist/daemon/index.d.ts +6 -4
  169. package/dist/daemon/index.d.ts.map +1 -1
  170. package/dist/daemon/index.js +3 -2
  171. package/dist/daemon/index.js.map +1 -1
  172. package/dist/daemon/ipc.d.ts.map +1 -1
  173. package/dist/daemon/ipc.js +8 -1
  174. package/dist/daemon/ipc.js.map +1 -1
  175. package/dist/daemon/lifecycle.d.ts.map +1 -1
  176. package/dist/daemon/lifecycle.js +138 -25
  177. package/dist/daemon/lifecycle.js.map +1 -1
  178. package/dist/daemon/location-state.d.ts +12 -6
  179. package/dist/daemon/location-state.d.ts.map +1 -1
  180. package/dist/daemon/location-state.js +50 -20
  181. package/dist/daemon/location-state.js.map +1 -1
  182. package/dist/daemon/methods/__tests__/graph.test.d.ts +5 -0
  183. package/dist/daemon/methods/__tests__/graph.test.d.ts.map +1 -0
  184. package/dist/daemon/methods/__tests__/graph.test.js +274 -0
  185. package/dist/daemon/methods/__tests__/graph.test.js.map +1 -0
  186. package/dist/daemon/methods/__tests__/provider.test.d.ts +5 -0
  187. package/dist/daemon/methods/__tests__/provider.test.d.ts.map +1 -0
  188. package/dist/daemon/methods/__tests__/provider.test.js +184 -0
  189. package/dist/daemon/methods/__tests__/provider.test.js.map +1 -0
  190. package/dist/daemon/methods/__tests__/tools.test.d.ts +5 -0
  191. package/dist/daemon/methods/__tests__/tools.test.d.ts.map +1 -0
  192. package/dist/daemon/methods/__tests__/tools.test.js +295 -0
  193. package/dist/daemon/methods/__tests__/tools.test.js.map +1 -0
  194. package/dist/daemon/methods/context-files.d.ts +14 -0
  195. package/dist/daemon/methods/context-files.d.ts.map +1 -0
  196. package/dist/daemon/methods/context-files.js +95 -0
  197. package/dist/daemon/methods/context-files.js.map +1 -0
  198. package/dist/daemon/methods/provider.d.ts.map +1 -1
  199. package/dist/daemon/methods/provider.js +15 -0
  200. package/dist/daemon/methods/provider.js.map +1 -1
  201. package/dist/daemon/methods/tools.d.ts +1 -1
  202. package/dist/daemon/methods/tools.d.ts.map +1 -1
  203. package/dist/daemon/methods/tools.js +3 -2
  204. package/dist/daemon/methods/tools.js.map +1 -1
  205. package/dist/daemon/sessionlog-linker.d.ts +71 -0
  206. package/dist/daemon/sessionlog-linker.d.ts.map +1 -0
  207. package/dist/daemon/sessionlog-linker.js +472 -0
  208. package/dist/daemon/sessionlog-linker.js.map +1 -0
  209. package/dist/daemon/sessionlog-watcher.d.ts +79 -0
  210. package/dist/daemon/sessionlog-watcher.d.ts.map +1 -0
  211. package/dist/daemon/sessionlog-watcher.js +289 -0
  212. package/dist/daemon/sessionlog-watcher.js.map +1 -0
  213. package/dist/graph/__tests__/EdgeTypeRegistry.test.d.ts +2 -0
  214. package/dist/graph/__tests__/EdgeTypeRegistry.test.d.ts.map +1 -0
  215. package/dist/graph/__tests__/EdgeTypeRegistry.test.js +212 -0
  216. package/dist/graph/__tests__/EdgeTypeRegistry.test.js.map +1 -0
  217. package/dist/graph/__tests__/FederatedGraph.test.d.ts +2 -0
  218. package/dist/graph/__tests__/FederatedGraph.test.d.ts.map +1 -0
  219. package/dist/graph/__tests__/FederatedGraph.test.js +661 -0
  220. package/dist/graph/__tests__/FederatedGraph.test.js.map +1 -0
  221. package/dist/graph/__tests__/GraphologyAdapter.test.d.ts +2 -0
  222. package/dist/graph/__tests__/GraphologyAdapter.test.d.ts.map +1 -0
  223. package/dist/graph/__tests__/GraphologyAdapter.test.js +326 -0
  224. package/dist/graph/__tests__/GraphologyAdapter.test.js.map +1 -0
  225. package/dist/graph/__tests__/HydratingFederatedGraph.test.d.ts +2 -0
  226. package/dist/graph/__tests__/HydratingFederatedGraph.test.d.ts.map +1 -0
  227. package/dist/graph/__tests__/HydratingFederatedGraph.test.js +587 -0
  228. package/dist/graph/__tests__/HydratingFederatedGraph.test.js.map +1 -0
  229. package/dist/graph/__tests__/debounce.test.d.ts +5 -0
  230. package/dist/graph/__tests__/debounce.test.d.ts.map +1 -0
  231. package/dist/graph/__tests__/debounce.test.js +195 -0
  232. package/dist/graph/__tests__/debounce.test.js.map +1 -0
  233. package/dist/graph/__tests__/edge-cases.test.d.ts +8 -0
  234. package/dist/graph/__tests__/edge-cases.test.d.ts.map +1 -0
  235. package/dist/graph/__tests__/edge-cases.test.js +472 -0
  236. package/dist/graph/__tests__/edge-cases.test.js.map +1 -0
  237. package/dist/graph/__tests__/expansion.test.d.ts +2 -0
  238. package/dist/graph/__tests__/expansion.test.d.ts.map +1 -0
  239. package/dist/graph/__tests__/expansion.test.js +105 -0
  240. package/dist/graph/__tests__/expansion.test.js.map +1 -0
  241. package/dist/graph/__tests__/provider-store.test.d.ts +5 -0
  242. package/dist/graph/__tests__/provider-store.test.d.ts.map +1 -0
  243. package/dist/graph/__tests__/provider-store.test.js +791 -0
  244. package/dist/graph/__tests__/provider-store.test.js.map +1 -0
  245. package/dist/graph/__tests__/query.test.d.ts +5 -0
  246. package/dist/graph/__tests__/query.test.d.ts.map +1 -0
  247. package/dist/graph/__tests__/query.test.js +774 -0
  248. package/dist/graph/__tests__/query.test.js.map +1 -0
  249. package/dist/graph/__tests__/store.test.d.ts +5 -0
  250. package/dist/graph/__tests__/store.test.d.ts.map +1 -0
  251. package/dist/graph/__tests__/store.test.js +489 -0
  252. package/dist/graph/__tests__/store.test.js.map +1 -0
  253. package/dist/graph/__tests__/sync.test.d.ts +5 -0
  254. package/dist/graph/__tests__/sync.test.d.ts.map +1 -0
  255. package/dist/graph/__tests__/sync.test.js +129 -0
  256. package/dist/graph/__tests__/sync.test.js.map +1 -0
  257. package/dist/graph/__tests__/validation.test.d.ts +2 -0
  258. package/dist/graph/__tests__/validation.test.d.ts.map +1 -0
  259. package/dist/graph/__tests__/validation.test.js +521 -0
  260. package/dist/graph/__tests__/validation.test.js.map +1 -0
  261. package/dist/graph/index.d.ts +1 -1
  262. package/dist/graph/index.d.ts.map +1 -1
  263. package/dist/graph/index.js.map +1 -1
  264. package/dist/graph/provider-store.d.ts +78 -4
  265. package/dist/graph/provider-store.d.ts.map +1 -1
  266. package/dist/graph/provider-store.js +579 -55
  267. package/dist/graph/provider-store.js.map +1 -1
  268. package/dist/graph/store.d.ts.map +1 -1
  269. package/dist/graph/store.js +3 -0
  270. package/dist/graph/store.js.map +1 -1
  271. package/dist/graph/types.d.ts +16 -0
  272. package/dist/graph/types.d.ts.map +1 -1
  273. package/dist/graph/types.js.map +1 -1
  274. package/dist/index.d.ts +4 -2
  275. package/dist/index.d.ts.map +1 -1
  276. package/dist/index.js +9 -3
  277. package/dist/index.js.map +1 -1
  278. package/dist/materialization/git-archive-store.js +2 -2
  279. package/dist/materialization/git-archive-store.js.map +1 -1
  280. package/dist/materialization/git-remote-store.js +2 -2
  281. package/dist/materialization/git-remote-store.js.map +1 -1
  282. package/dist/materialization/snapshot.js +4 -4
  283. package/dist/materialization/snapshot.js.map +1 -1
  284. package/dist/mcp/index.d.ts +8 -0
  285. package/dist/mcp/index.d.ts.map +1 -0
  286. package/dist/mcp/index.js +8 -0
  287. package/dist/mcp/index.js.map +1 -0
  288. package/dist/mcp/server.d.ts +39 -0
  289. package/dist/mcp/server.d.ts.map +1 -0
  290. package/dist/mcp/server.js +677 -0
  291. package/dist/mcp/server.js.map +1 -0
  292. package/dist/mcp/stdio.d.ts +14 -0
  293. package/dist/mcp/stdio.d.ts.map +1 -0
  294. package/dist/mcp/stdio.js +19 -0
  295. package/dist/mcp/stdio.js.map +1 -0
  296. package/dist/providers/__tests__/beads.test.d.ts +5 -0
  297. package/dist/providers/__tests__/beads.test.d.ts.map +1 -0
  298. package/dist/providers/__tests__/beads.test.js +591 -0
  299. package/dist/providers/__tests__/beads.test.js.map +1 -0
  300. package/dist/providers/__tests__/claude-tasks.test.d.ts +5 -0
  301. package/dist/providers/__tests__/claude-tasks.test.d.ts.map +1 -0
  302. package/dist/providers/__tests__/claude-tasks.test.js +392 -0
  303. package/dist/providers/__tests__/claude-tasks.test.js.map +1 -0
  304. package/dist/providers/__tests__/from-config.test.d.ts +5 -0
  305. package/dist/providers/__tests__/from-config.test.d.ts.map +1 -0
  306. package/dist/providers/__tests__/from-config.test.js +152 -0
  307. package/dist/providers/__tests__/from-config.test.js.map +1 -0
  308. package/dist/providers/__tests__/materialization.test.d.ts +5 -0
  309. package/dist/providers/__tests__/materialization.test.d.ts.map +1 -0
  310. package/dist/providers/__tests__/materialization.test.js +407 -0
  311. package/dist/providers/__tests__/materialization.test.js.map +1 -0
  312. package/dist/providers/__tests__/native.test.d.ts +5 -0
  313. package/dist/providers/__tests__/native.test.d.ts.map +1 -0
  314. package/dist/providers/__tests__/native.test.js +566 -0
  315. package/dist/providers/__tests__/native.test.js.map +1 -0
  316. package/dist/providers/__tests__/registry.test.d.ts +5 -0
  317. package/dist/providers/__tests__/registry.test.d.ts.map +1 -0
  318. package/dist/providers/__tests__/registry.test.js +183 -0
  319. package/dist/providers/__tests__/registry.test.js.map +1 -0
  320. package/dist/providers/beads.d.ts.map +1 -1
  321. package/dist/providers/beads.js +17 -1
  322. package/dist/providers/beads.js.map +1 -1
  323. package/dist/providers/claude-tasks-fs.d.ts +22 -0
  324. package/dist/providers/claude-tasks-fs.d.ts.map +1 -0
  325. package/dist/providers/claude-tasks-fs.js +158 -0
  326. package/dist/providers/claude-tasks-fs.js.map +1 -0
  327. package/dist/providers/claude-tasks.d.ts +13 -4
  328. package/dist/providers/claude-tasks.d.ts.map +1 -1
  329. package/dist/providers/claude-tasks.js +318 -5
  330. package/dist/providers/claude-tasks.js.map +1 -1
  331. package/dist/providers/from-config.d.ts.map +1 -1
  332. package/dist/providers/from-config.js +35 -17
  333. package/dist/providers/from-config.js.map +1 -1
  334. package/dist/providers/global.d.ts.map +1 -1
  335. package/dist/providers/global.js +5 -0
  336. package/dist/providers/global.js.map +1 -1
  337. package/dist/providers/index.d.ts +6 -4
  338. package/dist/providers/index.d.ts.map +1 -1
  339. package/dist/providers/index.js +4 -3
  340. package/dist/providers/index.js.map +1 -1
  341. package/dist/providers/map.d.ts.map +1 -1
  342. package/dist/providers/map.js +5 -0
  343. package/dist/providers/map.js.map +1 -1
  344. package/dist/providers/materialization.d.ts +23 -5
  345. package/dist/providers/materialization.d.ts.map +1 -1
  346. package/dist/providers/materialization.js +95 -4
  347. package/dist/providers/materialization.js.map +1 -1
  348. package/dist/providers/native.d.ts.map +1 -1
  349. package/dist/providers/native.js +5 -0
  350. package/dist/providers/native.js.map +1 -1
  351. package/dist/providers/sessionlog.d.ts +81 -0
  352. package/dist/providers/sessionlog.d.ts.map +1 -0
  353. package/dist/providers/sessionlog.js +478 -0
  354. package/dist/providers/sessionlog.js.map +1 -0
  355. package/dist/providers/sudocode.d.ts.map +1 -1
  356. package/dist/providers/sudocode.js +17 -1
  357. package/dist/providers/sudocode.js.map +1 -1
  358. package/dist/providers/traits/Reconcilable.d.ts +57 -0
  359. package/dist/providers/traits/Reconcilable.d.ts.map +1 -0
  360. package/dist/providers/traits/Reconcilable.js +18 -0
  361. package/dist/providers/traits/Reconcilable.js.map +1 -0
  362. package/dist/providers/traits/__tests__/RelationshipQueryable.test.d.ts +2 -0
  363. package/dist/providers/traits/__tests__/RelationshipQueryable.test.d.ts.map +1 -0
  364. package/dist/providers/traits/__tests__/RelationshipQueryable.test.js +169 -0
  365. package/dist/providers/traits/__tests__/RelationshipQueryable.test.js.map +1 -0
  366. package/dist/providers/traits/__tests__/TaskManageable.test.d.ts +2 -0
  367. package/dist/providers/traits/__tests__/TaskManageable.test.d.ts.map +1 -0
  368. package/dist/providers/traits/__tests__/TaskManageable.test.js +172 -0
  369. package/dist/providers/traits/__tests__/TaskManageable.test.js.map +1 -0
  370. package/dist/providers/traits/index.d.ts +2 -0
  371. package/dist/providers/traits/index.d.ts.map +1 -1
  372. package/dist/providers/traits/index.js +1 -0
  373. package/dist/providers/traits/index.js.map +1 -1
  374. package/dist/providers/types.d.ts +63 -0
  375. package/dist/providers/types.d.ts.map +1 -1
  376. package/dist/providers/types.js +22 -0
  377. package/dist/providers/types.js.map +1 -1
  378. package/dist/schema/__tests__/validation.test.d.ts +2 -0
  379. package/dist/schema/__tests__/validation.test.d.ts.map +1 -0
  380. package/dist/schema/__tests__/validation.test.js +241 -0
  381. package/dist/schema/__tests__/validation.test.js.map +1 -0
  382. package/dist/schema/edges.d.ts +3 -3
  383. package/dist/schema/edges.d.ts.map +1 -1
  384. package/dist/sessionlog/agent/agents/claude-code.d.ts +76 -0
  385. package/dist/sessionlog/agent/agents/claude-code.d.ts.map +1 -0
  386. package/dist/sessionlog/agent/agents/claude-code.js +759 -0
  387. package/dist/sessionlog/agent/agents/claude-code.js.map +1 -0
  388. package/dist/sessionlog/agent/agents/cursor.d.ts +35 -0
  389. package/dist/sessionlog/agent/agents/cursor.d.ts.map +1 -0
  390. package/dist/sessionlog/agent/agents/cursor.js +294 -0
  391. package/dist/sessionlog/agent/agents/cursor.js.map +1 -0
  392. package/dist/sessionlog/agent/agents/gemini-cli.d.ts +62 -0
  393. package/dist/sessionlog/agent/agents/gemini-cli.d.ts.map +1 -0
  394. package/dist/sessionlog/agent/agents/gemini-cli.js +462 -0
  395. package/dist/sessionlog/agent/agents/gemini-cli.js.map +1 -0
  396. package/dist/sessionlog/agent/agents/opencode.d.ts +100 -0
  397. package/dist/sessionlog/agent/agents/opencode.d.ts.map +1 -0
  398. package/dist/sessionlog/agent/agents/opencode.js +423 -0
  399. package/dist/sessionlog/agent/agents/opencode.js.map +1 -0
  400. package/dist/sessionlog/agent/registry.d.ts +54 -0
  401. package/dist/sessionlog/agent/registry.d.ts.map +1 -0
  402. package/dist/sessionlog/agent/registry.js +123 -0
  403. package/dist/sessionlog/agent/registry.js.map +1 -0
  404. package/dist/sessionlog/agent/session-types.d.ts +45 -0
  405. package/dist/sessionlog/agent/session-types.d.ts.map +1 -0
  406. package/dist/sessionlog/agent/session-types.js +50 -0
  407. package/dist/sessionlog/agent/session-types.js.map +1 -0
  408. package/dist/sessionlog/agent/types.d.ts +126 -0
  409. package/dist/sessionlog/agent/types.d.ts.map +1 -0
  410. package/dist/sessionlog/agent/types.js +39 -0
  411. package/dist/sessionlog/agent/types.js.map +1 -0
  412. package/dist/sessionlog/commands/clean.d.ts +40 -0
  413. package/dist/sessionlog/commands/clean.d.ts.map +1 -0
  414. package/dist/sessionlog/commands/clean.js +105 -0
  415. package/dist/sessionlog/commands/clean.js.map +1 -0
  416. package/dist/sessionlog/commands/disable.d.ts +23 -0
  417. package/dist/sessionlog/commands/disable.d.ts.map +1 -0
  418. package/dist/sessionlog/commands/disable.js +57 -0
  419. package/dist/sessionlog/commands/disable.js.map +1 -0
  420. package/dist/sessionlog/commands/doctor.d.ts +43 -0
  421. package/dist/sessionlog/commands/doctor.d.ts.map +1 -0
  422. package/dist/sessionlog/commands/doctor.js +97 -0
  423. package/dist/sessionlog/commands/doctor.js.map +1 -0
  424. package/dist/sessionlog/commands/enable.d.ts +31 -0
  425. package/dist/sessionlog/commands/enable.d.ts.map +1 -0
  426. package/dist/sessionlog/commands/enable.js +102 -0
  427. package/dist/sessionlog/commands/enable.js.map +1 -0
  428. package/dist/sessionlog/commands/explain.d.ts +69 -0
  429. package/dist/sessionlog/commands/explain.d.ts.map +1 -0
  430. package/dist/sessionlog/commands/explain.js +185 -0
  431. package/dist/sessionlog/commands/explain.js.map +1 -0
  432. package/dist/sessionlog/commands/reset.d.ts +23 -0
  433. package/dist/sessionlog/commands/reset.d.ts.map +1 -0
  434. package/dist/sessionlog/commands/reset.js +68 -0
  435. package/dist/sessionlog/commands/reset.js.map +1 -0
  436. package/dist/sessionlog/commands/resume.d.ts +42 -0
  437. package/dist/sessionlog/commands/resume.d.ts.map +1 -0
  438. package/dist/sessionlog/commands/resume.js +134 -0
  439. package/dist/sessionlog/commands/resume.js.map +1 -0
  440. package/dist/sessionlog/commands/rewind.d.ts +40 -0
  441. package/dist/sessionlog/commands/rewind.d.ts.map +1 -0
  442. package/dist/sessionlog/commands/rewind.js +155 -0
  443. package/dist/sessionlog/commands/rewind.js.map +1 -0
  444. package/dist/sessionlog/commands/status.d.ts +54 -0
  445. package/dist/sessionlog/commands/status.d.ts.map +1 -0
  446. package/dist/sessionlog/commands/status.js +95 -0
  447. package/dist/sessionlog/commands/status.js.map +1 -0
  448. package/dist/sessionlog/config.d.ts +40 -0
  449. package/dist/sessionlog/config.d.ts.map +1 -0
  450. package/dist/sessionlog/config.js +126 -0
  451. package/dist/sessionlog/config.js.map +1 -0
  452. package/dist/sessionlog/git-operations.d.ts +173 -0
  453. package/dist/sessionlog/git-operations.d.ts.map +1 -0
  454. package/dist/sessionlog/git-operations.js +399 -0
  455. package/dist/sessionlog/git-operations.js.map +1 -0
  456. package/dist/sessionlog/hooks/git-hooks.d.ts +22 -0
  457. package/dist/sessionlog/hooks/git-hooks.d.ts.map +1 -0
  458. package/dist/sessionlog/hooks/git-hooks.js +145 -0
  459. package/dist/sessionlog/hooks/git-hooks.js.map +1 -0
  460. package/dist/sessionlog/hooks/lifecycle.d.ts +21 -0
  461. package/dist/sessionlog/hooks/lifecycle.d.ts.map +1 -0
  462. package/dist/sessionlog/hooks/lifecycle.js +179 -0
  463. package/dist/sessionlog/hooks/lifecycle.js.map +1 -0
  464. package/dist/sessionlog/index.d.ts +69 -0
  465. package/dist/sessionlog/index.d.ts.map +1 -0
  466. package/dist/sessionlog/index.js +154 -0
  467. package/dist/sessionlog/index.js.map +1 -0
  468. package/dist/sessionlog/security/redaction.d.ts +35 -0
  469. package/dist/sessionlog/security/redaction.d.ts.map +1 -0
  470. package/dist/sessionlog/security/redaction.js +221 -0
  471. package/dist/sessionlog/security/redaction.js.map +1 -0
  472. package/dist/sessionlog/session/state-machine.d.ts +90 -0
  473. package/dist/sessionlog/session/state-machine.d.ts.map +1 -0
  474. package/dist/sessionlog/session/state-machine.js +347 -0
  475. package/dist/sessionlog/session/state-machine.js.map +1 -0
  476. package/dist/sessionlog/store/checkpoint-store.d.ts +47 -0
  477. package/dist/sessionlog/store/checkpoint-store.d.ts.map +1 -0
  478. package/dist/sessionlog/store/checkpoint-store.js +309 -0
  479. package/dist/sessionlog/store/checkpoint-store.js.map +1 -0
  480. package/dist/sessionlog/store/native-store.d.ts +21 -0
  481. package/dist/sessionlog/store/native-store.d.ts.map +1 -0
  482. package/dist/sessionlog/store/native-store.js +162 -0
  483. package/dist/sessionlog/store/native-store.js.map +1 -0
  484. package/dist/sessionlog/store/provider-types.d.ts +78 -0
  485. package/dist/sessionlog/store/provider-types.d.ts.map +1 -0
  486. package/dist/sessionlog/store/provider-types.js +12 -0
  487. package/dist/sessionlog/store/provider-types.js.map +1 -0
  488. package/dist/sessionlog/store/session-store.d.ts +28 -0
  489. package/dist/sessionlog/store/session-store.d.ts.map +1 -0
  490. package/dist/sessionlog/store/session-store.js +187 -0
  491. package/dist/sessionlog/store/session-store.js.map +1 -0
  492. package/dist/sessionlog/strategy/attribution.d.ts +39 -0
  493. package/dist/sessionlog/strategy/attribution.d.ts.map +1 -0
  494. package/dist/sessionlog/strategy/attribution.js +227 -0
  495. package/dist/sessionlog/strategy/attribution.js.map +1 -0
  496. package/dist/sessionlog/strategy/common.d.ts +60 -0
  497. package/dist/sessionlog/strategy/common.d.ts.map +1 -0
  498. package/dist/sessionlog/strategy/common.js +162 -0
  499. package/dist/sessionlog/strategy/common.js.map +1 -0
  500. package/dist/sessionlog/strategy/content-overlap.d.ts +33 -0
  501. package/dist/sessionlog/strategy/content-overlap.d.ts.map +1 -0
  502. package/dist/sessionlog/strategy/content-overlap.js +168 -0
  503. package/dist/sessionlog/strategy/content-overlap.js.map +1 -0
  504. package/dist/sessionlog/strategy/manual-commit.d.ts +35 -0
  505. package/dist/sessionlog/strategy/manual-commit.d.ts.map +1 -0
  506. package/dist/sessionlog/strategy/manual-commit.js +732 -0
  507. package/dist/sessionlog/strategy/manual-commit.js.map +1 -0
  508. package/dist/sessionlog/strategy/types.d.ts +163 -0
  509. package/dist/sessionlog/strategy/types.d.ts.map +1 -0
  510. package/dist/sessionlog/strategy/types.js +49 -0
  511. package/dist/sessionlog/strategy/types.js.map +1 -0
  512. package/dist/sessionlog/summarize/claude-generator.d.ts +25 -0
  513. package/dist/sessionlog/summarize/claude-generator.d.ts.map +1 -0
  514. package/dist/sessionlog/summarize/claude-generator.js +87 -0
  515. package/dist/sessionlog/summarize/claude-generator.js.map +1 -0
  516. package/dist/sessionlog/summarize/summarize.d.ts +52 -0
  517. package/dist/sessionlog/summarize/summarize.d.ts.map +1 -0
  518. package/dist/sessionlog/summarize/summarize.js +335 -0
  519. package/dist/sessionlog/summarize/summarize.js.map +1 -0
  520. package/dist/sessionlog/types.d.ts +298 -0
  521. package/dist/sessionlog/types.d.ts.map +1 -0
  522. package/dist/sessionlog/types.js +104 -0
  523. package/dist/sessionlog/types.js.map +1 -0
  524. package/dist/sessionlog/utils/chunk-files.d.ts +25 -0
  525. package/dist/sessionlog/utils/chunk-files.d.ts.map +1 -0
  526. package/dist/sessionlog/utils/chunk-files.js +47 -0
  527. package/dist/sessionlog/utils/chunk-files.js.map +1 -0
  528. package/dist/sessionlog/utils/commit-message.d.ts +11 -0
  529. package/dist/sessionlog/utils/commit-message.d.ts.map +1 -0
  530. package/dist/sessionlog/utils/commit-message.js +54 -0
  531. package/dist/sessionlog/utils/commit-message.js.map +1 -0
  532. package/dist/sessionlog/utils/detect-agent.d.ts +19 -0
  533. package/dist/sessionlog/utils/detect-agent.d.ts.map +1 -0
  534. package/dist/sessionlog/utils/detect-agent.js +34 -0
  535. package/dist/sessionlog/utils/detect-agent.js.map +1 -0
  536. package/dist/sessionlog/utils/hook-managers.d.ts +24 -0
  537. package/dist/sessionlog/utils/hook-managers.d.ts.map +1 -0
  538. package/dist/sessionlog/utils/hook-managers.js +87 -0
  539. package/dist/sessionlog/utils/hook-managers.js.map +1 -0
  540. package/dist/sessionlog/utils/ide-tags.d.ts +12 -0
  541. package/dist/sessionlog/utils/ide-tags.d.ts.map +1 -0
  542. package/dist/sessionlog/utils/ide-tags.js +30 -0
  543. package/dist/sessionlog/utils/ide-tags.js.map +1 -0
  544. package/dist/sessionlog/utils/paths.d.ts +32 -0
  545. package/dist/sessionlog/utils/paths.d.ts.map +1 -0
  546. package/dist/sessionlog/utils/paths.js +55 -0
  547. package/dist/sessionlog/utils/paths.js.map +1 -0
  548. package/dist/sessionlog/utils/preview-rewind.d.ts +23 -0
  549. package/dist/sessionlog/utils/preview-rewind.d.ts.map +1 -0
  550. package/dist/sessionlog/utils/preview-rewind.js +63 -0
  551. package/dist/sessionlog/utils/preview-rewind.js.map +1 -0
  552. package/dist/sessionlog/utils/rewind-conflict.d.ts +52 -0
  553. package/dist/sessionlog/utils/rewind-conflict.d.ts.map +1 -0
  554. package/dist/sessionlog/utils/rewind-conflict.js +79 -0
  555. package/dist/sessionlog/utils/rewind-conflict.js.map +1 -0
  556. package/dist/sessionlog/utils/shadow-branch.d.ts +53 -0
  557. package/dist/sessionlog/utils/shadow-branch.d.ts.map +1 -0
  558. package/dist/sessionlog/utils/shadow-branch.js +97 -0
  559. package/dist/sessionlog/utils/shadow-branch.js.map +1 -0
  560. package/dist/sessionlog/utils/string-utils.d.ts +24 -0
  561. package/dist/sessionlog/utils/string-utils.d.ts.map +1 -0
  562. package/dist/sessionlog/utils/string-utils.js +47 -0
  563. package/dist/sessionlog/utils/string-utils.js.map +1 -0
  564. package/dist/sessionlog/utils/todo-extract.d.ts +52 -0
  565. package/dist/sessionlog/utils/todo-extract.d.ts.map +1 -0
  566. package/dist/sessionlog/utils/todo-extract.js +167 -0
  567. package/dist/sessionlog/utils/todo-extract.js.map +1 -0
  568. package/dist/sessionlog/utils/trailers.d.ts +36 -0
  569. package/dist/sessionlog/utils/trailers.d.ts.map +1 -0
  570. package/dist/sessionlog/utils/trailers.js +149 -0
  571. package/dist/sessionlog/utils/trailers.js.map +1 -0
  572. package/dist/sessionlog/utils/transcript-parse.d.ts +57 -0
  573. package/dist/sessionlog/utils/transcript-parse.d.ts.map +1 -0
  574. package/dist/sessionlog/utils/transcript-parse.js +126 -0
  575. package/dist/sessionlog/utils/transcript-parse.js.map +1 -0
  576. package/dist/sessionlog/utils/transcript-timestamp.d.ts +22 -0
  577. package/dist/sessionlog/utils/transcript-timestamp.d.ts.map +1 -0
  578. package/dist/sessionlog/utils/transcript-timestamp.js +56 -0
  579. package/dist/sessionlog/utils/transcript-timestamp.js.map +1 -0
  580. package/dist/sessionlog/utils/tree-ops.d.ts +47 -0
  581. package/dist/sessionlog/utils/tree-ops.d.ts.map +1 -0
  582. package/dist/sessionlog/utils/tree-ops.js +145 -0
  583. package/dist/sessionlog/utils/tree-ops.js.map +1 -0
  584. package/dist/sessionlog/utils/tty.d.ts +25 -0
  585. package/dist/sessionlog/utils/tty.d.ts.map +1 -0
  586. package/dist/sessionlog/utils/tty.js +70 -0
  587. package/dist/sessionlog/utils/tty.js.map +1 -0
  588. package/dist/sessionlog/utils/validation.d.ts +31 -0
  589. package/dist/sessionlog/utils/validation.d.ts.map +1 -0
  590. package/dist/sessionlog/utils/validation.js +59 -0
  591. package/dist/sessionlog/utils/validation.js.map +1 -0
  592. package/dist/sessionlog/utils/worktree.d.ts +16 -0
  593. package/dist/sessionlog/utils/worktree.d.ts.map +1 -0
  594. package/dist/sessionlog/utils/worktree.js +50 -0
  595. package/dist/sessionlog/utils/worktree.js.map +1 -0
  596. package/dist/storage/__tests__/atomic-write.test.d.ts +5 -0
  597. package/dist/storage/__tests__/atomic-write.test.d.ts.map +1 -0
  598. package/dist/storage/__tests__/atomic-write.test.js +170 -0
  599. package/dist/storage/__tests__/atomic-write.test.js.map +1 -0
  600. package/dist/storage/__tests__/file-lock.test.d.ts +2 -0
  601. package/dist/storage/__tests__/file-lock.test.d.ts.map +1 -0
  602. package/dist/storage/__tests__/file-lock.test.js +89 -0
  603. package/dist/storage/__tests__/file-lock.test.js.map +1 -0
  604. package/dist/storage/__tests__/jsonl.test.d.ts +2 -0
  605. package/dist/storage/__tests__/jsonl.test.d.ts.map +1 -0
  606. package/dist/storage/__tests__/jsonl.test.js +228 -0
  607. package/dist/storage/__tests__/jsonl.test.js.map +1 -0
  608. package/dist/storage/__tests__/locked-writer.test.d.ts +2 -0
  609. package/dist/storage/__tests__/locked-writer.test.d.ts.map +1 -0
  610. package/dist/storage/__tests__/locked-writer.test.js +109 -0
  611. package/dist/storage/__tests__/locked-writer.test.js.map +1 -0
  612. package/dist/storage/__tests__/sqlite.test.d.ts +2 -0
  613. package/dist/storage/__tests__/sqlite.test.d.ts.map +1 -0
  614. package/dist/storage/__tests__/sqlite.test.js +470 -0
  615. package/dist/storage/__tests__/sqlite.test.js.map +1 -0
  616. package/dist/storage/sqlite-schema.d.ts.map +1 -1
  617. package/dist/storage/sqlite-schema.js +2 -0
  618. package/dist/storage/sqlite-schema.js.map +1 -1
  619. package/dist/storage/sqlite.d.ts.map +1 -1
  620. package/dist/storage/sqlite.js +18 -4
  621. package/dist/storage/sqlite.js.map +1 -1
  622. package/dist/tools/__tests__/annotate.test.d.ts +5 -0
  623. package/dist/tools/__tests__/annotate.test.d.ts.map +1 -0
  624. package/dist/tools/__tests__/annotate.test.js +314 -0
  625. package/dist/tools/__tests__/annotate.test.js.map +1 -0
  626. package/dist/tools/__tests__/link.test.d.ts +5 -0
  627. package/dist/tools/__tests__/link.test.d.ts.map +1 -0
  628. package/dist/tools/__tests__/link.test.js +245 -0
  629. package/dist/tools/__tests__/link.test.js.map +1 -0
  630. package/dist/tools/__tests__/query.test.d.ts +5 -0
  631. package/dist/tools/__tests__/query.test.d.ts.map +1 -0
  632. package/dist/tools/__tests__/query.test.js +288 -0
  633. package/dist/tools/__tests__/query.test.js.map +1 -0
  634. package/dist/tools/__tests__/task.test.d.ts +5 -0
  635. package/dist/tools/__tests__/task.test.d.ts.map +1 -0
  636. package/dist/tools/__tests__/task.test.js +178 -0
  637. package/dist/tools/__tests__/task.test.js.map +1 -0
  638. package/dist/tools/index.d.ts +1 -1
  639. package/dist/tools/index.d.ts.map +1 -1
  640. package/dist/tools/index.js.map +1 -1
  641. package/dist/tools/query.d.ts +2 -1
  642. package/dist/tools/query.d.ts.map +1 -1
  643. package/dist/tools/query.js +217 -7
  644. package/dist/tools/query.js.map +1 -1
  645. package/dist/tools/types.d.ts +57 -0
  646. package/dist/tools/types.d.ts.map +1 -1
  647. package/dist/tools/types.js.map +1 -1
  648. package/dist/tracking/claude-task-reconstructor.d.ts +41 -0
  649. package/dist/tracking/claude-task-reconstructor.d.ts.map +1 -0
  650. package/dist/tracking/claude-task-reconstructor.js +91 -0
  651. package/dist/tracking/claude-task-reconstructor.js.map +1 -0
  652. package/dist/tracking/plan-mode-tracker.d.ts +20 -0
  653. package/dist/tracking/plan-mode-tracker.d.ts.map +1 -0
  654. package/dist/tracking/plan-mode-tracker.js +35 -0
  655. package/dist/tracking/plan-mode-tracker.js.map +1 -0
  656. package/dist/tracking/transcript-extractor.d.ts +3 -3
  657. package/dist/tracking/transcript-extractor.d.ts.map +1 -1
  658. package/dist/tracking/transcript-extractor.js +1 -1
  659. package/dist/tracking/transcript-extractor.js.map +1 -1
  660. package/package.json +3 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FederatedGraph.test.d.ts","sourceRoot":"","sources":["../../../src/graph/__tests__/FederatedGraph.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,661 @@
1
+ import { describe, it, expect, beforeEach } from 'vitest';
2
+ import { createFederatedGraph, } from '../FederatedGraph.js';
3
+ import { createGraphologyAdapter } from '../GraphologyAdapter.js';
4
+ describe('FederatedGraph', () => {
5
+ let adapter;
6
+ let graph;
7
+ beforeEach(() => {
8
+ adapter = createGraphologyAdapter();
9
+ graph = createFederatedGraph(adapter);
10
+ });
11
+ // Test fixtures - a simple graph:
12
+ //
13
+ // s-spec1 ──implements──> i-issue1 ──blocks──> i-issue2 ──blocks──> i-issue3
14
+ // │
15
+ // └──blocks──> i-issue4
16
+ //
17
+ const spec1 = {
18
+ id: 's-spec1',
19
+ uuid: 'uuid-spec1',
20
+ type: 'spec',
21
+ title: 'Spec 1',
22
+ created_at: '2025-01-01T00:00:00Z',
23
+ updated_at: '2025-01-01T00:00:00Z',
24
+ };
25
+ const issue1 = {
26
+ id: 'i-issue1',
27
+ uuid: 'uuid-issue1',
28
+ type: 'issue',
29
+ title: 'Issue 1',
30
+ status: 'open',
31
+ created_at: '2025-01-01T00:00:00Z',
32
+ updated_at: '2025-01-01T00:00:00Z',
33
+ };
34
+ const issue2 = {
35
+ id: 'i-issue2',
36
+ uuid: 'uuid-issue2',
37
+ type: 'issue',
38
+ title: 'Issue 2',
39
+ status: 'open',
40
+ created_at: '2025-01-01T00:00:00Z',
41
+ updated_at: '2025-01-01T00:00:00Z',
42
+ };
43
+ const issue3 = {
44
+ id: 'i-issue3',
45
+ uuid: 'uuid-issue3',
46
+ type: 'issue',
47
+ title: 'Issue 3',
48
+ status: 'closed',
49
+ created_at: '2025-01-01T00:00:00Z',
50
+ updated_at: '2025-01-01T00:00:00Z',
51
+ };
52
+ const issue4 = {
53
+ id: 'i-issue4',
54
+ uuid: 'uuid-issue4',
55
+ type: 'issue',
56
+ title: 'Issue 4',
57
+ status: 'open',
58
+ created_at: '2025-01-01T00:00:00Z',
59
+ updated_at: '2025-01-01T00:00:00Z',
60
+ };
61
+ const edgeImplements = {
62
+ id: 'e-impl',
63
+ uuid: 'uuid-impl',
64
+ from_id: 'i-issue1',
65
+ to_id: 's-spec1',
66
+ type: 'implements',
67
+ created_at: '2025-01-01T00:00:00Z',
68
+ };
69
+ const edgeBlocks1 = {
70
+ id: 'e-blocks1',
71
+ uuid: 'uuid-blocks1',
72
+ from_id: 'i-issue1',
73
+ to_id: 'i-issue2',
74
+ type: 'blocks',
75
+ created_at: '2025-01-01T00:00:00Z',
76
+ };
77
+ const edgeBlocks2 = {
78
+ id: 'e-blocks2',
79
+ uuid: 'uuid-blocks2',
80
+ from_id: 'i-issue2',
81
+ to_id: 'i-issue3',
82
+ type: 'blocks',
83
+ created_at: '2025-01-01T00:00:00Z',
84
+ };
85
+ const edgeBlocks3 = {
86
+ id: 'e-blocks3',
87
+ uuid: 'uuid-blocks3',
88
+ from_id: 'i-issue1',
89
+ to_id: 'i-issue4',
90
+ type: 'blocks',
91
+ created_at: '2025-01-01T00:00:00Z',
92
+ };
93
+ function setupGraph() {
94
+ adapter.onNodeCreated(spec1);
95
+ adapter.onNodeCreated(issue1);
96
+ adapter.onNodeCreated(issue2);
97
+ adapter.onNodeCreated(issue3);
98
+ adapter.onNodeCreated(issue4);
99
+ adapter.onEdgeCreated(edgeImplements);
100
+ adapter.onEdgeCreated(edgeBlocks1);
101
+ adapter.onEdgeCreated(edgeBlocks2);
102
+ adapter.onEdgeCreated(edgeBlocks3);
103
+ }
104
+ describe('related()', () => {
105
+ beforeEach(setupGraph);
106
+ it('returns outgoing neighbors', () => {
107
+ const result = graph.related('native://i-issue1', { direction: 'out' });
108
+ expect(result).toHaveLength(3);
109
+ expect(result).toContain('native://s-spec1');
110
+ expect(result).toContain('native://i-issue2');
111
+ expect(result).toContain('native://i-issue4');
112
+ });
113
+ it('returns incoming neighbors', () => {
114
+ const result = graph.related('native://i-issue2', { direction: 'in' });
115
+ expect(result).toHaveLength(1);
116
+ expect(result).toContain('native://i-issue1');
117
+ });
118
+ it('returns both directions by default', () => {
119
+ const result = graph.related('native://i-issue2');
120
+ expect(result).toHaveLength(2);
121
+ expect(result).toContain('native://i-issue1'); // incoming
122
+ expect(result).toContain('native://i-issue3'); // outgoing
123
+ });
124
+ it('filters by edge type (string)', () => {
125
+ const result = graph.related('native://i-issue1', {
126
+ direction: 'out',
127
+ edgeType: 'blocks',
128
+ });
129
+ expect(result).toHaveLength(2);
130
+ expect(result).toContain('native://i-issue2');
131
+ expect(result).toContain('native://i-issue4');
132
+ expect(result).not.toContain('native://s-spec1');
133
+ });
134
+ it('filters by edge type (array)', () => {
135
+ const result = graph.related('native://i-issue1', {
136
+ direction: 'out',
137
+ edgeType: ['implements'],
138
+ });
139
+ expect(result).toHaveLength(1);
140
+ expect(result).toContain('native://s-spec1');
141
+ });
142
+ it('returns empty for non-existent node', () => {
143
+ const result = graph.related('native://non-existent');
144
+ expect(result).toHaveLength(0);
145
+ });
146
+ it('removes duplicates with both direction', () => {
147
+ // Create a bidirectional relationship
148
+ adapter.onEdgeCreated({
149
+ id: 'e-related1',
150
+ uuid: 'uuid-related1',
151
+ from_id: 'i-issue2',
152
+ to_id: 'i-issue1',
153
+ type: 'related',
154
+ created_at: '2025-01-01T00:00:00Z',
155
+ });
156
+ const result = graph.related('native://i-issue1', {
157
+ direction: 'both',
158
+ edgeType: ['blocks', 'related'],
159
+ });
160
+ // issue2 should only appear once even though there are edges in both directions
161
+ const issue2Count = result.filter((r) => r === 'native://i-issue2').length;
162
+ expect(issue2Count).toBe(1);
163
+ });
164
+ });
165
+ describe('reachable()', () => {
166
+ beforeEach(setupGraph);
167
+ it('returns transitively reachable nodes (out)', () => {
168
+ const result = graph.reachable('native://i-issue1', {
169
+ direction: 'out',
170
+ edgeType: 'blocks',
171
+ });
172
+ expect(result).toHaveLength(3);
173
+ expect(result).toContain('native://i-issue2');
174
+ expect(result).toContain('native://i-issue3');
175
+ expect(result).toContain('native://i-issue4');
176
+ });
177
+ it('returns transitively reachable nodes (in)', () => {
178
+ const result = graph.reachable('native://i-issue3', {
179
+ direction: 'in',
180
+ edgeType: 'blocks',
181
+ });
182
+ expect(result).toHaveLength(2);
183
+ expect(result).toContain('native://i-issue2');
184
+ expect(result).toContain('native://i-issue1');
185
+ });
186
+ it('respects maxDepth', () => {
187
+ const result = graph.reachable('native://i-issue1', {
188
+ direction: 'out',
189
+ edgeType: 'blocks',
190
+ maxDepth: 1,
191
+ });
192
+ expect(result).toHaveLength(2);
193
+ expect(result).toContain('native://i-issue2');
194
+ expect(result).toContain('native://i-issue4');
195
+ expect(result).not.toContain('native://i-issue3'); // 2 hops away
196
+ });
197
+ it('does not include start node', () => {
198
+ const result = graph.reachable('native://i-issue1', { direction: 'out' });
199
+ expect(result).not.toContain('native://i-issue1');
200
+ });
201
+ it('handles cycles without infinite loop', () => {
202
+ // Create a cycle: issue3 -> issue1
203
+ adapter.onEdgeCreated({
204
+ id: 'e-cycle',
205
+ uuid: 'uuid-cycle',
206
+ from_id: 'i-issue3',
207
+ to_id: 'i-issue1',
208
+ type: 'blocks',
209
+ created_at: '2025-01-01T00:00:00Z',
210
+ });
211
+ const result = graph.reachable('native://i-issue1', {
212
+ direction: 'out',
213
+ edgeType: 'blocks',
214
+ });
215
+ // Should terminate and include all reachable nodes exactly once
216
+ expect(result).toHaveLength(3);
217
+ });
218
+ it('returns empty for non-existent node', () => {
219
+ const result = graph.reachable('native://non-existent');
220
+ expect(result).toHaveLength(0);
221
+ });
222
+ it('filters by multiple edge types', () => {
223
+ const result = graph.reachable('native://i-issue1', {
224
+ direction: 'out',
225
+ edgeType: ['blocks', 'implements'],
226
+ });
227
+ expect(result).toHaveLength(4);
228
+ expect(result).toContain('native://s-spec1');
229
+ expect(result).toContain('native://i-issue2');
230
+ expect(result).toContain('native://i-issue3');
231
+ expect(result).toContain('native://i-issue4');
232
+ });
233
+ });
234
+ describe('shortestPath()', () => {
235
+ beforeEach(setupGraph);
236
+ it('finds shortest path', () => {
237
+ const result = graph.shortestPath('native://i-issue1', 'native://i-issue3');
238
+ expect(result).not.toBeNull();
239
+ expect(result).toHaveLength(3);
240
+ expect(result[0]).toBe('native://i-issue1');
241
+ expect(result[1]).toBe('native://i-issue2');
242
+ expect(result[2]).toBe('native://i-issue3');
243
+ });
244
+ it('returns path of length 1 for adjacent nodes', () => {
245
+ const result = graph.shortestPath('native://i-issue1', 'native://i-issue2');
246
+ expect(result).toHaveLength(2);
247
+ });
248
+ it('returns path of length 0 for same node', () => {
249
+ const result = graph.shortestPath('native://i-issue1', 'native://i-issue1');
250
+ expect(result).toHaveLength(1);
251
+ expect(result[0]).toBe('native://i-issue1');
252
+ });
253
+ it('returns null for non-existent start node', () => {
254
+ const result = graph.shortestPath('native://non-existent', 'native://i-issue1');
255
+ expect(result).toBeNull();
256
+ });
257
+ it('returns null for non-existent end node', () => {
258
+ const result = graph.shortestPath('native://i-issue1', 'native://non-existent');
259
+ expect(result).toBeNull();
260
+ });
261
+ it('returns null when no path exists', () => {
262
+ // Create an isolated node
263
+ adapter.onNodeCreated({
264
+ id: 'i-isolated',
265
+ uuid: 'uuid-isolated',
266
+ type: 'issue',
267
+ title: 'Isolated',
268
+ created_at: '2025-01-01T00:00:00Z',
269
+ updated_at: '2025-01-01T00:00:00Z',
270
+ });
271
+ const result = graph.shortestPath('native://i-issue1', 'native://i-isolated');
272
+ expect(result).toBeNull();
273
+ });
274
+ it('filters by edge types', () => {
275
+ // issue1 -> issue2 is via 'blocks'
276
+ // There's no 'implements' path from issue1 to issue2
277
+ const result = graph.shortestPath('native://i-issue1', 'native://i-issue2', {
278
+ edgeTypes: ['implements'],
279
+ });
280
+ expect(result).toBeNull();
281
+ });
282
+ });
283
+ describe('hasPath()', () => {
284
+ beforeEach(setupGraph);
285
+ it('returns true when path exists', () => {
286
+ expect(graph.hasPath('native://i-issue1', 'native://i-issue3')).toBe(true);
287
+ });
288
+ it('returns false when no path exists', () => {
289
+ adapter.onNodeCreated({
290
+ id: 'i-isolated',
291
+ uuid: 'uuid-isolated',
292
+ type: 'issue',
293
+ title: 'Isolated',
294
+ created_at: '2025-01-01T00:00:00Z',
295
+ updated_at: '2025-01-01T00:00:00Z',
296
+ });
297
+ expect(graph.hasPath('native://i-issue1', 'native://i-isolated')).toBe(false);
298
+ });
299
+ });
300
+ describe('getNode()', () => {
301
+ beforeEach(setupGraph);
302
+ it('returns node attributes', () => {
303
+ const node = graph.getNode('native://i-issue1');
304
+ expect(node).not.toBeNull();
305
+ expect(node.title).toBe('Issue 1');
306
+ expect(node.type).toBe('issue');
307
+ });
308
+ it('returns null for non-existent node', () => {
309
+ expect(graph.getNode('native://non-existent')).toBeNull();
310
+ });
311
+ });
312
+ describe('hasNode()', () => {
313
+ beforeEach(setupGraph);
314
+ it('returns true for existing node', () => {
315
+ expect(graph.hasNode('native://i-issue1')).toBe(true);
316
+ });
317
+ it('returns false for non-existent node', () => {
318
+ expect(graph.hasNode('native://non-existent')).toBe(false);
319
+ });
320
+ });
321
+ describe('nodes()', () => {
322
+ beforeEach(setupGraph);
323
+ it('returns all node URIs', () => {
324
+ const nodes = graph.nodes();
325
+ expect(nodes).toHaveLength(5);
326
+ expect(nodes).toContain('native://s-spec1');
327
+ expect(nodes).toContain('native://i-issue1');
328
+ expect(nodes).toContain('native://i-issue2');
329
+ expect(nodes).toContain('native://i-issue3');
330
+ expect(nodes).toContain('native://i-issue4');
331
+ });
332
+ });
333
+ describe('stats()', () => {
334
+ beforeEach(setupGraph);
335
+ it('returns correct node and edge counts', () => {
336
+ const stats = graph.stats();
337
+ expect(stats.nodes).toBe(5);
338
+ expect(stats.edges).toBe(4);
339
+ });
340
+ });
341
+ describe('traverse()', () => {
342
+ beforeEach(setupGraph);
343
+ it('traverses single step pattern', async () => {
344
+ const results = [];
345
+ for await (const result of graph.traverse('native://i-issue1', {
346
+ steps: [{ type: 'blocks', direction: 'out' }],
347
+ })) {
348
+ results.push(result.uri);
349
+ }
350
+ expect(results).toContain('native://i-issue2');
351
+ expect(results).toContain('native://i-issue4');
352
+ expect(results).not.toContain('native://s-spec1'); // implements, not blocks
353
+ });
354
+ it('traverses multi-step pattern', async () => {
355
+ // First find specs, then issues that implement them
356
+ const results = [];
357
+ for await (const result of graph.traverse('native://i-issue1', {
358
+ steps: [
359
+ { type: 'implements', direction: 'out' }, // i-issue1 -> s-spec1
360
+ { type: 'implements', direction: 'in' }, // s-spec1 <- other issues
361
+ ],
362
+ })) {
363
+ results.push(result.uri);
364
+ }
365
+ // Should find s-spec1 first, then back to i-issue1
366
+ expect(results).toContain('native://s-spec1');
367
+ expect(results).toContain('native://i-issue1');
368
+ });
369
+ it('traverses with maxHops=Infinity for transitive closure', async () => {
370
+ const results = [];
371
+ for await (const result of graph.traverse('native://i-issue1', {
372
+ steps: [{ type: 'blocks', direction: 'out', maxHops: Infinity }],
373
+ })) {
374
+ results.push(result.uri);
375
+ }
376
+ // Should find all transitively blocked issues
377
+ expect(results).toContain('native://i-issue2');
378
+ expect(results).toContain('native://i-issue3');
379
+ expect(results).toContain('native://i-issue4');
380
+ });
381
+ it('respects limit option', async () => {
382
+ const results = [];
383
+ for await (const result of graph.traverse('native://i-issue1', {
384
+ steps: [{ type: 'blocks', direction: 'out', maxHops: Infinity }],
385
+ limit: 2,
386
+ })) {
387
+ results.push(result.uri);
388
+ }
389
+ expect(results).toHaveLength(2);
390
+ });
391
+ it('tracks depth correctly', async () => {
392
+ const depths = [];
393
+ for await (const result of graph.traverse('native://i-issue1', {
394
+ steps: [{ type: 'blocks', direction: 'out', maxHops: Infinity }],
395
+ })) {
396
+ depths.push(result.depth);
397
+ }
398
+ // issue2 and issue4 are depth 1, issue3 is depth 2
399
+ expect(depths).toContain(1);
400
+ expect(depths).toContain(2);
401
+ });
402
+ it('tracks path correctly', async () => {
403
+ let issue3Path = [];
404
+ for await (const result of graph.traverse('native://i-issue1', {
405
+ steps: [{ type: 'blocks', direction: 'out', maxHops: Infinity }],
406
+ })) {
407
+ if (result.uri === 'native://i-issue3') {
408
+ issue3Path = result.path;
409
+ break;
410
+ }
411
+ }
412
+ // Path should be: issue1 -> issue2 -> issue3
413
+ expect(issue3Path).toEqual([
414
+ 'native://i-issue1',
415
+ 'native://i-issue2',
416
+ 'native://i-issue3',
417
+ ]);
418
+ });
419
+ it('handles multiple start URIs', async () => {
420
+ const results = [];
421
+ for await (const result of graph.traverse(['native://i-issue1', 'native://i-issue2'], { steps: [{ type: 'blocks', direction: 'out' }] })) {
422
+ results.push(result.uri);
423
+ }
424
+ // issue1 blocks issue2 and issue4
425
+ // issue2 blocks issue3
426
+ expect(results).toContain('native://i-issue2');
427
+ expect(results).toContain('native://i-issue3');
428
+ expect(results).toContain('native://i-issue4');
429
+ });
430
+ it('handles non-existent start URI', async () => {
431
+ const results = [];
432
+ for await (const result of graph.traverse('native://non-existent', {
433
+ steps: [{ type: 'blocks', direction: 'out' }],
434
+ })) {
435
+ results.push(result.uri);
436
+ }
437
+ expect(results).toHaveLength(0);
438
+ });
439
+ it('handles empty steps', async () => {
440
+ const results = [];
441
+ for await (const result of graph.traverse('native://i-issue1', {
442
+ steps: [],
443
+ })) {
444
+ results.push(result.uri);
445
+ }
446
+ expect(results).toHaveLength(0);
447
+ });
448
+ it('respects minHops option', async () => {
449
+ const results = [];
450
+ for await (const result of graph.traverse('native://i-issue1', {
451
+ steps: [{ type: 'blocks', direction: 'out', minHops: 2, maxHops: 2 }],
452
+ })) {
453
+ results.push(result.uri);
454
+ }
455
+ // Only issue3 is exactly 2 hops away via blocks
456
+ expect(results).toContain('native://i-issue3');
457
+ expect(results).not.toContain('native://i-issue2'); // 1 hop
458
+ expect(results).not.toContain('native://i-issue4'); // 1 hop
459
+ });
460
+ it('handles cycles without infinite loop', async () => {
461
+ // Add a cycle: issue3 -> issue1
462
+ adapter.onEdgeCreated({
463
+ id: 'e-cycle',
464
+ uuid: 'uuid-cycle',
465
+ from_id: 'i-issue3',
466
+ to_id: 'i-issue1',
467
+ type: 'blocks',
468
+ created_at: '2025-01-01T00:00:00Z',
469
+ });
470
+ const results = [];
471
+ for await (const result of graph.traverse('native://i-issue1', {
472
+ steps: [{ type: 'blocks', direction: 'out', maxHops: 10 }],
473
+ })) {
474
+ results.push(result.uri);
475
+ }
476
+ // Should not hang, and should not include duplicates
477
+ expect(results.length).toBeLessThanOrEqual(4);
478
+ });
479
+ it('includes stepIndex and edgeType in results', async () => {
480
+ for await (const result of graph.traverse('native://i-issue1', {
481
+ steps: [{ type: 'blocks', direction: 'out' }],
482
+ })) {
483
+ expect(result.stepIndex).toBe(0);
484
+ expect(result.edgeType).toBe('blocks');
485
+ break;
486
+ }
487
+ });
488
+ it('applies filter predicate to exclude nodes', async () => {
489
+ const results = [];
490
+ for await (const result of graph.traverse('native://i-issue1', {
491
+ steps: [{ type: 'blocks', direction: 'out', maxHops: Infinity }],
492
+ filter: (uri, attrs) => {
493
+ // Only include open issues
494
+ return attrs?.data?.status === 'open';
495
+ },
496
+ })) {
497
+ results.push(result.uri);
498
+ }
499
+ // Should include issue2 and issue4 (open) but not issue3 (closed)
500
+ expect(results).toContain('native://i-issue2');
501
+ expect(results).toContain('native://i-issue4');
502
+ expect(results).not.toContain('native://i-issue3');
503
+ });
504
+ it('filter continues traversal through filtered nodes', async () => {
505
+ // Add another edge: issue3 -> issue5
506
+ adapter.onNodeCreated({
507
+ id: 'i-issue5',
508
+ uuid: 'uuid-issue5',
509
+ type: 'issue',
510
+ title: 'Issue 5',
511
+ status: 'open',
512
+ created_at: '2025-01-01T00:00:00Z',
513
+ updated_at: '2025-01-01T00:00:00Z',
514
+ });
515
+ adapter.onEdgeCreated({
516
+ id: 'e-blocks4',
517
+ uuid: 'uuid-blocks4',
518
+ from_id: 'i-issue3',
519
+ to_id: 'i-issue5',
520
+ type: 'blocks',
521
+ created_at: '2025-01-01T00:00:00Z',
522
+ });
523
+ const results = [];
524
+ for await (const result of graph.traverse('native://i-issue1', {
525
+ steps: [{ type: 'blocks', direction: 'out', maxHops: Infinity }],
526
+ filter: (uri, attrs) => attrs?.data?.status === 'open',
527
+ })) {
528
+ results.push(result.uri);
529
+ }
530
+ // Should find issue5 even though it goes through filtered issue3
531
+ expect(results).toContain('native://i-issue5');
532
+ expect(results).not.toContain('native://i-issue3');
533
+ });
534
+ });
535
+ describe('parseSelector()', () => {
536
+ it('parses children selector (+uri)', () => {
537
+ const result = graph.parseSelector('+native://s-spec1');
538
+ expect(result.type).toBe('children');
539
+ expect(result.uri).toBe('native://s-spec1');
540
+ expect(result.original).toBe('+native://s-spec1');
541
+ });
542
+ it('parses descendants selector (uri+)', () => {
543
+ const result = graph.parseSelector('native://i-issue1+');
544
+ expect(result.type).toBe('descendants');
545
+ expect(result.uri).toBe('native://i-issue1');
546
+ expect(result.original).toBe('native://i-issue1+');
547
+ });
548
+ it('parses neighbors selector (@uri)', () => {
549
+ const result = graph.parseSelector('@native://i-issue2');
550
+ expect(result.type).toBe('neighbors');
551
+ expect(result.uri).toBe('native://i-issue2');
552
+ expect(result.original).toBe('@native://i-issue2');
553
+ });
554
+ it('parses literal URI', () => {
555
+ const result = graph.parseSelector('native://i-issue1');
556
+ expect(result.type).toBe('literal');
557
+ expect(result.uri).toBe('native://i-issue1');
558
+ expect(result.original).toBe('native://i-issue1');
559
+ });
560
+ });
561
+ describe('expandSelector()', () => {
562
+ beforeEach(setupGraph);
563
+ it('expands literal to the node if exists', () => {
564
+ const result = graph.expandSelector('native://i-issue1');
565
+ expect(result).toEqual(['native://i-issue1']);
566
+ });
567
+ it('expands literal to empty if not exists', () => {
568
+ const result = graph.expandSelector('native://non-existent');
569
+ expect(result).toEqual([]);
570
+ });
571
+ it('expands children selector to direct outgoing neighbors', () => {
572
+ const result = graph.expandSelector('+native://i-issue1');
573
+ expect(result).toHaveLength(3);
574
+ expect(result).toContain('native://s-spec1');
575
+ expect(result).toContain('native://i-issue2');
576
+ expect(result).toContain('native://i-issue4');
577
+ });
578
+ it('expands children selector with edge type filter', () => {
579
+ const result = graph.expandSelector('+native://i-issue1', { edgeType: 'blocks' });
580
+ expect(result).toHaveLength(2);
581
+ expect(result).toContain('native://i-issue2');
582
+ expect(result).toContain('native://i-issue4');
583
+ expect(result).not.toContain('native://s-spec1');
584
+ });
585
+ it('expands descendants selector transitively', () => {
586
+ const result = graph.expandSelector('native://i-issue1+');
587
+ // Should include all transitively reachable nodes
588
+ expect(result).toContain('native://s-spec1');
589
+ expect(result).toContain('native://i-issue2');
590
+ expect(result).toContain('native://i-issue3');
591
+ expect(result).toContain('native://i-issue4');
592
+ });
593
+ it('expands descendants with edge type filter', () => {
594
+ const result = graph.expandSelector('native://i-issue1+', { edgeType: 'blocks' });
595
+ expect(result).toHaveLength(3);
596
+ expect(result).toContain('native://i-issue2');
597
+ expect(result).toContain('native://i-issue3');
598
+ expect(result).toContain('native://i-issue4');
599
+ expect(result).not.toContain('native://s-spec1');
600
+ });
601
+ it('expands neighbors selector to all connected nodes', () => {
602
+ const result = graph.expandSelector('@native://i-issue2');
603
+ expect(result).toHaveLength(2);
604
+ expect(result).toContain('native://i-issue1'); // incoming
605
+ expect(result).toContain('native://i-issue3'); // outgoing
606
+ });
607
+ it('expands neighbors with edge type filter', () => {
608
+ const result = graph.expandSelector('@native://i-issue1', { edgeType: 'implements' });
609
+ expect(result).toHaveLength(1);
610
+ expect(result).toContain('native://s-spec1');
611
+ });
612
+ it('returns empty for non-existent node selectors', () => {
613
+ expect(graph.expandSelector('+native://non-existent')).toEqual([]);
614
+ expect(graph.expandSelector('native://non-existent+')).toEqual([]);
615
+ expect(graph.expandSelector('@native://non-existent')).toEqual([]);
616
+ });
617
+ });
618
+ describe('edgeTypes()', () => {
619
+ it('returns all registered edge types', () => {
620
+ const types = graph.edgeTypes();
621
+ expect(types.length).toBeGreaterThan(0);
622
+ // Should include built-in types
623
+ const typeNames = types.map((t) => t.name);
624
+ expect(typeNames).toContain('blocks');
625
+ expect(typeNames).toContain('implements');
626
+ expect(typeNames).toContain('parent-of');
627
+ expect(typeNames).toContain('related');
628
+ });
629
+ it('includes edge type metadata', () => {
630
+ const types = graph.edgeTypes();
631
+ const blocksType = types.find((t) => t.name === 'blocks');
632
+ expect(blocksType).toBeDefined();
633
+ expect(blocksType.description).toBeDefined();
634
+ expect(blocksType.inverseOf).toBe('blocked-by');
635
+ expect(blocksType.affectsReady).toBe(true);
636
+ expect(blocksType.direction).toBe('directed');
637
+ });
638
+ });
639
+ describe('capabilities()', () => {
640
+ it('returns graph capabilities', () => {
641
+ const caps = graph.capabilities();
642
+ expect(caps.edgeTypes).toBeDefined();
643
+ expect(caps.edgeTypes.length).toBeGreaterThan(0);
644
+ });
645
+ it('includes ready-affecting types', () => {
646
+ const caps = graph.capabilities();
647
+ expect(caps.readyAffectingTypes).toContain('blocks');
648
+ expect(caps.readyAffectingTypes).toContain('blocked-by');
649
+ });
650
+ it('includes provider-specific capabilities', () => {
651
+ const caps = graph.capabilities();
652
+ expect(caps.providers).toBeDefined();
653
+ expect(caps.providers.get('native')).toBeDefined();
654
+ const nativeTypes = caps.providers.get('native');
655
+ const nativeTypeNames = nativeTypes.map((t) => t.name);
656
+ expect(nativeTypeNames).toContain('blocks');
657
+ expect(nativeTypeNames).toContain('implements');
658
+ });
659
+ });
660
+ });
661
+ //# sourceMappingURL=FederatedGraph.test.js.map