opentasks 0.0.7 → 0.0.9

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 (505) hide show
  1. package/dist/daemon/entire-linker.d.ts.map +1 -1
  2. package/dist/daemon/entire-linker.js +42 -48
  3. package/dist/daemon/entire-linker.js.map +1 -1
  4. package/dist/daemon/entire-watcher.d.ts +0 -11
  5. package/dist/daemon/entire-watcher.d.ts.map +1 -1
  6. package/dist/daemon/entire-watcher.js +1 -32
  7. package/dist/daemon/entire-watcher.js.map +1 -1
  8. package/dist/graph/query.js +3 -3
  9. package/dist/graph/query.js.map +1 -1
  10. package/dist/index.d.ts +1 -0
  11. package/dist/index.d.ts.map +1 -1
  12. package/dist/index.js +2 -0
  13. package/dist/index.js.map +1 -1
  14. package/dist/providers/entire.d.ts +0 -10
  15. package/dist/providers/entire.d.ts.map +1 -1
  16. package/dist/providers/entire.js +0 -13
  17. package/dist/providers/entire.js.map +1 -1
  18. package/dist/providers/index.d.ts +1 -0
  19. package/dist/providers/index.d.ts.map +1 -1
  20. package/dist/providers/index.js +2 -0
  21. package/dist/providers/index.js.map +1 -1
  22. package/dist/providers/map-connector.d.ts +87 -0
  23. package/dist/providers/map-connector.d.ts.map +1 -0
  24. package/dist/providers/map-connector.js +159 -0
  25. package/dist/providers/map-connector.js.map +1 -0
  26. package/dist/storage/interface.d.ts +6 -0
  27. package/dist/storage/interface.d.ts.map +1 -1
  28. package/dist/storage/interface.js.map +1 -1
  29. package/dist/storage/sqlite.d.ts +1 -0
  30. package/dist/storage/sqlite.d.ts.map +1 -1
  31. package/dist/storage/sqlite.js +11 -0
  32. package/dist/storage/sqlite.js.map +1 -1
  33. package/package.json +2 -2
  34. package/dist/__tests__/cli-tools.test.d.ts +0 -8
  35. package/dist/__tests__/cli-tools.test.d.ts.map +0 -1
  36. package/dist/__tests__/cli-tools.test.js +0 -546
  37. package/dist/__tests__/cli-tools.test.js.map +0 -1
  38. package/dist/__tests__/cli.test.d.ts +0 -5
  39. package/dist/__tests__/cli.test.d.ts.map +0 -1
  40. package/dist/__tests__/cli.test.js +0 -77
  41. package/dist/__tests__/cli.test.js.map +0 -1
  42. package/dist/__tests__/p1-p3-gaps.test.d.ts +0 -2
  43. package/dist/__tests__/p1-p3-gaps.test.d.ts.map +0 -1
  44. package/dist/__tests__/p1-p3-gaps.test.js +0 -463
  45. package/dist/__tests__/p1-p3-gaps.test.js.map +0 -1
  46. package/dist/client/__tests__/client-crud.test.d.ts +0 -7
  47. package/dist/client/__tests__/client-crud.test.d.ts.map +0 -1
  48. package/dist/client/__tests__/client-crud.test.js +0 -404
  49. package/dist/client/__tests__/client-crud.test.js.map +0 -1
  50. package/dist/client/__tests__/client.test.d.ts +0 -5
  51. package/dist/client/__tests__/client.test.d.ts.map +0 -1
  52. package/dist/client/__tests__/client.test.js +0 -518
  53. package/dist/client/__tests__/client.test.js.map +0 -1
  54. package/dist/config/__tests__/defaults.test.d.ts +0 -2
  55. package/dist/config/__tests__/defaults.test.d.ts.map +0 -1
  56. package/dist/config/__tests__/defaults.test.js +0 -57
  57. package/dist/config/__tests__/defaults.test.js.map +0 -1
  58. package/dist/config/__tests__/env.test.d.ts +0 -2
  59. package/dist/config/__tests__/env.test.d.ts.map +0 -1
  60. package/dist/config/__tests__/env.test.js +0 -136
  61. package/dist/config/__tests__/env.test.js.map +0 -1
  62. package/dist/config/__tests__/index.test.d.ts +0 -2
  63. package/dist/config/__tests__/index.test.d.ts.map +0 -1
  64. package/dist/config/__tests__/index.test.js +0 -113
  65. package/dist/config/__tests__/index.test.js.map +0 -1
  66. package/dist/config/__tests__/loader.test.d.ts +0 -2
  67. package/dist/config/__tests__/loader.test.d.ts.map +0 -1
  68. package/dist/config/__tests__/loader.test.js +0 -128
  69. package/dist/config/__tests__/loader.test.js.map +0 -1
  70. package/dist/config/__tests__/merge.test.d.ts +0 -2
  71. package/dist/config/__tests__/merge.test.d.ts.map +0 -1
  72. package/dist/config/__tests__/merge.test.js +0 -79
  73. package/dist/config/__tests__/merge.test.js.map +0 -1
  74. package/dist/config/__tests__/schema.test.d.ts +0 -2
  75. package/dist/config/__tests__/schema.test.d.ts.map +0 -1
  76. package/dist/config/__tests__/schema.test.js +0 -300
  77. package/dist/config/__tests__/schema.test.js.map +0 -1
  78. package/dist/core/__tests__/conditional-redirects.test.d.ts +0 -2
  79. package/dist/core/__tests__/conditional-redirects.test.d.ts.map +0 -1
  80. package/dist/core/__tests__/conditional-redirects.test.js +0 -83
  81. package/dist/core/__tests__/conditional-redirects.test.js.map +0 -1
  82. package/dist/core/__tests__/connections.test.d.ts +0 -2
  83. package/dist/core/__tests__/connections.test.d.ts.map +0 -1
  84. package/dist/core/__tests__/connections.test.js +0 -158
  85. package/dist/core/__tests__/connections.test.js.map +0 -1
  86. package/dist/core/__tests__/hash.test.d.ts +0 -2
  87. package/dist/core/__tests__/hash.test.d.ts.map +0 -1
  88. package/dist/core/__tests__/hash.test.js +0 -139
  89. package/dist/core/__tests__/hash.test.js.map +0 -1
  90. package/dist/core/__tests__/id.test.d.ts +0 -2
  91. package/dist/core/__tests__/id.test.d.ts.map +0 -1
  92. package/dist/core/__tests__/id.test.js +0 -142
  93. package/dist/core/__tests__/id.test.js.map +0 -1
  94. package/dist/core/__tests__/location.test.d.ts +0 -2
  95. package/dist/core/__tests__/location.test.d.ts.map +0 -1
  96. package/dist/core/__tests__/location.test.js +0 -77
  97. package/dist/core/__tests__/location.test.js.map +0 -1
  98. package/dist/core/__tests__/merge-driver.test.d.ts +0 -2
  99. package/dist/core/__tests__/merge-driver.test.d.ts.map +0 -1
  100. package/dist/core/__tests__/merge-driver.test.js +0 -218
  101. package/dist/core/__tests__/merge-driver.test.js.map +0 -1
  102. package/dist/core/__tests__/redirects.test.d.ts +0 -2
  103. package/dist/core/__tests__/redirects.test.d.ts.map +0 -1
  104. package/dist/core/__tests__/redirects.test.js +0 -123
  105. package/dist/core/__tests__/redirects.test.js.map +0 -1
  106. package/dist/core/__tests__/resolve-location-target.test.d.ts +0 -8
  107. package/dist/core/__tests__/resolve-location-target.test.d.ts.map +0 -1
  108. package/dist/core/__tests__/resolve-location-target.test.js +0 -303
  109. package/dist/core/__tests__/resolve-location-target.test.js.map +0 -1
  110. package/dist/core/__tests__/uri.test.d.ts +0 -2
  111. package/dist/core/__tests__/uri.test.d.ts.map +0 -1
  112. package/dist/core/__tests__/uri.test.js +0 -159
  113. package/dist/core/__tests__/uri.test.js.map +0 -1
  114. package/dist/core/__tests__/worktree.test.d.ts +0 -2
  115. package/dist/core/__tests__/worktree.test.d.ts.map +0 -1
  116. package/dist/core/__tests__/worktree.test.js +0 -120
  117. package/dist/core/__tests__/worktree.test.js.map +0 -1
  118. package/dist/daemon/__tests__/flush.test.d.ts +0 -5
  119. package/dist/daemon/__tests__/flush.test.d.ts.map +0 -1
  120. package/dist/daemon/__tests__/flush.test.js +0 -213
  121. package/dist/daemon/__tests__/flush.test.js.map +0 -1
  122. package/dist/daemon/__tests__/integration.test.d.ts +0 -7
  123. package/dist/daemon/__tests__/integration.test.d.ts.map +0 -1
  124. package/dist/daemon/__tests__/integration.test.js +0 -276
  125. package/dist/daemon/__tests__/integration.test.js.map +0 -1
  126. package/dist/daemon/__tests__/ipc.test.d.ts +0 -5
  127. package/dist/daemon/__tests__/ipc.test.d.ts.map +0 -1
  128. package/dist/daemon/__tests__/ipc.test.js +0 -314
  129. package/dist/daemon/__tests__/ipc.test.js.map +0 -1
  130. package/dist/daemon/__tests__/lifecycle.test.d.ts +0 -5
  131. package/dist/daemon/__tests__/lifecycle.test.d.ts.map +0 -1
  132. package/dist/daemon/__tests__/lifecycle.test.js +0 -301
  133. package/dist/daemon/__tests__/lifecycle.test.js.map +0 -1
  134. package/dist/daemon/__tests__/lock.test.d.ts +0 -5
  135. package/dist/daemon/__tests__/lock.test.d.ts.map +0 -1
  136. package/dist/daemon/__tests__/lock.test.js +0 -192
  137. package/dist/daemon/__tests__/lock.test.js.map +0 -1
  138. package/dist/daemon/__tests__/methods/graph.test.d.ts +0 -5
  139. package/dist/daemon/__tests__/methods/graph.test.d.ts.map +0 -1
  140. package/dist/daemon/__tests__/methods/graph.test.js +0 -309
  141. package/dist/daemon/__tests__/methods/graph.test.js.map +0 -1
  142. package/dist/daemon/__tests__/methods/provider.test.d.ts +0 -7
  143. package/dist/daemon/__tests__/methods/provider.test.d.ts.map +0 -1
  144. package/dist/daemon/__tests__/methods/provider.test.js +0 -181
  145. package/dist/daemon/__tests__/methods/provider.test.js.map +0 -1
  146. package/dist/daemon/__tests__/methods/tools.test.d.ts +0 -5
  147. package/dist/daemon/__tests__/methods/tools.test.d.ts.map +0 -1
  148. package/dist/daemon/__tests__/methods/tools.test.js +0 -587
  149. package/dist/daemon/__tests__/methods/tools.test.js.map +0 -1
  150. package/dist/daemon/__tests__/multi-location.test.d.ts +0 -8
  151. package/dist/daemon/__tests__/multi-location.test.d.ts.map +0 -1
  152. package/dist/daemon/__tests__/multi-location.test.js +0 -669
  153. package/dist/daemon/__tests__/multi-location.test.js.map +0 -1
  154. package/dist/daemon/__tests__/registry.test.d.ts +0 -5
  155. package/dist/daemon/__tests__/registry.test.d.ts.map +0 -1
  156. package/dist/daemon/__tests__/registry.test.js +0 -208
  157. package/dist/daemon/__tests__/registry.test.js.map +0 -1
  158. package/dist/daemon/__tests__/watcher.test.d.ts +0 -5
  159. package/dist/daemon/__tests__/watcher.test.d.ts.map +0 -1
  160. package/dist/daemon/__tests__/watcher.test.js +0 -234
  161. package/dist/daemon/__tests__/watcher.test.js.map +0 -1
  162. package/dist/daemon/methods/__tests__/graph.test.d.ts +0 -5
  163. package/dist/daemon/methods/__tests__/graph.test.d.ts.map +0 -1
  164. package/dist/daemon/methods/__tests__/graph.test.js +0 -274
  165. package/dist/daemon/methods/__tests__/graph.test.js.map +0 -1
  166. package/dist/daemon/methods/__tests__/provider.test.d.ts +0 -5
  167. package/dist/daemon/methods/__tests__/provider.test.d.ts.map +0 -1
  168. package/dist/daemon/methods/__tests__/provider.test.js +0 -184
  169. package/dist/daemon/methods/__tests__/provider.test.js.map +0 -1
  170. package/dist/daemon/methods/__tests__/tools.test.d.ts +0 -5
  171. package/dist/daemon/methods/__tests__/tools.test.d.ts.map +0 -1
  172. package/dist/daemon/methods/__tests__/tools.test.js +0 -295
  173. package/dist/daemon/methods/__tests__/tools.test.js.map +0 -1
  174. package/dist/entire/agent/agents/claude-code.d.ts +0 -76
  175. package/dist/entire/agent/agents/claude-code.d.ts.map +0 -1
  176. package/dist/entire/agent/agents/claude-code.js +0 -759
  177. package/dist/entire/agent/agents/claude-code.js.map +0 -1
  178. package/dist/entire/agent/agents/cursor.d.ts +0 -35
  179. package/dist/entire/agent/agents/cursor.d.ts.map +0 -1
  180. package/dist/entire/agent/agents/cursor.js +0 -294
  181. package/dist/entire/agent/agents/cursor.js.map +0 -1
  182. package/dist/entire/agent/agents/gemini-cli.d.ts +0 -62
  183. package/dist/entire/agent/agents/gemini-cli.d.ts.map +0 -1
  184. package/dist/entire/agent/agents/gemini-cli.js +0 -462
  185. package/dist/entire/agent/agents/gemini-cli.js.map +0 -1
  186. package/dist/entire/agent/agents/opencode.d.ts +0 -100
  187. package/dist/entire/agent/agents/opencode.d.ts.map +0 -1
  188. package/dist/entire/agent/agents/opencode.js +0 -423
  189. package/dist/entire/agent/agents/opencode.js.map +0 -1
  190. package/dist/entire/agent/registry.d.ts +0 -54
  191. package/dist/entire/agent/registry.d.ts.map +0 -1
  192. package/dist/entire/agent/registry.js +0 -123
  193. package/dist/entire/agent/registry.js.map +0 -1
  194. package/dist/entire/agent/session-types.d.ts +0 -45
  195. package/dist/entire/agent/session-types.d.ts.map +0 -1
  196. package/dist/entire/agent/session-types.js +0 -50
  197. package/dist/entire/agent/session-types.js.map +0 -1
  198. package/dist/entire/agent/types.d.ts +0 -126
  199. package/dist/entire/agent/types.d.ts.map +0 -1
  200. package/dist/entire/agent/types.js +0 -39
  201. package/dist/entire/agent/types.js.map +0 -1
  202. package/dist/entire/commands/clean.d.ts +0 -30
  203. package/dist/entire/commands/clean.d.ts.map +0 -1
  204. package/dist/entire/commands/clean.js +0 -99
  205. package/dist/entire/commands/clean.js.map +0 -1
  206. package/dist/entire/commands/disable.d.ts +0 -23
  207. package/dist/entire/commands/disable.d.ts.map +0 -1
  208. package/dist/entire/commands/disable.js +0 -57
  209. package/dist/entire/commands/disable.js.map +0 -1
  210. package/dist/entire/commands/doctor.d.ts +0 -43
  211. package/dist/entire/commands/doctor.d.ts.map +0 -1
  212. package/dist/entire/commands/doctor.js +0 -97
  213. package/dist/entire/commands/doctor.js.map +0 -1
  214. package/dist/entire/commands/enable.d.ts +0 -29
  215. package/dist/entire/commands/enable.d.ts.map +0 -1
  216. package/dist/entire/commands/enable.js +0 -102
  217. package/dist/entire/commands/enable.js.map +0 -1
  218. package/dist/entire/commands/explain.d.ts +0 -68
  219. package/dist/entire/commands/explain.d.ts.map +0 -1
  220. package/dist/entire/commands/explain.js +0 -182
  221. package/dist/entire/commands/explain.js.map +0 -1
  222. package/dist/entire/commands/reset.d.ts +0 -23
  223. package/dist/entire/commands/reset.d.ts.map +0 -1
  224. package/dist/entire/commands/reset.js +0 -68
  225. package/dist/entire/commands/reset.js.map +0 -1
  226. package/dist/entire/commands/resume.d.ts +0 -42
  227. package/dist/entire/commands/resume.d.ts.map +0 -1
  228. package/dist/entire/commands/resume.js +0 -134
  229. package/dist/entire/commands/resume.js.map +0 -1
  230. package/dist/entire/commands/rewind.d.ts +0 -34
  231. package/dist/entire/commands/rewind.d.ts.map +0 -1
  232. package/dist/entire/commands/rewind.js +0 -155
  233. package/dist/entire/commands/rewind.js.map +0 -1
  234. package/dist/entire/commands/status.d.ts +0 -51
  235. package/dist/entire/commands/status.d.ts.map +0 -1
  236. package/dist/entire/commands/status.js +0 -94
  237. package/dist/entire/commands/status.js.map +0 -1
  238. package/dist/entire/config.d.ts +0 -40
  239. package/dist/entire/config.d.ts.map +0 -1
  240. package/dist/entire/config.js +0 -126
  241. package/dist/entire/config.js.map +0 -1
  242. package/dist/entire/git-operations.d.ts +0 -170
  243. package/dist/entire/git-operations.d.ts.map +0 -1
  244. package/dist/entire/git-operations.js +0 -395
  245. package/dist/entire/git-operations.js.map +0 -1
  246. package/dist/entire/hooks/git-hooks.d.ts +0 -22
  247. package/dist/entire/hooks/git-hooks.d.ts.map +0 -1
  248. package/dist/entire/hooks/git-hooks.js +0 -145
  249. package/dist/entire/hooks/git-hooks.js.map +0 -1
  250. package/dist/entire/hooks/lifecycle.d.ts +0 -21
  251. package/dist/entire/hooks/lifecycle.d.ts.map +0 -1
  252. package/dist/entire/hooks/lifecycle.js +0 -179
  253. package/dist/entire/hooks/lifecycle.js.map +0 -1
  254. package/dist/entire/index.d.ts +0 -69
  255. package/dist/entire/index.d.ts.map +0 -1
  256. package/dist/entire/index.js +0 -152
  257. package/dist/entire/index.js.map +0 -1
  258. package/dist/entire/security/redaction.d.ts +0 -35
  259. package/dist/entire/security/redaction.d.ts.map +0 -1
  260. package/dist/entire/security/redaction.js +0 -221
  261. package/dist/entire/security/redaction.js.map +0 -1
  262. package/dist/entire/session/state-machine.d.ts +0 -90
  263. package/dist/entire/session/state-machine.d.ts.map +0 -1
  264. package/dist/entire/session/state-machine.js +0 -347
  265. package/dist/entire/session/state-machine.js.map +0 -1
  266. package/dist/entire/store/checkpoint-store.d.ts +0 -47
  267. package/dist/entire/store/checkpoint-store.d.ts.map +0 -1
  268. package/dist/entire/store/checkpoint-store.js +0 -307
  269. package/dist/entire/store/checkpoint-store.js.map +0 -1
  270. package/dist/entire/store/native-store.d.ts +0 -14
  271. package/dist/entire/store/native-store.d.ts.map +0 -1
  272. package/dist/entire/store/native-store.js +0 -159
  273. package/dist/entire/store/native-store.js.map +0 -1
  274. package/dist/entire/store/provider-types.d.ts +0 -78
  275. package/dist/entire/store/provider-types.d.ts.map +0 -1
  276. package/dist/entire/store/provider-types.js +0 -12
  277. package/dist/entire/store/provider-types.js.map +0 -1
  278. package/dist/entire/store/session-store.d.ts +0 -28
  279. package/dist/entire/store/session-store.d.ts.map +0 -1
  280. package/dist/entire/store/session-store.js +0 -187
  281. package/dist/entire/store/session-store.js.map +0 -1
  282. package/dist/entire/strategy/attribution.d.ts +0 -39
  283. package/dist/entire/strategy/attribution.d.ts.map +0 -1
  284. package/dist/entire/strategy/attribution.js +0 -227
  285. package/dist/entire/strategy/attribution.js.map +0 -1
  286. package/dist/entire/strategy/common.d.ts +0 -57
  287. package/dist/entire/strategy/common.d.ts.map +0 -1
  288. package/dist/entire/strategy/common.js +0 -156
  289. package/dist/entire/strategy/common.js.map +0 -1
  290. package/dist/entire/strategy/content-overlap.d.ts +0 -33
  291. package/dist/entire/strategy/content-overlap.d.ts.map +0 -1
  292. package/dist/entire/strategy/content-overlap.js +0 -168
  293. package/dist/entire/strategy/content-overlap.js.map +0 -1
  294. package/dist/entire/strategy/manual-commit.d.ts +0 -31
  295. package/dist/entire/strategy/manual-commit.d.ts.map +0 -1
  296. package/dist/entire/strategy/manual-commit.js +0 -730
  297. package/dist/entire/strategy/manual-commit.js.map +0 -1
  298. package/dist/entire/strategy/types.d.ts +0 -163
  299. package/dist/entire/strategy/types.d.ts.map +0 -1
  300. package/dist/entire/strategy/types.js +0 -49
  301. package/dist/entire/strategy/types.js.map +0 -1
  302. package/dist/entire/summarize/claude-generator.d.ts +0 -25
  303. package/dist/entire/summarize/claude-generator.d.ts.map +0 -1
  304. package/dist/entire/summarize/claude-generator.js +0 -87
  305. package/dist/entire/summarize/claude-generator.js.map +0 -1
  306. package/dist/entire/summarize/summarize.d.ts +0 -52
  307. package/dist/entire/summarize/summarize.d.ts.map +0 -1
  308. package/dist/entire/summarize/summarize.js +0 -335
  309. package/dist/entire/summarize/summarize.js.map +0 -1
  310. package/dist/entire/types.d.ts +0 -288
  311. package/dist/entire/types.d.ts.map +0 -1
  312. package/dist/entire/types.js +0 -94
  313. package/dist/entire/types.js.map +0 -1
  314. package/dist/entire/utils/chunk-files.d.ts +0 -25
  315. package/dist/entire/utils/chunk-files.d.ts.map +0 -1
  316. package/dist/entire/utils/chunk-files.js +0 -47
  317. package/dist/entire/utils/chunk-files.js.map +0 -1
  318. package/dist/entire/utils/commit-message.d.ts +0 -11
  319. package/dist/entire/utils/commit-message.d.ts.map +0 -1
  320. package/dist/entire/utils/commit-message.js +0 -54
  321. package/dist/entire/utils/commit-message.js.map +0 -1
  322. package/dist/entire/utils/detect-agent.d.ts +0 -19
  323. package/dist/entire/utils/detect-agent.d.ts.map +0 -1
  324. package/dist/entire/utils/detect-agent.js +0 -34
  325. package/dist/entire/utils/detect-agent.js.map +0 -1
  326. package/dist/entire/utils/hook-managers.d.ts +0 -24
  327. package/dist/entire/utils/hook-managers.d.ts.map +0 -1
  328. package/dist/entire/utils/hook-managers.js +0 -87
  329. package/dist/entire/utils/hook-managers.js.map +0 -1
  330. package/dist/entire/utils/ide-tags.d.ts +0 -12
  331. package/dist/entire/utils/ide-tags.d.ts.map +0 -1
  332. package/dist/entire/utils/ide-tags.js +0 -30
  333. package/dist/entire/utils/ide-tags.js.map +0 -1
  334. package/dist/entire/utils/paths.d.ts +0 -32
  335. package/dist/entire/utils/paths.d.ts.map +0 -1
  336. package/dist/entire/utils/paths.js +0 -55
  337. package/dist/entire/utils/paths.js.map +0 -1
  338. package/dist/entire/utils/preview-rewind.d.ts +0 -23
  339. package/dist/entire/utils/preview-rewind.d.ts.map +0 -1
  340. package/dist/entire/utils/preview-rewind.js +0 -63
  341. package/dist/entire/utils/preview-rewind.js.map +0 -1
  342. package/dist/entire/utils/rewind-conflict.d.ts +0 -52
  343. package/dist/entire/utils/rewind-conflict.d.ts.map +0 -1
  344. package/dist/entire/utils/rewind-conflict.js +0 -79
  345. package/dist/entire/utils/rewind-conflict.js.map +0 -1
  346. package/dist/entire/utils/shadow-branch.d.ts +0 -44
  347. package/dist/entire/utils/shadow-branch.d.ts.map +0 -1
  348. package/dist/entire/utils/shadow-branch.js +0 -93
  349. package/dist/entire/utils/shadow-branch.js.map +0 -1
  350. package/dist/entire/utils/string-utils.d.ts +0 -24
  351. package/dist/entire/utils/string-utils.d.ts.map +0 -1
  352. package/dist/entire/utils/string-utils.js +0 -47
  353. package/dist/entire/utils/string-utils.js.map +0 -1
  354. package/dist/entire/utils/todo-extract.d.ts +0 -52
  355. package/dist/entire/utils/todo-extract.d.ts.map +0 -1
  356. package/dist/entire/utils/todo-extract.js +0 -167
  357. package/dist/entire/utils/todo-extract.js.map +0 -1
  358. package/dist/entire/utils/trailers.d.ts +0 -36
  359. package/dist/entire/utils/trailers.d.ts.map +0 -1
  360. package/dist/entire/utils/trailers.js +0 -149
  361. package/dist/entire/utils/trailers.js.map +0 -1
  362. package/dist/entire/utils/transcript-parse.d.ts +0 -57
  363. package/dist/entire/utils/transcript-parse.d.ts.map +0 -1
  364. package/dist/entire/utils/transcript-parse.js +0 -126
  365. package/dist/entire/utils/transcript-parse.js.map +0 -1
  366. package/dist/entire/utils/transcript-timestamp.d.ts +0 -22
  367. package/dist/entire/utils/transcript-timestamp.d.ts.map +0 -1
  368. package/dist/entire/utils/transcript-timestamp.js +0 -56
  369. package/dist/entire/utils/transcript-timestamp.js.map +0 -1
  370. package/dist/entire/utils/tree-ops.d.ts +0 -47
  371. package/dist/entire/utils/tree-ops.d.ts.map +0 -1
  372. package/dist/entire/utils/tree-ops.js +0 -145
  373. package/dist/entire/utils/tree-ops.js.map +0 -1
  374. package/dist/entire/utils/tty.d.ts +0 -25
  375. package/dist/entire/utils/tty.d.ts.map +0 -1
  376. package/dist/entire/utils/tty.js +0 -70
  377. package/dist/entire/utils/tty.js.map +0 -1
  378. package/dist/entire/utils/validation.d.ts +0 -31
  379. package/dist/entire/utils/validation.d.ts.map +0 -1
  380. package/dist/entire/utils/validation.js +0 -59
  381. package/dist/entire/utils/validation.js.map +0 -1
  382. package/dist/entire/utils/worktree.d.ts +0 -16
  383. package/dist/entire/utils/worktree.d.ts.map +0 -1
  384. package/dist/entire/utils/worktree.js +0 -50
  385. package/dist/entire/utils/worktree.js.map +0 -1
  386. package/dist/graph/__tests__/EdgeTypeRegistry.test.d.ts +0 -2
  387. package/dist/graph/__tests__/EdgeTypeRegistry.test.d.ts.map +0 -1
  388. package/dist/graph/__tests__/EdgeTypeRegistry.test.js +0 -212
  389. package/dist/graph/__tests__/EdgeTypeRegistry.test.js.map +0 -1
  390. package/dist/graph/__tests__/FederatedGraph.test.d.ts +0 -2
  391. package/dist/graph/__tests__/FederatedGraph.test.d.ts.map +0 -1
  392. package/dist/graph/__tests__/FederatedGraph.test.js +0 -661
  393. package/dist/graph/__tests__/FederatedGraph.test.js.map +0 -1
  394. package/dist/graph/__tests__/GraphologyAdapter.test.d.ts +0 -2
  395. package/dist/graph/__tests__/GraphologyAdapter.test.d.ts.map +0 -1
  396. package/dist/graph/__tests__/GraphologyAdapter.test.js +0 -326
  397. package/dist/graph/__tests__/GraphologyAdapter.test.js.map +0 -1
  398. package/dist/graph/__tests__/HydratingFederatedGraph.test.d.ts +0 -2
  399. package/dist/graph/__tests__/HydratingFederatedGraph.test.d.ts.map +0 -1
  400. package/dist/graph/__tests__/HydratingFederatedGraph.test.js +0 -587
  401. package/dist/graph/__tests__/HydratingFederatedGraph.test.js.map +0 -1
  402. package/dist/graph/__tests__/debounce.test.d.ts +0 -5
  403. package/dist/graph/__tests__/debounce.test.d.ts.map +0 -1
  404. package/dist/graph/__tests__/debounce.test.js +0 -195
  405. package/dist/graph/__tests__/debounce.test.js.map +0 -1
  406. package/dist/graph/__tests__/edge-cases.test.d.ts +0 -8
  407. package/dist/graph/__tests__/edge-cases.test.d.ts.map +0 -1
  408. package/dist/graph/__tests__/edge-cases.test.js +0 -472
  409. package/dist/graph/__tests__/edge-cases.test.js.map +0 -1
  410. package/dist/graph/__tests__/expansion.test.d.ts +0 -2
  411. package/dist/graph/__tests__/expansion.test.d.ts.map +0 -1
  412. package/dist/graph/__tests__/expansion.test.js +0 -105
  413. package/dist/graph/__tests__/expansion.test.js.map +0 -1
  414. package/dist/graph/__tests__/provider-store.test.d.ts +0 -5
  415. package/dist/graph/__tests__/provider-store.test.d.ts.map +0 -1
  416. package/dist/graph/__tests__/provider-store.test.js +0 -791
  417. package/dist/graph/__tests__/provider-store.test.js.map +0 -1
  418. package/dist/graph/__tests__/query.test.d.ts +0 -5
  419. package/dist/graph/__tests__/query.test.d.ts.map +0 -1
  420. package/dist/graph/__tests__/query.test.js +0 -774
  421. package/dist/graph/__tests__/query.test.js.map +0 -1
  422. package/dist/graph/__tests__/store.test.d.ts +0 -5
  423. package/dist/graph/__tests__/store.test.d.ts.map +0 -1
  424. package/dist/graph/__tests__/store.test.js +0 -489
  425. package/dist/graph/__tests__/store.test.js.map +0 -1
  426. package/dist/graph/__tests__/sync.test.d.ts +0 -5
  427. package/dist/graph/__tests__/sync.test.d.ts.map +0 -1
  428. package/dist/graph/__tests__/sync.test.js +0 -129
  429. package/dist/graph/__tests__/sync.test.js.map +0 -1
  430. package/dist/graph/__tests__/validation.test.d.ts +0 -2
  431. package/dist/graph/__tests__/validation.test.d.ts.map +0 -1
  432. package/dist/graph/__tests__/validation.test.js +0 -521
  433. package/dist/graph/__tests__/validation.test.js.map +0 -1
  434. package/dist/providers/__tests__/beads.test.d.ts +0 -5
  435. package/dist/providers/__tests__/beads.test.d.ts.map +0 -1
  436. package/dist/providers/__tests__/beads.test.js +0 -591
  437. package/dist/providers/__tests__/beads.test.js.map +0 -1
  438. package/dist/providers/__tests__/claude-tasks.test.d.ts +0 -5
  439. package/dist/providers/__tests__/claude-tasks.test.d.ts.map +0 -1
  440. package/dist/providers/__tests__/claude-tasks.test.js +0 -392
  441. package/dist/providers/__tests__/claude-tasks.test.js.map +0 -1
  442. package/dist/providers/__tests__/from-config.test.d.ts +0 -5
  443. package/dist/providers/__tests__/from-config.test.d.ts.map +0 -1
  444. package/dist/providers/__tests__/from-config.test.js +0 -152
  445. package/dist/providers/__tests__/from-config.test.js.map +0 -1
  446. package/dist/providers/__tests__/materialization.test.d.ts +0 -5
  447. package/dist/providers/__tests__/materialization.test.d.ts.map +0 -1
  448. package/dist/providers/__tests__/materialization.test.js +0 -407
  449. package/dist/providers/__tests__/materialization.test.js.map +0 -1
  450. package/dist/providers/__tests__/native.test.d.ts +0 -5
  451. package/dist/providers/__tests__/native.test.d.ts.map +0 -1
  452. package/dist/providers/__tests__/native.test.js +0 -566
  453. package/dist/providers/__tests__/native.test.js.map +0 -1
  454. package/dist/providers/__tests__/registry.test.d.ts +0 -5
  455. package/dist/providers/__tests__/registry.test.d.ts.map +0 -1
  456. package/dist/providers/__tests__/registry.test.js +0 -183
  457. package/dist/providers/__tests__/registry.test.js.map +0 -1
  458. package/dist/providers/traits/__tests__/RelationshipQueryable.test.d.ts +0 -2
  459. package/dist/providers/traits/__tests__/RelationshipQueryable.test.d.ts.map +0 -1
  460. package/dist/providers/traits/__tests__/RelationshipQueryable.test.js +0 -169
  461. package/dist/providers/traits/__tests__/RelationshipQueryable.test.js.map +0 -1
  462. package/dist/providers/traits/__tests__/TaskManageable.test.d.ts +0 -2
  463. package/dist/providers/traits/__tests__/TaskManageable.test.d.ts.map +0 -1
  464. package/dist/providers/traits/__tests__/TaskManageable.test.js +0 -172
  465. package/dist/providers/traits/__tests__/TaskManageable.test.js.map +0 -1
  466. package/dist/schema/__tests__/validation.test.d.ts +0 -2
  467. package/dist/schema/__tests__/validation.test.d.ts.map +0 -1
  468. package/dist/schema/__tests__/validation.test.js +0 -241
  469. package/dist/schema/__tests__/validation.test.js.map +0 -1
  470. package/dist/storage/__tests__/atomic-write.test.d.ts +0 -5
  471. package/dist/storage/__tests__/atomic-write.test.d.ts.map +0 -1
  472. package/dist/storage/__tests__/atomic-write.test.js +0 -170
  473. package/dist/storage/__tests__/atomic-write.test.js.map +0 -1
  474. package/dist/storage/__tests__/file-lock.test.d.ts +0 -2
  475. package/dist/storage/__tests__/file-lock.test.d.ts.map +0 -1
  476. package/dist/storage/__tests__/file-lock.test.js +0 -89
  477. package/dist/storage/__tests__/file-lock.test.js.map +0 -1
  478. package/dist/storage/__tests__/jsonl.test.d.ts +0 -2
  479. package/dist/storage/__tests__/jsonl.test.d.ts.map +0 -1
  480. package/dist/storage/__tests__/jsonl.test.js +0 -228
  481. package/dist/storage/__tests__/jsonl.test.js.map +0 -1
  482. package/dist/storage/__tests__/locked-writer.test.d.ts +0 -2
  483. package/dist/storage/__tests__/locked-writer.test.d.ts.map +0 -1
  484. package/dist/storage/__tests__/locked-writer.test.js +0 -109
  485. package/dist/storage/__tests__/locked-writer.test.js.map +0 -1
  486. package/dist/storage/__tests__/sqlite.test.d.ts +0 -2
  487. package/dist/storage/__tests__/sqlite.test.d.ts.map +0 -1
  488. package/dist/storage/__tests__/sqlite.test.js +0 -470
  489. package/dist/storage/__tests__/sqlite.test.js.map +0 -1
  490. package/dist/tools/__tests__/annotate.test.d.ts +0 -5
  491. package/dist/tools/__tests__/annotate.test.d.ts.map +0 -1
  492. package/dist/tools/__tests__/annotate.test.js +0 -314
  493. package/dist/tools/__tests__/annotate.test.js.map +0 -1
  494. package/dist/tools/__tests__/link.test.d.ts +0 -5
  495. package/dist/tools/__tests__/link.test.d.ts.map +0 -1
  496. package/dist/tools/__tests__/link.test.js +0 -245
  497. package/dist/tools/__tests__/link.test.js.map +0 -1
  498. package/dist/tools/__tests__/query.test.d.ts +0 -5
  499. package/dist/tools/__tests__/query.test.d.ts.map +0 -1
  500. package/dist/tools/__tests__/query.test.js +0 -288
  501. package/dist/tools/__tests__/query.test.js.map +0 -1
  502. package/dist/tools/__tests__/task.test.d.ts +0 -5
  503. package/dist/tools/__tests__/task.test.d.ts.map +0 -1
  504. package/dist/tools/__tests__/task.test.js +0 -178
  505. package/dist/tools/__tests__/task.test.js.map +0 -1
