@stackmemoryai/stackmemory 0.2.9 → 0.3.0

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 (575) hide show
  1. package/dist/agents/core/agent-task-manager.js +512 -0
  2. package/dist/agents/core/agent-task-manager.js.map +7 -0
  3. package/dist/agents/verifiers/base-verifier.js +129 -0
  4. package/dist/agents/verifiers/base-verifier.js.map +7 -0
  5. package/dist/agents/verifiers/formatter-verifier.js +126 -0
  6. package/dist/agents/verifiers/formatter-verifier.js.map +7 -0
  7. package/dist/agents/verifiers/llm-judge.js +248 -0
  8. package/dist/agents/verifiers/llm-judge.js.map +7 -0
  9. package/dist/cli/__tests__/index.test.js +290 -0
  10. package/dist/cli/__tests__/index.test.js.map +7 -0
  11. package/dist/cli/auto-detect.js +317 -0
  12. package/dist/cli/auto-detect.js.map +7 -0
  13. package/dist/cli/browser-test.js +29 -0
  14. package/dist/cli/browser-test.js.map +7 -0
  15. package/dist/cli/claude-sm.js +369 -0
  16. package/dist/cli/claude-sm.js.map +7 -0
  17. package/dist/cli/codex-sm.js +283 -0
  18. package/dist/cli/codex-sm.js.map +7 -0
  19. package/dist/cli/commands/agent.js +286 -0
  20. package/dist/cli/commands/agent.js.map +7 -0
  21. package/dist/cli/commands/config.js +199 -0
  22. package/dist/cli/commands/config.js.map +7 -0
  23. package/dist/cli/commands/context.js +327 -0
  24. package/dist/cli/commands/context.js.map +7 -0
  25. package/dist/cli/commands/handoff.js +191 -0
  26. package/dist/cli/commands/handoff.js.map +7 -0
  27. package/dist/cli/commands/linear-test.js +115 -0
  28. package/dist/cli/commands/linear-test.js.map +7 -0
  29. package/dist/cli/commands/linear.js +378 -0
  30. package/dist/cli/commands/linear.js.map +7 -0
  31. package/dist/cli/commands/log.js +165 -0
  32. package/dist/cli/commands/log.js.map +7 -0
  33. package/dist/cli/commands/onboard.js +349 -0
  34. package/dist/cli/commands/onboard.js.map +7 -0
  35. package/dist/cli/commands/projects.js +195 -0
  36. package/dist/cli/commands/projects.js.map +7 -0
  37. package/dist/cli/commands/search.js +152 -0
  38. package/dist/cli/commands/search.js.map +7 -0
  39. package/dist/cli/commands/session.js +179 -0
  40. package/dist/cli/commands/session.js.map +7 -0
  41. package/dist/cli/commands/tasks.js +205 -0
  42. package/dist/cli/commands/tasks.js.map +7 -0
  43. package/dist/cli/commands/webhook.js +131 -0
  44. package/dist/cli/commands/webhook.js.map +7 -0
  45. package/dist/cli/commands/worktree.js +276 -0
  46. package/dist/cli/commands/worktree.js.map +7 -0
  47. package/dist/cli/index.js +953 -0
  48. package/dist/cli/index.js.map +7 -0
  49. package/dist/cli/utils/viewer.js +92 -0
  50. package/dist/cli/utils/viewer.js.map +7 -0
  51. package/dist/core/config/__tests__/config-manager.test.js +248 -0
  52. package/dist/core/config/__tests__/config-manager.test.js.map +7 -0
  53. package/dist/core/config/config-manager.js +368 -0
  54. package/dist/core/config/config-manager.js.map +7 -0
  55. package/dist/core/config/types.js +140 -0
  56. package/dist/core/config/types.js.map +7 -0
  57. package/dist/core/context/__tests__/frame-manager.test.js +879 -0
  58. package/dist/core/context/__tests__/frame-manager.test.js.map +7 -0
  59. package/dist/core/context/auto-context.js +72 -0
  60. package/dist/core/context/auto-context.js.map +7 -0
  61. package/dist/core/context/compaction-handler.js +326 -0
  62. package/dist/core/context/compaction-handler.js.map +7 -0
  63. package/dist/core/context/frame-database.js +376 -0
  64. package/dist/core/context/frame-database.js.map +7 -0
  65. package/dist/core/context/frame-digest.js +239 -0
  66. package/dist/core/context/frame-digest.js.map +7 -0
  67. package/dist/core/context/frame-manager.js +682 -0
  68. package/dist/core/context/frame-manager.js.map +7 -0
  69. package/dist/core/context/frame-stack.js +270 -0
  70. package/dist/core/context/frame-stack.js.map +7 -0
  71. package/dist/core/context/frame-types.js +1 -0
  72. package/dist/core/context/frame-types.js.map +7 -0
  73. package/dist/core/context/index.js +33 -0
  74. package/dist/core/context/index.js.map +7 -0
  75. package/dist/core/context/model-aware-compaction.js +619 -0
  76. package/dist/core/context/model-aware-compaction.js.map +7 -0
  77. package/dist/core/context/refactored-frame-manager.js +393 -0
  78. package/dist/core/context/refactored-frame-manager.js.map +7 -0
  79. package/dist/core/database/batch-operations.js +329 -0
  80. package/dist/core/database/batch-operations.js.map +7 -0
  81. package/dist/core/database/connection-pool.js +224 -0
  82. package/dist/core/database/connection-pool.js.map +7 -0
  83. package/dist/core/database/query-cache.js +284 -0
  84. package/dist/core/database/query-cache.js.map +7 -0
  85. package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js +379 -0
  86. package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js.map +7 -0
  87. package/dist/core/digest/__tests__/frame-digest-integration.test.js +230 -0
  88. package/dist/core/digest/__tests__/frame-digest-integration.test.js.map +7 -0
  89. package/dist/core/digest/enhanced-hybrid-digest.js +267 -0
  90. package/dist/core/digest/enhanced-hybrid-digest.js.map +7 -0
  91. package/dist/core/digest/frame-digest-integration.js +172 -0
  92. package/dist/core/digest/frame-digest-integration.js.map +7 -0
  93. package/dist/core/digest/hybrid-digest-generator.js +549 -0
  94. package/dist/core/digest/hybrid-digest-generator.js.map +7 -0
  95. package/dist/core/digest/index.js +5 -0
  96. package/dist/core/digest/index.js.map +7 -0
  97. package/dist/core/digest/types.js +21 -0
  98. package/dist/core/digest/types.js.map +7 -0
  99. package/dist/core/errors/__tests__/error-handling.test.js +270 -0
  100. package/dist/core/errors/__tests__/error-handling.test.js.map +7 -0
  101. package/dist/core/errors/index.js +239 -0
  102. package/dist/core/errors/index.js.map +7 -0
  103. package/dist/core/errors/recovery.js +258 -0
  104. package/dist/core/errors/recovery.js.map +7 -0
  105. package/dist/core/merge/__tests__/conflict-scenarios.test.js +414 -0
  106. package/dist/core/merge/__tests__/conflict-scenarios.test.js.map +7 -0
  107. package/dist/core/merge/conflict-detector.js +424 -0
  108. package/dist/core/merge/conflict-detector.js.map +7 -0
  109. package/dist/core/merge/index.js +5 -0
  110. package/dist/core/merge/index.js.map +7 -0
  111. package/dist/core/merge/resolution-engine.js +565 -0
  112. package/dist/core/merge/resolution-engine.js.map +7 -0
  113. package/dist/core/merge/stack-diff.js +528 -0
  114. package/dist/core/merge/stack-diff.js.map +7 -0
  115. package/dist/core/merge/types.js +1 -0
  116. package/dist/core/merge/types.js.map +7 -0
  117. package/dist/core/monitoring/error-handler.js +278 -0
  118. package/dist/core/monitoring/error-handler.js.map +7 -0
  119. package/dist/core/monitoring/logger.js +115 -0
  120. package/dist/core/monitoring/logger.js.map +7 -0
  121. package/dist/core/monitoring/metrics.js +157 -0
  122. package/dist/core/monitoring/metrics.js.map +7 -0
  123. package/dist/core/monitoring/progress-tracker.js +174 -0
  124. package/dist/core/monitoring/progress-tracker.js.map +7 -0
  125. package/dist/core/performance/context-cache.js +269 -0
  126. package/dist/core/performance/context-cache.js.map +7 -0
  127. package/dist/core/performance/index.js +7 -0
  128. package/dist/core/performance/index.js.map +7 -0
  129. package/dist/core/performance/lazy-context-loader.js +319 -0
  130. package/dist/core/performance/lazy-context-loader.js.map +7 -0
  131. package/dist/core/performance/monitor.js +217 -0
  132. package/dist/core/performance/monitor.js.map +7 -0
  133. package/dist/core/performance/optimized-frame-context.js +326 -0
  134. package/dist/core/performance/optimized-frame-context.js.map +7 -0
  135. package/dist/core/performance/performance-benchmark.js +269 -0
  136. package/dist/core/performance/performance-benchmark.js.map +7 -0
  137. package/dist/core/performance/performance-profiler.js +318 -0
  138. package/dist/core/performance/performance-profiler.js.map +7 -0
  139. package/dist/core/performance/streaming-jsonl-parser.js +187 -0
  140. package/dist/core/performance/streaming-jsonl-parser.js.map +7 -0
  141. package/dist/core/persistence/postgres-adapter.js +345 -0
  142. package/dist/core/persistence/postgres-adapter.js.map +7 -0
  143. package/dist/core/projects/project-manager.js +699 -0
  144. package/dist/core/projects/project-manager.js.map +7 -0
  145. package/dist/core/query/__tests__/query-parser.test.js +301 -0
  146. package/dist/core/query/__tests__/query-parser.test.js.map +7 -0
  147. package/dist/core/query/__tests__/query-templates.test.js +210 -0
  148. package/dist/core/query/__tests__/query-templates.test.js.map +7 -0
  149. package/dist/core/query/query-parser.js +366 -0
  150. package/dist/core/query/query-parser.js.map +7 -0
  151. package/dist/core/query/query-templates.js +317 -0
  152. package/dist/core/query/query-templates.js.map +7 -0
  153. package/dist/core/retrieval/index.js +4 -0
  154. package/dist/core/retrieval/index.js.map +7 -0
  155. package/dist/core/retrieval/llm-context-retrieval.js +577 -0
  156. package/dist/core/retrieval/llm-context-retrieval.js.map +7 -0
  157. package/dist/core/retrieval/summary-generator.js +585 -0
  158. package/dist/core/retrieval/summary-generator.js.map +7 -0
  159. package/dist/core/retrieval/types.js +17 -0
  160. package/dist/core/retrieval/types.js.map +7 -0
  161. package/dist/core/session/index.js +11 -0
  162. package/dist/core/session/index.js.map +7 -0
  163. package/dist/core/session/session-manager.js +297 -0
  164. package/dist/core/session/session-manager.js.map +7 -0
  165. package/dist/core/trace/cli-trace-wrapper.js +110 -0
  166. package/dist/core/trace/cli-trace-wrapper.js.map +7 -0
  167. package/dist/core/trace/db-trace-wrapper.js +215 -0
  168. package/dist/core/trace/db-trace-wrapper.js.map +7 -0
  169. package/dist/core/trace/debug-trace.js +385 -0
  170. package/dist/core/trace/debug-trace.js.map +7 -0
  171. package/dist/core/trace/index.js +158 -0
  172. package/dist/core/trace/index.js.map +7 -0
  173. package/dist/core/trace/linear-api-wrapper.js +169 -0
  174. package/dist/core/trace/linear-api-wrapper.js.map +7 -0
  175. package/dist/core/trace/trace-demo.js +135 -0
  176. package/dist/core/trace/trace-demo.js.map +7 -0
  177. package/dist/core/trace/trace-detector.demo.js +138 -0
  178. package/dist/core/trace/trace-detector.demo.js.map +7 -0
  179. package/dist/core/trace/trace-detector.js +386 -0
  180. package/dist/core/trace/trace-detector.js.map +7 -0
  181. package/dist/core/trace/trace-detector.test.js +401 -0
  182. package/dist/core/trace/trace-detector.test.js.map +7 -0
  183. package/dist/core/trace/trace-store.js +341 -0
  184. package/dist/core/trace/trace-store.js.map +7 -0
  185. package/dist/core/trace/types.js +73 -0
  186. package/dist/core/trace/types.js.map +7 -0
  187. package/dist/core/types.js +1 -0
  188. package/dist/core/types.js.map +7 -0
  189. package/dist/core/utils/update-checker.js +214 -0
  190. package/dist/core/utils/update-checker.js.map +7 -0
  191. package/dist/core/worktree/worktree-manager.js +450 -0
  192. package/dist/core/worktree/worktree-manager.js.map +7 -0
  193. package/dist/features/analytics/api/analytics-api.js +283 -0
  194. package/dist/features/analytics/api/analytics-api.js.map +7 -0
  195. package/dist/features/analytics/core/analytics-service.js +267 -0
  196. package/dist/features/analytics/core/analytics-service.js.map +7 -0
  197. package/dist/features/analytics/index.js +14 -0
  198. package/dist/features/analytics/index.js.map +7 -0
  199. package/dist/features/analytics/queries/metrics-queries.js +273 -0
  200. package/dist/features/analytics/queries/metrics-queries.js.map +7 -0
  201. package/dist/features/analytics/types/metrics.js +1 -0
  202. package/dist/features/analytics/types/metrics.js.map +7 -0
  203. package/dist/features/browser/browser-mcp.js +488 -0
  204. package/dist/features/browser/browser-mcp.js.map +7 -0
  205. package/dist/features/tasks/__tests__/pebbles-task-store.test.js +747 -0
  206. package/dist/features/tasks/__tests__/pebbles-task-store.test.js.map +7 -0
  207. package/dist/features/tasks/pebbles-task-store.js +647 -0
  208. package/dist/features/tasks/pebbles-task-store.js.map +7 -0
  209. package/dist/features/tasks/task-aware-context.js +406 -0
  210. package/dist/features/tasks/task-aware-context.js.map +7 -0
  211. package/dist/index.js +21 -0
  212. package/dist/index.js.map +7 -0
  213. package/dist/integrations/linear/__tests__/auth.test.js +558 -0
  214. package/dist/integrations/linear/__tests__/auth.test.js.map +7 -0
  215. package/dist/integrations/linear/__tests__/sync-service.test.js +760 -0
  216. package/dist/integrations/linear/__tests__/sync-service.test.js.map +7 -0
  217. package/dist/integrations/linear/auth.js +308 -0
  218. package/dist/integrations/linear/auth.js.map +7 -0
  219. package/dist/integrations/linear/auto-sync.js +244 -0
  220. package/dist/integrations/linear/auto-sync.js.map +7 -0
  221. package/dist/integrations/linear/client.js +448 -0
  222. package/dist/integrations/linear/client.js.map +7 -0
  223. package/dist/integrations/linear/config.js +115 -0
  224. package/dist/integrations/linear/config.js.map +7 -0
  225. package/dist/integrations/linear/sync-manager.js +233 -0
  226. package/dist/integrations/linear/sync-manager.js.map +7 -0
  227. package/dist/integrations/linear/sync-service.js +214 -0
  228. package/dist/integrations/linear/sync-service.js.map +7 -0
  229. package/dist/integrations/linear/sync.js +565 -0
  230. package/dist/integrations/linear/sync.js.map +7 -0
  231. package/dist/integrations/linear/types.js +1 -0
  232. package/dist/integrations/linear/types.js.map +7 -0
  233. package/dist/integrations/linear/webhook-server.js +204 -0
  234. package/dist/integrations/linear/webhook-server.js.map +7 -0
  235. package/dist/integrations/linear/webhook.js +269 -0
  236. package/dist/integrations/linear/webhook.js.map +7 -0
  237. package/dist/integrations/mcp/__tests__/server.test.js +798 -0
  238. package/dist/integrations/mcp/__tests__/server.test.js.map +7 -0
  239. package/dist/integrations/mcp/handlers/context-handlers.js +253 -0
  240. package/dist/integrations/mcp/handlers/context-handlers.js.map +7 -0
  241. package/dist/integrations/mcp/handlers/index.js +134 -0
  242. package/dist/integrations/mcp/handlers/index.js.map +7 -0
  243. package/dist/integrations/mcp/handlers/linear-handlers.js +243 -0
  244. package/dist/integrations/mcp/handlers/linear-handlers.js.map +7 -0
  245. package/dist/integrations/mcp/handlers/task-handlers.js +235 -0
  246. package/dist/integrations/mcp/handlers/task-handlers.js.map +7 -0
  247. package/dist/integrations/mcp/handlers/trace-handlers.js +304 -0
  248. package/dist/integrations/mcp/handlers/trace-handlers.js.map +7 -0
  249. package/dist/integrations/mcp/index.js +19 -0
  250. package/dist/integrations/mcp/index.js.map +7 -0
  251. package/dist/integrations/mcp/refactored-server.js +331 -0
  252. package/dist/integrations/mcp/refactored-server.js.map +7 -0
  253. package/dist/integrations/mcp/server.js +1621 -0
  254. package/dist/integrations/mcp/server.js.map +7 -0
  255. package/dist/integrations/mcp/tool-definitions.js +562 -0
  256. package/dist/integrations/mcp/tool-definitions.js.map +7 -0
  257. package/dist/integrations/mcp/trace-test.js +44 -0
  258. package/dist/integrations/mcp/trace-test.js.map +7 -0
  259. package/dist/integrations/pg-aiguide/embedding-provider.js +174 -0
  260. package/dist/integrations/pg-aiguide/embedding-provider.js.map +7 -0
  261. package/dist/integrations/pg-aiguide/semantic-search.js +183 -0
  262. package/dist/integrations/pg-aiguide/semantic-search.js.map +7 -0
  263. package/dist/integrations/pg-aiguide/timescale-analytics.js +220 -0
  264. package/dist/integrations/pg-aiguide/timescale-analytics.js.map +7 -0
  265. package/dist/mcp/stackmemory-mcp-server.js +550 -0
  266. package/dist/mcp/stackmemory-mcp-server.js.map +7 -0
  267. package/dist/middleware/exponential-rate-limiter.js +285 -0
  268. package/dist/middleware/exponential-rate-limiter.js.map +7 -0
  269. package/dist/models/user.model.js +351 -0
  270. package/dist/models/user.model.js.map +7 -0
  271. package/dist/scripts/benchmark-performance.d.ts +7 -0
  272. package/dist/scripts/benchmark-performance.d.ts.map +1 -0
  273. package/dist/scripts/benchmark-performance.js +44 -0
  274. package/dist/scripts/benchmark-performance.js.map +1 -0
  275. package/dist/scripts/cleanup-duplicate-tasks.d.ts +12 -0
  276. package/dist/scripts/cleanup-duplicate-tasks.d.ts.map +1 -0
  277. package/dist/scripts/cleanup-duplicate-tasks.js +215 -0
  278. package/dist/scripts/cleanup-duplicate-tasks.js.map +1 -0
  279. package/dist/servers/production/auth-middleware.js +513 -0
  280. package/dist/servers/production/auth-middleware.js.map +7 -0
  281. package/dist/servers/railway/index.js +390 -0
  282. package/dist/servers/railway/index.js.map +7 -0
  283. package/dist/services/config-service.js +62 -0
  284. package/dist/services/config-service.js.map +7 -0
  285. package/dist/services/context-service.js +191 -0
  286. package/dist/services/context-service.js.map +7 -0
  287. package/dist/src/agents/core/agent-task-manager.d.ts +154 -0
  288. package/dist/src/agents/core/agent-task-manager.d.ts.map +1 -0
  289. package/dist/src/agents/core/agent-task-manager.js +504 -0
  290. package/dist/src/agents/core/agent-task-manager.js.map +1 -0
  291. package/dist/src/agents/verifiers/base-verifier.d.ts +112 -0
  292. package/dist/src/agents/verifiers/base-verifier.d.ts.map +1 -0
  293. package/dist/src/agents/verifiers/base-verifier.js +130 -0
  294. package/dist/src/agents/verifiers/base-verifier.js.map +1 -0
  295. package/dist/src/agents/verifiers/formatter-verifier.d.ts +14 -0
  296. package/dist/src/agents/verifiers/formatter-verifier.d.ts.map +1 -0
  297. package/dist/src/agents/verifiers/formatter-verifier.js +107 -0
  298. package/dist/src/agents/verifiers/formatter-verifier.js.map +1 -0
  299. package/dist/src/agents/verifiers/llm-judge.d.ts +46 -0
  300. package/dist/src/agents/verifiers/llm-judge.d.ts.map +1 -0
  301. package/dist/src/agents/verifiers/llm-judge.js +248 -0
  302. package/dist/src/agents/verifiers/llm-judge.js.map +1 -0
  303. package/dist/src/cli/claude-sm.js +55 -0
  304. package/dist/src/cli/claude-sm.js.map +1 -1
  305. package/dist/src/cli/commands/agent.d.ts +9 -0
  306. package/dist/src/cli/commands/agent.d.ts.map +1 -0
  307. package/dist/src/cli/commands/agent.js +303 -0
  308. package/dist/src/cli/commands/agent.js.map +1 -0
  309. package/dist/src/cli/commands/handoff.d.ts +6 -0
  310. package/dist/src/cli/commands/handoff.d.ts.map +1 -0
  311. package/dist/src/cli/commands/handoff.js +212 -0
  312. package/dist/src/cli/commands/handoff.js.map +1 -0
  313. package/dist/src/cli/index.d.ts.map +1 -1
  314. package/dist/src/cli/index.js +4 -0
  315. package/dist/src/cli/index.js.map +1 -1
  316. package/dist/src/core/context/frame-database.d.ts +59 -0
  317. package/dist/src/core/context/frame-database.d.ts.map +1 -0
  318. package/dist/src/core/context/frame-database.js +333 -0
  319. package/dist/src/core/context/frame-database.js.map +1 -0
  320. package/dist/src/core/context/frame-digest.d.ts +59 -0
  321. package/dist/src/core/context/frame-digest.d.ts.map +1 -0
  322. package/dist/src/core/context/frame-digest.js +264 -0
  323. package/dist/src/core/context/frame-digest.js.map +1 -0
  324. package/dist/src/core/context/frame-manager.d.ts +2 -0
  325. package/dist/src/core/context/frame-manager.d.ts.map +1 -1
  326. package/dist/src/core/context/frame-manager.js +7 -0
  327. package/dist/src/core/context/frame-manager.js.map +1 -1
  328. package/dist/src/core/context/frame-stack.d.ts +85 -0
  329. package/dist/src/core/context/frame-stack.d.ts.map +1 -0
  330. package/dist/src/core/context/frame-stack.js +287 -0
  331. package/dist/src/core/context/frame-stack.js.map +1 -0
  332. package/dist/src/core/context/frame-types.d.ts +67 -0
  333. package/dist/src/core/context/frame-types.d.ts.map +1 -0
  334. package/dist/src/core/context/frame-types.js +6 -0
  335. package/dist/src/core/context/frame-types.js.map +1 -0
  336. package/dist/src/core/context/index.d.ts +11 -0
  337. package/dist/src/core/context/index.d.ts.map +1 -0
  338. package/dist/src/core/context/index.js +14 -0
  339. package/dist/src/core/context/index.js.map +1 -0
  340. package/dist/src/core/context/refactored-frame-manager.d.ts +99 -0
  341. package/dist/src/core/context/refactored-frame-manager.d.ts.map +1 -0
  342. package/dist/src/core/context/refactored-frame-manager.js +340 -0
  343. package/dist/src/core/context/refactored-frame-manager.js.map +1 -0
  344. package/dist/src/core/database/batch-operations.d.ts +118 -0
  345. package/dist/src/core/database/batch-operations.d.ts.map +1 -0
  346. package/dist/src/core/database/batch-operations.js +339 -0
  347. package/dist/src/core/database/batch-operations.js.map +1 -0
  348. package/dist/src/core/database/connection-pool.d.ts +79 -0
  349. package/dist/src/core/database/connection-pool.d.ts.map +1 -0
  350. package/dist/src/core/database/connection-pool.js +236 -0
  351. package/dist/src/core/database/connection-pool.js.map +1 -0
  352. package/dist/src/core/database/query-cache.d.ts +135 -0
  353. package/dist/src/core/database/query-cache.d.ts.map +1 -0
  354. package/dist/src/core/database/query-cache.js +294 -0
  355. package/dist/src/core/database/query-cache.js.map +1 -0
  356. package/dist/src/core/digest/enhanced-hybrid-digest.d.ts +125 -0
  357. package/dist/src/core/digest/enhanced-hybrid-digest.d.ts.map +1 -0
  358. package/dist/src/core/digest/enhanced-hybrid-digest.js +282 -0
  359. package/dist/src/core/digest/enhanced-hybrid-digest.js.map +1 -0
  360. package/dist/src/core/digest/frame-digest-integration.d.ts +67 -0
  361. package/dist/src/core/digest/frame-digest-integration.d.ts.map +1 -0
  362. package/dist/src/core/digest/frame-digest-integration.js +198 -0
  363. package/dist/src/core/digest/frame-digest-integration.js.map +1 -0
  364. package/dist/src/core/digest/hybrid-digest-generator.d.ts +3 -3
  365. package/dist/src/core/digest/hybrid-digest-generator.d.ts.map +1 -1
  366. package/dist/src/core/digest/hybrid-digest-generator.js.map +1 -1
  367. package/dist/src/core/digest/index.d.ts +3 -1
  368. package/dist/src/core/digest/index.d.ts.map +1 -1
  369. package/dist/src/core/digest/index.js +3 -1
  370. package/dist/src/core/digest/index.js.map +1 -1
  371. package/dist/src/core/errors/index.d.ts +13 -5
  372. package/dist/src/core/errors/index.d.ts.map +1 -1
  373. package/dist/src/core/errors/index.js +13 -5
  374. package/dist/src/core/errors/index.js.map +1 -1
  375. package/dist/src/core/merge/conflict-detector.d.ts +122 -0
  376. package/dist/src/core/merge/conflict-detector.d.ts.map +1 -0
  377. package/dist/src/core/merge/conflict-detector.js +468 -0
  378. package/dist/src/core/merge/conflict-detector.js.map +1 -0
  379. package/dist/src/core/merge/index.d.ts +9 -0
  380. package/dist/src/core/merge/index.d.ts.map +1 -0
  381. package/dist/src/core/merge/index.js +9 -0
  382. package/dist/src/core/merge/index.js.map +1 -0
  383. package/dist/src/core/merge/resolution-engine.d.ts +120 -0
  384. package/dist/src/core/merge/resolution-engine.d.ts.map +1 -0
  385. package/dist/src/core/merge/resolution-engine.js +573 -0
  386. package/dist/src/core/merge/resolution-engine.js.map +1 -0
  387. package/dist/src/core/merge/stack-diff.d.ts +97 -0
  388. package/dist/src/core/merge/stack-diff.d.ts.map +1 -0
  389. package/dist/src/core/merge/stack-diff.js +516 -0
  390. package/dist/src/core/merge/stack-diff.js.map +1 -0
  391. package/dist/src/core/merge/types.d.ts +110 -0
  392. package/dist/src/core/merge/types.d.ts.map +1 -0
  393. package/dist/src/core/merge/types.js +6 -0
  394. package/dist/src/core/merge/types.js.map +1 -0
  395. package/dist/src/core/performance/context-cache.d.ts +109 -0
  396. package/dist/src/core/performance/context-cache.d.ts.map +1 -0
  397. package/dist/src/core/performance/context-cache.js +280 -0
  398. package/dist/src/core/performance/context-cache.js.map +1 -0
  399. package/dist/src/core/performance/index.d.ts +3 -0
  400. package/dist/src/core/performance/index.d.ts.map +1 -0
  401. package/dist/src/core/performance/index.js +3 -0
  402. package/dist/src/core/performance/index.js.map +1 -0
  403. package/dist/src/core/performance/lazy-context-loader.d.ts +93 -0
  404. package/dist/src/core/performance/lazy-context-loader.d.ts.map +1 -0
  405. package/dist/src/core/performance/lazy-context-loader.js +332 -0
  406. package/dist/src/core/performance/lazy-context-loader.js.map +1 -0
  407. package/dist/src/core/performance/monitor.d.ts +48 -0
  408. package/dist/src/core/performance/monitor.d.ts.map +1 -0
  409. package/dist/src/core/performance/monitor.js +226 -0
  410. package/dist/src/core/performance/monitor.js.map +1 -0
  411. package/dist/src/core/performance/optimized-frame-context.d.ts +74 -0
  412. package/dist/src/core/performance/optimized-frame-context.d.ts.map +1 -0
  413. package/dist/src/core/performance/optimized-frame-context.js +330 -0
  414. package/dist/src/core/performance/optimized-frame-context.js.map +1 -0
  415. package/dist/src/core/performance/performance-benchmark.d.ts +50 -0
  416. package/dist/src/core/performance/performance-benchmark.d.ts.map +1 -0
  417. package/dist/src/core/performance/performance-benchmark.js +290 -0
  418. package/dist/src/core/performance/performance-benchmark.js.map +1 -0
  419. package/dist/src/core/performance/performance-profiler.d.ts +151 -0
  420. package/dist/src/core/performance/performance-profiler.d.ts.map +1 -0
  421. package/dist/src/core/performance/performance-profiler.js +346 -0
  422. package/dist/src/core/performance/performance-profiler.js.map +1 -0
  423. package/dist/src/core/performance/streaming-jsonl-parser.d.ts +41 -0
  424. package/dist/src/core/performance/streaming-jsonl-parser.d.ts.map +1 -0
  425. package/dist/src/core/performance/streaming-jsonl-parser.js +193 -0
  426. package/dist/src/core/performance/streaming-jsonl-parser.js.map +1 -0
  427. package/dist/src/core/persistence/postgres-adapter.d.ts.map +1 -1
  428. package/dist/src/core/persistence/postgres-adapter.js +18 -4
  429. package/dist/src/core/persistence/postgres-adapter.js.map +1 -1
  430. package/dist/src/core/query/query-parser.d.ts +5 -0
  431. package/dist/src/core/query/query-parser.d.ts.map +1 -1
  432. package/dist/src/core/query/query-parser.js +86 -18
  433. package/dist/src/core/query/query-parser.js.map +1 -1
  434. package/dist/src/core/query/query-templates.d.ts +44 -0
  435. package/dist/src/core/query/query-templates.d.ts.map +1 -0
  436. package/dist/src/core/query/query-templates.js +326 -0
  437. package/dist/src/core/query/query-templates.js.map +1 -0
  438. package/dist/src/core/retrieval/llm-context-retrieval.d.ts +5 -3
  439. package/dist/src/core/retrieval/llm-context-retrieval.d.ts.map +1 -1
  440. package/dist/src/core/retrieval/llm-context-retrieval.js +73 -21
  441. package/dist/src/core/retrieval/llm-context-retrieval.js.map +1 -1
  442. package/dist/src/core/trace/cli-trace-wrapper.d.ts +23 -0
  443. package/dist/src/core/trace/cli-trace-wrapper.d.ts.map +1 -0
  444. package/dist/src/core/trace/cli-trace-wrapper.js +141 -0
  445. package/dist/src/core/trace/cli-trace-wrapper.js.map +1 -0
  446. package/dist/src/core/trace/db-trace-wrapper.d.ts +36 -0
  447. package/dist/src/core/trace/db-trace-wrapper.d.ts.map +1 -0
  448. package/dist/src/core/trace/db-trace-wrapper.js +252 -0
  449. package/dist/src/core/trace/db-trace-wrapper.js.map +1 -0
  450. package/dist/src/core/trace/debug-trace.d.ts +84 -0
  451. package/dist/src/core/trace/debug-trace.d.ts.map +1 -0
  452. package/dist/src/core/trace/debug-trace.js +402 -0
  453. package/dist/src/core/trace/debug-trace.js.map +1 -0
  454. package/dist/src/core/trace/error-test.d.ts +6 -0
  455. package/dist/src/core/trace/error-test.d.ts.map +1 -0
  456. package/dist/src/core/trace/error-test.js +128 -0
  457. package/dist/src/core/trace/error-test.js.map +1 -0
  458. package/dist/src/core/trace/index.d.ts +25 -0
  459. package/dist/src/core/trace/index.d.ts.map +1 -0
  460. package/dist/src/core/trace/index.js +121 -0
  461. package/dist/src/core/trace/index.js.map +1 -0
  462. package/dist/src/core/trace/linear-api-wrapper.d.ts +17 -0
  463. package/dist/src/core/trace/linear-api-wrapper.d.ts.map +1 -0
  464. package/dist/src/core/trace/linear-api-wrapper.js +205 -0
  465. package/dist/src/core/trace/linear-api-wrapper.js.map +1 -0
  466. package/dist/src/core/trace/performance-test.d.ts +6 -0
  467. package/dist/src/core/trace/performance-test.d.ts.map +1 -0
  468. package/dist/src/core/trace/performance-test.js +111 -0
  469. package/dist/src/core/trace/performance-test.js.map +1 -0
  470. package/dist/src/core/trace/trace-demo.d.ts +8 -0
  471. package/dist/src/core/trace/trace-demo.d.ts.map +1 -0
  472. package/dist/src/core/trace/trace-demo.js +154 -0
  473. package/dist/src/core/trace/trace-demo.js.map +1 -0
  474. package/dist/src/core/trace/trace-detector.d.ts +2 -2
  475. package/dist/src/core/trace/trace-detector.d.ts.map +1 -1
  476. package/dist/src/core/trace/trace-detector.demo.js +1 -1
  477. package/dist/src/core/trace/trace-detector.demo.js.map +1 -1
  478. package/dist/src/core/trace/trace-detector.js +3 -3
  479. package/dist/src/core/trace/trace-detector.js.map +1 -1
  480. package/dist/src/features/tasks/pebbles-task-store.d.ts +9 -2
  481. package/dist/src/features/tasks/pebbles-task-store.d.ts.map +1 -1
  482. package/dist/src/features/tasks/pebbles-task-store.js +97 -18
  483. package/dist/src/features/tasks/pebbles-task-store.js.map +1 -1
  484. package/dist/src/integrations/linear/auth.d.ts.map +1 -1
  485. package/dist/src/integrations/linear/auth.js.map +1 -1
  486. package/dist/src/integrations/linear/client.d.ts +15 -1
  487. package/dist/src/integrations/linear/client.d.ts.map +1 -1
  488. package/dist/src/integrations/linear/client.js +85 -3
  489. package/dist/src/integrations/linear/client.js.map +1 -1
  490. package/dist/src/integrations/linear/sync-manager.d.ts +2 -0
  491. package/dist/src/integrations/linear/sync-manager.d.ts.map +1 -1
  492. package/dist/src/integrations/linear/sync-manager.js +16 -4
  493. package/dist/src/integrations/linear/sync-manager.js.map +1 -1
  494. package/dist/src/integrations/linear/sync-service.d.ts +23 -2
  495. package/dist/src/integrations/linear/sync-service.d.ts.map +1 -1
  496. package/dist/src/integrations/linear/sync-service.js +44 -25
  497. package/dist/src/integrations/linear/sync-service.js.map +1 -1
  498. package/dist/src/integrations/linear/sync.d.ts +6 -0
  499. package/dist/src/integrations/linear/sync.d.ts.map +1 -1
  500. package/dist/src/integrations/linear/sync.js +27 -2
  501. package/dist/src/integrations/linear/sync.js.map +1 -1
  502. package/dist/src/integrations/linear/types.d.ts +16 -1
  503. package/dist/src/integrations/linear/types.d.ts.map +1 -1
  504. package/dist/src/integrations/linear/webhook-server.d.ts.map +1 -1
  505. package/dist/src/integrations/linear/webhook-server.js +10 -8
  506. package/dist/src/integrations/linear/webhook-server.js.map +1 -1
  507. package/dist/src/integrations/linear/webhook.d.ts +13 -0
  508. package/dist/src/integrations/linear/webhook.d.ts.map +1 -1
  509. package/dist/src/integrations/linear/webhook.js +101 -14
  510. package/dist/src/integrations/linear/webhook.js.map +1 -1
  511. package/dist/src/integrations/mcp/handlers/context-handlers.d.ts +39 -0
  512. package/dist/src/integrations/mcp/handlers/context-handlers.d.ts.map +1 -0
  513. package/dist/src/integrations/mcp/handlers/context-handlers.js +266 -0
  514. package/dist/src/integrations/mcp/handlers/context-handlers.js.map +1 -0
  515. package/dist/src/integrations/mcp/handlers/index.d.ts +37 -0
  516. package/dist/src/integrations/mcp/handlers/index.d.ts.map +1 -0
  517. package/dist/src/integrations/mcp/handlers/index.js +134 -0
  518. package/dist/src/integrations/mcp/handlers/index.js.map +1 -0
  519. package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts +33 -0
  520. package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts.map +1 -0
  521. package/dist/src/integrations/mcp/handlers/linear-handlers.js +251 -0
  522. package/dist/src/integrations/mcp/handlers/linear-handlers.js.map +1 -0
  523. package/dist/src/integrations/mcp/handlers/task-handlers.d.ts +42 -0
  524. package/dist/src/integrations/mcp/handlers/task-handlers.d.ts.map +1 -0
  525. package/dist/src/integrations/mcp/handlers/task-handlers.js +238 -0
  526. package/dist/src/integrations/mcp/handlers/task-handlers.js.map +1 -0
  527. package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts +41 -0
  528. package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts.map +1 -0
  529. package/dist/src/integrations/mcp/handlers/trace-handlers.js +298 -0
  530. package/dist/src/integrations/mcp/handlers/trace-handlers.js.map +1 -0
  531. package/dist/src/integrations/mcp/index.d.ts +13 -0
  532. package/dist/src/integrations/mcp/index.d.ts.map +1 -0
  533. package/dist/src/integrations/mcp/index.js +17 -0
  534. package/dist/src/integrations/mcp/index.js.map +1 -0
  535. package/dist/src/integrations/mcp/refactored-server.d.ts +76 -0
  536. package/dist/src/integrations/mcp/refactored-server.d.ts.map +1 -0
  537. package/dist/src/integrations/mcp/refactored-server.js +351 -0
  538. package/dist/src/integrations/mcp/refactored-server.js.map +1 -0
  539. package/dist/src/integrations/mcp/tool-definitions.d.ts +44 -0
  540. package/dist/src/integrations/mcp/tool-definitions.d.ts.map +1 -0
  541. package/dist/src/integrations/mcp/tool-definitions.js +563 -0
  542. package/dist/src/integrations/mcp/tool-definitions.js.map +1 -0
  543. package/dist/src/integrations/pg-aiguide/semantic-search.d.ts.map +1 -1
  544. package/dist/src/integrations/pg-aiguide/semantic-search.js +43 -21
  545. package/dist/src/integrations/pg-aiguide/semantic-search.js.map +1 -1
  546. package/dist/src/mcp/stackmemory-mcp-server.d.ts +9 -0
  547. package/dist/src/mcp/stackmemory-mcp-server.d.ts.map +1 -0
  548. package/dist/src/mcp/stackmemory-mcp-server.js +519 -0
  549. package/dist/src/mcp/stackmemory-mcp-server.js.map +1 -0
  550. package/dist/src/middleware/exponential-rate-limiter.d.ts +78 -0
  551. package/dist/src/middleware/exponential-rate-limiter.d.ts.map +1 -0
  552. package/dist/src/middleware/exponential-rate-limiter.js +293 -0
  553. package/dist/src/middleware/exponential-rate-limiter.js.map +1 -0
  554. package/dist/src/models/user.model.d.ts +8 -1
  555. package/dist/src/models/user.model.d.ts.map +1 -1
  556. package/dist/src/models/user.model.js +62 -14
  557. package/dist/src/models/user.model.js.map +1 -1
  558. package/dist/src/servers/production/auth-middleware.d.ts +5 -2
  559. package/dist/src/servers/production/auth-middleware.d.ts.map +1 -1
  560. package/dist/src/servers/production/auth-middleware.js +71 -34
  561. package/dist/src/servers/production/auth-middleware.js.map +1 -1
  562. package/dist/src/services/context-service.d.ts.map +1 -1
  563. package/dist/src/services/context-service.js +86 -1
  564. package/dist/src/services/context-service.js.map +1 -1
  565. package/dist/src/validation/schemas.d.ts +633 -0
  566. package/dist/src/validation/schemas.d.ts.map +1 -0
  567. package/dist/src/validation/schemas.js +347 -0
  568. package/dist/src/validation/schemas.js.map +1 -0
  569. package/dist/types/task.js +1 -0
  570. package/dist/types/task.js.map +7 -0
  571. package/dist/utils/logger.js +52 -0
  572. package/dist/utils/logger.js.map +7 -0
  573. package/dist/validation/schemas.js +218 -0
  574. package/dist/validation/schemas.js.map +7 -0
  575. package/package.json +7 -3
