codna 0.1.0__py3-none-any.whl

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 (761) hide show
  1. codna/__init__.py +8 -0
  2. codna/_wheel_guard.py +28 -0
  3. codna/admission_control.py +275 -0
  4. codna/agent-core/CLINE_FORK.md +55 -0
  5. codna/agent-core/CLINE_SDK_AZ_INTEGRATION_PLAN.md +191 -0
  6. codna/agent-core/CLINE_SDK_INTERFACE.md +655 -0
  7. codna/agent-core/CLINE_SDK_RESEARCH.md +104 -0
  8. codna/agent-core/package.json +12 -0
  9. codna/agent-core/run-server.mjs +87 -0
  10. codna/agent-core/run-server.stub.mjs +149 -0
  11. codna/agent-core/vendor/cline/.gitignore +3 -0
  12. codna/agent-core/vendor/cline/LICENSE +201 -0
  13. codna/agent-core/vendor/cline/NOTICE +24 -0
  14. codna/agent-core/vendor/cline/UPSTREAM_COMMIT.txt +1 -0
  15. codna/agent-core/vendor/cline/algenta/README.md +27 -0
  16. codna/agent-core/vendor/cline/algenta/acp-editor.ts +176 -0
  17. codna/agent-core/vendor/cline/algenta/adapter.ts +452 -0
  18. codna/agent-core/vendor/cline/algenta/algenta-plugin.ts +30 -0
  19. codna/agent-core/vendor/cline/algenta/artifacts.test.ts +133 -0
  20. codna/agent-core/vendor/cline/algenta/execution.test.ts +63 -0
  21. codna/agent-core/vendor/cline/algenta/fallback.test.ts +73 -0
  22. codna/agent-core/vendor/cline/algenta/fallback.ts +83 -0
  23. codna/agent-core/vendor/cline/algenta/fix-runner.ts +27 -0
  24. codna/agent-core/vendor/cline/algenta/http.test.ts +48 -0
  25. codna/agent-core/vendor/cline/algenta/mojo-gate.test.ts +76 -0
  26. codna/agent-core/vendor/cline/algenta/mojo-gate.ts +151 -0
  27. codna/agent-core/vendor/cline/algenta/policy.test.ts +260 -0
  28. codna/agent-core/vendor/cline/algenta/postbuild.sh +31 -0
  29. codna/agent-core/vendor/cline/algenta/proof-artifacts.test.ts +55 -0
  30. codna/agent-core/vendor/cline/algenta/proof-provider.ts +301 -0
  31. codna/agent-core/vendor/cline/algenta/proofs.ts +311 -0
  32. codna/agent-core/vendor/cline/algenta/provider-key.test.ts +197 -0
  33. codna/agent-core/vendor/cline/algenta/run-server.ts +645 -0
  34. codna/agent-core/vendor/cline/algenta/scheduled-agents.ts +430 -0
  35. codna/agent-core/vendor/cline/algenta/server/artifacts.ts +532 -0
  36. codna/agent-core/vendor/cline/algenta/server/contracts.ts +254 -0
  37. codna/agent-core/vendor/cline/algenta/server/execution.ts +284 -0
  38. codna/agent-core/vendor/cline/algenta/server/http.ts +146 -0
  39. codna/agent-core/vendor/cline/algenta/server/policy.ts +391 -0
  40. codna/agent-core/vendor/cline/algenta/server/state.ts +21 -0
  41. codna/agent-core/vendor/cline/algenta/server/utils.ts +508 -0
  42. codna/agent-core/vendor/cline/algenta/task-policy.ts +82 -0
  43. codna/agent-core/vendor/cline/algenta/telys-localize.test.ts +416 -0
  44. codna/agent-core/vendor/cline/algenta/telys-localize.ts +608 -0
  45. codna/agent-core/vendor/cline/algenta/telys-worker.test.ts +99 -0
  46. codna/agent-core/vendor/cline/algenta/telys-worker.ts +245 -0
  47. codna/agent-core/vendor/cline/algenta/tools.test.ts +59 -0
  48. codna/agent-core/vendor/cline/algenta/tools.ts +196 -0
  49. codna/agent-core/vendor/cline/algenta/write-scope.test.ts +26 -0
  50. codna/agent-core/vendor/cline/algenta/write-scope.ts +60 -0
  51. codna/agent-core/vendor/cline/biome.json +19 -0
  52. codna/agent-core/vendor/cline/bun.lock +1179 -0
  53. codna/agent-core/vendor/cline/package.json +60 -0
  54. codna/agent-core/vendor/cline/sdk/.cline/rules/worktree_dependency_hygiene.md +15 -0
  55. codna/agent-core/vendor/cline/sdk/.cline/skills/plugin.md +892 -0
  56. codna/agent-core/vendor/cline/sdk/.gitignore +69 -0
  57. codna/agent-core/vendor/cline/sdk/AGENTS.md +109 -0
  58. codna/agent-core/vendor/cline/sdk/ARCHITECTURE.md +525 -0
  59. codna/agent-core/vendor/cline/sdk/CHANGELOG.md +32 -0
  60. codna/agent-core/vendor/cline/sdk/CONTRIBUTING.md +196 -0
  61. codna/agent-core/vendor/cline/sdk/README.md +273 -0
  62. codna/agent-core/vendor/cline/sdk/biome.json +140 -0
  63. codna/agent-core/vendor/cline/sdk/examples/README.md +196 -0
  64. codna/agent-core/vendor/cline/sdk/examples/cron/README.md +419 -0
  65. codna/agent-core/vendor/cline/sdk/examples/cron/changelog-generator.cron.md +37 -0
  66. codna/agent-core/vendor/cline/sdk/examples/cron/code-style-audit.cron.md +47 -0
  67. codna/agent-core/vendor/cline/sdk/examples/cron/daily-code-review.cron.md +28 -0
  68. codna/agent-core/vendor/cline/sdk/examples/cron/dead-code-finder.cron.md +58 -0
  69. codna/agent-core/vendor/cline/sdk/examples/cron/dependency-check.cron.md +35 -0
  70. codna/agent-core/vendor/cline/sdk/examples/cron/documentation-check.cron.md +66 -0
  71. codna/agent-core/vendor/cline/sdk/examples/cron/events/local-manual-test.event.md +28 -0
  72. codna/agent-core/vendor/cline/sdk/examples/cron/events/local-plugin-event.event.md +20 -0
  73. codna/agent-core/vendor/cline/sdk/examples/cron/events/pr-changelog-check.event.md +42 -0
  74. codna/agent-core/vendor/cline/sdk/examples/cron/events/pr-review.event.md +32 -0
  75. codna/agent-core/vendor/cline/sdk/examples/cron/events/pr-test-coverage.event.md +55 -0
  76. codna/agent-core/vendor/cline/sdk/examples/cron/performance-baseline.cron.md +45 -0
  77. codna/agent-core/vendor/cline/sdk/examples/cron/test-coverage-report.cron.md +41 -0
  78. codna/agent-core/vendor/cline/sdk/examples/cron/type-check-strict.cron.md +44 -0
  79. codna/agent-core/vendor/cline/sdk/examples/cron/weekly-metrics-summary.cron.md +67 -0
  80. codna/agent-core/vendor/cline/sdk/examples/hooks/PostToolUse.py +62 -0
  81. codna/agent-core/vendor/cline/sdk/examples/hooks/PostToolUse.sh +17 -0
  82. codna/agent-core/vendor/cline/sdk/examples/hooks/PostToolUse.ts +86 -0
  83. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse.py +34 -0
  84. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse.sh +16 -0
  85. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse.ts +66 -0
  86. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse_BlockDestructive.sh +25 -0
  87. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse_InjectContext.py +116 -0
  88. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse_InjectFileContext.sh +57 -0
  89. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse_ModifyInput.ts +125 -0
  90. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse_RequireReview.sh +19 -0
  91. codna/agent-core/vendor/cline/sdk/examples/hooks/README.md +435 -0
  92. codna/agent-core/vendor/cline/sdk/examples/hooks/SessionShutdown.sh +14 -0
  93. codna/agent-core/vendor/cline/sdk/examples/hooks/TaskComplete.sh +27 -0
  94. codna/agent-core/vendor/cline/sdk/examples/hooks/TaskStart.sh +14 -0
  95. codna/agent-core/vendor/cline/sdk/examples/hooks/custom-compaction-hook.example.ts +246 -0
  96. codna/agent-core/vendor/cline/sdk/examples/package.json +19 -0
  97. codna/agent-core/vendor/cline/sdk/examples/plugins/README.md +203 -0
  98. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/README.md +122 -0
  99. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/agents/anvil.md +16 -0
  100. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/agents/inquisitor.md +18 -0
  101. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/agents/oracle.md +18 -0
  102. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/agents/phantom.md +17 -0
  103. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/index.ts +831 -0
  104. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/package.json +39 -0
  105. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/skills/api-design.md +63 -0
  106. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/skills/code-review.md +61 -0
  107. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/skills/debugging.md +62 -0
  108. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/skills/documentation.md +83 -0
  109. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/skills/migration.md +77 -0
  110. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/skills/refactoring.md +58 -0
  111. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/skills/test-generation.md +76 -0
  112. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/tsconfig.json +4 -0
  113. codna/agent-core/vendor/cline/sdk/examples/plugins/automation-events.ts +91 -0
  114. codna/agent-core/vendor/cline/sdk/examples/plugins/background-terminal.ts +444 -0
  115. codna/agent-core/vendor/cline/sdk/examples/plugins/custom-compaction.ts +225 -0
  116. codna/agent-core/vendor/cline/sdk/examples/plugins/env-blocker.ts +118 -0
  117. codna/agent-core/vendor/cline/sdk/examples/plugins/gitignore-read-files-guard.ts +270 -0
  118. codna/agent-core/vendor/cline/sdk/examples/plugins/mac-notify.ts +67 -0
  119. codna/agent-core/vendor/cline/sdk/examples/plugins/openrouter-provider.ts +144 -0
  120. codna/agent-core/vendor/cline/sdk/examples/plugins/typescript-lsp/README.md +106 -0
  121. codna/agent-core/vendor/cline/sdk/examples/plugins/typescript-lsp/index.ts +298 -0
  122. codna/agent-core/vendor/cline/sdk/examples/plugins/weather-metrics.ts +151 -0
  123. codna/agent-core/vendor/cline/sdk/examples/plugins/web-search.ts +324 -0
  124. codna/agent-core/vendor/cline/sdk/examples/tsconfig.json +58 -0
  125. codna/agent-core/vendor/cline/sdk/packages/README.md +44 -0
  126. codna/agent-core/vendor/cline/sdk/packages/agents/README.md +278 -0
  127. codna/agent-core/vendor/cline/sdk/packages/agents/bun.mts +29 -0
  128. codna/agent-core/vendor/cline/sdk/packages/agents/package.json +45 -0
  129. codna/agent-core/vendor/cline/sdk/packages/agents/src/agent-runtime.provider-form.test.ts +210 -0
  130. codna/agent-core/vendor/cline/sdk/packages/agents/src/agent-runtime.test.ts +1427 -0
  131. codna/agent-core/vendor/cline/sdk/packages/agents/src/agent-runtime.ts +1558 -0
  132. codna/agent-core/vendor/cline/sdk/packages/agents/src/index.ts +57 -0
  133. codna/agent-core/vendor/cline/sdk/packages/agents/tsconfig.build.json +13 -0
  134. codna/agent-core/vendor/cline/sdk/packages/agents/tsconfig.dev.json +13 -0
  135. codna/agent-core/vendor/cline/sdk/packages/agents/tsconfig.json +9 -0
  136. codna/agent-core/vendor/cline/sdk/packages/agents/vitest.config.ts +10 -0
  137. codna/agent-core/vendor/cline/sdk/packages/core/README.md +110 -0
  138. codna/agent-core/vendor/cline/sdk/packages/core/bun.mts +75 -0
  139. codna/agent-core/vendor/cline/sdk/packages/core/docs/messages-contract-v1.md +148 -0
  140. codna/agent-core/vendor/cline/sdk/packages/core/fixtures/messages/success.messages.json +72 -0
  141. codna/agent-core/vendor/cline/sdk/packages/core/package.json +80 -0
  142. codna/agent-core/vendor/cline/sdk/packages/core/scripts/telemetry-smoke-host.ts +204 -0
  143. codna/agent-core/vendor/cline/sdk/packages/core/scripts/telemetry-smoke.ts +431 -0
  144. codna/agent-core/vendor/cline/sdk/packages/core/src/ClineCore.test.ts +607 -0
  145. codna/agent-core/vendor/cline/sdk/packages/core/src/ClineCore.ts +566 -0
  146. codna/agent-core/vendor/cline/sdk/packages/core/src/account/cline-account-service.test.ts +217 -0
  147. codna/agent-core/vendor/cline/sdk/packages/core/src/account/cline-account-service.ts +338 -0
  148. codna/agent-core/vendor/cline/sdk/packages/core/src/account/featurebase-token.test.ts +175 -0
  149. codna/agent-core/vendor/cline/sdk/packages/core/src/account/index.ts +24 -0
  150. codna/agent-core/vendor/cline/sdk/packages/core/src/account/rpc.test.ts +63 -0
  151. codna/agent-core/vendor/cline/sdk/packages/core/src/account/rpc.ts +185 -0
  152. codna/agent-core/vendor/cline/sdk/packages/core/src/account/types.ts +108 -0
  153. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/bounded-ttl-cache.test.ts +38 -0
  154. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/bounded-ttl-cache.ts +53 -0
  155. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/client.test.ts +93 -0
  156. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/client.ts +50 -0
  157. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/cline.test.ts +233 -0
  158. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/cline.ts +722 -0
  159. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/codex.test.ts +170 -0
  160. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/codex.ts +491 -0
  161. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/oca.test.ts +340 -0
  162. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/oca.ts +588 -0
  163. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/server.test.ts +319 -0
  164. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/server.ts +265 -0
  165. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/types.ts +110 -0
  166. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/utils.test.ts +128 -0
  167. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/utils.ts +247 -0
  168. codna/agent-core/vendor/cline/sdk/packages/core/src/cline-core/automation.ts +250 -0
  169. codna/agent-core/vendor/cline/sdk/packages/core/src/cline-core/runtime-services.ts +75 -0
  170. codna/agent-core/vendor/cline/sdk/packages/core/src/cline-core/start-input.ts +91 -0
  171. codna/agent-core/vendor/cline/sdk/packages/core/src/cline-core/telemetry.ts +39 -0
  172. codna/agent-core/vendor/cline/sdk/packages/core/src/cline-core/types.ts +274 -0
  173. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/events/cron-event-ingress.test.ts +255 -0
  174. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/events/cron-event-ingress.ts +357 -0
  175. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/events/index.ts +1 -0
  176. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/index.ts +7 -0
  177. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/reports/cron-report-writer.ts +153 -0
  178. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/reports/index.ts +1 -0
  179. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/runner/cron-materializer.test.ts +152 -0
  180. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/runner/cron-materializer.ts +100 -0
  181. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/runner/cron-runner.test.ts +342 -0
  182. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/runner/cron-runner.ts +547 -0
  183. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/runner/index.ts +3 -0
  184. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/runner/resource-limiter.ts +46 -0
  185. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/schedule/index.ts +1 -0
  186. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/schedule/scheduler.test.ts +16 -0
  187. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/schedule/scheduler.ts +373 -0
  188. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/service/cron-service.ts +163 -0
  189. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/service/index.ts +3 -0
  190. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/service/schedule-command-service.ts +198 -0
  191. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/service/schedule-service.test.ts +213 -0
  192. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/service/schedule-service.ts +416 -0
  193. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/specs/cron-reconciler.test.ts +138 -0
  194. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/specs/cron-reconciler.ts +241 -0
  195. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/specs/cron-spec-parser.test.ts +198 -0
  196. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/specs/cron-spec-parser.ts +489 -0
  197. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/specs/cron-watcher.test.ts +87 -0
  198. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/specs/cron-watcher.ts +102 -0
  199. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/specs/index.ts +3 -0
  200. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/store/cron-schema.ts +127 -0
  201. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/store/index.ts +2 -0
  202. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/store/sqlite-cron-store.test.ts +354 -0
  203. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/store/sqlite-cron-store.ts +1552 -0
  204. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/index.ts +46 -0
  205. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/runtime-commands.test.ts +185 -0
  206. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/runtime-commands.ts +92 -0
  207. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/skill-frontmatter-toggle.test.ts +109 -0
  208. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/skill-frontmatter-toggle.ts +83 -0
  209. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/unified-config-file-watcher.test.ts +193 -0
  210. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/unified-config-file-watcher.ts +496 -0
  211. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/user-instruction-config-loader.test.ts +424 -0
  212. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/user-instruction-config-loader.ts +628 -0
  213. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/user-instruction-plugin.ts +277 -0
  214. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/user-instruction-service.ts +128 -0
  215. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/context/agentic-compaction.ts +153 -0
  216. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/context/basic-compaction.ts +419 -0
  217. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/context/compaction-shared.ts +511 -0
  218. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/context/compaction.live.test.ts +346 -0
  219. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/context/compaction.test.ts +1729 -0
  220. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/context/compaction.ts +430 -0
  221. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/index.ts +19 -0
  222. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/client.ts +579 -0
  223. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/config-loader.test.ts +402 -0
  224. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/config-loader.ts +446 -0
  225. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/index.ts +57 -0
  226. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/manager.test.ts +105 -0
  227. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/manager.ts +260 -0
  228. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/name-transform.ts +33 -0
  229. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/oauth.test.ts +79 -0
  230. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/oauth.ts +401 -0
  231. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/policies.ts +47 -0
  232. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/tools.ts +47 -0
  233. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/types.ts +135 -0
  234. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-config-loader.test.ts +480 -0
  235. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-config-loader.ts +313 -0
  236. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-load-report.ts +20 -0
  237. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-loader.test.ts +473 -0
  238. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-loader.ts +214 -0
  239. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-module-import.ts +682 -0
  240. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-sandbox-bootstrap.ts +781 -0
  241. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-sandbox.test.ts +810 -0
  242. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-sandbox.ts +640 -0
  243. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-targeting.ts +32 -0
  244. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/constants.ts +37 -0
  245. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/definitions.test.ts +1408 -0
  246. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/definitions.ts +863 -0
  247. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/apply-patch-parser.ts +520 -0
  248. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/apply-patch.test.ts +147 -0
  249. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/apply-patch.ts +348 -0
  250. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/bash.test.ts +108 -0
  251. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/bash.ts +211 -0
  252. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/editor.test.ts +113 -0
  253. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/editor.ts +220 -0
  254. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/file-read.test.ts +167 -0
  255. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/file-read.ts +140 -0
  256. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/index.ts +87 -0
  257. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/search.ts +471 -0
  258. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/web-fetch.ts +259 -0
  259. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/helpers.ts +126 -0
  260. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/index.ts +183 -0
  261. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/model-tool-routing.test.ts +86 -0
  262. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/model-tool-routing.ts +134 -0
  263. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/presets.test.ts +72 -0
  264. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/presets.ts +190 -0
  265. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/runtime.test.ts +74 -0
  266. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/runtime.ts +261 -0
  267. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/schemas.ts +345 -0
  268. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/delegated-agent.ts +136 -0
  269. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/index.ts +5 -0
  270. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/multi-agent.lifecycle.test.ts +649 -0
  271. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/multi-agent.ts +1845 -0
  272. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/projections.ts +283 -0
  273. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/runtime.ts +54 -0
  274. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/spawn-agent-tool.test.ts +378 -0
  275. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/spawn-agent-tool.ts +203 -0
  276. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/subagent-prompts.ts +41 -0
  277. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/team-tools.test.ts +991 -0
  278. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/team-tools.ts +912 -0
  279. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/types.ts +358 -0
  280. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/checkpoint-hooks.test.ts +276 -0
  281. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/checkpoint-hooks.ts +291 -0
  282. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/hook-extension.ts +15 -0
  283. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/hook-file-config.test.ts +17 -0
  284. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/hook-file-config.ts +117 -0
  285. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/hook-file-hooks.test.ts +593 -0
  286. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/hook-file-hooks.ts +1140 -0
  287. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/index.ts +34 -0
  288. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/subprocess-runner.ts +196 -0
  289. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/subprocess.ts +543 -0
  290. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/client/connect.test.ts +74 -0
  291. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/client/connect.ts +187 -0
  292. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/client/index.test.ts +994 -0
  293. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/client/index.ts +1087 -0
  294. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/client/session-client.test.ts +310 -0
  295. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/client/session-client.ts +734 -0
  296. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/client/ui-client.ts +128 -0
  297. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/daemon/entry.ts +129 -0
  298. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/daemon/index.test.ts +357 -0
  299. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/daemon/index.ts +345 -0
  300. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/daemon/runtime-handlers.ts +144 -0
  301. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/daemon/start-shared-server.ts +61 -0
  302. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/discovery/defaults.test.ts +122 -0
  303. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/discovery/defaults.ts +70 -0
  304. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/discovery/index.test.ts +91 -0
  305. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/discovery/index.ts +260 -0
  306. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/discovery/workspace.ts +19 -0
  307. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/index.ts +37 -0
  308. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/runtime-host/hub-runtime-host.test.ts +1485 -0
  309. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/runtime-host/hub-runtime-host.ts +1948 -0
  310. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/runtime-host/remote-runtime-host.ts +27 -0
  311. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/boundary.test.ts +1142 -0
  312. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/browser-websocket.test.ts +173 -0
  313. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/browser-websocket.ts +295 -0
  314. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/command-transport.ts +14 -0
  315. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/fetch-wiring.test.ts +102 -0
  316. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/approval-handlers.ts +133 -0
  317. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/capability-handlers.ts +278 -0
  318. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/client-handlers.ts +86 -0
  319. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/context.ts +211 -0
  320. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/run-handlers.test.ts +186 -0
  321. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/run-handlers.ts +337 -0
  322. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/session-event-projector.ts +355 -0
  323. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/session-handlers.ts +842 -0
  324. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-capability-tool-executors.test.ts +215 -0
  325. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-client-contributions.ts +687 -0
  326. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-notifications.ts +94 -0
  327. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-schedule-events.ts +20 -0
  328. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-server-logging.ts +69 -0
  329. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-server-options.ts +66 -0
  330. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-server-transport.ts +593 -0
  331. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-session-records.ts +99 -0
  332. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-websocket-server.ts +562 -0
  333. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/index.test.ts +358 -0
  334. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/index.ts +4 -0
  335. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/native-transport.ts +31 -0
  336. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/notification.test.ts +21 -0
  337. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/ui-events.test.ts +232 -0
  338. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/settings.test.ts +143 -0
  339. codna/agent-core/vendor/cline/sdk/packages/core/src/index.ts +789 -0
  340. codna/agent-core/vendor/cline/sdk/packages/core/src/remote-config/integration.ts +133 -0
  341. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/capabilities/index.ts +2 -0
  342. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/capabilities/normalize-runtime-capabilities.ts +33 -0
  343. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/capabilities/runtime-capabilities.ts +9 -0
  344. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/config/agent-message-codec.test.ts +171 -0
  345. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/config/agent-message-codec.ts +301 -0
  346. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/config/agent-runtime-config-builder.test.ts +268 -0
  347. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/config/agent-runtime-config-builder.ts +181 -0
  348. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/history.test.ts +573 -0
  349. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/history.ts +516 -0
  350. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/host.test.ts +297 -0
  351. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/host.ts +248 -0
  352. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local/agent-event-bridge.ts +231 -0
  353. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local/session-record.ts +52 -0
  354. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local/session-service-invoker.ts +40 -0
  355. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local/spawn-tool.ts +162 -0
  356. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local/user-files.ts +18 -0
  357. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local-runtime-host.e2e.test.ts +576 -0
  358. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local-runtime-host.test.ts +5167 -0
  359. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local-runtime-host.ts +1755 -0
  360. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/runtime-host-support.test.ts +55 -0
  361. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/runtime-host-support.ts +140 -0
  362. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/runtime-host.ts +323 -0
  363. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/index.ts +24 -0
  364. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-builder.team-persistence.test.ts +290 -0
  365. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-builder.test.ts +887 -0
  366. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-builder.ts +637 -0
  367. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-event-adapter.test.ts +901 -0
  368. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-event-adapter.ts +426 -0
  369. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-oauth-token-manager.test.ts +137 -0
  370. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-oauth-token-manager.ts +269 -0
  371. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-parity.test.ts +165 -0
  372. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/session-runtime-orchestrator.test.ts +1900 -0
  373. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/session-runtime-orchestrator.ts +1334 -0
  374. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/session-runtime.ts +73 -0
  375. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/user-input-builder.ts +159 -0
  376. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/safety/loop-detection.ts +162 -0
  377. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/safety/mistake-tracker.ts +221 -0
  378. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/safety/rules.test.ts +22 -0
  379. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/safety/rules.ts +49 -0
  380. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/tools/subprocess-sandbox.test.ts +81 -0
  381. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/tools/subprocess-sandbox.ts +333 -0
  382. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/tools/tool-approval.ts +102 -0
  383. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/turn-queue/pending-prompt-service.test.ts +168 -0
  384. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/turn-queue/pending-prompt-service.ts +381 -0
  385. codna/agent-core/vendor/cline/sdk/packages/core/src/services/agent-events.ts +321 -0
  386. codna/agent-core/vendor/cline/sdk/packages/core/src/services/config.ts +5 -0
  387. codna/agent-core/vendor/cline/sdk/packages/core/src/services/global-settings.test.ts +352 -0
  388. codna/agent-core/vendor/cline/sdk/packages/core/src/services/global-settings.ts +324 -0
  389. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/apihandler-agent-model-adapter.test.ts +229 -0
  390. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/apihandler-agent-model-adapter.ts +170 -0
  391. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/cline-recommended-models.ts +168 -0
  392. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/configured-provider-registry.ts +193 -0
  393. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/handler-factory.test.ts +288 -0
  394. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/handler-factory.ts +197 -0
  395. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/provider-defaults.test.ts +260 -0
  396. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/provider-defaults.ts +887 -0
  397. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/provider-settings.test.ts +26 -0
  398. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/provider-settings.ts +322 -0
  399. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/runtime-config.ts +43 -0
  400. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/runtime-registry.ts +172 -0
  401. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/runtime-types.ts +121 -0
  402. codna/agent-core/vendor/cline/sdk/packages/core/src/services/local-runtime-bootstrap.startup.test.ts +249 -0
  403. codna/agent-core/vendor/cline/sdk/packages/core/src/services/local-runtime-bootstrap.test.ts +543 -0
  404. codna/agent-core/vendor/cline/sdk/packages/core/src/services/local-runtime-bootstrap.ts +470 -0
  405. codna/agent-core/vendor/cline/sdk/packages/core/src/services/plugin-tools.ts +230 -0
  406. codna/agent-core/vendor/cline/sdk/packages/core/src/services/plugin-uninstall.test.ts +165 -0
  407. codna/agent-core/vendor/cline/sdk/packages/core/src/services/plugin-uninstall.ts +425 -0
  408. codna/agent-core/vendor/cline/sdk/packages/core/src/services/providers/local-provider-registry.ts +468 -0
  409. codna/agent-core/vendor/cline/sdk/packages/core/src/services/providers/local-provider-service.test.ts +1358 -0
  410. codna/agent-core/vendor/cline/sdk/packages/core/src/services/providers/local-provider-service.ts +948 -0
  411. codna/agent-core/vendor/cline/sdk/packages/core/src/services/providers/model-source.ts +105 -0
  412. codna/agent-core/vendor/cline/sdk/packages/core/src/services/providers/provider-config-fields.test.ts +137 -0
  413. codna/agent-core/vendor/cline/sdk/packages/core/src/services/providers/provider-config-fields.ts +211 -0
  414. codna/agent-core/vendor/cline/sdk/packages/core/src/services/session-artifacts.ts +138 -0
  415. codna/agent-core/vendor/cline/sdk/packages/core/src/services/session-data.test.ts +307 -0
  416. codna/agent-core/vendor/cline/sdk/packages/core/src/services/session-data.ts +405 -0
  417. codna/agent-core/vendor/cline/sdk/packages/core/src/services/session-telemetry.ts +89 -0
  418. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/artifact-store.ts +1 -0
  419. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/file-team-store.ts +250 -0
  420. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/index.ts +11 -0
  421. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/provider-settings-legacy-migration.test.ts +656 -0
  422. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/provider-settings-legacy-migration.ts +798 -0
  423. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/provider-settings-manager.test.ts +354 -0
  424. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/provider-settings-manager.ts +194 -0
  425. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/session-store.ts +1 -0
  426. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/sqlite-session-store.ts +272 -0
  427. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/sqlite-team-store.ts +537 -0
  428. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/team-store.ts +36 -0
  429. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/ITelemetryAdapter.ts +94 -0
  430. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/OpenTelemetryAdapter.test.ts +157 -0
  431. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/OpenTelemetryAdapter.ts +348 -0
  432. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/OpenTelemetryProvider.test.ts +401 -0
  433. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/OpenTelemetryProvider.ts +545 -0
  434. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/TelemetryLoggerSink.test.ts +42 -0
  435. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/TelemetryLoggerSink.ts +121 -0
  436. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/TelemetryService.test.ts +134 -0
  437. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/TelemetryService.ts +139 -0
  438. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/core-events.test.ts +696 -0
  439. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/core-events.ts +680 -0
  440. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/distinct-id.test.ts +57 -0
  441. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/distinct-id.ts +69 -0
  442. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/index.ts +22 -0
  443. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/tool-context.ts +15 -0
  444. codna/agent-core/vendor/cline/sdk/packages/core/src/services/usage.test.ts +75 -0
  445. codna/agent-core/vendor/cline/sdk/packages/core/src/services/usage.ts +87 -0
  446. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/file-indexer.test.ts +156 -0
  447. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/file-indexer.ts +362 -0
  448. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/index.ts +7 -0
  449. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/mention-enricher.test.ts +106 -0
  450. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/mention-enricher.ts +122 -0
  451. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/workspace-manager.ts +100 -0
  452. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/workspace-manifest.ts +129 -0
  453. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/workspace-telemetry.test.ts +166 -0
  454. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/workspace-telemetry.ts +70 -0
  455. codna/agent-core/vendor/cline/sdk/packages/core/src/session/checkpoint-restore.test.ts +154 -0
  456. codna/agent-core/vendor/cline/sdk/packages/core/src/session/checkpoint-restore.ts +189 -0
  457. codna/agent-core/vendor/cline/sdk/packages/core/src/session/index.ts +32 -0
  458. codna/agent-core/vendor/cline/sdk/packages/core/src/session/models/session-graph.ts +92 -0
  459. codna/agent-core/vendor/cline/sdk/packages/core/src/session/models/session-manifest.ts +29 -0
  460. codna/agent-core/vendor/cline/sdk/packages/core/src/session/models/session-row.ts +199 -0
  461. codna/agent-core/vendor/cline/sdk/packages/core/src/session/services/file-session-service.ts +284 -0
  462. codna/agent-core/vendor/cline/sdk/packages/core/src/session/services/message-builder.test.ts +375 -0
  463. codna/agent-core/vendor/cline/sdk/packages/core/src/session/services/message-builder.ts +976 -0
  464. codna/agent-core/vendor/cline/sdk/packages/core/src/session/services/persistence-service.test.ts +553 -0
  465. codna/agent-core/vendor/cline/sdk/packages/core/src/session/services/persistence-service.ts +582 -0
  466. codna/agent-core/vendor/cline/sdk/packages/core/src/session/services/session-service.team-persistence.test.ts +48 -0
  467. codna/agent-core/vendor/cline/sdk/packages/core/src/session/services/session-service.ts +326 -0
  468. codna/agent-core/vendor/cline/sdk/packages/core/src/session/session-snapshot.ts +208 -0
  469. codna/agent-core/vendor/cline/sdk/packages/core/src/session/session-versioning-service.test.ts +195 -0
  470. codna/agent-core/vendor/cline/sdk/packages/core/src/session/session-versioning-service.ts +245 -0
  471. codna/agent-core/vendor/cline/sdk/packages/core/src/session/stores/conversation-store.ts +77 -0
  472. codna/agent-core/vendor/cline/sdk/packages/core/src/session/stores/session-manifest-store.ts +160 -0
  473. codna/agent-core/vendor/cline/sdk/packages/core/src/session/stores/team-persistence-store.ts +176 -0
  474. codna/agent-core/vendor/cline/sdk/packages/core/src/session/team/index.ts +12 -0
  475. codna/agent-core/vendor/cline/sdk/packages/core/src/session/team/team-child-session-manager.ts +415 -0
  476. codna/agent-core/vendor/cline/sdk/packages/core/src/session/team/team-session-coordinator.ts +240 -0
  477. codna/agent-core/vendor/cline/sdk/packages/core/src/settings/index.ts +15 -0
  478. codna/agent-core/vendor/cline/sdk/packages/core/src/settings/settings-service.test.ts +303 -0
  479. codna/agent-core/vendor/cline/sdk/packages/core/src/settings/settings-service.ts +317 -0
  480. codna/agent-core/vendor/cline/sdk/packages/core/src/settings/types.ts +67 -0
  481. codna/agent-core/vendor/cline/sdk/packages/core/src/types/chat-schema.ts +90 -0
  482. codna/agent-core/vendor/cline/sdk/packages/core/src/types/common.ts +54 -0
  483. codna/agent-core/vendor/cline/sdk/packages/core/src/types/config.ts +220 -0
  484. codna/agent-core/vendor/cline/sdk/packages/core/src/types/events.ts +88 -0
  485. codna/agent-core/vendor/cline/sdk/packages/core/src/types/index.ts +26 -0
  486. codna/agent-core/vendor/cline/sdk/packages/core/src/types/provider-settings.ts +56 -0
  487. codna/agent-core/vendor/cline/sdk/packages/core/src/types/session.ts +134 -0
  488. codna/agent-core/vendor/cline/sdk/packages/core/src/types/sessions.ts +45 -0
  489. codna/agent-core/vendor/cline/sdk/packages/core/src/types/storage.ts +56 -0
  490. codna/agent-core/vendor/cline/sdk/packages/core/src/types.ts +184 -0
  491. codna/agent-core/vendor/cline/sdk/packages/core/src/version.ts +3 -0
  492. codna/agent-core/vendor/cline/sdk/packages/core/tsconfig.build.json +18 -0
  493. codna/agent-core/vendor/cline/sdk/packages/core/tsconfig.dev.json +8 -0
  494. codna/agent-core/vendor/cline/sdk/packages/core/tsconfig.json +24 -0
  495. codna/agent-core/vendor/cline/sdk/packages/core/tsconfig.smoke.json +18 -0
  496. codna/agent-core/vendor/cline/sdk/packages/core/vitest.config.ts +9 -0
  497. codna/agent-core/vendor/cline/sdk/packages/core/vitest.e2e.config.ts +10 -0
  498. codna/agent-core/vendor/cline/sdk/packages/llms/AGENTS.md +39 -0
  499. codna/agent-core/vendor/cline/sdk/packages/llms/README.md +227 -0
  500. codna/agent-core/vendor/cline/sdk/packages/llms/bun.mts +49 -0
  501. codna/agent-core/vendor/cline/sdk/packages/llms/fixtures/usage.json +308 -0
  502. codna/agent-core/vendor/cline/sdk/packages/llms/package.json +73 -0
  503. codna/agent-core/vendor/cline/sdk/packages/llms/scripts/fix-esm-imports.ts +109 -0
  504. codna/agent-core/vendor/cline/sdk/packages/llms/scripts/generate-models.ts +136 -0
  505. codna/agent-core/vendor/cline/sdk/packages/llms/scripts/models/generate-models-dev.ts +24 -0
  506. codna/agent-core/vendor/cline/sdk/packages/llms/scripts/tsconfig.json +14 -0
  507. codna/agent-core/vendor/cline/sdk/packages/llms/src/catalog/README.md +165 -0
  508. codna/agent-core/vendor/cline/sdk/packages/llms/src/catalog/catalog-live.test.ts +275 -0
  509. codna/agent-core/vendor/cline/sdk/packages/llms/src/catalog/catalog-live.ts +186 -0
  510. codna/agent-core/vendor/cline/sdk/packages/llms/src/catalog/catalog.generated-access.ts +41 -0
  511. codna/agent-core/vendor/cline/sdk/packages/llms/src/catalog/catalog.generated.ts +22756 -0
  512. codna/agent-core/vendor/cline/sdk/packages/llms/src/catalog/types.ts +97 -0
  513. codna/agent-core/vendor/cline/sdk/packages/llms/src/index.browser.ts +33 -0
  514. codna/agent-core/vendor/cline/sdk/packages/llms/src/index.ts +74 -0
  515. codna/agent-core/vendor/cline/sdk/packages/llms/src/models.ts +31 -0
  516. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/ai-sdk.test.ts +371 -0
  517. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/ai-sdk.ts +1012 -0
  518. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/async.ts +7 -0
  519. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/billing.test.ts +28 -0
  520. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/billing.ts +23 -0
  521. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/builtins-runtime.ts +101 -0
  522. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/builtins.test.ts +137 -0
  523. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/builtins.ts +1084 -0
  524. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/compat.test.ts +562 -0
  525. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/compat.ts +669 -0
  526. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/config.ts +429 -0
  527. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/factory-registry.ts +161 -0
  528. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/format.test.ts +43 -0
  529. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/format.ts +70 -0
  530. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/gateway.test.ts +3575 -0
  531. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/gateway.ts +310 -0
  532. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/handler.ts +91 -0
  533. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/http.ts +121 -0
  534. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/ids.test.ts +143 -0
  535. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/ids.ts +95 -0
  536. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/messages.ts +17 -0
  537. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/middleware/split-tool-images.test.ts +504 -0
  538. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/middleware/split-tool-images.ts +293 -0
  539. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/model-facts.ts +270 -0
  540. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/model-registry.ts +122 -0
  541. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/openai-codex-models.ts +35 -0
  542. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/provider-keys.ts +153 -0
  543. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/registry.ts +279 -0
  544. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/anthropic-compatible.test.ts +503 -0
  545. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/anthropic-compatible.ts +602 -0
  546. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/generic-compatible.ts +151 -0
  547. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/glm-thinking.ts +106 -0
  548. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/minimax-thinking.ts +78 -0
  549. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/provider-option-rules.ts +546 -0
  550. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/provider-options-types.ts +92 -0
  551. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/provider-options.test.ts +1872 -0
  552. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/provider-options.ts +119 -0
  553. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/reasoning-codecs.ts +40 -0
  554. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/utils.ts +47 -0
  555. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/stream.ts +117 -0
  556. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/types.ts +77 -0
  557. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/anthropic.test.ts +90 -0
  558. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/anthropic.ts +39 -0
  559. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/bedrock.test.ts +201 -0
  560. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/bedrock.ts +171 -0
  561. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/community.test.ts +55 -0
  562. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/community.ts +207 -0
  563. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/google.ts +61 -0
  564. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/minimax-thinking.test.ts +69 -0
  565. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/minimax-thinking.ts +104 -0
  566. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/mistral.ts +31 -0
  567. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/openai-compatible.ts +49 -0
  568. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/openai.ts +24 -0
  569. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/types.ts +141 -0
  570. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/vertex.test.ts +125 -0
  571. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/vertex.ts +56 -0
  572. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers.browser.ts +5 -0
  573. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers.ts +106 -0
  574. codna/agent-core/vendor/cline/sdk/packages/llms/src/services/langfuse-telemetry.test.ts +90 -0
  575. codna/agent-core/vendor/cline/sdk/packages/llms/src/services/langfuse-telemetry.ts +187 -0
  576. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/live-providers.example.json +254 -0
  577. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/live-providers.openai-codex.example.json +19 -0
  578. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/live-providers.openai-codex.reasoning.example.json +22 -0
  579. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/live-providers.reasoning-disabled.example.json +423 -0
  580. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/live-providers.reasoning.example.json +349 -0
  581. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/live-providers.tools.example.json +199 -0
  582. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-live-config.test.ts +98 -0
  583. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-live-config.ts +193 -0
  584. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-live-minimax-routing.test.ts +264 -0
  585. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-live-reasoning.test.ts +290 -0
  586. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-live-runner.ts +47 -0
  587. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-live-tools.test.ts +265 -0
  588. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-live.test.ts +350 -0
  589. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-vcr/README.md +31 -0
  590. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-vcr/anthropic-claude-sonnet-4-6.json +12 -0
  591. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-vcr/cline-anthropic-sonnet.json +12 -0
  592. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-vcr/openai-codex-gpt-5-4.json +11 -0
  593. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-vcr/openai-compatible-deepseek-v4-pro.json +12 -0
  594. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-vcr.test.ts +450 -0
  595. codna/agent-core/vendor/cline/sdk/packages/llms/tsconfig.build.json +19 -0
  596. codna/agent-core/vendor/cline/sdk/packages/llms/tsconfig.dev.json +12 -0
  597. codna/agent-core/vendor/cline/sdk/packages/llms/tsconfig.json +11 -0
  598. codna/agent-core/vendor/cline/sdk/packages/llms/vitest.config.ts +24 -0
  599. codna/agent-core/vendor/cline/sdk/packages/sdk/bun.mts +18 -0
  600. codna/agent-core/vendor/cline/sdk/packages/sdk/package.json +37 -0
  601. codna/agent-core/vendor/cline/sdk/packages/sdk/src/index.ts +1 -0
  602. codna/agent-core/vendor/cline/sdk/packages/sdk/tsconfig.build.json +12 -0
  603. codna/agent-core/vendor/cline/sdk/packages/sdk/tsconfig.json +11 -0
  604. codna/agent-core/vendor/cline/sdk/packages/shared/README.md +47 -0
  605. codna/agent-core/vendor/cline/sdk/packages/shared/bun.mts +70 -0
  606. codna/agent-core/vendor/cline/sdk/packages/shared/package.json +63 -0
  607. codna/agent-core/vendor/cline/sdk/packages/shared/src/agent.ts +561 -0
  608. codna/agent-core/vendor/cline/sdk/packages/shared/src/agents/index.ts +1 -0
  609. codna/agent-core/vendor/cline/sdk/packages/shared/src/agents/types.ts +1055 -0
  610. codna/agent-core/vendor/cline/sdk/packages/shared/src/automation/index.ts +31 -0
  611. codna/agent-core/vendor/cline/sdk/packages/shared/src/automation/schemas.ts +99 -0
  612. codna/agent-core/vendor/cline/sdk/packages/shared/src/automation/types.ts +187 -0
  613. codna/agent-core/vendor/cline/sdk/packages/shared/src/connectors/events.ts +73 -0
  614. codna/agent-core/vendor/cline/sdk/packages/shared/src/connectors/options.ts +190 -0
  615. codna/agent-core/vendor/cline/sdk/packages/shared/src/cron/cron-spec-types.ts +104 -0
  616. codna/agent-core/vendor/cline/sdk/packages/shared/src/cron/index.ts +13 -0
  617. codna/agent-core/vendor/cline/sdk/packages/shared/src/db/index.ts +14 -0
  618. codna/agent-core/vendor/cline/sdk/packages/shared/src/db/sqlite-db.test.ts +155 -0
  619. codna/agent-core/vendor/cline/sdk/packages/shared/src/db/sqlite-db.ts +381 -0
  620. codna/agent-core/vendor/cline/sdk/packages/shared/src/dispose.ts +31 -0
  621. codna/agent-core/vendor/cline/sdk/packages/shared/src/extensions/context.ts +92 -0
  622. codna/agent-core/vendor/cline/sdk/packages/shared/src/extensions/contribution-registry.test.ts +156 -0
  623. codna/agent-core/vendor/cline/sdk/packages/shared/src/extensions/contribution-registry.ts +524 -0
  624. codna/agent-core/vendor/cline/sdk/packages/shared/src/extensions/plugin.ts +1 -0
  625. codna/agent-core/vendor/cline/sdk/packages/shared/src/hooks/contracts.ts +9 -0
  626. codna/agent-core/vendor/cline/sdk/packages/shared/src/hooks/events.ts +327 -0
  627. codna/agent-core/vendor/cline/sdk/packages/shared/src/hub.ts +723 -0
  628. codna/agent-core/vendor/cline/sdk/packages/shared/src/index.browser.ts +355 -0
  629. codna/agent-core/vendor/cline/sdk/packages/shared/src/index.ts +405 -0
  630. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/ai-sdk-format.test.ts +898 -0
  631. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/ai-sdk-format.ts +389 -0
  632. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/gateway.ts +202 -0
  633. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/messages.ts +168 -0
  634. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/model-info.ts +94 -0
  635. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/reasoning-effort.ts +73 -0
  636. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/requests.ts +12 -0
  637. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/tokens.ts +12 -0
  638. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/tools.ts +96 -0
  639. codna/agent-core/vendor/cline/sdk/packages/shared/src/logging/logger.ts +45 -0
  640. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/error.ts +18 -0
  641. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/headers/utils.ts +28 -0
  642. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/json.test.ts +14 -0
  643. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/json.ts +86 -0
  644. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/shell.test.ts +46 -0
  645. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/shell.ts +32 -0
  646. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/string.ts +29 -0
  647. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/time.ts +39 -0
  648. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/zod.ts +23 -0
  649. codna/agent-core/vendor/cline/sdk/packages/shared/src/prompt/cline.ts +117 -0
  650. codna/agent-core/vendor/cline/sdk/packages/shared/src/prompt/format.test.ts +39 -0
  651. codna/agent-core/vendor/cline/sdk/packages/shared/src/prompt/format.ts +99 -0
  652. codna/agent-core/vendor/cline/sdk/packages/shared/src/prompt/system.ts +64 -0
  653. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/artifact-store.ts +70 -0
  654. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/blob-storage.ts +416 -0
  655. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/bundle.ts +181 -0
  656. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/constants.ts +5 -0
  657. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/index.ts +9 -0
  658. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/materializer.ts +165 -0
  659. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/paths.ts +33 -0
  660. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/runtime.test.ts +102 -0
  661. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/runtime.ts +236 -0
  662. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/schema.test.ts +977 -0
  663. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/schema.ts +262 -0
  664. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/telemetry.ts +124 -0
  665. codna/agent-core/vendor/cline/sdk/packages/shared/src/rpc/index.ts +5 -0
  666. codna/agent-core/vendor/cline/sdk/packages/shared/src/rpc/runtime.ts +429 -0
  667. codna/agent-core/vendor/cline/sdk/packages/shared/src/rpc/team-progress.ts +71 -0
  668. codna/agent-core/vendor/cline/sdk/packages/shared/src/runtime/build-env.test.ts +115 -0
  669. codna/agent-core/vendor/cline/sdk/packages/shared/src/runtime/build-env.ts +183 -0
  670. codna/agent-core/vendor/cline/sdk/packages/shared/src/runtime/cline-environment.test.ts +106 -0
  671. codna/agent-core/vendor/cline/sdk/packages/shared/src/runtime/cline-environment.ts +88 -0
  672. codna/agent-core/vendor/cline/sdk/packages/shared/src/runtime/hub-daemon-env.test.ts +20 -0
  673. codna/agent-core/vendor/cline/sdk/packages/shared/src/runtime/hub-daemon-env.ts +7 -0
  674. codna/agent-core/vendor/cline/sdk/packages/shared/src/services/telemetry-config.ts +58 -0
  675. codna/agent-core/vendor/cline/sdk/packages/shared/src/services/telemetry.test.ts +66 -0
  676. codna/agent-core/vendor/cline/sdk/packages/shared/src/services/telemetry.ts +295 -0
  677. codna/agent-core/vendor/cline/sdk/packages/shared/src/session/hook-context.ts +45 -0
  678. codna/agent-core/vendor/cline/sdk/packages/shared/src/session/index.ts +6 -0
  679. codna/agent-core/vendor/cline/sdk/packages/shared/src/session/records.ts +41 -0
  680. codna/agent-core/vendor/cline/sdk/packages/shared/src/session/runtime-config.ts +69 -0
  681. codna/agent-core/vendor/cline/sdk/packages/shared/src/session/runtime-env.ts +8 -0
  682. codna/agent-core/vendor/cline/sdk/packages/shared/src/session/workspace.ts +45 -0
  683. codna/agent-core/vendor/cline/sdk/packages/shared/src/storage/index.ts +47 -0
  684. codna/agent-core/vendor/cline/sdk/packages/shared/src/storage/path-resolution.test.ts +63 -0
  685. codna/agent-core/vendor/cline/sdk/packages/shared/src/storage/path-resolution.ts +114 -0
  686. codna/agent-core/vendor/cline/sdk/packages/shared/src/storage/paths.home-dir.test.ts +61 -0
  687. codna/agent-core/vendor/cline/sdk/packages/shared/src/storage/paths.test.ts +180 -0
  688. codna/agent-core/vendor/cline/sdk/packages/shared/src/storage/paths.ts +588 -0
  689. codna/agent-core/vendor/cline/sdk/packages/shared/src/team/index.ts +2 -0
  690. codna/agent-core/vendor/cline/sdk/packages/shared/src/team/schema.ts +452 -0
  691. codna/agent-core/vendor/cline/sdk/packages/shared/src/team/types.ts +235 -0
  692. codna/agent-core/vendor/cline/sdk/packages/shared/src/tools/create.test.ts +201 -0
  693. codna/agent-core/vendor/cline/sdk/packages/shared/src/tools/create.ts +130 -0
  694. codna/agent-core/vendor/cline/sdk/packages/shared/src/types/auth.ts +41 -0
  695. codna/agent-core/vendor/cline/sdk/packages/shared/src/types/index.ts +2 -0
  696. codna/agent-core/vendor/cline/sdk/packages/shared/src/types/vcr.ts +14 -0
  697. codna/agent-core/vendor/cline/sdk/packages/shared/src/vcr.test.ts +229 -0
  698. codna/agent-core/vendor/cline/sdk/packages/shared/src/vcr.ts +900 -0
  699. codna/agent-core/vendor/cline/sdk/packages/shared/tsconfig.build.json +7 -0
  700. codna/agent-core/vendor/cline/sdk/packages/shared/tsconfig.json +9 -0
  701. codna/agent-core/vendor/cline/sdk/packages/shared/vitest.config.ts +9 -0
  702. codna/agent-core/vendor/cline/sdk/packages/tsconfig.base.json +22 -0
  703. codna/agent-core/vendor/cline/sdk/scripts/check-publish.ts +351 -0
  704. codna/agent-core/vendor/cline/sdk/scripts/ci-node-smoke.ts +155 -0
  705. codna/agent-core/vendor/cline/sdk/scripts/clean.ts +91 -0
  706. codna/agent-core/vendor/cline/sdk/scripts/release.ts +548 -0
  707. codna/agent-core/vendor/cline/sdk/scripts/run-vendored-tests.sh +44 -0
  708. codna/agent-core/vendor/cline/sdk/scripts/version.ts +120 -0
  709. codna/agent-core/vendor/cline/sdk/tsconfig.json +53 -0
  710. codna/agent_core_runtime.py +816 -0
  711. codna/cli.py +921 -0
  712. codna/cli_errors.py +50 -0
  713. codna/cline_agent.py +90 -0
  714. codna/codeunits.py +221 -0
  715. codna/codeunits_treesitter.py +148 -0
  716. codna/doctor.py +212 -0
  717. codna/doctor_output.py +61 -0
  718. codna/engine.py +149 -0
  719. codna/evasion.py +192 -0
  720. codna/evidence.py +163 -0
  721. codna/findings.py +272 -0
  722. codna/gate.py +132 -0
  723. codna/gitpush.py +57 -0
  724. codna/local_client.py +932 -0
  725. codna/local_mojo_daemon.py +568 -0
  726. codna/local_mojo_pool.py +861 -0
  727. codna/local_repository_shims.py +419 -0
  728. codna/local_runtime.py +650 -0
  729. codna/localfix.py +121 -0
  730. codna/manifest.py +164 -0
  731. codna/mcp_server.py +155 -0
  732. codna/memory.py +885 -0
  733. codna/netjail.py +68 -0
  734. codna/packaged_agent_runner.py +354 -0
  735. codna/packaged_git.py +378 -0
  736. codna/packaged_repository_advanced.py +618 -0
  737. codna/packaged_repository_backend.py +887 -0
  738. codna/patchgen.py +115 -0
  739. codna/policy.py +85 -0
  740. codna/refengine.py +132 -0
  741. codna/repo_backend.py +78 -0
  742. codna/repository_artifacts.py +291 -0
  743. codna/runtime/__init__.py +17 -0
  744. codna/runtime/config.py +394 -0
  745. codna/runtime/health.py +130 -0
  746. codna/runtime/local_stack.py +978 -0
  747. codna/runtime/ports.py +137 -0
  748. codna/runtime/processes.py +199 -0
  749. codna/runtime_config.py +94 -0
  750. codna/sandbox.py +111 -0
  751. codna/sarif.py +610 -0
  752. codna/secure.py +250 -0
  753. codna/supervisor.py +108 -0
  754. codna/worker.py +161 -0
  755. codna/worktree.py +73 -0
  756. codna/writer.py +169 -0
  757. codna-0.1.0.dist-info/METADATA +153 -0
  758. codna-0.1.0.dist-info/RECORD +761 -0
  759. codna-0.1.0.dist-info/WHEEL +5 -0
  760. codna-0.1.0.dist-info/entry_points.txt +2 -0
  761. codna-0.1.0.dist-info/top_level.txt +1 -0