@@ -1,129 +0,0 @@
1
- /**
2
- * Tests for Sync Manager
3
- */
4
- import { describe, it, expect, beforeEach, vi, afterEach } from 'vitest';
5
- import { createSyncManager } from '../sync.js';
6
- describe('SyncManager', () => {
7
- let storage;
8
- let syncManager;
9
- let flushCallback;
10
- const config = {
11
- debounceMs: 100,
12
- maxDelayMs: 500,
13
- };
14
- beforeEach(() => {
15
- vi.useFakeTimers();
16
- // Create mock storage
17
- const dirtyNodes = new Set();
18
- storage = {
19
- markDirty: vi.fn().mockImplementation(async (nodeId) => {
20
- dirtyNodes.add(nodeId);
21
- }),
22
- getDirtyNodes: vi.fn().mockImplementation(async () => {
23
- return Array.from(dirtyNodes);
24
- }),
25
- clearDirty: vi.fn().mockImplementation(async (nodeIds) => {
26
- for (const id of nodeIds) {
27
- dirtyNodes.delete(id);
28
- }
29
- }),
30
- };
31
- flushCallback = vi.fn().mockResolvedValue(undefined);
32
- syncManager = createSyncManager(config, storage, flushCallback);
33
- });
34
- afterEach(() => {
35
- vi.useRealTimers();
36
- syncManager.cancel();
37
- });
38
- describe('markDirty', () => {
39
- it('should track dirty nodes', () => {
40
- syncManager.markDirty('s-abc1');
41
- syncManager.markDirty('s-abc2');
42
- expect(syncManager.hasPendingChanges()).toBe(true);
43
- });
44
- });
45
- describe('scheduleFlush', () => {
46
- it('should flush after debounce delay', async () => {
47
- syncManager.markDirty('s-abc1');
48
- syncManager.scheduleFlush();
49
- expect(flushCallback).not.toHaveBeenCalled();
50
- // Advance past debounce
51
- await vi.advanceTimersByTimeAsync(config.debounceMs + 10);
52
- expect(flushCallback).toHaveBeenCalled();
53
- });
54
- it('should reset debounce timer on multiple calls', async () => {
55
- syncManager.markDirty('s-abc1');
56
- syncManager.scheduleFlush();
57
- // Advance halfway
58
- await vi.advanceTimersByTimeAsync(config.debounceMs / 2);
59
- syncManager.markDirty('s-abc2');
60
- syncManager.scheduleFlush();
61
- // Advance halfway again (would be past original debounce)
62
- await vi.advanceTimersByTimeAsync(config.debounceMs / 2);
63
- // Should not have flushed yet (debounce was reset)
64
- expect(flushCallback).not.toHaveBeenCalled();
65
- // Advance remaining time
66
- await vi.advanceTimersByTimeAsync(config.debounceMs / 2 + 10);
67
- expect(flushCallback).toHaveBeenCalled();
68
- });
69
- it('should force flush at max delay', async () => {
70
- syncManager.markDirty('s-abc1');
71
- syncManager.scheduleFlush();
72
- // Keep resetting debounce but stay under max delay
73
- // debounceMs = 100, maxDelayMs = 500
74
- // Advance 80ms at a time, which is less than debounce
75
- // After 4 iterations: 320ms total (still under 500ms max)
76
- for (let i = 0; i < 4; i++) {
77
- await vi.advanceTimersByTimeAsync(80);
78
- syncManager.scheduleFlush();
79
- }
80
- // Should not have flushed yet (320ms < 500ms maxDelay)
81
- expect(flushCallback).not.toHaveBeenCalled();
82
- // Advance to max delay (need another 180ms to reach 500ms)
83
- await vi.advanceTimersByTimeAsync(200);
84
- expect(flushCallback).toHaveBeenCalled();
85
- });
86
- });
87
- describe('flush', () => {
88
- it('should flush immediately', async () => {
89
- syncManager.markDirty('s-abc1');
90
- await syncManager.flush();
91
- expect(flushCallback).toHaveBeenCalled();
92
- });
93
- it('should clear pending changes after flush', async () => {
94
- syncManager.markDirty('s-abc1');
95
- await syncManager.flush();
96
- expect(syncManager.hasPendingChanges()).toBe(false);
97
- });
98
- it('should not flush when no pending changes', async () => {
99
- await syncManager.flush();
100
- expect(flushCallback).not.toHaveBeenCalled();
101
- });
102
- it('should deduplicate concurrent flush calls', async () => {
103
- syncManager.markDirty('s-abc1');
104
- // Call flush multiple times concurrently
105
- const promise1 = syncManager.flush();
106
- const promise2 = syncManager.flush();
107
- const promise3 = syncManager.flush();
108
- await Promise.all([promise1, promise2, promise3]);
109
- // Should only call flush callback once
110
- expect(flushCallback).toHaveBeenCalledTimes(1);
111
- });
112
- });
113
- describe('cancel', () => {
114
- it('should cancel pending flush', async () => {
115
- syncManager.markDirty('s-abc1');
116
- syncManager.scheduleFlush();
117
- syncManager.cancel();
118
- // Advance past debounce
119
- await vi.advanceTimersByTimeAsync(config.debounceMs + 10);
120
- expect(flushCallback).not.toHaveBeenCalled();
121
- });
122
- it('should clear pending changes', () => {
123
- syncManager.markDirty('s-abc1');
124
- syncManager.cancel();
125
- expect(syncManager.hasPendingChanges()).toBe(false);
126
- });
127
- });
128
- });
129
- //# sourceMappingURL=sync.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sync.test.js","sourceRoot":"","sources":["../../../src/graph/__tests__/sync.test.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=validation.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"validation.test.d.ts","sourceRoot":"","sources":["../../../src/graph/__tests__/validation.test.ts"],"names":[],"mappings":""}
@@ -1,521 +0,0 @@
1
- import { describe, it, expect } from 'vitest';
2
- import { createValidationService } from '../validation.js';
3
- describe('ValidationService', () => {
4
- const service = createValidationService();
5
- // =========================================================================
6
- // Node Creation Validation
7
- // =========================================================================
8
- describe('validateCreateNode', () => {
9
- describe('common fields', () => {
10
- it('requires type', () => {
11
- const input = { title: 'Test' };
12
- const result = service.validateCreateNode(input);
13
- expect(result.valid).toBe(false);
14
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'REQUIRED', field: 'type' }));
15
- });
16
- it('rejects invalid type', () => {
17
- const input = { type: 'invalid', title: 'Test' };
18
- const result = service.validateCreateNode(input);
19
- expect(result.valid).toBe(false);
20
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'INVALID_TYPE', field: 'type' }));
21
- });
22
- it('requires title', () => {
23
- const input = { type: 'spec' };
24
- const result = service.validateCreateNode(input);
25
- expect(result.valid).toBe(false);
26
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'REQUIRED', field: 'title' }));
27
- });
28
- it('rejects empty title', () => {
29
- const input = { type: 'spec', title: '' };
30
- const result = service.validateCreateNode(input);
31
- expect(result.valid).toBe(false);
32
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'REQUIRED', field: 'title' }));
33
- });
34
- it('rejects title exceeding max length', () => {
35
- const input = {
36
- type: 'spec',
37
- title: 'a'.repeat(501),
38
- };
39
- const result = service.validateCreateNode(input);
40
- expect(result.valid).toBe(false);
41
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'MAX_LENGTH', field: 'title' }));
42
- });
43
- it('rejects content exceeding max length', () => {
44
- const input = {
45
- type: 'spec',
46
- title: 'Test',
47
- content: 'a'.repeat(100_001),
48
- };
49
- const result = service.validateCreateNode(input);
50
- expect(result.valid).toBe(false);
51
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'MAX_LENGTH', field: 'content' }));
52
- });
53
- it('rejects invalid priority (out of range)', () => {
54
- const input = {
55
- type: 'spec',
56
- title: 'Test',
57
- priority: 5,
58
- };
59
- const result = service.validateCreateNode(input);
60
- expect(result.valid).toBe(false);
61
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'INVALID_RANGE', field: 'priority' }));
62
- });
63
- it('rejects negative priority', () => {
64
- const input = {
65
- type: 'spec',
66
- title: 'Test',
67
- priority: -1,
68
- };
69
- const result = service.validateCreateNode(input);
70
- expect(result.valid).toBe(false);
71
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'INVALID_RANGE', field: 'priority' }));
72
- });
73
- it('accepts valid priority', () => {
74
- const input = {
75
- type: 'spec',
76
- title: 'Test',
77
- priority: 2,
78
- };
79
- const result = service.validateCreateNode(input);
80
- expect(result.valid).toBe(true);
81
- });
82
- });
83
- describe('spec validation', () => {
84
- it('accepts valid spec', () => {
85
- const input = {
86
- type: 'spec',
87
- title: 'Test Spec',
88
- content: 'Some content',
89
- };
90
- const result = service.validateCreateNode(input);
91
- expect(result.valid).toBe(true);
92
- expect(result.errors).toHaveLength(0);
93
- });
94
- it('accepts spec with optional status', () => {
95
- const input = {
96
- type: 'spec',
97
- title: 'Test Spec',
98
- status: 'draft',
99
- };
100
- const result = service.validateCreateNode(input);
101
- expect(result.valid).toBe(true);
102
- });
103
- });
104
- describe('issue validation', () => {
105
- it('requires status for issues', () => {
106
- const input = {
107
- type: 'issue',
108
- title: 'Test Issue',
109
- };
110
- const result = service.validateCreateNode(input);
111
- expect(result.valid).toBe(false);
112
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'REQUIRED', field: 'status' }));
113
- });
114
- it('accepts valid issue', () => {
115
- const input = {
116
- type: 'issue',
117
- title: 'Test Issue',
118
- status: 'open',
119
- };
120
- const result = service.validateCreateNode(input);
121
- expect(result.valid).toBe(true);
122
- });
123
- it('warns for non-standard status', () => {
124
- const input = {
125
- type: 'issue',
126
- title: 'Test Issue',
127
- status: 'custom_status',
128
- };
129
- const result = service.validateCreateNode(input);
130
- expect(result.valid).toBe(true); // Warnings don't fail validation
131
- expect(result.warnings).toContainEqual(expect.objectContaining({
132
- code: 'NON_STANDARD_STATUS',
133
- field: 'status',
134
- }));
135
- });
136
- });
137
- describe('feedback validation', () => {
138
- it('requires target_id for feedback', () => {
139
- const input = {
140
- type: 'feedback',
141
- title: 'Test Feedback',
142
- feedback_type: 'comment',
143
- };
144
- const result = service.validateCreateNode(input);
145
- expect(result.valid).toBe(false);
146
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'REQUIRED', field: 'target_id' }));
147
- });
148
- it('requires feedback_type for feedback', () => {
149
- const input = {
150
- type: 'feedback',
151
- title: 'Test Feedback',
152
- target_id: 's-abc123',
153
- };
154
- const result = service.validateCreateNode(input);
155
- expect(result.valid).toBe(false);
156
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'REQUIRED', field: 'feedback_type' }));
157
- });
158
- it('accepts valid feedback', () => {
159
- const input = {
160
- type: 'feedback',
161
- title: 'Test Feedback',
162
- target_id: 's-abc123',
163
- feedback_type: 'comment',
164
- };
165
- const result = service.validateCreateNode(input);
166
- expect(result.valid).toBe(true);
167
- });
168
- });
169
- describe('external validation', () => {
170
- it('requires uri for external', () => {
171
- const input = {
172
- type: 'external',
173
- title: 'External Node',
174
- source: 'jira',
175
- };
176
- const result = service.validateCreateNode(input);
177
- expect(result.valid).toBe(false);
178
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'REQUIRED', field: 'uri' }));
179
- });
180
- it('requires source for external', () => {
181
- const input = {
182
- type: 'external',
183
- title: 'External Node',
184
- uri: 'jira://PROJ-123',
185
- };
186
- const result = service.validateCreateNode(input);
187
- expect(result.valid).toBe(false);
188
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'REQUIRED', field: 'source' }));
189
- });
190
- it('accepts valid external node', () => {
191
- const input = {
192
- type: 'external',
193
- title: 'External Node',
194
- uri: 'jira://PROJ-123',
195
- source: 'jira',
196
- };
197
- const result = service.validateCreateNode(input);
198
- expect(result.valid).toBe(true);
199
- });
200
- });
201
- });
202
- // =========================================================================
203
- // Node Update Validation
204
- // =========================================================================
205
- describe('validateUpdateNode', () => {
206
- const existingIssue = {
207
- id: 'i-test',
208
- uuid: 'test-uuid',
209
- type: 'issue',
210
- title: 'Existing Issue',
211
- status: 'open',
212
- created_at: '2025-01-26T10:00:00Z',
213
- updated_at: '2025-01-26T10:00:00Z',
214
- };
215
- it('accepts valid update', () => {
216
- const result = service.validateUpdateNode(existingIssue, {
217
- title: 'Updated Title',
218
- });
219
- expect(result.valid).toBe(true);
220
- });
221
- it('rejects title exceeding max length', () => {
222
- const result = service.validateUpdateNode(existingIssue, {
223
- title: 'a'.repeat(501),
224
- });
225
- expect(result.valid).toBe(false);
226
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'MAX_LENGTH', field: 'title' }));
227
- });
228
- it('warns for non-standard status on issues', () => {
229
- const result = service.validateUpdateNode(existingIssue, {
230
- status: 'custom',
231
- });
232
- expect(result.valid).toBe(true);
233
- expect(result.warnings).toContainEqual(expect.objectContaining({ code: 'NON_STANDARD_STATUS' }));
234
- });
235
- });
236
- // =========================================================================
237
- // Edge Validation
238
- // =========================================================================
239
- describe('validateCreateEdge', () => {
240
- const mockGetNode = async (id) => {
241
- const nodes = {
242
- 's-spec1': {
243
- id: 's-spec1',
244
- uuid: 'spec-uuid',
245
- type: 'spec',
246
- title: 'Test Spec',
247
- created_at: '2025-01-26T10:00:00Z',
248
- updated_at: '2025-01-26T10:00:00Z',
249
- },
250
- 'i-issue1': {
251
- id: 'i-issue1',
252
- uuid: 'issue-uuid',
253
- type: 'issue',
254
- title: 'Test Issue',
255
- status: 'open',
256
- created_at: '2025-01-26T10:00:00Z',
257
- updated_at: '2025-01-26T10:00:00Z',
258
- },
259
- };
260
- return nodes[id] || null;
261
- };
262
- it('requires from_id', async () => {
263
- const input = { to_id: 's-spec1', type: 'blocks' };
264
- const result = await service.validateCreateEdge(input, mockGetNode);
265
- expect(result.valid).toBe(false);
266
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'REQUIRED', field: 'from_id' }));
267
- });
268
- it('requires to_id', async () => {
269
- const input = { from_id: 'i-issue1', type: 'blocks' };
270
- const result = await service.validateCreateEdge(input, mockGetNode);
271
- expect(result.valid).toBe(false);
272
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'REQUIRED', field: 'to_id' }));
273
- });
274
- it('requires type', async () => {
275
- const input = { from_id: 'i-issue1', to_id: 's-spec1' };
276
- const result = await service.validateCreateEdge(input, mockGetNode);
277
- expect(result.valid).toBe(false);
278
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'REQUIRED', field: 'type' }));
279
- });
280
- it('rejects self-reference', async () => {
281
- const input = {
282
- from_id: 'i-issue1',
283
- to_id: 'i-issue1',
284
- type: 'blocks',
285
- };
286
- const result = await service.validateCreateEdge(input, mockGetNode);
287
- expect(result.valid).toBe(false);
288
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'SELF_REFERENCE' }));
289
- });
290
- it('errors when source node not found', async () => {
291
- const input = {
292
- from_id: 'i-nonexistent',
293
- to_id: 's-spec1',
294
- type: 'implements',
295
- };
296
- const result = await service.validateCreateEdge(input, mockGetNode);
297
- expect(result.valid).toBe(false);
298
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'NOT_FOUND', field: 'from_id' }));
299
- });
300
- it('errors when target node not found', async () => {
301
- const input = {
302
- from_id: 'i-issue1',
303
- to_id: 's-nonexistent',
304
- type: 'implements',
305
- };
306
- const result = await service.validateCreateEdge(input, mockGetNode);
307
- expect(result.valid).toBe(false);
308
- expect(result.errors).toContainEqual(expect.objectContaining({ code: 'NOT_FOUND', field: 'to_id' }));
309
- });
310
- it('accepts valid edge', async () => {
311
- const input = {
312
- from_id: 'i-issue1',
313
- to_id: 's-spec1',
314
- type: 'implements',
315
- };
316
- const result = await service.validateCreateEdge(input, mockGetNode);
317
- expect(result.valid).toBe(true);
318
- });
319
- it('warns when implements edge has non-issue source', async () => {
320
- const input = {
321
- from_id: 's-spec1',
322
- to_id: 'i-issue1',
323
- type: 'implements',
324
- };
325
- const result = await service.validateCreateEdge(input, mockGetNode);
326
- expect(result.valid).toBe(true); // Warning, not error
327
- expect(result.warnings).toContainEqual(expect.objectContaining({ code: 'IMPLEMENTS_FROM_NON_ISSUE' }));
328
- });
329
- it('warns when implements edge has non-spec target', async () => {
330
- const input = {
331
- from_id: 'i-issue1',
332
- to_id: 'i-issue1',
333
- type: 'implements',
334
- };
335
- // Note: This will hit self-reference first, so use different nodes
336
- const getNodeWithTwoIssues = async (id) => {
337
- const nodes = {
338
- 'i-issue1': {
339
- id: 'i-issue1',
340
- uuid: 'issue-uuid-1',
341
- type: 'issue',
342
- title: 'Test Issue 1',
343
- status: 'open',
344
- created_at: '2025-01-26T10:00:00Z',
345
- updated_at: '2025-01-26T10:00:00Z',
346
- },
347
- 'i-issue2': {
348
- id: 'i-issue2',
349
- uuid: 'issue-uuid-2',
350
- type: 'issue',
351
- title: 'Test Issue 2',
352
- status: 'open',
353
- created_at: '2025-01-26T10:00:00Z',
354
- updated_at: '2025-01-26T10:00:00Z',
355
- },
356
- };
357
- return nodes[id] || null;
358
- };
359
- const input2 = {
360
- from_id: 'i-issue1',
361
- to_id: 'i-issue2',
362
- type: 'implements',
363
- };
364
- const result = await service.validateCreateEdge(input2, getNodeWithTwoIssues);
365
- expect(result.valid).toBe(true);
366
- expect(result.warnings).toContainEqual(expect.objectContaining({ code: 'IMPLEMENTS_TO_NON_SPEC' }));
367
- });
368
- it('allows external URIs without node lookup', async () => {
369
- const input = {
370
- from_id: 'i-issue1',
371
- to_id: 'jira://PROJ-123',
372
- type: 'references',
373
- };
374
- const result = await service.validateCreateEdge(input, mockGetNode);
375
- expect(result.valid).toBe(true);
376
- });
377
- });
378
- // =========================================================================
379
- // Cycle Detection
380
- // =========================================================================
381
- describe('detectCycle', () => {
382
- it('detects simple cycle (A→B, adding B→A)', async () => {
383
- // A blocks B already exists
384
- const getBlocksEdges = async (nodeId) => {
385
- if (nodeId === 'i-b') {
386
- return []; // B doesn't block anything yet
387
- }
388
- if (nodeId === 'i-a') {
389
- return [
390
- {
391
- id: 'x-1',
392
- uuid: 'edge-uuid-1',
393
- from_id: 'i-a',
394
- to_id: 'i-b',
395
- type: 'blocks',
396
- created_at: '2025-01-26T10:00:00Z',
397
- },
398
- ];
399
- }
400
- return [];
401
- };
402
- // Adding B→A would create cycle
403
- const result = await service.detectCycle('i-b', 'i-a', getBlocksEdges);
404
- expect(result.hasCycle).toBe(true);
405
- expect(result.cycle).toEqual(['i-b', 'i-a']);
406
- });
407
- it('detects transitive cycle (A→B→C, adding C→A)', async () => {
408
- // A→B, B→C exists
409
- const getBlocksEdges = async (nodeId) => {
410
- const edges = {
411
- 'i-a': [
412
- {
413
- id: 'x-1',
414
- uuid: 'edge-1',
415
- from_id: 'i-a',
416
- to_id: 'i-b',
417
- type: 'blocks',
418
- created_at: '2025-01-26T10:00:00Z',
419
- },
420
- ],
421
- 'i-b': [
422
- {
423
- id: 'x-2',
424
- uuid: 'edge-2',
425
- from_id: 'i-b',
426
- to_id: 'i-c',
427
- type: 'blocks',
428
- created_at: '2025-01-26T10:00:00Z',
429
- },
430
- ],
431
- 'i-c': [],
432
- };
433
- return edges[nodeId] || [];
434
- };
435
- // Adding C→A would create cycle
436
- const result = await service.detectCycle('i-c', 'i-a', getBlocksEdges);
437
- expect(result.hasCycle).toBe(true);
438
- expect(result.cycle).toContain('i-a');
439
- expect(result.cycle).toContain('i-b');
440
- expect(result.cycle).toContain('i-c');
441
- });
442
- it('returns no cycle for valid edge', async () => {
443
- // A→B exists
444
- const getBlocksEdges = async (nodeId) => {
445
- if (nodeId === 'i-a') {
446
- return [
447
- {
448
- id: 'x-1',
449
- uuid: 'edge-uuid-1',
450
- from_id: 'i-a',
451
- to_id: 'i-b',
452
- type: 'blocks',
453
- created_at: '2025-01-26T10:00:00Z',
454
- },
455
- ];
456
- }
457
- return [];
458
- };
459
- // Adding A→C is fine (no cycle)
460
- const result = await service.detectCycle('i-a', 'i-c', getBlocksEdges);
461
- expect(result.hasCycle).toBe(false);
462
- expect(result.cycle).toBeUndefined();
463
- });
464
- it('handles no existing edges', async () => {
465
- const getBlocksEdges = async () => [];
466
- const result = await service.detectCycle('i-a', 'i-b', getBlocksEdges);
467
- expect(result.hasCycle).toBe(false);
468
- });
469
- it('handles complex graph without cycle', async () => {
470
- // Diamond: A→B, A→C, B→D, C→D
471
- const getBlocksEdges = async (nodeId) => {
472
- const edges = {
473
- 'i-a': [
474
- {
475
- id: 'x-1',
476
- uuid: 'e1',
477
- from_id: 'i-a',
478
- to_id: 'i-b',
479
- type: 'blocks',
480
- created_at: '2025-01-26T10:00:00Z',
481
- },
482
- {
483
- id: 'x-2',
484
- uuid: 'e2',
485
- from_id: 'i-a',
486
- to_id: 'i-c',
487
- type: 'blocks',
488
- created_at: '2025-01-26T10:00:00Z',
489
- },
490
- ],
491
- 'i-b': [
492
- {
493
- id: 'x-3',
494
- uuid: 'e3',
495
- from_id: 'i-b',
496
- to_id: 'i-d',
497
- type: 'blocks',
498
- created_at: '2025-01-26T10:00:00Z',
499
- },
500
- ],
501
- 'i-c': [
502
- {
503
- id: 'x-4',
504
- uuid: 'e4',
505
- from_id: 'i-c',
506
- to_id: 'i-d',
507
- type: 'blocks',
508
- created_at: '2025-01-26T10:00:00Z',
509
- },
510
- ],
511
- 'i-d': [],
512
- };
513
- return edges[nodeId] || [];
514
- };
515
- // Adding D→E is fine
516
- const result = await service.detectCycle('i-d', 'i-e', getBlocksEdges);
517
- expect(result.hasCycle).toBe(false);
518
- });
519
- });
520
- });
521
- //# sourceMappingURL=validation.test.js.map