@@ -0,0 +1,760 @@
1
+ import { describe, it, expect, beforeEach, afterEach, vi } from "vitest";
2
+ import { LinearSyncService } from "../sync-service.js";
3
+ const mockLinearClientInstance = {
4
+ getIssues: vi.fn(),
5
+ updateIssue: vi.fn(),
6
+ createIssue: vi.fn()
7
+ };
8
+ const mockContextServiceInstance = {
9
+ getTaskByExternalId: vi.fn(),
10
+ updateTask: vi.fn(),
11
+ createTask: vi.fn(),
12
+ getTask: vi.fn(),
13
+ deleteTask: vi.fn(),
14
+ getAllTasks: vi.fn()
15
+ };
16
+ const mockConfigServiceInstance = {
17
+ getConfig: vi.fn()
18
+ };
19
+ vi.mock("../client.js", () => ({
20
+ LinearClient: class {
21
+ getIssues = mockLinearClientInstance.getIssues;
22
+ updateIssue = mockLinearClientInstance.updateIssue;
23
+ createIssue = mockLinearClientInstance.createIssue;
24
+ }
25
+ }));
26
+ vi.mock("../../../services/context-service.js", () => ({
27
+ ContextService: class {
28
+ getTaskByExternalId = mockContextServiceInstance.getTaskByExternalId;
29
+ updateTask = mockContextServiceInstance.updateTask;
30
+ createTask = mockContextServiceInstance.createTask;
31
+ getTask = mockContextServiceInstance.getTask;
32
+ deleteTask = mockContextServiceInstance.deleteTask;
33
+ getAllTasks = mockContextServiceInstance.getAllTasks;
34
+ }
35
+ }));
36
+ vi.mock("../../../services/config-service.js", () => ({
37
+ ConfigService: class {
38
+ getConfig = mockConfigServiceInstance.getConfig;
39
+ }
40
+ }));
41
+ vi.mock("../../../utils/logger.js", () => ({
42
+ Logger: class {
43
+ info = vi.fn();
44
+ error = vi.fn();
45
+ debug = vi.fn();
46
+ warn = vi.fn();
47
+ }
48
+ }));
49
+ describe("LinearSyncService", () => {
50
+ let syncService;
51
+ let originalEnv;
52
+ beforeEach(() => {
53
+ originalEnv = process.env;
54
+ process.env.LINEAR_API_KEY = "test-api-key";
55
+ mockLinearClientInstance.getIssues.mockReset();
56
+ mockLinearClientInstance.updateIssue.mockReset();
57
+ mockLinearClientInstance.createIssue.mockReset();
58
+ mockContextServiceInstance.getTaskByExternalId.mockReset();
59
+ mockContextServiceInstance.updateTask.mockReset();
60
+ mockContextServiceInstance.createTask.mockReset();
61
+ mockContextServiceInstance.getTask.mockReset();
62
+ mockContextServiceInstance.deleteTask.mockReset();
63
+ mockContextServiceInstance.getAllTasks.mockReset();
64
+ mockConfigServiceInstance.getConfig.mockReset();
65
+ syncService = new LinearSyncService();
66
+ });
67
+ afterEach(() => {
68
+ process.env = originalEnv;
69
+ });
70
+ const mockLinearClient = mockLinearClientInstance;
71
+ const mockContextService = mockContextServiceInstance;
72
+ const mockConfigService = mockConfigServiceInstance;
73
+ describe("Initialization", () => {
74
+ it("should initialize with Linear API key from environment", () => {
75
+ expect(syncService).toBeDefined();
76
+ });
77
+ it("should throw error when LINEAR_API_KEY is not set", () => {
78
+ delete process.env.LINEAR_API_KEY;
79
+ expect(() => {
80
+ new LinearSyncService();
81
+ }).toThrow("LINEAR_API_KEY environment variable not set");
82
+ });
83
+ it("should initialize services correctly", () => {
84
+ expect(syncService).toBeDefined();
85
+ });
86
+ });
87
+ describe("syncAllIssues", () => {
88
+ beforeEach(() => {
89
+ mockConfigService.getConfig.mockResolvedValue({
90
+ integrations: {
91
+ linear: {
92
+ teamId: "test-team-id"
93
+ }
94
+ }
95
+ });
96
+ });
97
+ it("should sync all issues from Linear successfully", async () => {
98
+ const mockIssues = [
99
+ {
100
+ id: "issue-1",
101
+ identifier: "STA-1",
102
+ title: "Test Issue 1",
103
+ description: "Description 1",
104
+ state: { type: "unstarted" },
105
+ priority: 2,
106
+ url: "https://linear.app/issue-1",
107
+ team: { id: "team-1", key: "STA" },
108
+ labels: [{ name: "bug" }],
109
+ updatedAt: (/* @__PURE__ */ new Date()).toISOString()
110
+ },
111
+ {
112
+ id: "issue-2",
113
+ identifier: "STA-2",
114
+ title: "Test Issue 2",
115
+ description: "Description 2",
116
+ state: { type: "completed" },
117
+ priority: 3,
118
+ url: "https://linear.app/issue-2",
119
+ team: { id: "team-1", key: "STA" },
120
+ labels: [],
121
+ updatedAt: (/* @__PURE__ */ new Date()).toISOString()
122
+ }
123
+ ];
124
+ mockLinearClient.getIssues.mockResolvedValue(mockIssues);
125
+ mockContextService.getTaskByExternalId.mockResolvedValue(null);
126
+ const result = await syncService.syncAllIssues();
127
+ expect(result.created).toBe(2);
128
+ expect(result.updated).toBe(0);
129
+ expect(result.errors).toHaveLength(0);
130
+ expect(mockContextService.createTask).toHaveBeenCalledTimes(2);
131
+ });
132
+ it("should update existing tasks when they have changes", async () => {
133
+ const mockIssue = {
134
+ id: "issue-1",
135
+ identifier: "STA-1",
136
+ title: "Updated Title",
137
+ description: "Updated Description",
138
+ state: { type: "completed" },
139
+ priority: 3,
140
+ url: "https://linear.app/issue-1",
141
+ team: { id: "team-1", key: "STA" },
142
+ labels: [{ name: "feature" }],
143
+ updatedAt: (/* @__PURE__ */ new Date()).toISOString()
144
+ };
145
+ const existingTask = {
146
+ id: "local-task-1",
147
+ title: "Old Title",
148
+ description: "Old Description",
149
+ status: "todo",
150
+ priority: "high",
151
+ externalId: "issue-1"
152
+ };
153
+ mockLinearClient.getIssues.mockResolvedValue([mockIssue]);
154
+ mockContextService.getTaskByExternalId.mockResolvedValue(existingTask);
155
+ const result = await syncService.syncAllIssues();
156
+ expect(result.created).toBe(0);
157
+ expect(result.updated).toBe(1);
158
+ expect(mockContextService.updateTask).toHaveBeenCalledWith(
159
+ "local-task-1",
160
+ expect.objectContaining({
161
+ title: "Updated Title",
162
+ description: "Updated Description",
163
+ status: "done",
164
+ priority: "medium"
165
+ })
166
+ );
167
+ });
168
+ it("should skip tasks without changes", async () => {
169
+ const mockIssue = {
170
+ id: "issue-1",
171
+ identifier: "STA-1",
172
+ title: "Same Title",
173
+ description: "Same Description",
174
+ state: { type: "unstarted" },
175
+ priority: 2,
176
+ url: "https://linear.app/issue-1",
177
+ team: { id: "team-1", key: "STA" },
178
+ labels: [{ name: "bug" }],
179
+ updatedAt: (/* @__PURE__ */ new Date()).toISOString()
180
+ };
181
+ const existingTask = {
182
+ id: "local-task-1",
183
+ title: "Same Title",
184
+ description: "Same Description",
185
+ status: "todo",
186
+ priority: "high",
187
+ tags: ["bug"],
188
+ externalId: "issue-1"
189
+ };
190
+ mockLinearClient.getIssues.mockResolvedValue([mockIssue]);
191
+ mockContextService.getTaskByExternalId.mockResolvedValue(existingTask);
192
+ const result = await syncService.syncAllIssues();
193
+ expect(result.created).toBe(0);
194
+ expect(result.updated).toBe(0);
195
+ expect(mockContextService.updateTask).not.toHaveBeenCalled();
196
+ });
197
+ it("should handle sync errors gracefully", async () => {
198
+ const mockIssues = [
199
+ {
200
+ id: "issue-1",
201
+ identifier: "STA-1",
202
+ title: "Test Issue",
203
+ state: { type: "unstarted" },
204
+ team: { id: "team-1", key: "STA" },
205
+ updatedAt: (/* @__PURE__ */ new Date()).toISOString()
206
+ }
207
+ ];
208
+ mockLinearClient.getIssues.mockResolvedValue(mockIssues);
209
+ mockContextService.getTaskByExternalId.mockRejectedValue(
210
+ new Error("Database error")
211
+ );
212
+ const result = await syncService.syncAllIssues();
213
+ expect(result.errors).toHaveLength(1);
214
+ expect(result.errors[0]).toContain("Failed to sync STA-1");
215
+ });
216
+ it("should throw error when Linear team ID is not configured", async () => {
217
+ mockConfigService.getConfig.mockResolvedValue({
218
+ integrations: {}
219
+ });
220
+ const result = await syncService.syncAllIssues();
221
+ expect(result.errors).toContain("Linear team ID not configured");
222
+ });
223
+ it("should handle Linear API errors", async () => {
224
+ mockConfigService.getConfig.mockResolvedValue({
225
+ integrations: {
226
+ linear: { teamId: "test-team-id" }
227
+ }
228
+ });
229
+ mockLinearClient.getIssues.mockRejectedValue(
230
+ new Error("Linear API error")
231
+ );
232
+ const result = await syncService.syncAllIssues();
233
+ expect(result.errors).toContain("Linear API error");
234
+ });
235
+ });
236
+ describe("syncIssueToLocal", () => {
237
+ it("should create new local task from Linear issue", async () => {
238
+ const mockIssue = {
239
+ id: "issue-1",
240
+ identifier: "STA-1",
241
+ title: "New Issue",
242
+ description: "Issue description",
243
+ state: { type: "unstarted", id: "state-1", name: "Todo" },
244
+ priority: 1,
245
+ url: "https://linear.app/issue-1",
246
+ team: { id: "team-1", key: "STA" },
247
+ labels: [{ name: "bug" }, { name: "urgent" }],
248
+ project: { id: "proj-1", name: "Main Project" },
249
+ assignee: { id: "user-1", name: "John Doe" },
250
+ updatedAt: (/* @__PURE__ */ new Date()).toISOString()
251
+ };
252
+ mockContextService.getTaskByExternalId.mockResolvedValue(null);
253
+ const result = await syncService.syncIssueToLocal(mockIssue);
254
+ expect(result).toBe("created");
255
+ expect(mockContextService.createTask).toHaveBeenCalledWith(
256
+ expect.objectContaining({
257
+ title: "New Issue",
258
+ description: "Issue description",
259
+ status: "todo",
260
+ priority: "urgent",
261
+ externalId: "issue-1",
262
+ externalIdentifier: "STA-1",
263
+ externalUrl: "https://linear.app/issue-1",
264
+ tags: ["bug", "urgent"],
265
+ metadata: {
266
+ linear: {
267
+ stateId: "state-1",
268
+ stateName: "Todo",
269
+ assigneeId: "user-1",
270
+ assigneeName: "John Doe"
271
+ }
272
+ }
273
+ })
274
+ );
275
+ });
276
+ it("should update existing local task", async () => {
277
+ const mockIssue = {
278
+ id: "issue-1",
279
+ identifier: "STA-1",
280
+ title: "Updated Issue",
281
+ description: "Updated description",
282
+ state: { type: "started", id: "state-2", name: "In Progress" },
283
+ priority: 2,
284
+ url: "https://linear.app/issue-1",
285
+ team: { id: "team-1", key: "STA" },
286
+ labels: [{ name: "feature" }],
287
+ updatedAt: (/* @__PURE__ */ new Date()).toISOString()
288
+ };
289
+ const existingTask = {
290
+ id: "local-1",
291
+ title: "Old Title",
292
+ description: "Old description",
293
+ status: "todo",
294
+ priority: "low",
295
+ tags: ["old-tag"],
296
+ externalId: "issue-1",
297
+ createdAt: /* @__PURE__ */ new Date(),
298
+ updatedAt: /* @__PURE__ */ new Date()
299
+ };
300
+ mockContextService.getTaskByExternalId.mockResolvedValue(existingTask);
301
+ const result = await syncService.syncIssueToLocal(mockIssue);
302
+ expect(result).toBe("updated");
303
+ expect(mockContextService.updateTask).toHaveBeenCalledWith(
304
+ "local-1",
305
+ expect.objectContaining({
306
+ title: "Updated Issue",
307
+ description: "Updated description",
308
+ status: "in_progress",
309
+ priority: "high",
310
+ externalId: "issue-1",
311
+ externalIdentifier: "STA-1",
312
+ externalUrl: "https://linear.app/issue-1",
313
+ tags: ["feature"],
314
+ metadata: {
315
+ linear: {
316
+ stateId: "state-2",
317
+ stateName: "In Progress",
318
+ assigneeId: void 0,
319
+ assigneeName: void 0
320
+ }
321
+ }
322
+ })
323
+ );
324
+ });
325
+ it("should handle sync errors and rethrow", async () => {
326
+ const mockIssue = {
327
+ id: "issue-1",
328
+ identifier: "STA-1",
329
+ title: "Error Issue",
330
+ state: { type: "unstarted" },
331
+ team: { id: "team-1", key: "STA" },
332
+ updatedAt: (/* @__PURE__ */ new Date()).toISOString()
333
+ };
334
+ mockContextService.getTaskByExternalId.mockRejectedValue(
335
+ new Error("Database error")
336
+ );
337
+ await expect(syncService.syncIssueToLocal(mockIssue)).rejects.toThrow(
338
+ "Database error"
339
+ );
340
+ });
341
+ });
342
+ describe("syncLocalToLinear", () => {
343
+ beforeEach(() => {
344
+ mockConfigService.getConfig.mockResolvedValue({
345
+ integrations: {
346
+ linear: {
347
+ teamId: "test-team-id"
348
+ }
349
+ }
350
+ });
351
+ });
352
+ it("should create new Linear issue from local task", async () => {
353
+ const mockTask = {
354
+ id: "local-1",
355
+ title: "Local Task",
356
+ description: "Local description",
357
+ status: "todo",
358
+ priority: "high",
359
+ tags: [],
360
+ createdAt: /* @__PURE__ */ new Date(),
361
+ updatedAt: /* @__PURE__ */ new Date()
362
+ };
363
+ const mockCreatedIssue = {
364
+ id: "issue-1",
365
+ identifier: "STA-1",
366
+ title: "Local Task",
367
+ url: "https://linear.app/issue-1"
368
+ };
369
+ mockContextService.getTask.mockResolvedValue(mockTask);
370
+ mockLinearClient.createIssue.mockResolvedValue(mockCreatedIssue);
371
+ const result = await syncService.syncLocalToLinear("local-1");
372
+ expect(result).toEqual(mockCreatedIssue);
373
+ expect(mockLinearClient.createIssue).toHaveBeenCalledWith({
374
+ title: "Local Task",
375
+ description: "Local description",
376
+ teamId: "test-team-id",
377
+ priority: 2
378
+ // high -> 2
379
+ });
380
+ expect(mockContextService.updateTask).toHaveBeenCalledWith("local-1", {
381
+ externalId: "issue-1"
382
+ });
383
+ });
384
+ it("should update existing Linear issue", async () => {
385
+ const mockTask = {
386
+ id: "local-1",
387
+ title: "Updated Local Task",
388
+ description: "Updated description",
389
+ status: "in_progress",
390
+ priority: "medium",
391
+ tags: [],
392
+ externalId: "issue-1",
393
+ metadata: {
394
+ linear: {
395
+ stateId: "state-1",
396
+ projectId: "proj-1",
397
+ assigneeId: "user-1"
398
+ }
399
+ },
400
+ createdAt: /* @__PURE__ */ new Date(),
401
+ updatedAt: /* @__PURE__ */ new Date()
402
+ };
403
+ const mockUpdatedIssue = {
404
+ id: "issue-1",
405
+ identifier: "STA-1",
406
+ title: "Updated Local Task"
407
+ };
408
+ mockContextService.getTask.mockResolvedValue(mockTask);
409
+ mockLinearClient.updateIssue.mockResolvedValue(mockUpdatedIssue);
410
+ const result = await syncService.syncLocalToLinear("local-1");
411
+ expect(result).toEqual(mockUpdatedIssue);
412
+ expect(mockLinearClient.updateIssue).toHaveBeenCalledWith("issue-1", {
413
+ title: "Updated Local Task",
414
+ description: "Updated description",
415
+ priority: 3,
416
+ // medium -> 3
417
+ stateId: "state-1"
418
+ });
419
+ });
420
+ it("should throw error for non-existent task", async () => {
421
+ mockContextService.getTask.mockResolvedValue(null);
422
+ await expect(
423
+ syncService.syncLocalToLinear("non-existent")
424
+ ).rejects.toThrow("Task non-existent not found");
425
+ });
426
+ it("should handle Linear API errors", async () => {
427
+ const mockTask = {
428
+ id: "local-1",
429
+ title: "Task",
430
+ description: "Test task description",
431
+ status: "todo",
432
+ priority: "medium",
433
+ tags: [],
434
+ createdAt: /* @__PURE__ */ new Date(),
435
+ updatedAt: /* @__PURE__ */ new Date()
436
+ };
437
+ mockContextService.getTask.mockResolvedValue(mockTask);
438
+ mockLinearClient.createIssue.mockRejectedValue(
439
+ new Error("Linear API error")
440
+ );
441
+ await expect(syncService.syncLocalToLinear("local-1")).rejects.toThrow(
442
+ "Linear API error"
443
+ );
444
+ });
445
+ });
446
+ describe("removeLocalIssue", () => {
447
+ it("should remove local task by Linear identifier", async () => {
448
+ const mockTasks = [
449
+ {
450
+ id: "local-1",
451
+ title: "Task 1",
452
+ description: "Task 1 description",
453
+ status: "todo",
454
+ priority: "medium",
455
+ tags: [],
456
+ externalIdentifier: "STA-1",
457
+ createdAt: /* @__PURE__ */ new Date(),
458
+ updatedAt: /* @__PURE__ */ new Date()
459
+ },
460
+ {
461
+ id: "local-2",
462
+ title: "Task 2",
463
+ description: "Task 2 description",
464
+ status: "todo",
465
+ priority: "medium",
466
+ tags: [],
467
+ externalIdentifier: "STA-2",
468
+ createdAt: /* @__PURE__ */ new Date(),
469
+ updatedAt: /* @__PURE__ */ new Date()
470
+ }
471
+ ];
472
+ mockContextService.getAllTasks.mockResolvedValue(mockTasks);
473
+ await syncService.removeLocalIssue("STA-1");
474
+ expect(mockContextService.deleteTask).toHaveBeenCalledWith("local-1");
475
+ });
476
+ it("should handle non-existent identifier gracefully", async () => {
477
+ mockContextService.getAllTasks.mockResolvedValue([]);
478
+ await expect(
479
+ syncService.removeLocalIssue("NON-EXISTENT")
480
+ ).resolves.not.toThrow();
481
+ expect(mockContextService.deleteTask).not.toHaveBeenCalled();
482
+ });
483
+ it("should handle deletion errors", async () => {
484
+ const mockTasks = [
485
+ {
486
+ id: "local-1",
487
+ title: "Task",
488
+ description: "Task description",
489
+ status: "todo",
490
+ priority: "medium",
491
+ tags: [],
492
+ externalIdentifier: "STA-1",
493
+ createdAt: /* @__PURE__ */ new Date(),
494
+ updatedAt: /* @__PURE__ */ new Date()
495
+ }
496
+ ];
497
+ mockContextService.getAllTasks.mockResolvedValue(mockTasks);
498
+ mockContextService.deleteTask.mockRejectedValue(
499
+ new Error("Delete error")
500
+ );
501
+ await expect(syncService.removeLocalIssue("STA-1")).rejects.toThrow(
502
+ "Delete error"
503
+ );
504
+ });
505
+ });
506
+ describe("Status and Priority Mapping", () => {
507
+ beforeEach(() => {
508
+ mockConfigService.getConfig.mockResolvedValue({
509
+ integrations: {
510
+ linear: {
511
+ teamId: "test-team-id"
512
+ }
513
+ }
514
+ });
515
+ });
516
+ it("should map Linear states to task statuses correctly", async () => {
517
+ const testCases = [
518
+ { linearState: "backlog", expectedStatus: "todo" },
519
+ { linearState: "triage", expectedStatus: "todo" },
520
+ { linearState: "unstarted", expectedStatus: "todo" },
521
+ { linearState: "todo", expectedStatus: "todo" },
522
+ { linearState: "started", expectedStatus: "in_progress" },
523
+ { linearState: "in_progress", expectedStatus: "in_progress" },
524
+ { linearState: "completed", expectedStatus: "done" },
525
+ { linearState: "done", expectedStatus: "done" },
526
+ { linearState: "canceled", expectedStatus: "cancelled" },
527
+ { linearState: "cancelled", expectedStatus: "cancelled" },
528
+ { linearState: "unknown", expectedStatus: "todo" }
529
+ ];
530
+ for (const { linearState, expectedStatus } of testCases) {
531
+ const mockIssue = {
532
+ id: "test-issue",
533
+ identifier: "TEST-1",
534
+ title: "Test",
535
+ state: { type: linearState },
536
+ team: { id: "team-1", key: "TEST" },
537
+ updatedAt: (/* @__PURE__ */ new Date()).toISOString()
538
+ };
539
+ mockContextService.getTaskByExternalId.mockResolvedValue(null);
540
+ await syncService.syncIssueToLocal(mockIssue);
541
+ expect(mockContextService.createTask).toHaveBeenCalledWith(
542
+ expect.objectContaining({ status: expectedStatus })
543
+ );
544
+ mockContextService.createTask.mockClear();
545
+ mockContextService.getTaskByExternalId.mockClear();
546
+ }
547
+ });
548
+ it("should map Linear priorities to task priorities correctly", async () => {
549
+ const testCases = [
550
+ { linearPriority: 1, expectedPriority: "urgent" },
551
+ { linearPriority: 2, expectedPriority: "high" },
552
+ { linearPriority: 3, expectedPriority: "medium" },
553
+ { linearPriority: 4, expectedPriority: "low" },
554
+ { linearPriority: void 0, expectedPriority: void 0 }
555
+ ];
556
+ for (const { linearPriority, expectedPriority } of testCases) {
557
+ const mockIssue = {
558
+ id: "test-issue",
559
+ identifier: "TEST-1",
560
+ title: "Test",
561
+ state: { type: "unstarted" },
562
+ priority: linearPriority,
563
+ team: { id: "team-1", key: "TEST" },
564
+ updatedAt: (/* @__PURE__ */ new Date()).toISOString()
565
+ };
566
+ mockContextService.getTaskByExternalId.mockResolvedValue(null);
567
+ await syncService.syncIssueToLocal(mockIssue);
568
+ expect(mockContextService.createTask).toHaveBeenCalledWith(
569
+ expect.objectContaining({ priority: expectedPriority })
570
+ );
571
+ mockContextService.createTask.mockClear();
572
+ mockContextService.getTaskByExternalId.mockClear();
573
+ }
574
+ });
575
+ it("should map task priorities to Linear priorities correctly", async () => {
576
+ const testCases = [
577
+ { taskPriority: "urgent", expectedLinearPriority: 1 },
578
+ { taskPriority: "high", expectedLinearPriority: 2 },
579
+ { taskPriority: "medium", expectedLinearPriority: 3 },
580
+ { taskPriority: "low", expectedLinearPriority: 4 },
581
+ { taskPriority: void 0, expectedLinearPriority: 0 }
582
+ ];
583
+ for (const { taskPriority, expectedLinearPriority } of testCases) {
584
+ const mockTask = {
585
+ id: "local-1",
586
+ title: "Test Task",
587
+ description: "Test description",
588
+ status: "todo",
589
+ priority: taskPriority,
590
+ tags: [],
591
+ createdAt: /* @__PURE__ */ new Date(),
592
+ updatedAt: /* @__PURE__ */ new Date()
593
+ };
594
+ mockContextService.getTask.mockResolvedValue(mockTask);
595
+ mockLinearClient.createIssue.mockResolvedValue({
596
+ id: "created",
597
+ identifier: "TEST-1"
598
+ });
599
+ await syncService.syncLocalToLinear("local-1");
600
+ expect(mockLinearClient.createIssue).toHaveBeenCalledWith(
601
+ expect.objectContaining({ priority: expectedLinearPriority })
602
+ );
603
+ mockLinearClient.createIssue.mockClear();
604
+ mockContextService.getTask.mockClear();
605
+ mockContextService.updateTask.mockClear();
606
+ }
607
+ });
608
+ });
609
+ describe("Change Detection", () => {
610
+ it("should detect changes in title", async () => {
611
+ const existing = {
612
+ id: "1",
613
+ title: "Old Title",
614
+ description: "Same",
615
+ status: "todo",
616
+ priority: "medium",
617
+ tags: [],
618
+ createdAt: /* @__PURE__ */ new Date(),
619
+ updatedAt: /* @__PURE__ */ new Date()
620
+ };
621
+ mockContextService.getTaskByExternalId.mockResolvedValue(existing);
622
+ const mockIssue = {
623
+ id: "issue-1",
624
+ identifier: "STA-1",
625
+ title: "New Title",
626
+ description: "Same",
627
+ state: { type: "unstarted" },
628
+ priority: 2,
629
+ team: { id: "team-1", key: "STA" },
630
+ labels: [],
631
+ updatedAt: (/* @__PURE__ */ new Date()).toISOString()
632
+ };
633
+ await syncService.syncIssueToLocal(mockIssue);
634
+ expect(mockContextService.updateTask).toHaveBeenCalled();
635
+ });
636
+ it("should detect changes in tags", async () => {
637
+ const existing = {
638
+ id: "1",
639
+ title: "Same",
640
+ description: "Same",
641
+ status: "todo",
642
+ priority: "medium",
643
+ tags: ["old-tag"],
644
+ createdAt: /* @__PURE__ */ new Date(),
645
+ updatedAt: /* @__PURE__ */ new Date()
646
+ };
647
+ mockContextService.getTaskByExternalId.mockResolvedValue(existing);
648
+ const mockIssue = {
649
+ id: "issue-1",
650
+ identifier: "STA-1",
651
+ title: "Same",
652
+ description: "Same",
653
+ state: { type: "unstarted" },
654
+ priority: 2,
655
+ team: { id: "team-1", key: "STA" },
656
+ labels: [{ name: "new-tag" }],
657
+ updatedAt: (/* @__PURE__ */ new Date()).toISOString()
658
+ };
659
+ await syncService.syncIssueToLocal(mockIssue);
660
+ expect(mockContextService.updateTask).toHaveBeenCalled();
661
+ });
662
+ it("should not update when no changes detected", async () => {
663
+ const existing = {
664
+ id: "1",
665
+ title: "Same Title",
666
+ description: "Same Description",
667
+ status: "todo",
668
+ priority: "high",
669
+ // Linear priority 2 maps to 'high'
670
+ tags: ["tag1"],
671
+ createdAt: /* @__PURE__ */ new Date(),
672
+ updatedAt: /* @__PURE__ */ new Date()
673
+ };
674
+ mockContextService.getTaskByExternalId.mockResolvedValue(existing);
675
+ const mockIssue = {
676
+ id: "issue-1",
677
+ identifier: "STA-1",
678
+ title: "Same Title",
679
+ description: "Same Description",
680
+ state: { type: "unstarted" },
681
+ priority: 2,
682
+ // Maps to 'high'
683
+ team: { id: "team-1", key: "STA" },
684
+ labels: [{ name: "tag1" }],
685
+ updatedAt: (/* @__PURE__ */ new Date()).toISOString()
686
+ };
687
+ await syncService.syncIssueToLocal(mockIssue);
688
+ expect(mockContextService.updateTask).not.toHaveBeenCalled();
689
+ });
690
+ });
691
+ describe("Error Recovery and Edge Cases", () => {
692
+ it("should handle partial sync failures gracefully", async () => {
693
+ const mockIssues = [
694
+ {
695
+ id: "issue-1",
696
+ identifier: "STA-1",
697
+ title: "Good Issue",
698
+ state: { type: "unstarted" },
699
+ team: { id: "team-1", key: "STA" },
700
+ updatedAt: (/* @__PURE__ */ new Date()).toISOString()
701
+ },
702
+ {
703
+ id: "issue-2",
704
+ identifier: "STA-2",
705
+ title: "Bad Issue",
706
+ state: { type: "unstarted" },
707
+ team: { id: "team-1", key: "STA" },
708
+ updatedAt: (/* @__PURE__ */ new Date()).toISOString()
709
+ }
710
+ ];
711
+ mockConfigService.getConfig.mockResolvedValue({
712
+ integrations: { linear: { teamId: "test-team-id" } }
713
+ });
714
+ mockLinearClient.getIssues.mockResolvedValue(mockIssues);
715
+ mockContextService.getTaskByExternalId.mockResolvedValue(null);
716
+ mockContextService.createTask.mockResolvedValueOnce("success").mockRejectedValueOnce(new Error("Creation failed"));
717
+ const result = await syncService.syncAllIssues();
718
+ expect(result.created).toBe(1);
719
+ expect(result.errors).toHaveLength(1);
720
+ expect(result.errors[0]).toContain("Failed to sync STA-2");
721
+ });
722
+ it("should handle empty issues list", async () => {
723
+ mockConfigService.getConfig.mockResolvedValue({
724
+ integrations: { linear: { teamId: "test-team-id" } }
725
+ });
726
+ mockLinearClient.getIssues.mockResolvedValue([]);
727
+ const result = await syncService.syncAllIssues();
728
+ expect(result.created).toBe(0);
729
+ expect(result.updated).toBe(0);
730
+ expect(result.errors).toHaveLength(0);
731
+ });
732
+ it("should handle malformed Linear issues", async () => {
733
+ const malformedIssue = {
734
+ // Missing required fields
735
+ id: "issue-1",
736
+ title: null,
737
+ state: null,
738
+ team: null
739
+ };
740
+ mockConfigService.getConfig.mockResolvedValue({
741
+ integrations: { linear: { teamId: "test-team-id" } }
742
+ });
743
+ mockLinearClient.getIssues.mockResolvedValue([malformedIssue]);
744
+ const result = await syncService.syncAllIssues();
745
+ expect(result.errors).toHaveLength(1);
746
+ });
747
+ it("should handle network timeouts gracefully", async () => {
748
+ mockConfigService.getConfig.mockResolvedValue({
749
+ integrations: { linear: { teamId: "test-team-id" } }
750
+ });
751
+ const timeoutError = new Error("Request timeout");
752
+ timeoutError.name = "TimeoutError";
753
+ mockLinearClient.getIssues.mockRejectedValue(timeoutError);
754
+ const result = await syncService.syncAllIssues();
755
+ expect(result.errors).toHaveLength(1);
756
+ expect(result.errors[0]).toContain("Request timeout");
757
+ });
758
+ });
759
+ });
760
+ //# sourceMappingURL=sync-service.test.js.map