@@ -0,0 +1,1900 @@
1
+ /**
2
+ * Unit tests for the new `SessionRuntime` orchestrator (PLAN.md
3
+ * Step 8d).
4
+ *
5
+ * Scope:
6
+ * - constructor wires every state owner (conversation store, mistake
7
+ * tracker, loop detector, hook bridge, event adapter) correctly;
8
+ * - `run()` drives the injected `AgentRuntime` and fans adapted
9
+ * legacy `AgentEvent`s to subscribers;
10
+ * - `abort()` forwards into the active runtime;
11
+ * - `subscribeEvents` delivers **legacy** `AgentEvent` shapes;
12
+ * - `addTools` / `updateConnection` / `clearHistory` / `restore`
13
+ * mutate state;
14
+ * - `canStartRun` / `shutdown` guards enforce the lifecycle rules.
15
+ */
16
+
17
+ import type { AgentRuntime, AgentRuntimeConfig } from "@cline/agents";
18
+ import type {
19
+ AgentConfig,
20
+ AgentEvent,
21
+ AgentExtension,
22
+ AgentExtensionContext,
23
+ AgentMessage,
24
+ AgentRunResult,
25
+ AgentRuntimeEvent,
26
+ AgentTool,
27
+ AgentToolContext,
28
+ } from "@cline/shared";
29
+ import { describe, expect, it, vi } from "vitest";
30
+ import { CLINE_INTERNAL_TELEMETRY_METADATA_KEY } from "../../services/telemetry/tool-context";
31
+ import {
32
+ SessionRuntime,
33
+ type SessionRuntimeOrchestratorDeps,
34
+ } from "./session-runtime-orchestrator";
35
+
36
+ // ---------------------------------------------------------------------------
37
+ // Fixtures
38
+ // ---------------------------------------------------------------------------
39
+
40
+ function makeAgentConfig(overrides: Partial<AgentConfig> = {}): AgentConfig {
41
+ return {
42
+ providerId: "anthropic",
43
+ modelId: "claude-3-5-sonnet",
44
+ apiKey: "test-key",
45
+ systemPrompt: "You are a helpful assistant.",
46
+ tools: [],
47
+ ...overrides,
48
+ };
49
+ }
50
+
51
+ interface FakeAgentRuntimeScript {
52
+ /** Events to emit synchronously when `run`/`continue` is called. */
53
+ readonly events?: readonly AgentRuntimeEvent[];
54
+ /** Result returned by `run`/`continue`. Defaults to a completed run. */
55
+ readonly result?: Partial<AgentRunResult>;
56
+ /** If true, reject with the provided error instead of returning. */
57
+ readonly throwError?: Error;
58
+ }
59
+
60
+ /**
61
+ * Build a lightweight fake `AgentRuntime` that records calls and
62
+ * deterministically emits the scripted events/result.
63
+ */
64
+ function makeFakeAgentRuntime(script: FakeAgentRuntimeScript = {}): {
65
+ runtime: AgentRuntime;
66
+ calls: { run: unknown[]; continue: unknown[]; abort: unknown[] };
67
+ listeners: Set<(event: AgentRuntimeEvent) => void>;
68
+ } {
69
+ const listeners = new Set<(event: AgentRuntimeEvent) => void>();
70
+ const calls = {
71
+ run: [] as unknown[],
72
+ continue: [] as unknown[],
73
+ abort: [] as unknown[],
74
+ };
75
+
76
+ const baseResult: AgentRunResult = {
77
+ agentId: "agent_fake",
78
+ runId: "run_fake",
79
+ status: "completed",
80
+ iterations: 1,
81
+ outputText: "ok",
82
+ messages: [],
83
+ usage: {
84
+ inputTokens: 10,
85
+ outputTokens: 5,
86
+ cacheReadTokens: 0,
87
+ cacheWriteTokens: 0,
88
+ totalCost: 0,
89
+ },
90
+ ...script.result,
91
+ };
92
+
93
+ const emit = (): void => {
94
+ for (const event of script.events ?? []) {
95
+ for (const listener of listeners) {
96
+ listener(event);
97
+ }
98
+ }
99
+ };
100
+
101
+ const runtime = {
102
+ async run(input: unknown) {
103
+ calls.run.push(input);
104
+ emit();
105
+ if (script.throwError) {
106
+ throw script.throwError;
107
+ }
108
+ return baseResult;
109
+ },
110
+ async continue(input: unknown) {
111
+ calls.continue.push(input);
112
+ emit();
113
+ if (script.throwError) {
114
+ throw script.throwError;
115
+ }
116
+ return baseResult;
117
+ },
118
+ abort(reason?: string) {
119
+ calls.abort.push(reason);
120
+ },
121
+ subscribe(listener: (event: AgentRuntimeEvent) => void) {
122
+ listeners.add(listener);
123
+ return () => {
124
+ listeners.delete(listener);
125
+ };
126
+ },
127
+ snapshot() {
128
+ return {
129
+ agentId: "agent_fake",
130
+ runId: "run_fake",
131
+ status: "running" as const,
132
+ iteration: 0,
133
+ messages: [] as readonly AgentMessage[],
134
+ pendingToolCalls: [] as readonly string[],
135
+ usage: {
136
+ inputTokens: 0,
137
+ outputTokens: 0,
138
+ cacheReadTokens: 0,
139
+ cacheWriteTokens: 0,
140
+ totalCost: 0,
141
+ },
142
+ };
143
+ },
144
+ } as unknown as AgentRuntime;
145
+
146
+ return { runtime, calls, listeners };
147
+ }
148
+
149
+ function makeSnapshot() {
150
+ return {
151
+ agentId: "agent_fake",
152
+ runId: "run_fake",
153
+ status: "running" as const,
154
+ iteration: 0,
155
+ messages: [] as readonly AgentMessage[],
156
+ pendingToolCalls: [] as readonly string[],
157
+ usage: {
158
+ inputTokens: 0,
159
+ outputTokens: 0,
160
+ cacheReadTokens: 0,
161
+ cacheWriteTokens: 0,
162
+ totalCost: 0,
163
+ },
164
+ };
165
+ }
166
+
167
+ function makeAgentMessage(
168
+ id: string,
169
+ role: AgentMessage["role"],
170
+ text: string,
171
+ ): AgentMessage {
172
+ return {
173
+ id,
174
+ role,
175
+ content: [{ type: "text", text }],
176
+ createdAt: Date.now(),
177
+ };
178
+ }
179
+
180
+ /** Convenience to stitch a fake runtime into SessionRuntime deps. */
181
+ function withFakeRuntime(script: FakeAgentRuntimeScript = {}): {
182
+ deps: SessionRuntimeOrchestratorDeps;
183
+ calls: ReturnType<typeof makeFakeAgentRuntime>["calls"];
184
+ listeners: ReturnType<typeof makeFakeAgentRuntime>["listeners"];
185
+ } {
186
+ const { runtime, calls, listeners } = makeFakeAgentRuntime(script);
187
+ return {
188
+ deps: { createAgentRuntimeImpl: () => runtime },
189
+ calls,
190
+ listeners,
191
+ };
192
+ }
193
+
194
+ function withCapturingFakeRuntime(script: FakeAgentRuntimeScript = {}): {
195
+ deps: SessionRuntimeOrchestratorDeps;
196
+ configs: Parameters<
197
+ NonNullable<SessionRuntimeOrchestratorDeps["createAgentRuntimeImpl"]>
198
+ >[0][];
199
+ } {
200
+ const configs: AgentRuntimeConfig[] = [];
201
+ return {
202
+ deps: {
203
+ createAgentRuntimeImpl: (config) => {
204
+ configs.push(config);
205
+ return makeFakeAgentRuntime(script).runtime;
206
+ },
207
+ },
208
+ configs,
209
+ };
210
+ }
211
+
212
+ // ---------------------------------------------------------------------------
213
+ // Construction
214
+ // ---------------------------------------------------------------------------
215
+
216
+ describe("SessionRuntime construction", () => {
217
+ it("wires agentId, conversationId, and canStartRun", () => {
218
+ const session = new SessionRuntime(makeAgentConfig());
219
+ expect(session.getAgentId()).toMatch(/^agent_/);
220
+ expect(session.getConversationId()).toMatch(/^conv_/);
221
+ expect(session.canStartRun()).toBe(true);
222
+ expect(session.getMessages()).toEqual([]);
223
+ });
224
+
225
+ it("seeds initial messages through ConversationStore", () => {
226
+ const session = new SessionRuntime(
227
+ makeAgentConfig({
228
+ initialMessages: [
229
+ { role: "user", content: [{ type: "text", text: "hi" }] },
230
+ ],
231
+ }),
232
+ );
233
+ expect(session.getMessages()).toHaveLength(1);
234
+ });
235
+
236
+ it("exposes an empty extension registry snapshot when no extensions are declared", () => {
237
+ const session = new SessionRuntime(makeAgentConfig());
238
+ const registry = session.getExtensionRegistry();
239
+ expect(registry).toEqual({
240
+ tools: [],
241
+ commands: [],
242
+ rules: [],
243
+ messageBuilder: [],
244
+ providers: [],
245
+ automationEventTypes: [],
246
+ });
247
+ });
248
+ });
249
+
250
+ // ---------------------------------------------------------------------------
251
+ // getExtensionRegistry — real contribution-registry snapshot
252
+ // ---------------------------------------------------------------------------
253
+
254
+ describe("SessionRuntime.getExtensionRegistry", () => {
255
+ it("returns tools/commands registered by extension setup() after the first run", async () => {
256
+ const extTool: AgentTool = {
257
+ name: "ext-echo",
258
+ description: "extension tool",
259
+ inputSchema: {},
260
+ execute: async () => ({}),
261
+ };
262
+ const extCommand = {
263
+ name: "ext-cmd",
264
+ description: "extension command",
265
+ execute: async () => ({}),
266
+ };
267
+ const extension = {
268
+ name: "test-ext",
269
+ manifest: { capabilities: ["tools", "commands"] },
270
+ setup: (api: {
271
+ registerTool: (t: AgentTool) => void;
272
+ registerCommand: (c: typeof extCommand) => void;
273
+ }) => {
274
+ api.registerTool(extTool);
275
+ api.registerCommand(extCommand);
276
+ },
277
+ };
278
+ const { deps } = withFakeRuntime();
279
+ const session = new SessionRuntime(
280
+ makeAgentConfig({
281
+ // @ts-expect-error — AgentExtension interface validates at runtime;
282
+ // this fixture supplies only the fields ContributionRegistry needs.
283
+ extensions: [extension],
284
+ }),
285
+ deps,
286
+ );
287
+ // Before run: registry is validated but not initialized yet.
288
+ expect(session.getExtensionRegistry().tools).toEqual([]);
289
+
290
+ await session.run("go");
291
+
292
+ const registry = session.getExtensionRegistry();
293
+ expect(registry.tools).toHaveLength(1);
294
+ expect(registry.tools[0].name).toBe("ext-echo");
295
+ expect(registry.commands).toHaveLength(1);
296
+ expect(registry.commands[0].name).toBe("ext-cmd");
297
+ expect(registry.automationEventTypes).toEqual([]);
298
+ });
299
+
300
+ it("composes extension-registered rules into the runtime system prompt", async () => {
301
+ const extension: AgentExtension = {
302
+ name: "rules-ext",
303
+ manifest: { capabilities: ["rules"] },
304
+ setup: (api) => {
305
+ api.registerRule({
306
+ id: "rules-ext:primary",
307
+ content: "Always preserve architectural boundaries.",
308
+ });
309
+ },
310
+ };
311
+ const { deps, configs } = withCapturingFakeRuntime();
312
+ const session = new SessionRuntime(
313
+ makeAgentConfig({
314
+ systemPrompt: "Base prompt.",
315
+ extensions: [extension],
316
+ }),
317
+ deps,
318
+ );
319
+
320
+ await session.run("go");
321
+
322
+ expect(configs[0]?.systemPrompt).toBe(
323
+ "Base prompt.\n\nAlways preserve architectural boundaries.",
324
+ );
325
+ });
326
+
327
+ it("passes session, caller, and logger context into extension setup()", async () => {
328
+ const logger = {
329
+ debug: vi.fn(),
330
+ log: vi.fn(),
331
+ error: vi.fn(),
332
+ };
333
+ const telemetry = {
334
+ capture: vi.fn(),
335
+ } as unknown as AgentConfig["telemetry"];
336
+ const ingestEvent = vi.fn();
337
+ let observed: AgentExtensionContext | undefined;
338
+ const extension: AgentExtension = {
339
+ name: "context-ext",
340
+ manifest: { capabilities: ["tools", "automationEvents"] },
341
+ setup: (_api, ctx) => {
342
+ observed = ctx;
343
+ ctx.logger?.log("plugin setup", {
344
+ sessionId: ctx.session?.sessionId,
345
+ });
346
+ },
347
+ };
348
+ const { deps } = withFakeRuntime();
349
+ const session = new SessionRuntime(
350
+ makeAgentConfig({
351
+ extensions: [extension],
352
+ extensionContext: {
353
+ session: { sessionId: "sess_plugin_context" },
354
+ client: { name: "cline-sdk", version: "1.2.3" },
355
+ user: { distinctId: "user-1" },
356
+ workspace: { rootPath: "/tmp/workspace" },
357
+ automation: { ingestEvent },
358
+ logger,
359
+ telemetry,
360
+ },
361
+ }),
362
+ deps,
363
+ );
364
+
365
+ await session.run("go");
366
+
367
+ expect(observed?.session?.sessionId).toBe("sess_plugin_context");
368
+ expect(observed?.client).toEqual({
369
+ name: "cline-sdk",
370
+ version: "1.2.3",
371
+ });
372
+ expect(observed?.user?.distinctId).toBe("user-1");
373
+ expect(observed?.workspaceInfo?.rootPath).toBe("/tmp/workspace");
374
+ expect(observed?.automation?.ingestEvent).toBe(ingestEvent);
375
+ expect(observed?.telemetry).toBe(telemetry);
376
+ expect(logger.log).toHaveBeenCalledWith("plugin setup", {
377
+ sessionId: "sess_plugin_context",
378
+ });
379
+ });
380
+
381
+ it("passes effective telemetry into AgentRuntime config", async () => {
382
+ const telemetry = {
383
+ capture: vi.fn(),
384
+ } as unknown as AgentConfig["telemetry"];
385
+ const { deps, configs } = withCapturingFakeRuntime();
386
+ const session = new SessionRuntime(makeAgentConfig({ telemetry }), deps);
387
+
388
+ await session.run("go");
389
+
390
+ expect(configs[0]?.telemetry).toBe(telemetry);
391
+ });
392
+
393
+ it("passes dependency telemetry into AgentRuntime config", async () => {
394
+ const telemetry = {
395
+ capture: vi.fn(),
396
+ } as unknown as AgentConfig["telemetry"];
397
+ const { deps, configs } = withCapturingFakeRuntime();
398
+ const session = new SessionRuntime(makeAgentConfig(), {
399
+ ...deps,
400
+ telemetry,
401
+ });
402
+
403
+ await session.run("go");
404
+
405
+ expect(configs[0]?.telemetry).toBe(telemetry);
406
+ });
407
+
408
+ it("merges extension-registered tools into the AgentRuntime tools for the turn", async () => {
409
+ const extTool: AgentTool = {
410
+ name: "ext-tool-a",
411
+ description: "ext tool a",
412
+ inputSchema: {},
413
+ execute: async () => ({}),
414
+ };
415
+ const configTool: AgentTool = {
416
+ name: "config-tool-b",
417
+ description: "config tool b",
418
+ inputSchema: {},
419
+ execute: async () => ({}),
420
+ };
421
+ const extension = {
422
+ name: "tool-ext",
423
+ manifest: { capabilities: ["tools"] },
424
+ setup: (api: { registerTool: (t: AgentTool) => void }) => {
425
+ api.registerTool(extTool);
426
+ },
427
+ };
428
+
429
+ let observedTools: ReadonlyArray<{ readonly name: string }> = [];
430
+ const { runtime } = makeFakeAgentRuntime();
431
+ const session = new SessionRuntime(
432
+ makeAgentConfig({
433
+ tools: [configTool],
434
+ // @ts-expect-error — minimal fixture, see note above.
435
+ extensions: [extension],
436
+ }),
437
+ {
438
+ createAgentRuntimeImpl: (config) => {
439
+ observedTools = (config.tools ?? []) as ReadonlyArray<{
440
+ readonly name: string;
441
+ }>;
442
+ return runtime;
443
+ },
444
+ },
445
+ );
446
+ await session.run("go");
447
+ const toolNames = observedTools.map((t) => t.name).sort();
448
+ expect(toolNames).toEqual(["config-tool-b", "ext-tool-a"]);
449
+ });
450
+ });
451
+
452
+ describe("SessionRuntime message preparation", () => {
453
+ it("runs registered message builders and API-safe normalization before model calls", async () => {
454
+ const build = vi.fn(async (messages) => [
455
+ ...messages,
456
+ {
457
+ role: "user" as const,
458
+ content: [
459
+ {
460
+ type: "text" as const,
461
+ text: "<user_input>builder-added</user_input>",
462
+ },
463
+ ],
464
+ },
465
+ ]);
466
+ const extension: AgentExtension = {
467
+ name: "message-builder-ext",
468
+ manifest: { capabilities: ["messageBuilders"] },
469
+ setup(api) {
470
+ api.registerMessageBuilder({
471
+ name: "append-builder-message",
472
+ build,
473
+ });
474
+ },
475
+ };
476
+ const { deps, configs } = makeRecordingRuntimeFactory();
477
+ const session = new SessionRuntime(
478
+ makeAgentConfig({ extensions: [extension] }),
479
+ deps,
480
+ );
481
+
482
+ await session.run("go");
483
+ const beforeModel = configs[0]?.hooks?.beforeModel;
484
+ expect(beforeModel).toBeDefined();
485
+
486
+ const result = await beforeModel?.({
487
+ snapshot: makeSnapshot(),
488
+ request: {
489
+ systemPrompt: "system",
490
+ messages: [
491
+ {
492
+ id: "m1",
493
+ role: "user",
494
+ content: [
495
+ {
496
+ type: "text",
497
+ text: "<user_input>original</user_input>",
498
+ },
499
+ ],
500
+ createdAt: 1,
501
+ },
502
+ ],
503
+ tools: [],
504
+ },
505
+ });
506
+
507
+ expect(build).toHaveBeenCalledTimes(1);
508
+ expect(build.mock.calls[0]?.[0]).toEqual([
509
+ {
510
+ role: "user",
511
+ content: [
512
+ {
513
+ type: "text",
514
+ text: "<user_input>original</user_input>",
515
+ },
516
+ ],
517
+ },
518
+ ]);
519
+ const textParts = result?.messages?.flatMap((message) =>
520
+ message.content.flatMap((part) =>
521
+ part.type === "text" ? [part.text] : [],
522
+ ),
523
+ );
524
+ expect(textParts).toEqual(["original", "builder-added"]);
525
+ });
526
+
527
+ it("adapts prepareTurn with API-safe messages for runtime compaction", async () => {
528
+ const prepareTurn = vi.fn(() => ({
529
+ messages: [
530
+ {
531
+ role: "user" as const,
532
+ content: "compacted transcript",
533
+ },
534
+ ],
535
+ }));
536
+ const { deps, configs } = makeRecordingRuntimeFactory();
537
+ const session = new SessionRuntime(
538
+ makeAgentConfig({
539
+ prepareTurn,
540
+ knownModels: {
541
+ "claude-3-5-sonnet": {
542
+ id: "claude-3-5-sonnet",
543
+ maxInputTokens: 200_000,
544
+ },
545
+ },
546
+ }),
547
+ deps,
548
+ );
549
+
550
+ await session.run("go");
551
+ const runtimePrepareTurn = configs[0]?.prepareTurn;
552
+ expect(runtimePrepareTurn).toBeDefined();
553
+
554
+ const result = await runtimePrepareTurn?.({
555
+ agentId: "agent-1",
556
+ conversationId: "conv-1",
557
+ parentAgentId: null,
558
+ iteration: 1,
559
+ messages: [
560
+ {
561
+ id: "m1",
562
+ role: "user",
563
+ content: [
564
+ {
565
+ type: "text",
566
+ text: "<user_input>large context</user_input>",
567
+ },
568
+ ],
569
+ createdAt: 1,
570
+ },
571
+ ],
572
+ systemPrompt: "system",
573
+ tools: [],
574
+ model: {},
575
+ });
576
+
577
+ expect(prepareTurn).toHaveBeenCalledWith(
578
+ expect.objectContaining({
579
+ agentId: "agent-1",
580
+ conversationId: "conv-1",
581
+ parentAgentId: null,
582
+ iteration: 1,
583
+ messages: [
584
+ expect.objectContaining({
585
+ id: "m1",
586
+ role: "user",
587
+ content: [
588
+ {
589
+ type: "text",
590
+ text: "<user_input>large context</user_input>",
591
+ },
592
+ ],
593
+ ts: 1,
594
+ }),
595
+ ],
596
+ apiMessages: [
597
+ expect.objectContaining({
598
+ id: "m1",
599
+ role: "user",
600
+ content: [{ type: "text", text: "large context" }],
601
+ ts: 1,
602
+ }),
603
+ ],
604
+ model: {
605
+ id: "claude-3-5-sonnet",
606
+ provider: "anthropic",
607
+ info: {
608
+ id: "claude-3-5-sonnet",
609
+ maxInputTokens: 200_000,
610
+ },
611
+ },
612
+ }),
613
+ );
614
+ expect(result?.messages).toHaveLength(1);
615
+ expect(result?.messages?.[0]?.content).toEqual([
616
+ { type: "text", text: "compacted transcript" },
617
+ ]);
618
+ expect(Object.hasOwn(result ?? {}, "systemPrompt")).toBe(false);
619
+ });
620
+
621
+ it("allows prepareTurn to return only a system prompt", async () => {
622
+ const prepareTurn = vi.fn(() => ({
623
+ systemPrompt: "rewritten system prompt",
624
+ }));
625
+ const { deps, configs } = makeRecordingRuntimeFactory();
626
+ const session = new SessionRuntime(makeAgentConfig({ prepareTurn }), deps);
627
+
628
+ await session.run("go");
629
+ const runtimePrepareTurn = configs[0]?.prepareTurn;
630
+ expect(runtimePrepareTurn).toBeDefined();
631
+
632
+ const result = await runtimePrepareTurn?.({
633
+ agentId: "agent-1",
634
+ conversationId: "conv-1",
635
+ parentAgentId: null,
636
+ iteration: 1,
637
+ messages: [
638
+ {
639
+ id: "m1",
640
+ role: "user",
641
+ content: [{ type: "text", text: "keep me" }],
642
+ createdAt: 1,
643
+ },
644
+ ],
645
+ systemPrompt: "system",
646
+ tools: [],
647
+ model: {},
648
+ });
649
+
650
+ expect(result).toEqual({
651
+ systemPrompt: "rewritten system prompt",
652
+ });
653
+ });
654
+ });
655
+
656
+ // ---------------------------------------------------------------------------
657
+ // run() / continue()
658
+ // ---------------------------------------------------------------------------
659
+
660
+ it("derives tool image support metadata from resolved provider model catalog", async () => {
661
+ const { deps, configs } = withCapturingFakeRuntime();
662
+ const execute = vi.fn(async () => "ok");
663
+ const telemetry = {
664
+ capture: vi.fn(),
665
+ captureRequired: vi.fn(),
666
+ } as unknown as AgentConfig["telemetry"];
667
+ const session = new SessionRuntime(
668
+ makeAgentConfig({
669
+ providerId: "cline",
670
+ modelId: "anthropic/claude-sonnet-4.6",
671
+ telemetry,
672
+ tools: [
673
+ {
674
+ name: "read_file",
675
+ description: "read a file",
676
+ inputSchema: {},
677
+ execute,
678
+ },
679
+ ],
680
+ }),
681
+ deps,
682
+ );
683
+
684
+ await session.run("inspect image");
685
+
686
+ expect(configs).toHaveLength(1);
687
+ const runtimeConfig = configs[0];
688
+ if (!runtimeConfig) {
689
+ throw new Error("Expected runtime config");
690
+ }
691
+ const tool = runtimeConfig.tools?.[0];
692
+ expect(tool?.execute).toBeDefined();
693
+ if (!tool?.execute) {
694
+ throw new Error("Expected adapted tool execute function");
695
+ }
696
+ const toolContext: AgentToolContext = {
697
+ agentId: "agent-1",
698
+ runId: "run-1",
699
+ iteration: 0,
700
+ toolCallId: "call-1",
701
+ snapshot: {
702
+ agentId: "agent-1",
703
+ status: "running",
704
+ iteration: 0,
705
+ messages: [],
706
+ pendingToolCalls: [],
707
+ usage: {
708
+ inputTokens: 0,
709
+ outputTokens: 0,
710
+ cacheReadTokens: 0,
711
+ cacheWriteTokens: 0,
712
+ },
713
+ },
714
+ emitUpdate: () => {},
715
+ };
716
+ const result = await tool.execute({}, toolContext);
717
+ expect(result).toBe("ok");
718
+ expect(execute).toHaveBeenCalledTimes(1);
719
+ expect(execute.mock.calls[0]).toEqual([expect.anything(), toolContext]);
720
+ expect(runtimeConfig.toolContextMetadata).toEqual(
721
+ expect.objectContaining({
722
+ modelSupportsImages: true,
723
+ [CLINE_INTERNAL_TELEMETRY_METADATA_KEY]: telemetry,
724
+ }),
725
+ );
726
+ expect(runtimeConfig.toolContextMetadata?.telemetry).toBeUndefined();
727
+ });
728
+
729
+ describe("SessionRuntime.run", () => {
730
+ it("invokes the injected AgentRuntime and returns an AgentResult", async () => {
731
+ const { deps, calls } = withFakeRuntime({
732
+ result: { outputText: "hello world", iterations: 2 },
733
+ });
734
+ const session = new SessionRuntime(makeAgentConfig(), deps);
735
+ const result = await session.run("Say hi");
736
+ expect(calls.run).toHaveLength(1);
737
+ expect(result.text).toBe("hello world");
738
+ expect(result.iterations).toBe(2);
739
+ expect(result.finishReason).toBe("completed");
740
+ expect(result.model.provider).toBe("anthropic");
741
+ expect(result.model.id).toBe("claude-3-5-sonnet");
742
+ expect(result.startedAt).toBeInstanceOf(Date);
743
+ expect(result.endedAt).toBeInstanceOf(Date);
744
+ expect(typeof result.durationMs).toBe("number");
745
+ });
746
+
747
+ it("appends the user turn into the conversation store", async () => {
748
+ const { deps } = withFakeRuntime();
749
+ const session = new SessionRuntime(makeAgentConfig(), deps);
750
+ await session.run("question one");
751
+ // After run.resetForRun() + append, the conversation should
752
+ // contain at least the user message we appended.
753
+ const messages = session.getMessages();
754
+ const userMessage = messages.find((m) => m.role === "user");
755
+ expect(userMessage).toBeDefined();
756
+ });
757
+
758
+ it("fans legacy events to subscribers (not new AgentRuntimeEvent shape)", async () => {
759
+ const { deps } = withFakeRuntime({
760
+ events: [
761
+ {
762
+ type: "turn-started",
763
+ iteration: 1,
764
+ snapshot: makeSnapshot(),
765
+ },
766
+ ],
767
+ });
768
+ const session = new SessionRuntime(makeAgentConfig(), deps);
769
+ const received: AgentEvent[] = [];
770
+ session.subscribeEvents((event) => received.push(event));
771
+ await session.run("go");
772
+
773
+ // Legacy shape: iteration_start, not turn-started.
774
+ const iterationStart = received.find((e) => e.type === "iteration_start");
775
+ expect(iterationStart).toBeDefined();
776
+ expect(
777
+ received.some((e) => (e as { type: string }).type === "turn-started"),
778
+ ).toBe(false);
779
+ });
780
+
781
+ it("maps run-failed errors into AgentResult via thrown error", async () => {
782
+ const { deps } = withFakeRuntime({ throwError: new Error("boom") });
783
+ const session = new SessionRuntime(makeAgentConfig(), deps);
784
+ await expect(session.run("go")).rejects.toThrow("boom");
785
+ });
786
+
787
+ it("rejects re-entrant run while the previous run is still active", async () => {
788
+ let release: (() => void) | undefined;
789
+ const gate = new Promise<void>((resolve) => {
790
+ release = resolve;
791
+ });
792
+ const slowRuntime = {
793
+ async run() {
794
+ await gate;
795
+ return {
796
+ agentId: "agent_fake",
797
+ runId: "run_fake",
798
+ status: "completed" as const,
799
+ iterations: 1,
800
+ outputText: "",
801
+ messages: [] as readonly AgentMessage[],
802
+ usage: {
803
+ inputTokens: 0,
804
+ outputTokens: 0,
805
+ cacheReadTokens: 0,
806
+ cacheWriteTokens: 0,
807
+ totalCost: 0,
808
+ },
809
+ };
810
+ },
811
+ async continue() {
812
+ await gate;
813
+ return {
814
+ agentId: "agent_fake",
815
+ runId: "run_fake",
816
+ status: "completed" as const,
817
+ iterations: 1,
818
+ outputText: "",
819
+ messages: [] as readonly AgentMessage[],
820
+ usage: {
821
+ inputTokens: 0,
822
+ outputTokens: 0,
823
+ cacheReadTokens: 0,
824
+ cacheWriteTokens: 0,
825
+ totalCost: 0,
826
+ },
827
+ };
828
+ },
829
+ abort() {},
830
+ subscribe() {
831
+ return () => {};
832
+ },
833
+ snapshot() {
834
+ return {
835
+ agentId: "a",
836
+ status: "running" as const,
837
+ iteration: 0,
838
+ messages: [],
839
+ pendingToolCalls: [],
840
+ usage: {
841
+ inputTokens: 0,
842
+ outputTokens: 0,
843
+ cacheReadTokens: 0,
844
+ cacheWriteTokens: 0,
845
+ totalCost: 0,
846
+ },
847
+ };
848
+ },
849
+ } as unknown as AgentRuntime;
850
+
851
+ const session = new SessionRuntime(makeAgentConfig(), {
852
+ createAgentRuntimeImpl: () => slowRuntime,
853
+ });
854
+ const first = session.run("one");
855
+ await Promise.resolve();
856
+ expect(session.canStartRun()).toBe(false);
857
+ await expect(session.continue("two")).rejects.toThrow(/"running"/i);
858
+ release?.();
859
+ await first;
860
+ expect(session.canStartRun()).toBe(true);
861
+ });
862
+ });
863
+
864
+ describe("SessionRuntime.continue", () => {
865
+ it("delegates to AgentRuntime.continue", async () => {
866
+ const { deps, calls } = withFakeRuntime();
867
+ const session = new SessionRuntime(makeAgentConfig(), deps);
868
+ await session.continue("more");
869
+ expect(calls.continue).toHaveLength(1);
870
+ expect(calls.run).toHaveLength(0);
871
+ });
872
+ });
873
+
874
+ // ---------------------------------------------------------------------------
875
+ // abort
876
+ // ---------------------------------------------------------------------------
877
+
878
+ describe("SessionRuntime.abort", () => {
879
+ it("forwards the reason into the active AgentRuntime", async () => {
880
+ let release: (() => void) | undefined;
881
+ const gate = new Promise<void>((resolve) => {
882
+ release = resolve;
883
+ });
884
+ const abortCalls: unknown[] = [];
885
+ const runtime = {
886
+ async run() {
887
+ await gate;
888
+ return {
889
+ agentId: "agent_fake",
890
+ runId: "run_fake",
891
+ status: "aborted" as const,
892
+ iterations: 0,
893
+ outputText: "",
894
+ messages: [] as readonly AgentMessage[],
895
+ usage: {
896
+ inputTokens: 0,
897
+ outputTokens: 0,
898
+ cacheReadTokens: 0,
899
+ cacheWriteTokens: 0,
900
+ totalCost: 0,
901
+ },
902
+ };
903
+ },
904
+ async continue() {
905
+ await gate;
906
+ return {
907
+ agentId: "agent_fake",
908
+ runId: "run_fake",
909
+ status: "aborted" as const,
910
+ iterations: 0,
911
+ outputText: "",
912
+ messages: [] as readonly AgentMessage[],
913
+ usage: {
914
+ inputTokens: 0,
915
+ outputTokens: 0,
916
+ cacheReadTokens: 0,
917
+ cacheWriteTokens: 0,
918
+ totalCost: 0,
919
+ },
920
+ };
921
+ },
922
+ abort(reason?: unknown) {
923
+ abortCalls.push(reason);
924
+ release?.();
925
+ },
926
+ subscribe() {
927
+ return () => {};
928
+ },
929
+ snapshot() {
930
+ return makeSnapshot();
931
+ },
932
+ } as unknown as AgentRuntime;
933
+
934
+ const session = new SessionRuntime(makeAgentConfig(), {
935
+ createAgentRuntimeImpl: () => runtime,
936
+ });
937
+ const runPromise = session.run("slow");
938
+ // Wait for the session to install the active runtime. The
939
+ // `buildUserTurnContent` dynamic-import + handler/tool setup
940
+ // yield a handful of microtasks before `runtime.run()` is
941
+ // awaited. Poll until `abort()` produces a call record.
942
+ for (let i = 0; i < 50 && abortCalls.length === 0; i++) {
943
+ session.abort("user cancelled");
944
+ if (abortCalls.length === 0) {
945
+ await new Promise((resolve) => setTimeout(resolve, 5));
946
+ }
947
+ }
948
+ const result = await runPromise;
949
+ expect(abortCalls).toEqual(["user cancelled"]);
950
+ expect(result.finishReason).toBe("aborted");
951
+ });
952
+
953
+ it("does not swallow the caller-visible rejection when abort rejects the run", async () => {
954
+ let rejectRun: ((error: Error) => void) | undefined;
955
+ const runGate = new Promise<AgentRunResult>((_resolve, reject) => {
956
+ rejectRun = reject;
957
+ });
958
+ let markRunStarted: (() => void) | undefined;
959
+ const runStarted = new Promise<void>((resolve) => {
960
+ markRunStarted = resolve;
961
+ });
962
+ const abortCalls: unknown[] = [];
963
+ const runtime = {
964
+ async run() {
965
+ markRunStarted?.();
966
+ return await runGate;
967
+ },
968
+ async continue() {
969
+ markRunStarted?.();
970
+ return await runGate;
971
+ },
972
+ abort(reason?: unknown) {
973
+ abortCalls.push(reason);
974
+ rejectRun?.(new Error(String(reason ?? "aborted")));
975
+ },
976
+ subscribe() {
977
+ return () => {};
978
+ },
979
+ snapshot() {
980
+ return makeSnapshot();
981
+ },
982
+ } as unknown as AgentRuntime;
983
+
984
+ const session = new SessionRuntime(makeAgentConfig(), {
985
+ createAgentRuntimeImpl: () => runtime,
986
+ });
987
+ const runPromise = session.run("slow");
988
+ await runStarted;
989
+ session.abort("user cancelled");
990
+
991
+ await expect(runPromise).rejects.toThrow("user cancelled");
992
+ expect(abortCalls).toEqual(["user cancelled"]);
993
+ });
994
+
995
+ it("observes an abort rejection before the caller awaits the run", async () => {
996
+ let rejectRun: ((error: Error) => void) | undefined;
997
+ const runGate = new Promise<AgentRunResult>((_resolve, reject) => {
998
+ rejectRun = reject;
999
+ });
1000
+ let markRunStarted: (() => void) | undefined;
1001
+ const runStarted = new Promise<void>((resolve) => {
1002
+ markRunStarted = resolve;
1003
+ });
1004
+ const abortCalls: unknown[] = [];
1005
+ const runtime = {
1006
+ async run() {
1007
+ markRunStarted?.();
1008
+ return await runGate;
1009
+ },
1010
+ async continue() {
1011
+ markRunStarted?.();
1012
+ return await runGate;
1013
+ },
1014
+ abort(reason?: unknown) {
1015
+ abortCalls.push(reason);
1016
+ rejectRun?.(new Error(String(reason ?? "aborted")));
1017
+ },
1018
+ subscribe() {
1019
+ return () => {};
1020
+ },
1021
+ snapshot() {
1022
+ return makeSnapshot();
1023
+ },
1024
+ } as unknown as AgentRuntime;
1025
+ const unhandledReasons: unknown[] = [];
1026
+ const onUnhandledRejection = (reason: unknown): void => {
1027
+ unhandledReasons.push(reason);
1028
+ };
1029
+
1030
+ process.prependListener("unhandledRejection", onUnhandledRejection);
1031
+ try {
1032
+ const session = new SessionRuntime(makeAgentConfig(), {
1033
+ createAgentRuntimeImpl: () => runtime,
1034
+ });
1035
+ const runPromise = session.run("slow");
1036
+ await runStarted;
1037
+ session.abort("user cancelled");
1038
+ await new Promise((resolve) => setTimeout(resolve, 0));
1039
+
1040
+ expect(unhandledReasons).toEqual([]);
1041
+ await expect(runPromise).rejects.toThrow("user cancelled");
1042
+ expect(abortCalls).toEqual(["user cancelled"]);
1043
+ } finally {
1044
+ process.off("unhandledRejection", onUnhandledRejection);
1045
+ }
1046
+ });
1047
+
1048
+ it("is a no-op when no run is active", () => {
1049
+ const { deps } = withFakeRuntime();
1050
+ const session = new SessionRuntime(makeAgentConfig(), deps);
1051
+ expect(() => session.abort()).not.toThrow();
1052
+ });
1053
+ });
1054
+
1055
+ // ---------------------------------------------------------------------------
1056
+ // state mutators
1057
+ // ---------------------------------------------------------------------------
1058
+
1059
+ describe("SessionRuntime.addTools / updateConnection / clearHistory / restore", () => {
1060
+ const echoTool: AgentTool = {
1061
+ name: "echo",
1062
+ description: "e",
1063
+ inputSchema: {},
1064
+ execute: async () => ({}),
1065
+ };
1066
+
1067
+ it("addTools is a no-op when the list is empty", () => {
1068
+ const session = new SessionRuntime(makeAgentConfig({ tools: [echoTool] }));
1069
+ session.addTools([]);
1070
+ expect(session.canStartRun()).toBe(true);
1071
+ });
1072
+
1073
+ it("addTools merges new tools and skips duplicates by name", () => {
1074
+ const session = new SessionRuntime(makeAgentConfig({ tools: [echoTool] }));
1075
+ session.addTools([echoTool, { ...echoTool, name: "other" }]);
1076
+ expect(session.canStartRun()).toBe(true);
1077
+ });
1078
+
1079
+ it("updateConnection mutates provider/model/api fields for next run", async () => {
1080
+ const { deps, calls } = withFakeRuntime();
1081
+ const session = new SessionRuntime(makeAgentConfig(), deps);
1082
+ session.updateConnection({ modelId: "claude-4", apiKey: "new-key" });
1083
+ const result = await session.run("go");
1084
+ expect(result.model.id).toBe("claude-4");
1085
+ expect(calls.run).toHaveLength(1);
1086
+ });
1087
+
1088
+ it("clearHistory resets the conversation store", () => {
1089
+ const session = new SessionRuntime(
1090
+ makeAgentConfig({
1091
+ initialMessages: [
1092
+ { role: "user", content: [{ type: "text", text: "hi" }] },
1093
+ ],
1094
+ }),
1095
+ );
1096
+ expect(session.getMessages()).toHaveLength(1);
1097
+ session.clearHistory();
1098
+ expect(session.getMessages()).toEqual([]);
1099
+ });
1100
+
1101
+ it("restore replaces the conversation store with provided messages", () => {
1102
+ const session = new SessionRuntime(makeAgentConfig());
1103
+ session.restore([
1104
+ { role: "user", content: [{ type: "text", text: "first" }] },
1105
+ { role: "assistant", content: [{ type: "text", text: "second" }] },
1106
+ ]);
1107
+ const messages = session.getMessages();
1108
+ expect(messages).toHaveLength(2);
1109
+ expect(messages[0].role).toBe("user");
1110
+ expect(messages[1].role).toBe("assistant");
1111
+ });
1112
+ });
1113
+
1114
+ // ---------------------------------------------------------------------------
1115
+ // shutdown
1116
+ // ---------------------------------------------------------------------------
1117
+
1118
+ describe("SessionRuntime.shutdown", () => {
1119
+ it("completes successfully when no run is active and locks out future runs", async () => {
1120
+ const session = new SessionRuntime(makeAgentConfig());
1121
+ await expect(session.shutdown()).resolves.toBeUndefined();
1122
+ expect(session.canStartRun()).toBe(false);
1123
+ });
1124
+
1125
+ it("is idempotent across repeat calls", async () => {
1126
+ const session = new SessionRuntime(makeAgentConfig());
1127
+ await session.shutdown();
1128
+ await expect(session.shutdown()).resolves.toBeUndefined();
1129
+ });
1130
+
1131
+ it("waits for an aborted in-flight run before shutting down", async () => {
1132
+ let releaseRun: (() => void) | undefined;
1133
+ let markRunEntered: (() => void) | undefined;
1134
+ const runEntered = new Promise<void>((resolve) => {
1135
+ markRunEntered = resolve;
1136
+ });
1137
+ const abortCalls: unknown[] = [];
1138
+ const runtime = {
1139
+ async run() {
1140
+ await new Promise<void>((resolve) => {
1141
+ releaseRun = resolve;
1142
+ markRunEntered?.();
1143
+ });
1144
+ return {
1145
+ agentId: "agent_fake",
1146
+ runId: "run_fake",
1147
+ status: "aborted" as const,
1148
+ iterations: 1,
1149
+ outputText: "",
1150
+ messages: [],
1151
+ usage: {
1152
+ inputTokens: 0,
1153
+ outputTokens: 0,
1154
+ cacheReadTokens: 0,
1155
+ cacheWriteTokens: 0,
1156
+ totalCost: 0,
1157
+ },
1158
+ };
1159
+ },
1160
+ async continue() {
1161
+ throw new Error("not used");
1162
+ },
1163
+ abort(reason?: unknown) {
1164
+ abortCalls.push(reason);
1165
+ releaseRun?.();
1166
+ },
1167
+ subscribe() {
1168
+ return () => {};
1169
+ },
1170
+ snapshot() {
1171
+ return makeSnapshot();
1172
+ },
1173
+ } as unknown as AgentRuntime;
1174
+
1175
+ const session = new SessionRuntime(makeAgentConfig(), {
1176
+ createAgentRuntimeImpl: () => runtime,
1177
+ });
1178
+
1179
+ const runPromise = session.run("slow");
1180
+ await runEntered;
1181
+ session.abort("session_stop");
1182
+ expect(abortCalls).toEqual(["session_stop"]);
1183
+ await expect(session.shutdown("session_stop")).resolves.toBeUndefined();
1184
+ await expect(runPromise).resolves.toMatchObject({
1185
+ finishReason: "aborted",
1186
+ });
1187
+ expect(session.canStartRun()).toBe(false);
1188
+ });
1189
+ });
1190
+
1191
+ // ---------------------------------------------------------------------------
1192
+ // subscribeEvents lifecycle
1193
+ // ---------------------------------------------------------------------------
1194
+
1195
+ describe("SessionRuntime.subscribeEvents", () => {
1196
+ it("makes assistant messages visible to getMessages as soon as the runtime emits them", async () => {
1197
+ const userMessage = makeAgentMessage("msg_user", "user", "go");
1198
+ const assistantMessage = makeAgentMessage(
1199
+ "msg_assistant",
1200
+ "assistant",
1201
+ "saved before run end",
1202
+ );
1203
+ const snapshot = {
1204
+ ...makeSnapshot(),
1205
+ messages: [userMessage, assistantMessage],
1206
+ };
1207
+ const { deps } = withFakeRuntime({
1208
+ events: [
1209
+ {
1210
+ type: "message-added",
1211
+ snapshot,
1212
+ message: assistantMessage,
1213
+ },
1214
+ {
1215
+ type: "assistant-message",
1216
+ snapshot,
1217
+ iteration: 1,
1218
+ message: assistantMessage,
1219
+ finishReason: "stop",
1220
+ },
1221
+ ],
1222
+ });
1223
+ const session = new SessionRuntime(makeAgentConfig(), deps);
1224
+
1225
+ await session.run("go");
1226
+
1227
+ expect(session.getMessages()).toMatchObject([
1228
+ { role: "user", content: [{ type: "text", text: "go" }] },
1229
+ {
1230
+ role: "assistant",
1231
+ content: [{ type: "text", text: "saved before run end" }],
1232
+ },
1233
+ ]);
1234
+ });
1235
+
1236
+ it("appends fallback event messages instead of replacing history when the runtime snapshot is empty", async () => {
1237
+ const assistantMessage = makeAgentMessage(
1238
+ "msg_assistant",
1239
+ "assistant",
1240
+ "new answer",
1241
+ );
1242
+ const { deps } = withFakeRuntime({
1243
+ events: [
1244
+ {
1245
+ type: "assistant-message",
1246
+ snapshot: makeSnapshot(),
1247
+ iteration: 1,
1248
+ message: assistantMessage,
1249
+ finishReason: "stop",
1250
+ },
1251
+ ],
1252
+ });
1253
+ const session = new SessionRuntime(
1254
+ makeAgentConfig({
1255
+ initialMessages: [
1256
+ {
1257
+ role: "user",
1258
+ content: [{ type: "text", text: "prior question" }],
1259
+ },
1260
+ {
1261
+ role: "assistant",
1262
+ content: [{ type: "text", text: "prior answer" }],
1263
+ },
1264
+ ],
1265
+ }),
1266
+ deps,
1267
+ );
1268
+
1269
+ await session.continue("next question");
1270
+
1271
+ expect(session.getMessages()).toMatchObject([
1272
+ {
1273
+ role: "user",
1274
+ content: [{ type: "text", text: "prior question" }],
1275
+ },
1276
+ {
1277
+ role: "assistant",
1278
+ content: [{ type: "text", text: "prior answer" }],
1279
+ },
1280
+ {
1281
+ role: "user",
1282
+ content: "next question",
1283
+ },
1284
+ {
1285
+ role: "assistant",
1286
+ content: [{ type: "text", text: "new answer" }],
1287
+ },
1288
+ ]);
1289
+ });
1290
+
1291
+ it("unsubscribes cleanly", async () => {
1292
+ const { deps } = withFakeRuntime({
1293
+ events: [
1294
+ {
1295
+ type: "turn-finished",
1296
+ iteration: 1,
1297
+ toolCallCount: 0,
1298
+ snapshot: makeSnapshot(),
1299
+ },
1300
+ ],
1301
+ });
1302
+ const session = new SessionRuntime(makeAgentConfig(), deps);
1303
+ const received: AgentEvent[] = [];
1304
+ const unsubscribe = session.subscribeEvents((event) =>
1305
+ received.push(event),
1306
+ );
1307
+ unsubscribe();
1308
+ await session.run("go");
1309
+ expect(received).toHaveLength(0);
1310
+ });
1311
+
1312
+ it("swallows listener errors without breaking fanout", async () => {
1313
+ const { deps } = withFakeRuntime({
1314
+ events: [
1315
+ {
1316
+ type: "turn-finished",
1317
+ iteration: 1,
1318
+ toolCallCount: 0,
1319
+ snapshot: makeSnapshot(),
1320
+ },
1321
+ ],
1322
+ });
1323
+ const session = new SessionRuntime(makeAgentConfig(), {
1324
+ ...deps,
1325
+ logger: {
1326
+ debug: vi.fn(),
1327
+ log: vi.fn(),
1328
+ error: vi.fn(),
1329
+ },
1330
+ });
1331
+ const good = vi.fn();
1332
+ session.subscribeEvents(() => {
1333
+ throw new Error("listener boom");
1334
+ });
1335
+ session.subscribeEvents(good);
1336
+ await session.run("go");
1337
+ expect(good).toHaveBeenCalled();
1338
+ });
1339
+ });
1340
+
1341
+ // ===========================================================================
1342
+ // P1 defect regression suites (#1, #2, #3) — added by impl-session-fixer.
1343
+ // ===========================================================================
1344
+
1345
+ /**
1346
+ * Build a runtime-factory that records the `AgentRuntimeConfig` it
1347
+ * receives on every call and returns an `AgentRunResult` produced by
1348
+ * the caller-supplied `producer`. Used to assert seeding / hook wiring.
1349
+ */
1350
+ function makeRecordingRuntimeFactory(
1351
+ producer: (
1352
+ call: number,
1353
+ ) => Pick<AgentRunResult, "messages" | "outputText"> | undefined = () =>
1354
+ undefined,
1355
+ ): {
1356
+ deps: SessionRuntimeOrchestratorDeps;
1357
+ configs: Array<
1358
+ Parameters<
1359
+ NonNullable<SessionRuntimeOrchestratorDeps["createAgentRuntimeImpl"]>
1360
+ >[0]
1361
+ >;
1362
+ } {
1363
+ const configs: Array<
1364
+ Parameters<
1365
+ NonNullable<SessionRuntimeOrchestratorDeps["createAgentRuntimeImpl"]>
1366
+ >[0]
1367
+ > = [];
1368
+ const deps: SessionRuntimeOrchestratorDeps = {
1369
+ createAgentRuntimeImpl: (config) => {
1370
+ configs.push(config);
1371
+ const callIndex = configs.length;
1372
+ const produced = producer(callIndex);
1373
+ const baseResult: AgentRunResult = {
1374
+ agentId: "agent_fake",
1375
+ runId: `run_fake_${callIndex}`,
1376
+ status: "completed",
1377
+ iterations: 1,
1378
+ outputText: produced?.outputText ?? "",
1379
+ messages: produced?.messages ?? [],
1380
+ usage: {
1381
+ inputTokens: 0,
1382
+ outputTokens: 0,
1383
+ cacheReadTokens: 0,
1384
+ cacheWriteTokens: 0,
1385
+ totalCost: 0,
1386
+ },
1387
+ };
1388
+ return {
1389
+ async run() {
1390
+ return baseResult;
1391
+ },
1392
+ async continue() {
1393
+ return baseResult;
1394
+ },
1395
+ abort() {},
1396
+ subscribe() {
1397
+ return () => {};
1398
+ },
1399
+ snapshot: makeSnapshot,
1400
+ } as unknown as AgentRuntime;
1401
+ },
1402
+ };
1403
+ return { deps, configs };
1404
+ }
1405
+
1406
+ // ---------------------------------------------------------------------------
1407
+ // [#1] initialMessages seeding (P1 defect #1)
1408
+ // ---------------------------------------------------------------------------
1409
+
1410
+ describe("SessionRuntime.run — initialMessages seeding (P1 #1)", () => {
1411
+ it("seeds prior transcript into every subsequent run's runtime config", async () => {
1412
+ const { deps, configs } = makeRecordingRuntimeFactory((call) => {
1413
+ if (call === 1) {
1414
+ return {
1415
+ outputText: "hi back",
1416
+ messages: [
1417
+ {
1418
+ id: "m1",
1419
+ role: "user",
1420
+ content: [{ type: "text", text: "hello" }],
1421
+ createdAt: 1,
1422
+ },
1423
+ {
1424
+ id: "m2",
1425
+ role: "assistant",
1426
+ content: [{ type: "text", text: "hi back" }],
1427
+ createdAt: 2,
1428
+ },
1429
+ ],
1430
+ };
1431
+ }
1432
+ return undefined;
1433
+ });
1434
+ const session = new SessionRuntime(makeAgentConfig(), deps);
1435
+ await session.run("hello");
1436
+ await session.continue("again");
1437
+ expect(configs).toHaveLength(2);
1438
+ // Turn 1 seeds: just the current-turn user message.
1439
+ const firstSeed = configs[0].initialMessages ?? [];
1440
+ expect(firstSeed.length).toBe(1);
1441
+ expect(firstSeed[0].role).toBe("user");
1442
+ // Turn 2 seeds: turn-1 user + assistant + turn-2 user.
1443
+ const secondSeed = configs[1].initialMessages ?? [];
1444
+ expect(secondSeed.length).toBeGreaterThanOrEqual(3);
1445
+ expect(secondSeed.some((m) => m.role === "assistant")).toBe(true);
1446
+ });
1447
+
1448
+ it("preserves multi-turn transcript in getMessages() across run + continue", async () => {
1449
+ const { deps } = makeRecordingRuntimeFactory((call) => {
1450
+ if (call === 1) {
1451
+ return {
1452
+ outputText: "one",
1453
+ messages: [
1454
+ {
1455
+ id: "u1",
1456
+ role: "user",
1457
+ content: [{ type: "text", text: "q1" }],
1458
+ createdAt: 1,
1459
+ },
1460
+ {
1461
+ id: "a1",
1462
+ role: "assistant",
1463
+ content: [{ type: "text", text: "one" }],
1464
+ createdAt: 2,
1465
+ },
1466
+ ],
1467
+ };
1468
+ }
1469
+ return {
1470
+ outputText: "two",
1471
+ messages: [
1472
+ {
1473
+ id: "u1",
1474
+ role: "user",
1475
+ content: [{ type: "text", text: "q1" }],
1476
+ createdAt: 1,
1477
+ },
1478
+ {
1479
+ id: "a1",
1480
+ role: "assistant",
1481
+ content: [{ type: "text", text: "one" }],
1482
+ createdAt: 2,
1483
+ },
1484
+ {
1485
+ id: "u2",
1486
+ role: "user",
1487
+ content: [{ type: "text", text: "q2" }],
1488
+ createdAt: 3,
1489
+ },
1490
+ {
1491
+ id: "a2",
1492
+ role: "assistant",
1493
+ content: [{ type: "text", text: "two" }],
1494
+ createdAt: 4,
1495
+ },
1496
+ ],
1497
+ };
1498
+ });
1499
+ const session = new SessionRuntime(makeAgentConfig(), deps);
1500
+ await session.run("q1");
1501
+ await session.continue("q2");
1502
+ const messages = session.getMessages();
1503
+ expect(messages).toHaveLength(4);
1504
+ expect(messages.map((m) => m.role)).toEqual([
1505
+ "user",
1506
+ "assistant",
1507
+ "user",
1508
+ "assistant",
1509
+ ]);
1510
+ });
1511
+
1512
+ it("seeds runtime with messages provided via restore()", async () => {
1513
+ const { deps, configs } = makeRecordingRuntimeFactory();
1514
+ const session = new SessionRuntime(makeAgentConfig(), deps);
1515
+ session.restore([
1516
+ { role: "user", content: [{ type: "text", text: "prior-user" }] },
1517
+ {
1518
+ role: "assistant",
1519
+ content: [{ type: "text", text: "prior-assistant" }],
1520
+ },
1521
+ ]);
1522
+ await session.continue("followup");
1523
+ expect(configs).toHaveLength(1);
1524
+ const seed = configs[0].initialMessages ?? [];
1525
+ expect(seed.length).toBeGreaterThanOrEqual(3);
1526
+ expect(seed.some((m) => m.role === "assistant")).toBe(true);
1527
+ });
1528
+ });
1529
+
1530
+ // ---------------------------------------------------------------------------
1531
+ // [#3] MistakeTracker + LoopDetectionTracker wiring (P1 defect #3)
1532
+ // ---------------------------------------------------------------------------
1533
+
1534
+ /**
1535
+ * Build a manual AgentRuntime stub that exposes listener fan-out so
1536
+ * tests can drive the tracker pipeline by emitting scripted
1537
+ * `AgentRuntimeEvent`s synchronously from `run()`/`continue()`.
1538
+ */
1539
+ function makeScriptedRuntime(script: {
1540
+ events: readonly AgentRuntimeEvent[];
1541
+ }): {
1542
+ deps: SessionRuntimeOrchestratorDeps;
1543
+ abortCalls: string[];
1544
+ } {
1545
+ const abortCalls: string[] = [];
1546
+ const baseResult: AgentRunResult = {
1547
+ agentId: "agent_fake",
1548
+ runId: "run_fake",
1549
+ status: "completed",
1550
+ iterations: 1,
1551
+ outputText: "",
1552
+ messages: [],
1553
+ usage: {
1554
+ inputTokens: 0,
1555
+ outputTokens: 0,
1556
+ cacheReadTokens: 0,
1557
+ cacheWriteTokens: 0,
1558
+ totalCost: 0,
1559
+ },
1560
+ };
1561
+ let listener: ((e: AgentRuntimeEvent) => void) | undefined;
1562
+ const runtime = {
1563
+ async run() {
1564
+ for (const e of script.events) listener?.(e);
1565
+ return baseResult;
1566
+ },
1567
+ async continue() {
1568
+ for (const e of script.events) listener?.(e);
1569
+ return baseResult;
1570
+ },
1571
+ abort(reason?: string) {
1572
+ abortCalls.push(reason ?? "");
1573
+ },
1574
+ subscribe(l: (e: AgentRuntimeEvent) => void) {
1575
+ listener = l;
1576
+ return () => {
1577
+ listener = undefined;
1578
+ };
1579
+ },
1580
+ snapshot: makeSnapshot,
1581
+ } as unknown as AgentRuntime;
1582
+ return {
1583
+ deps: { createAgentRuntimeImpl: () => runtime },
1584
+ abortCalls,
1585
+ };
1586
+ }
1587
+
1588
+ function failedToolTurnEvents(): AgentRuntimeEvent[] {
1589
+ return [
1590
+ { type: "turn-started", iteration: 1, snapshot: makeSnapshot() },
1591
+ {
1592
+ type: "tool-started",
1593
+ iteration: 1,
1594
+ toolCall: {
1595
+ type: "tool-call",
1596
+ toolCallId: "tc",
1597
+ toolName: "t",
1598
+ input: { n: 1 },
1599
+ },
1600
+ snapshot: makeSnapshot(),
1601
+ },
1602
+ {
1603
+ type: "tool-finished",
1604
+ iteration: 1,
1605
+ toolCall: {
1606
+ type: "tool-call",
1607
+ toolCallId: "tc",
1608
+ toolName: "t",
1609
+ input: { n: 1 },
1610
+ },
1611
+ message: {
1612
+ id: "m",
1613
+ role: "tool",
1614
+ content: [
1615
+ {
1616
+ type: "tool-result",
1617
+ toolCallId: "tc",
1618
+ toolName: "t",
1619
+ output: "fail",
1620
+ isError: true,
1621
+ },
1622
+ ],
1623
+ createdAt: 1,
1624
+ },
1625
+ snapshot: makeSnapshot(),
1626
+ },
1627
+ {
1628
+ type: "turn-finished",
1629
+ iteration: 1,
1630
+ toolCallCount: 1,
1631
+ snapshot: makeSnapshot(),
1632
+ },
1633
+ ];
1634
+ }
1635
+
1636
+ function failedStructuredToolTurnEvents(): AgentRuntimeEvent[] {
1637
+ return [
1638
+ { type: "turn-started", iteration: 1, snapshot: makeSnapshot() },
1639
+ {
1640
+ type: "tool-started",
1641
+ iteration: 1,
1642
+ toolCall: {
1643
+ type: "tool-call",
1644
+ toolCallId: "tc_structured",
1645
+ toolName: "exec",
1646
+ input: { cmd: "pwd" },
1647
+ },
1648
+ snapshot: makeSnapshot(),
1649
+ },
1650
+ {
1651
+ type: "tool-finished",
1652
+ iteration: 1,
1653
+ toolCall: {
1654
+ type: "tool-call",
1655
+ toolCallId: "tc_structured",
1656
+ toolName: "exec",
1657
+ input: { cmd: "pwd" },
1658
+ },
1659
+ message: {
1660
+ id: "m_structured",
1661
+ role: "tool",
1662
+ content: [
1663
+ {
1664
+ type: "tool-result",
1665
+ toolCallId: "tc_structured",
1666
+ toolName: "exec",
1667
+ output: {
1668
+ message: "sandbox denied",
1669
+ code: "EPERM",
1670
+ },
1671
+ isError: true,
1672
+ },
1673
+ ],
1674
+ createdAt: 1,
1675
+ },
1676
+ snapshot: makeSnapshot(),
1677
+ },
1678
+ {
1679
+ type: "turn-finished",
1680
+ iteration: 1,
1681
+ toolCallCount: 1,
1682
+ snapshot: makeSnapshot(),
1683
+ },
1684
+ ];
1685
+ }
1686
+
1687
+ describe("SessionRuntime.run — tracker wiring (P1 #3)", () => {
1688
+ it("aborts after maxConsecutiveMistakes failed-tool turns", async () => {
1689
+ const { deps, abortCalls } = makeScriptedRuntime({
1690
+ events: failedToolTurnEvents(),
1691
+ });
1692
+ const session = new SessionRuntime(
1693
+ makeAgentConfig({ execution: { maxConsecutiveMistakes: 2 } }),
1694
+ deps,
1695
+ );
1696
+ await session.run("one");
1697
+ // First failed turn — counter 1 < 2, no abort yet.
1698
+ expect(abortCalls).toHaveLength(0);
1699
+ await session.continue("two");
1700
+ // Second failed turn — counter reaches 2, tracker calls abort.
1701
+ expect(abortCalls.length).toBeGreaterThanOrEqual(1);
1702
+ });
1703
+
1704
+ it("serializes structured tool errors in mistake details", async () => {
1705
+ const errors: string[] = [];
1706
+ const { deps } = makeScriptedRuntime({
1707
+ events: failedStructuredToolTurnEvents(),
1708
+ });
1709
+ const session = new SessionRuntime(
1710
+ makeAgentConfig({ execution: { maxConsecutiveMistakes: 1 } }),
1711
+ {
1712
+ ...deps,
1713
+ telemetry: undefined,
1714
+ logger: {
1715
+ log() {},
1716
+ debug() {},
1717
+ error() {},
1718
+ },
1719
+ },
1720
+ );
1721
+ session.subscribeEvents((event) => {
1722
+ if (event.type === "error") {
1723
+ errors.push(event.error.message);
1724
+ }
1725
+ });
1726
+
1727
+ await session.run("run tool");
1728
+
1729
+ expect(errors).toContain(
1730
+ '1 tool call(s) failed: [exec] {"message":"sandbox denied","code":"EPERM"}',
1731
+ );
1732
+ });
1733
+
1734
+ it("resets mistake tracking when run() starts a fresh conversation", async () => {
1735
+ const { deps, abortCalls } = makeScriptedRuntime({
1736
+ events: failedToolTurnEvents(),
1737
+ });
1738
+ const session = new SessionRuntime(
1739
+ makeAgentConfig({ execution: { maxConsecutiveMistakes: 2 } }),
1740
+ deps,
1741
+ );
1742
+ await session.run("task one");
1743
+ expect(abortCalls).toHaveLength(0);
1744
+ await session.run("task two");
1745
+ expect(abortCalls).toHaveLength(0);
1746
+ });
1747
+
1748
+ it("aborts on hard-threshold loop detection of identical tool calls", async () => {
1749
+ const identical = (i: number): AgentRuntimeEvent => ({
1750
+ type: "tool-started",
1751
+ iteration: i,
1752
+ toolCall: {
1753
+ type: "tool-call",
1754
+ toolCallId: `tc${i}`,
1755
+ toolName: "same",
1756
+ input: { a: 1 },
1757
+ },
1758
+ snapshot: makeSnapshot(),
1759
+ });
1760
+ const { deps, abortCalls } = makeScriptedRuntime({
1761
+ events: [
1762
+ { type: "turn-started", iteration: 1, snapshot: makeSnapshot() },
1763
+ identical(1),
1764
+ identical(1),
1765
+ identical(1),
1766
+ ],
1767
+ });
1768
+ const session = new SessionRuntime(
1769
+ makeAgentConfig({
1770
+ execution: {
1771
+ maxConsecutiveMistakes: 6,
1772
+ loopDetection: { softThreshold: 2, hardThreshold: 3 },
1773
+ },
1774
+ }),
1775
+ deps,
1776
+ );
1777
+ await session.run("loop-me");
1778
+ expect(abortCalls.length).toBeGreaterThanOrEqual(1);
1779
+ });
1780
+
1781
+ it("resets loop detection when run() starts a fresh conversation", async () => {
1782
+ const identical = (i: number): AgentRuntimeEvent => ({
1783
+ type: "tool-started",
1784
+ iteration: i,
1785
+ toolCall: {
1786
+ type: "tool-call",
1787
+ toolCallId: `tc${i}`,
1788
+ toolName: "same",
1789
+ input: { a: 1 },
1790
+ },
1791
+ snapshot: makeSnapshot(),
1792
+ });
1793
+ const { deps, abortCalls } = makeScriptedRuntime({
1794
+ events: [
1795
+ { type: "turn-started", iteration: 1, snapshot: makeSnapshot() },
1796
+ identical(1),
1797
+ identical(1),
1798
+ ],
1799
+ });
1800
+ const session = new SessionRuntime(
1801
+ makeAgentConfig({
1802
+ execution: {
1803
+ maxConsecutiveMistakes: 6,
1804
+ loopDetection: { softThreshold: 2, hardThreshold: 3 },
1805
+ },
1806
+ }),
1807
+ deps,
1808
+ );
1809
+ await session.run("task one");
1810
+ expect(abortCalls).toHaveLength(0);
1811
+ await session.run("task two");
1812
+ expect(abortCalls).toHaveLength(0);
1813
+ });
1814
+
1815
+ it("does not trigger loop-detection when execution.loopDetection === false", async () => {
1816
+ const identical = (i: number): AgentRuntimeEvent => ({
1817
+ type: "tool-started",
1818
+ iteration: i,
1819
+ toolCall: {
1820
+ type: "tool-call",
1821
+ toolCallId: `tc${i}`,
1822
+ toolName: "same",
1823
+ input: { a: 1 },
1824
+ },
1825
+ snapshot: makeSnapshot(),
1826
+ });
1827
+ const { deps, abortCalls } = makeScriptedRuntime({
1828
+ events: [
1829
+ { type: "turn-started", iteration: 1, snapshot: makeSnapshot() },
1830
+ identical(1),
1831
+ identical(1),
1832
+ identical(1),
1833
+ identical(1),
1834
+ identical(1),
1835
+ ],
1836
+ });
1837
+ const session = new SessionRuntime(
1838
+ makeAgentConfig({ execution: { loopDetection: false } }),
1839
+ deps,
1840
+ );
1841
+ await session.run("many-identical");
1842
+ expect(abortCalls).toHaveLength(0);
1843
+ });
1844
+
1845
+ it("does not abort on productive turns (successful tool calls)", async () => {
1846
+ const events: AgentRuntimeEvent[] = [
1847
+ { type: "turn-started", iteration: 1, snapshot: makeSnapshot() },
1848
+ {
1849
+ type: "tool-started",
1850
+ iteration: 1,
1851
+ toolCall: {
1852
+ type: "tool-call",
1853
+ toolCallId: "ok",
1854
+ toolName: "t",
1855
+ input: { n: 1 },
1856
+ },
1857
+ snapshot: makeSnapshot(),
1858
+ },
1859
+ {
1860
+ type: "tool-finished",
1861
+ iteration: 1,
1862
+ toolCall: {
1863
+ type: "tool-call",
1864
+ toolCallId: "ok",
1865
+ toolName: "t",
1866
+ input: { n: 1 },
1867
+ },
1868
+ message: {
1869
+ id: "m",
1870
+ role: "tool",
1871
+ content: [
1872
+ {
1873
+ type: "tool-result",
1874
+ toolCallId: "ok",
1875
+ toolName: "t",
1876
+ output: "ok",
1877
+ },
1878
+ ],
1879
+ createdAt: 1,
1880
+ },
1881
+ snapshot: makeSnapshot(),
1882
+ },
1883
+ {
1884
+ type: "turn-finished",
1885
+ iteration: 1,
1886
+ toolCallCount: 1,
1887
+ snapshot: makeSnapshot(),
1888
+ },
1889
+ ];
1890
+ const { deps, abortCalls } = makeScriptedRuntime({ events });
1891
+ const session = new SessionRuntime(
1892
+ makeAgentConfig({ execution: { maxConsecutiveMistakes: 2 } }),
1893
+ deps,
1894
+ );
1895
+ await session.run("a");
1896
+ await session.continue("b");
1897
+ await session.continue("c");
1898
+ expect(abortCalls).toHaveLength(0);
1899
+ });
1900
+ });