@resolveio/server-lib 22.3.125 → 22.3.126

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 (735) hide show
  1. package/.nodemon.json +5 -0
  2. package/.vscode/settings.json +21 -0
  3. package/AGENTS.md +195 -0
  4. package/README.md +22 -0
  5. package/build_package.sh +5 -0
  6. package/compileDTS.pl +64 -0
  7. package/docs/ai-assistant-nightly-eval.md +65 -0
  8. package/docs/ai-assistant-preflight-checklist.md +23 -0
  9. package/docs/ai-assistant-report-builder-bridge-playbook.md +115 -0
  10. package/eslint-plugin-custom/index.js +7 -0
  11. package/eslint-plugin-custom/rules/no-filter-zero-index.js +44 -0
  12. package/eslint.config.js +103 -0
  13. package/gulpfile.js +216 -0
  14. package/methodAndPublicationListGenerator.py +375 -0
  15. package/mongodbensurers.js +2 -0
  16. package/mongostop.js +3 -0
  17. package/package.json +1 -1
  18. package/scripts/cleanup-bypassed-callmethod-logs.js +616 -0
  19. package/settings.development.json +25 -0
  20. package/settings.development.redacted.json +25 -0
  21. package/src/.env +12 -0
  22. package/src/ai/assistant-core-heuristics.ts +379 -0
  23. package/src/ai/resolveio-platform-intelligence-memory-corpus.ts +185 -0
  24. package/src/ai/resolveio-platform-intelligence-memory.ts +325 -0
  25. package/{ai/resolveio-platform-intelligence-types.d.ts → src/ai/resolveio-platform-intelligence-types.ts} +20 -15
  26. package/src/ai/resolveio-platform-intelligence.ts +462 -0
  27. package/src/client-server-app.ts +12 -0
  28. package/src/collections/ai-run.collection.ts +117 -0
  29. package/src/collections/ai-terminal-conversation.collection.ts +91 -0
  30. package/src/collections/ai-terminal-issue-report.collection.ts +99 -0
  31. package/src/collections/ai-terminal-message.collection.ts +77 -0
  32. package/src/collections/app-setting.collection.ts +104 -0
  33. package/src/collections/app-status.collection.ts +58 -0
  34. package/src/collections/communication-metric.collection.ts +84 -0
  35. package/src/collections/counter.collection.ts +56 -0
  36. package/src/collections/cron-job-history.collection.ts +94 -0
  37. package/src/collections/cron-job.collection.ts +92 -0
  38. package/src/collections/customer-notification.collection.ts +131 -0
  39. package/src/collections/customer-portal-password.collection.ts +76 -0
  40. package/src/collections/email-history.collection.ts +134 -0
  41. package/src/collections/email-verified.collection.ts +62 -0
  42. package/src/collections/file.collection.ts +74 -0
  43. package/src/collections/flag-update.collection.ts +57 -0
  44. package/src/collections/flag.collection.ts +57 -0
  45. package/src/collections/log-method-latency.collection.ts +77 -0
  46. package/src/collections/log-subscription.collection.ts +80 -0
  47. package/src/collections/log.collection.ts +93 -0
  48. package/src/collections/logged-in-users.collection.ts +67 -0
  49. package/src/collections/monitor-cpu.collection.ts +65 -0
  50. package/src/collections/monitor-function.collection.ts +74 -0
  51. package/src/collections/monitor-memory.collection.ts +77 -0
  52. package/src/collections/monitor-mongo.collection.ts +71 -0
  53. package/src/collections/notification.collection.ts +57 -0
  54. package/src/collections/openai-usage-ledger.collection.ts +77 -0
  55. package/src/collections/report-builder-dashboard-builder.collection.ts +109 -0
  56. package/src/collections/report-builder-library.collection.ts +89 -0
  57. package/src/collections/report-builder-report.collection.ts +184 -0
  58. package/src/collections/user-group.collection.ts +89 -0
  59. package/src/collections/user-guide.collection.ts +57 -0
  60. package/src/collections/user.collection.ts +181 -0
  61. package/src/cron/cron.ts +117 -0
  62. package/src/fixtures/cron-jobs.ts +95 -0
  63. package/src/fixtures/init.ts +35 -0
  64. package/src/http/auth.ts +818 -0
  65. package/src/http/health.ts +7 -0
  66. package/src/http/home.ts +90 -0
  67. package/src/http/slow-query-publication.ts +49 -0
  68. package/src/index.ts +1 -0
  69. package/src/managers/ai-assistant-codex-manager.manager.ts +1131 -0
  70. package/src/managers/ai-run-evidence.manager.ts +264 -0
  71. package/src/managers/communication-metric.manager.ts +82 -0
  72. package/src/managers/cron.manager.ts +333 -0
  73. package/src/managers/customer-notification-content.manager.ts +236 -0
  74. package/src/managers/diagnostic-manager-bootstrap.ts +165 -0
  75. package/src/managers/error-auto-fix.manager.ts +2767 -0
  76. package/src/managers/local-log.manager.ts +113 -0
  77. package/src/managers/method.manager.ts +1857 -0
  78. package/src/managers/mongo.manager.ts +4575 -0
  79. package/src/managers/monitor.manager.ts +507 -0
  80. package/src/managers/openai-usage-ledger.manager.ts +57 -0
  81. package/src/managers/slow-query-verifier.manager.ts +3590 -0
  82. package/src/managers/slow-query.manager.ts +519 -0
  83. package/src/managers/subscription.manager.ts +3128 -0
  84. package/src/managers/websocket.manager.ts +746 -0
  85. package/src/managers/worker-dispatcher.manager.ts +1360 -0
  86. package/src/managers/worker-server.manager.ts +536 -0
  87. package/src/methods/accounts.ts +532 -0
  88. package/src/methods/ai-terminal.ts +23497 -0
  89. package/src/methods/app-settings.ts +114 -0
  90. package/src/methods/aws.ts +649 -0
  91. package/src/methods/collections.ts +641 -0
  92. package/src/methods/counters.ts +69 -0
  93. package/src/methods/cron-jobs.ts +2614 -0
  94. package/src/methods/customer-notifications.ts +458 -0
  95. package/src/methods/diagnostics.ts +616 -0
  96. package/src/methods/flag-updates.ts +7 -0
  97. package/src/methods/flags.ts +7 -0
  98. package/src/methods/logs.ts +657 -0
  99. package/src/methods/mongo-explorer.ts +1880 -0
  100. package/src/methods/monitor.ts +540 -0
  101. package/src/methods/pdf.ts +1236 -0
  102. package/src/methods/publications.ts +129 -0
  103. package/src/methods/report-builder.ts +3300 -0
  104. package/src/methods/support.ts +335 -0
  105. package/src/models/ai-run.model.ts +27 -0
  106. package/src/models/ai-terminal-conversation.model.ts +19 -0
  107. package/src/models/ai-terminal-issue-report.model.ts +21 -0
  108. package/src/models/ai-terminal-message.model.ts +24 -0
  109. package/src/models/app-setting.model.ts +17 -0
  110. package/{models/app-status.model.d.ts → src/models/app-status.model.ts} +3 -2
  111. package/{models/billing-logged-in-users.model.d.ts → src/models/billing-logged-in-users.model.ts} +5 -4
  112. package/src/models/collection-document.model.ts +24 -0
  113. package/src/models/communication-metric.model.ts +23 -0
  114. package/{models/counter.model.d.ts → src/models/counter.model.ts} +4 -3
  115. package/src/models/cron-job-history.model.ts +16 -0
  116. package/src/models/cron-job.model.ts +15 -0
  117. package/src/models/customer-notification.model.ts +28 -0
  118. package/src/models/customer-portal-password.model.ts +12 -0
  119. package/src/models/dialog.model.ts +25 -0
  120. package/{models/email-history.model.js → src/models/email-history.model.ts} +36 -4
  121. package/{models/email-verified.model.d.ts → src/models/email-verified.model.ts} +6 -5
  122. package/{models/file.model.d.ts → src/models/file.model.ts} +8 -7
  123. package/{models/flag-update.model.d.ts → src/models/flag-update.model.ts} +4 -3
  124. package/{models/flag.model.d.ts → src/models/flag.model.ts} +4 -3
  125. package/src/models/log-method-latency.model.ts +11 -0
  126. package/{models/log-subscription.model.d.ts → src/models/log-subscription.model.ts} +11 -9
  127. package/src/models/log.model.ts +19 -0
  128. package/{models/logged-in-users.model.d.ts → src/models/logged-in-users.model.ts} +6 -5
  129. package/{models/method-response.model.d.ts → src/models/method-response.model.ts} +7 -6
  130. package/src/models/method.model.ts +25 -0
  131. package/{models/monitor-cpu.model.d.ts → src/models/monitor-cpu.model.ts} +9 -7
  132. package/src/models/monitor-function.model.ts +16 -0
  133. package/src/models/monitor-memory.model.ts +17 -0
  134. package/src/models/monitor-mongo.model.ts +15 -0
  135. package/{models/notification.model.d.ts → src/models/notification.model.ts} +6 -4
  136. package/src/models/openai-usage-ledger.model.ts +16 -0
  137. package/src/models/pagination.model.ts +35 -0
  138. package/src/models/permission.model.ts +14 -0
  139. package/src/models/report-builder-dashboard-builder.model.ts +29 -0
  140. package/src/models/report-builder-library.model.ts +20 -0
  141. package/src/models/report-builder-report.model.ts +136 -0
  142. package/src/models/report-builder.model.ts +68 -0
  143. package/src/models/select-data-label.model.ts +9 -0
  144. package/src/models/server-message.model.ts +31 -0
  145. package/src/models/slow-query-report.model.ts +23 -0
  146. package/src/models/subscription.model.ts +73 -0
  147. package/src/models/support-ticket.model.ts +104 -0
  148. package/src/models/user-group.model.ts +24 -0
  149. package/{models/user-guide.model.d.ts → src/models/user-guide.model.ts} +5 -4
  150. package/src/models/user.model.ts +96 -0
  151. package/src/private/images/ResolveIO.png +0 -0
  152. package/src/publications/ai-terminal.ts +73 -0
  153. package/src/publications/app-settings.ts +25 -0
  154. package/src/publications/app-status.ts +13 -0
  155. package/src/publications/cron-jobs.ts +40 -0
  156. package/src/publications/customer-notifications.ts +101 -0
  157. package/src/publications/files.ts +33 -0
  158. package/src/publications/flags-update.ts +19 -0
  159. package/src/publications/flags.ts +19 -0
  160. package/src/publications/logs.ts +163 -0
  161. package/src/publications/notifications.ts +13 -0
  162. package/src/publications/report-builder-dashboard-builders.ts +39 -0
  163. package/src/publications/report-builder-libraries.ts +41 -0
  164. package/src/publications/report-builder-reports.ts +47 -0
  165. package/src/publications/super-admin.ts +13 -0
  166. package/src/publications/user-groups.ts +12 -0
  167. package/src/publications/user-guides.ts +12 -0
  168. package/src/resolveio-server-app.ts +617 -0
  169. package/src/server-app.ts +3354 -0
  170. package/src/services/codex-client.ts +1231 -0
  171. package/src/services/openai-client.ts +265 -0
  172. package/src/types/error-report.ts +26 -0
  173. package/src/types/js-tiktoken.d.ts +11 -0
  174. package/src/types/slow-query-report.ts +28 -0
  175. package/src/util/ai-qa-policy.ts +925 -0
  176. package/src/util/ai-run-evidence-adapters.ts +521 -0
  177. package/src/util/ai-run-evidence-dashboard.ts +271 -0
  178. package/src/util/ai-run-evidence-eval.ts +885 -0
  179. package/src/util/ai-run-evidence.ts +964 -0
  180. package/src/util/ai-runner-artifacts.ts +586 -0
  181. package/src/util/ai-runner-qa-auth.ts +821 -0
  182. package/src/util/ai-runner-qa-tools.ts +3045 -0
  183. package/src/util/aicoder-runner-v6.ts +526 -0
  184. package/src/util/common.ts +649 -0
  185. package/src/util/customer-portal-password.ts +183 -0
  186. package/src/util/error-reporter.ts +332 -0
  187. package/src/util/error-tracking.ts +79 -0
  188. package/src/util/openai-usage-cost.ts +114 -0
  189. package/src/util/report-builder-unwinds.ts +180 -0
  190. package/src/util/runner-process-janitor.ts +219 -0
  191. package/src/util/schema-report-builder.ts +448 -0
  192. package/src/util/slow-query-reporter.ts +216 -0
  193. package/src/util/subscription-dependency-context.ts +1096 -0
  194. package/src/util/support-runner-v5.ts +897 -0
  195. package/src/util/tokenizer.ts +38 -0
  196. package/src/workers/codex-runner.worker.ts +142 -0
  197. package/start_server.sh +5 -0
  198. package/tests/ai-assistant-corpus-build.ts +484 -0
  199. package/tests/ai-assistant-corpus-replay-e2e.ts +774 -0
  200. package/tests/ai-assistant-data-parity-e2e.ts +1989 -0
  201. package/tests/ai-assistant-eval-triage.ts +831 -0
  202. package/tests/ai-assistant-openai-e2e.ts +1061 -0
  203. package/tests/ai-assistant-openai-git-e2e.ts +155 -0
  204. package/tests/ai-assistant-preflight-matrix.ts +215 -0
  205. package/tests/ai-assistant-routing-eval.test.ts +560 -0
  206. package/tests/ai-assistant-snf-live-eval.ts +975 -0
  207. package/tests/ai-assistant-utils.test.ts +2968 -0
  208. package/tests/ai-run-eval.test.ts +88 -0
  209. package/tests/ai-run-evidence.test.ts +232 -0
  210. package/tests/ai-runner-contract.test.ts +488 -0
  211. package/tests/aicoder-runner-v6.test.ts +92 -0
  212. package/tests/error-reporter.test.ts +145 -0
  213. package/tests/method-publication-generator.test.ts +46 -0
  214. package/tests/report-builder-linking.test.ts +79 -0
  215. package/tests/resolveio-platform-intelligence.test.ts +352 -0
  216. package/tests/server-app-cron-owner.test.ts +127 -0
  217. package/tests/subscription-connect-race.test.ts +158 -0
  218. package/tests/subscription-dependency-context.test.ts +324 -0
  219. package/tests/subscription-manager-collection-tracking.test.ts +86 -0
  220. package/tests/subscription-manager-invalidation.test.ts +86 -0
  221. package/tests/support-runner-v5.test.ts +191 -0
  222. package/tsconfig.json +34 -0
  223. package/ai/assistant-core-heuristics.d.ts +0 -11
  224. package/ai/assistant-core-heuristics.js +0 -356
  225. package/ai/assistant-core-heuristics.js.map +0 -1
  226. package/ai/resolveio-platform-intelligence-memory-corpus.d.ts +0 -3
  227. package/ai/resolveio-platform-intelligence-memory-corpus.js +0 -214
  228. package/ai/resolveio-platform-intelligence-memory-corpus.js.map +0 -1
  229. package/ai/resolveio-platform-intelligence-memory.d.ts +0 -20
  230. package/ai/resolveio-platform-intelligence-memory.js +0 -341
  231. package/ai/resolveio-platform-intelligence-memory.js.map +0 -1
  232. package/ai/resolveio-platform-intelligence-types.js +0 -4
  233. package/ai/resolveio-platform-intelligence-types.js.map +0 -1
  234. package/ai/resolveio-platform-intelligence.d.ts +0 -6
  235. package/ai/resolveio-platform-intelligence.js +0 -463
  236. package/ai/resolveio-platform-intelligence.js.map +0 -1
  237. package/client-server-app.d.ts +0 -1
  238. package/client-server-app.js +0 -68
  239. package/client-server-app.js.map +0 -1
  240. package/collections/ai-run.collection.d.ts +0 -3
  241. package/collections/ai-run.collection.js +0 -170
  242. package/collections/ai-run.collection.js.map +0 -1
  243. package/collections/ai-terminal-conversation.collection.d.ts +0 -2
  244. package/collections/ai-terminal-conversation.collection.js +0 -140
  245. package/collections/ai-terminal-conversation.collection.js.map +0 -1
  246. package/collections/ai-terminal-issue-report.collection.d.ts +0 -2
  247. package/collections/ai-terminal-issue-report.collection.js +0 -148
  248. package/collections/ai-terminal-issue-report.collection.js.map +0 -1
  249. package/collections/ai-terminal-message.collection.d.ts +0 -2
  250. package/collections/ai-terminal-message.collection.js +0 -121
  251. package/collections/ai-terminal-message.collection.js.map +0 -1
  252. package/collections/app-setting.collection.d.ts +0 -3
  253. package/collections/app-setting.collection.js +0 -103
  254. package/collections/app-setting.collection.js.map +0 -1
  255. package/collections/app-status.collection.d.ts +0 -3
  256. package/collections/app-status.collection.js +0 -57
  257. package/collections/app-status.collection.js.map +0 -1
  258. package/collections/communication-metric.collection.d.ts +0 -2
  259. package/collections/communication-metric.collection.js +0 -133
  260. package/collections/communication-metric.collection.js.map +0 -1
  261. package/collections/counter.collection.d.ts +0 -3
  262. package/collections/counter.collection.js +0 -56
  263. package/collections/counter.collection.js.map +0 -1
  264. package/collections/cron-job-history.collection.d.ts +0 -3
  265. package/collections/cron-job-history.collection.js +0 -137
  266. package/collections/cron-job-history.collection.js.map +0 -1
  267. package/collections/cron-job.collection.d.ts +0 -3
  268. package/collections/cron-job.collection.js +0 -92
  269. package/collections/cron-job.collection.js.map +0 -1
  270. package/collections/customer-notification.collection.d.ts +0 -3
  271. package/collections/customer-notification.collection.js +0 -130
  272. package/collections/customer-notification.collection.js.map +0 -1
  273. package/collections/customer-portal-password.collection.d.ts +0 -3
  274. package/collections/customer-portal-password.collection.js +0 -75
  275. package/collections/customer-portal-password.collection.js.map +0 -1
  276. package/collections/email-history.collection.d.ts +0 -3
  277. package/collections/email-history.collection.js +0 -134
  278. package/collections/email-history.collection.js.map +0 -1
  279. package/collections/email-verified.collection.d.ts +0 -3
  280. package/collections/email-verified.collection.js +0 -62
  281. package/collections/email-verified.collection.js.map +0 -1
  282. package/collections/file.collection.d.ts +0 -3
  283. package/collections/file.collection.js +0 -74
  284. package/collections/file.collection.js.map +0 -1
  285. package/collections/flag-update.collection.d.ts +0 -3
  286. package/collections/flag-update.collection.js +0 -57
  287. package/collections/flag-update.collection.js.map +0 -1
  288. package/collections/flag.collection.d.ts +0 -3
  289. package/collections/flag.collection.js +0 -57
  290. package/collections/flag.collection.js.map +0 -1
  291. package/collections/log-method-latency.collection.d.ts +0 -3
  292. package/collections/log-method-latency.collection.js +0 -77
  293. package/collections/log-method-latency.collection.js.map +0 -1
  294. package/collections/log-subscription.collection.d.ts +0 -3
  295. package/collections/log-subscription.collection.js +0 -80
  296. package/collections/log-subscription.collection.js.map +0 -1
  297. package/collections/log.collection.d.ts +0 -3
  298. package/collections/log.collection.js +0 -93
  299. package/collections/log.collection.js.map +0 -1
  300. package/collections/logged-in-users.collection.d.ts +0 -3
  301. package/collections/logged-in-users.collection.js +0 -67
  302. package/collections/logged-in-users.collection.js.map +0 -1
  303. package/collections/monitor-cpu.collection.d.ts +0 -3
  304. package/collections/monitor-cpu.collection.js +0 -65
  305. package/collections/monitor-cpu.collection.js.map +0 -1
  306. package/collections/monitor-function.collection.d.ts +0 -3
  307. package/collections/monitor-function.collection.js +0 -74
  308. package/collections/monitor-function.collection.js.map +0 -1
  309. package/collections/monitor-memory.collection.d.ts +0 -3
  310. package/collections/monitor-memory.collection.js +0 -77
  311. package/collections/monitor-memory.collection.js.map +0 -1
  312. package/collections/monitor-mongo.collection.d.ts +0 -3
  313. package/collections/monitor-mongo.collection.js +0 -71
  314. package/collections/monitor-mongo.collection.js.map +0 -1
  315. package/collections/notification.collection.d.ts +0 -3
  316. package/collections/notification.collection.js +0 -57
  317. package/collections/notification.collection.js.map +0 -1
  318. package/collections/openai-usage-ledger.collection.d.ts +0 -2
  319. package/collections/openai-usage-ledger.collection.js +0 -124
  320. package/collections/openai-usage-ledger.collection.js.map +0 -1
  321. package/collections/report-builder-dashboard-builder.collection.d.ts +0 -3
  322. package/collections/report-builder-dashboard-builder.collection.js +0 -109
  323. package/collections/report-builder-dashboard-builder.collection.js.map +0 -1
  324. package/collections/report-builder-library.collection.d.ts +0 -3
  325. package/collections/report-builder-library.collection.js +0 -87
  326. package/collections/report-builder-library.collection.js.map +0 -1
  327. package/collections/report-builder-report.collection.d.ts +0 -4
  328. package/collections/report-builder-report.collection.js +0 -184
  329. package/collections/report-builder-report.collection.js.map +0 -1
  330. package/collections/user-group.collection.d.ts +0 -4
  331. package/collections/user-group.collection.js +0 -89
  332. package/collections/user-group.collection.js.map +0 -1
  333. package/collections/user-guide.collection.d.ts +0 -3
  334. package/collections/user-guide.collection.js +0 -57
  335. package/collections/user-guide.collection.js.map +0 -1
  336. package/collections/user.collection.d.ts +0 -4
  337. package/collections/user.collection.js +0 -180
  338. package/collections/user.collection.js.map +0 -1
  339. package/cron/cron.d.ts +0 -14
  340. package/cron/cron.js +0 -216
  341. package/cron/cron.js.map +0 -1
  342. package/fixtures/cron-jobs.d.ts +0 -1
  343. package/fixtures/cron-jobs.js +0 -150
  344. package/fixtures/cron-jobs.js.map +0 -1
  345. package/fixtures/init.d.ts +0 -1
  346. package/fixtures/init.js +0 -91
  347. package/fixtures/init.js.map +0 -1
  348. package/http/auth.d.ts +0 -2
  349. package/http/auth.js +0 -951
  350. package/http/auth.js.map +0 -1
  351. package/http/health.d.ts +0 -1
  352. package/http/health.js +0 -11
  353. package/http/health.js.map +0 -1
  354. package/http/home.d.ts +0 -1
  355. package/http/home.js +0 -134
  356. package/http/home.js.map +0 -1
  357. package/http/slow-query-publication.d.ts +0 -2
  358. package/http/slow-query-publication.js +0 -99
  359. package/http/slow-query-publication.js.map +0 -1
  360. package/index.d.ts +0 -1
  361. package/index.js +0 -19
  362. package/index.js.map +0 -1
  363. package/managers/ai-assistant-codex-manager.manager.d.ts +0 -67
  364. package/managers/ai-assistant-codex-manager.manager.js +0 -1113
  365. package/managers/ai-assistant-codex-manager.manager.js.map +0 -1
  366. package/managers/ai-run-evidence.manager.d.ts +0 -36
  367. package/managers/ai-run-evidence.manager.js +0 -377
  368. package/managers/ai-run-evidence.manager.js.map +0 -1
  369. package/managers/communication-metric.manager.d.ts +0 -16
  370. package/managers/communication-metric.manager.js +0 -134
  371. package/managers/communication-metric.manager.js.map +0 -1
  372. package/managers/cron.manager.d.ts +0 -20
  373. package/managers/cron.manager.js +0 -534
  374. package/managers/cron.manager.js.map +0 -1
  375. package/managers/customer-notification-content.manager.d.ts +0 -55
  376. package/managers/customer-notification-content.manager.js +0 -158
  377. package/managers/customer-notification-content.manager.js.map +0 -1
  378. package/managers/diagnostic-manager-bootstrap.d.ts +0 -9
  379. package/managers/diagnostic-manager-bootstrap.js +0 -260
  380. package/managers/diagnostic-manager-bootstrap.js.map +0 -1
  381. package/managers/error-auto-fix.manager.d.ts +0 -149
  382. package/managers/error-auto-fix.manager.js +0 -3064
  383. package/managers/error-auto-fix.manager.js.map +0 -1
  384. package/managers/local-log.manager.d.ts +0 -18
  385. package/managers/local-log.manager.js +0 -88
  386. package/managers/local-log.manager.js.map +0 -1
  387. package/managers/method.manager.d.ts +0 -84
  388. package/managers/method.manager.js +0 -1964
  389. package/managers/method.manager.js.map +0 -1
  390. package/managers/mongo.manager.d.ts +0 -224
  391. package/managers/mongo.manager.js +0 -5000
  392. package/managers/mongo.manager.js.map +0 -1
  393. package/managers/monitor.manager.d.ts +0 -70
  394. package/managers/monitor.manager.js +0 -550
  395. package/managers/monitor.manager.js.map +0 -1
  396. package/managers/openai-usage-ledger.manager.d.ts +0 -16
  397. package/managers/openai-usage-ledger.manager.js +0 -93
  398. package/managers/openai-usage-ledger.manager.js.map +0 -1
  399. package/managers/slow-query-verifier.manager.d.ts +0 -144
  400. package/managers/slow-query-verifier.manager.js +0 -3857
  401. package/managers/slow-query-verifier.manager.js.map +0 -1
  402. package/managers/slow-query.manager.d.ts +0 -28
  403. package/managers/slow-query.manager.js +0 -468
  404. package/managers/slow-query.manager.js.map +0 -1
  405. package/managers/subscription.manager.d.ts +0 -169
  406. package/managers/subscription.manager.js +0 -3434
  407. package/managers/subscription.manager.js.map +0 -1
  408. package/managers/websocket.manager.d.ts +0 -73
  409. package/managers/websocket.manager.js +0 -673
  410. package/managers/websocket.manager.js.map +0 -1
  411. package/managers/worker-dispatcher.manager.d.ts +0 -120
  412. package/managers/worker-dispatcher.manager.js +0 -1266
  413. package/managers/worker-dispatcher.manager.js.map +0 -1
  414. package/managers/worker-server.manager.d.ts +0 -35
  415. package/managers/worker-server.manager.js +0 -582
  416. package/managers/worker-server.manager.js.map +0 -1
  417. package/methods/accounts.d.ts +0 -2
  418. package/methods/accounts.js +0 -624
  419. package/methods/accounts.js.map +0 -1
  420. package/methods/ai-terminal.d.ts +0 -337
  421. package/methods/ai-terminal.js +0 -23166
  422. package/methods/ai-terminal.js.map +0 -1
  423. package/methods/app-settings.d.ts +0 -2
  424. package/methods/app-settings.js +0 -169
  425. package/methods/app-settings.js.map +0 -1
  426. package/methods/aws.d.ts +0 -2
  427. package/methods/aws.js +0 -877
  428. package/methods/aws.js.map +0 -1
  429. package/methods/collections.d.ts +0 -2
  430. package/methods/collections.js +0 -719
  431. package/methods/collections.js.map +0 -1
  432. package/methods/counters.d.ts +0 -2
  433. package/methods/counters.js +0 -113
  434. package/methods/counters.js.map +0 -1
  435. package/methods/cron-jobs.d.ts +0 -2
  436. package/methods/cron-jobs.js +0 -2475
  437. package/methods/cron-jobs.js.map +0 -1
  438. package/methods/customer-notifications.d.ts +0 -2
  439. package/methods/customer-notifications.js +0 -528
  440. package/methods/customer-notifications.js.map +0 -1
  441. package/methods/diagnostics.d.ts +0 -2
  442. package/methods/diagnostics.js +0 -703
  443. package/methods/diagnostics.js.map +0 -1
  444. package/methods/flag-updates.d.ts +0 -2
  445. package/methods/flag-updates.js +0 -8
  446. package/methods/flag-updates.js.map +0 -1
  447. package/methods/flags.d.ts +0 -2
  448. package/methods/flags.js +0 -8
  449. package/methods/flags.js.map +0 -1
  450. package/methods/logs.d.ts +0 -2
  451. package/methods/logs.js +0 -751
  452. package/methods/logs.js.map +0 -1
  453. package/methods/mongo-explorer.d.ts +0 -2
  454. package/methods/mongo-explorer.js +0 -1808
  455. package/methods/mongo-explorer.js.map +0 -1
  456. package/methods/monitor.d.ts +0 -2
  457. package/methods/monitor.js +0 -543
  458. package/methods/monitor.js.map +0 -1
  459. package/methods/pdf.d.ts +0 -2
  460. package/methods/pdf.js +0 -1216
  461. package/methods/pdf.js.map +0 -1
  462. package/methods/publications.d.ts +0 -1
  463. package/methods/publications.js +0 -183
  464. package/methods/publications.js.map +0 -1
  465. package/methods/report-builder.d.ts +0 -2
  466. package/methods/report-builder.js +0 -3094
  467. package/methods/report-builder.js.map +0 -1
  468. package/methods/support.d.ts +0 -2
  469. package/methods/support.js +0 -430
  470. package/methods/support.js.map +0 -1
  471. package/models/ai-run.model.d.ts +0 -19
  472. package/models/ai-run.model.js +0 -4
  473. package/models/ai-run.model.js.map +0 -1
  474. package/models/ai-terminal-conversation.model.d.ts +0 -17
  475. package/models/ai-terminal-conversation.model.js +0 -4
  476. package/models/ai-terminal-conversation.model.js.map +0 -1
  477. package/models/ai-terminal-issue-report.model.d.ts +0 -19
  478. package/models/ai-terminal-issue-report.model.js +0 -4
  479. package/models/ai-terminal-issue-report.model.js.map +0 -1
  480. package/models/ai-terminal-message.model.d.ts +0 -22
  481. package/models/ai-terminal-message.model.js +0 -4
  482. package/models/ai-terminal-message.model.js.map +0 -1
  483. package/models/app-setting.model.d.ts +0 -16
  484. package/models/app-setting.model.js +0 -4
  485. package/models/app-setting.model.js.map +0 -1
  486. package/models/app-status.model.js +0 -4
  487. package/models/app-status.model.js.map +0 -1
  488. package/models/billing-logged-in-users.model.js +0 -4
  489. package/models/billing-logged-in-users.model.js.map +0 -1
  490. package/models/collection-document.model.d.ts +0 -21
  491. package/models/collection-document.model.js +0 -4
  492. package/models/collection-document.model.js.map +0 -1
  493. package/models/communication-metric.model.d.ts +0 -20
  494. package/models/communication-metric.model.js +0 -4
  495. package/models/communication-metric.model.js.map +0 -1
  496. package/models/counter.model.js +0 -4
  497. package/models/counter.model.js.map +0 -1
  498. package/models/cron-job-history.model.d.ts +0 -15
  499. package/models/cron-job-history.model.js +0 -4
  500. package/models/cron-job-history.model.js.map +0 -1
  501. package/models/cron-job.model.d.ts +0 -14
  502. package/models/cron-job.model.js +0 -4
  503. package/models/cron-job.model.js.map +0 -1
  504. package/models/customer-notification.model.d.ts +0 -26
  505. package/models/customer-notification.model.js +0 -4
  506. package/models/customer-notification.model.js.map +0 -1
  507. package/models/customer-portal-password.model.d.ts +0 -11
  508. package/models/customer-portal-password.model.js +0 -4
  509. package/models/customer-portal-password.model.js.map +0 -1
  510. package/models/dialog.model.d.ts +0 -23
  511. package/models/dialog.model.js +0 -4
  512. package/models/dialog.model.js.map +0 -1
  513. package/models/email-history.model.d.ts +0 -32
  514. package/models/email-history.model.js.map +0 -1
  515. package/models/email-verified.model.js +0 -4
  516. package/models/email-verified.model.js.map +0 -1
  517. package/models/file.model.js +0 -4
  518. package/models/file.model.js.map +0 -1
  519. package/models/flag-update.model.js +0 -4
  520. package/models/flag-update.model.js.map +0 -1
  521. package/models/flag.model.js +0 -4
  522. package/models/flag.model.js.map +0 -1
  523. package/models/log-method-latency.model.d.ts +0 -10
  524. package/models/log-method-latency.model.js +0 -4
  525. package/models/log-method-latency.model.js.map +0 -1
  526. package/models/log-subscription.model.js +0 -4
  527. package/models/log-subscription.model.js.map +0 -1
  528. package/models/log.model.d.ts +0 -17
  529. package/models/log.model.js +0 -4
  530. package/models/log.model.js.map +0 -1
  531. package/models/logged-in-users.model.js +0 -4
  532. package/models/logged-in-users.model.js.map +0 -1
  533. package/models/method-response.model.js +0 -4
  534. package/models/method-response.model.js.map +0 -1
  535. package/models/method.model.d.ts +0 -26
  536. package/models/method.model.js +0 -4
  537. package/models/method.model.js.map +0 -1
  538. package/models/monitor-cpu.model.js +0 -4
  539. package/models/monitor-cpu.model.js.map +0 -1
  540. package/models/monitor-function.model.d.ts +0 -14
  541. package/models/monitor-function.model.js +0 -4
  542. package/models/monitor-function.model.js.map +0 -1
  543. package/models/monitor-memory.model.d.ts +0 -15
  544. package/models/monitor-memory.model.js +0 -4
  545. package/models/monitor-memory.model.js.map +0 -1
  546. package/models/monitor-mongo.model.d.ts +0 -13
  547. package/models/monitor-mongo.model.js +0 -4
  548. package/models/monitor-mongo.model.js.map +0 -1
  549. package/models/notification.model.js +0 -4
  550. package/models/notification.model.js.map +0 -1
  551. package/models/openai-usage-ledger.model.d.ts +0 -15
  552. package/models/openai-usage-ledger.model.js +0 -4
  553. package/models/openai-usage-ledger.model.js.map +0 -1
  554. package/models/pagination.model.d.ts +0 -11
  555. package/models/pagination.model.js +0 -28
  556. package/models/pagination.model.js.map +0 -1
  557. package/models/permission.model.d.ts +0 -12
  558. package/models/permission.model.js +0 -4
  559. package/models/permission.model.js.map +0 -1
  560. package/models/report-builder-dashboard-builder.model.d.ts +0 -25
  561. package/models/report-builder-dashboard-builder.model.js +0 -4
  562. package/models/report-builder-dashboard-builder.model.js.map +0 -1
  563. package/models/report-builder-library.model.d.ts +0 -17
  564. package/models/report-builder-library.model.js +0 -4
  565. package/models/report-builder-library.model.js.map +0 -1
  566. package/models/report-builder-report.model.d.ts +0 -121
  567. package/models/report-builder-report.model.js +0 -4
  568. package/models/report-builder-report.model.js.map +0 -1
  569. package/models/report-builder.model.d.ts +0 -61
  570. package/models/report-builder.model.js +0 -4
  571. package/models/report-builder.model.js.map +0 -1
  572. package/models/select-data-label.model.d.ts +0 -9
  573. package/models/select-data-label.model.js +0 -4
  574. package/models/select-data-label.model.js.map +0 -1
  575. package/models/server-message.model.d.ts +0 -32
  576. package/models/server-message.model.js +0 -4
  577. package/models/server-message.model.js.map +0 -1
  578. package/models/slow-query-report.model.d.ts +0 -23
  579. package/models/slow-query-report.model.js +0 -4
  580. package/models/slow-query-report.model.js.map +0 -1
  581. package/models/subscription.model.d.ts +0 -31
  582. package/models/subscription.model.js +0 -4
  583. package/models/subscription.model.js.map +0 -1
  584. package/models/support-ticket.model.d.ts +0 -87
  585. package/models/support-ticket.model.js +0 -4
  586. package/models/support-ticket.model.js.map +0 -1
  587. package/models/user-group.model.d.ts +0 -20
  588. package/models/user-group.model.js +0 -4
  589. package/models/user-group.model.js.map +0 -1
  590. package/models/user-guide.model.js +0 -4
  591. package/models/user-guide.model.js.map +0 -1
  592. package/models/user.model.d.ts +0 -84
  593. package/models/user.model.js +0 -4
  594. package/models/user.model.js.map +0 -1
  595. package/private/images/ResolveIO.png +0 -0
  596. package/public_api.js +0 -125
  597. package/public_api.js.map +0 -1
  598. package/publications/ai-terminal.d.ts +0 -1
  599. package/publications/ai-terminal.js +0 -122
  600. package/publications/ai-terminal.js.map +0 -1
  601. package/publications/app-settings.d.ts +0 -2
  602. package/publications/app-settings.js +0 -28
  603. package/publications/app-settings.js.map +0 -1
  604. package/publications/app-status.d.ts +0 -2
  605. package/publications/app-status.js +0 -16
  606. package/publications/app-status.js.map +0 -1
  607. package/publications/cron-jobs.d.ts +0 -2
  608. package/publications/cron-jobs.js +0 -88
  609. package/publications/cron-jobs.js.map +0 -1
  610. package/publications/customer-notifications.d.ts +0 -2
  611. package/publications/customer-notifications.js +0 -161
  612. package/publications/customer-notifications.js.map +0 -1
  613. package/publications/files.d.ts +0 -2
  614. package/publications/files.js +0 -36
  615. package/publications/files.js.map +0 -1
  616. package/publications/flags-update.d.ts +0 -2
  617. package/publications/flags-update.js +0 -22
  618. package/publications/flags-update.js.map +0 -1
  619. package/publications/flags.d.ts +0 -2
  620. package/publications/flags.js +0 -22
  621. package/publications/flags.js.map +0 -1
  622. package/publications/logs.d.ts +0 -2
  623. package/publications/logs.js +0 -164
  624. package/publications/logs.js.map +0 -1
  625. package/publications/notifications.d.ts +0 -2
  626. package/publications/notifications.js +0 -16
  627. package/publications/notifications.js.map +0 -1
  628. package/publications/report-builder-dashboard-builders.d.ts +0 -2
  629. package/publications/report-builder-dashboard-builders.js +0 -42
  630. package/publications/report-builder-dashboard-builders.js.map +0 -1
  631. package/publications/report-builder-libraries.d.ts +0 -2
  632. package/publications/report-builder-libraries.js +0 -90
  633. package/publications/report-builder-libraries.js.map +0 -1
  634. package/publications/report-builder-reports.d.ts +0 -2
  635. package/publications/report-builder-reports.js +0 -50
  636. package/publications/report-builder-reports.js.map +0 -1
  637. package/publications/super-admin.d.ts +0 -2
  638. package/publications/super-admin.js +0 -16
  639. package/publications/super-admin.js.map +0 -1
  640. package/publications/user-groups.d.ts +0 -1
  641. package/publications/user-groups.js +0 -16
  642. package/publications/user-groups.js.map +0 -1
  643. package/publications/user-guides.d.ts +0 -1
  644. package/publications/user-guides.js +0 -16
  645. package/publications/user-guides.js.map +0 -1
  646. package/resolveio-server-app.d.ts +0 -70
  647. package/resolveio-server-app.js +0 -801
  648. package/resolveio-server-app.js.map +0 -1
  649. package/server-app.d.ts +0 -228
  650. package/server-app.js +0 -3566
  651. package/server-app.js.map +0 -1
  652. package/services/codex-client.d.ts +0 -128
  653. package/services/codex-client.js +0 -1629
  654. package/services/codex-client.js.map +0 -1
  655. package/services/openai-client.d.ts +0 -46
  656. package/services/openai-client.js +0 -318
  657. package/services/openai-client.js.map +0 -1
  658. package/types/error-report.d.ts +0 -25
  659. package/types/error-report.js +0 -4
  660. package/types/error-report.js.map +0 -1
  661. package/types/slow-query-report.d.ts +0 -27
  662. package/types/slow-query-report.js +0 -6
  663. package/types/slow-query-report.js.map +0 -1
  664. package/util/ai-qa-policy.d.ts +0 -124
  665. package/util/ai-qa-policy.js +0 -736
  666. package/util/ai-qa-policy.js.map +0 -1
  667. package/util/ai-run-evidence-adapters.d.ts +0 -33
  668. package/util/ai-run-evidence-adapters.js +0 -660
  669. package/util/ai-run-evidence-adapters.js.map +0 -1
  670. package/util/ai-run-evidence-dashboard.d.ts +0 -67
  671. package/util/ai-run-evidence-dashboard.js +0 -309
  672. package/util/ai-run-evidence-dashboard.js.map +0 -1
  673. package/util/ai-run-evidence-eval.d.ts +0 -86
  674. package/util/ai-run-evidence-eval.js +0 -854
  675. package/util/ai-run-evidence-eval.js.map +0 -1
  676. package/util/ai-run-evidence.d.ts +0 -212
  677. package/util/ai-run-evidence.js +0 -649
  678. package/util/ai-run-evidence.js.map +0 -1
  679. package/util/ai-runner-artifacts.d.ts +0 -82
  680. package/util/ai-runner-artifacts.js +0 -713
  681. package/util/ai-runner-artifacts.js.map +0 -1
  682. package/util/ai-runner-qa-auth.d.ts +0 -5
  683. package/util/ai-runner-qa-auth.js +0 -822
  684. package/util/ai-runner-qa-auth.js.map +0 -1
  685. package/util/ai-runner-qa-tools.d.ts +0 -26
  686. package/util/ai-runner-qa-tools.js +0 -3029
  687. package/util/ai-runner-qa-tools.js.map +0 -1
  688. package/util/aicoder-runner-v6.d.ts +0 -168
  689. package/util/aicoder-runner-v6.js +0 -347
  690. package/util/aicoder-runner-v6.js.map +0 -1
  691. package/util/common.d.ts +0 -31
  692. package/util/common.js +0 -683
  693. package/util/common.js.map +0 -1
  694. package/util/customer-portal-password.d.ts +0 -13
  695. package/util/customer-portal-password.js +0 -209
  696. package/util/customer-portal-password.js.map +0 -1
  697. package/util/error-reporter.d.ts +0 -52
  698. package/util/error-reporter.js +0 -326
  699. package/util/error-reporter.js.map +0 -1
  700. package/util/error-tracking.d.ts +0 -13
  701. package/util/error-tracking.js +0 -120
  702. package/util/error-tracking.js.map +0 -1
  703. package/util/openai-usage-cost.d.ts +0 -6
  704. package/util/openai-usage-cost.js +0 -92
  705. package/util/openai-usage-cost.js.map +0 -1
  706. package/util/report-builder-unwinds.d.ts +0 -15
  707. package/util/report-builder-unwinds.js +0 -156
  708. package/util/report-builder-unwinds.js.map +0 -1
  709. package/util/runner-process-janitor.d.ts +0 -27
  710. package/util/runner-process-janitor.js +0 -208
  711. package/util/runner-process-janitor.js.map +0 -1
  712. package/util/schema-report-builder.d.ts +0 -6
  713. package/util/schema-report-builder.js +0 -481
  714. package/util/schema-report-builder.js.map +0 -1
  715. package/util/slow-query-reporter.d.ts +0 -28
  716. package/util/slow-query-reporter.js +0 -226
  717. package/util/slow-query-reporter.js.map +0 -1
  718. package/util/subscription-dependency-context.d.ts +0 -34
  719. package/util/subscription-dependency-context.js +0 -1283
  720. package/util/subscription-dependency-context.js.map +0 -1
  721. package/util/support-runner-v5.d.ts +0 -250
  722. package/util/support-runner-v5.js +0 -634
  723. package/util/support-runner-v5.js.map +0 -1
  724. package/util/tokenizer.d.ts +0 -5
  725. package/util/tokenizer.js +0 -41
  726. package/util/tokenizer.js.map +0 -1
  727. package/workers/codex-runner.worker.d.ts +0 -1
  728. package/workers/codex-runner.worker.js +0 -192
  729. package/workers/codex-runner.worker.js.map +0 -1
  730. /package/{private → src/private}/email-templates/enrollment.html +0 -0
  731. /package/{private → src/private}/email-templates/forgot-password.html +0 -0
  732. /package/{private → src/private}/email-templates/support-ticket-deleted.html +0 -0
  733. /package/{private → src/private}/email-templates/support-ticket-modified.html +0 -0
  734. /package/{private → src/private}/email-templates/support-ticket.html +0 -0
  735. /package/{public_api.d.ts → src/public_api.ts} +0 -0
@@ -0,0 +1,885 @@
1
+ import {
2
+ AIRun,
3
+ AIRunOutcomeLabel,
4
+ AIRunSource,
5
+ AIRunTrainingExample,
6
+ buildAIRun,
7
+ buildAIQaRun,
8
+ redactAIRunTrainingExample
9
+ } from './ai-run-evidence';
10
+
11
+ export type AIRunFailureClass =
12
+ | 'none'
13
+ | 'infra'
14
+ | 'compile'
15
+ | 'route'
16
+ | 'business'
17
+ | 'release'
18
+ | 'false_pass'
19
+ | 'assistant_correctness'
20
+ | 'manual'
21
+ | 'stopped'
22
+ | 'unknown';
23
+
24
+ export type AIRunRetryAction =
25
+ | 'none'
26
+ | 'stop'
27
+ | 'retry_infra_repair'
28
+ | 'retry_build_repair'
29
+ | 'retry_route_repair'
30
+ | 'retry_business_repair'
31
+ | 'retry_release_repair'
32
+ | 'manual_handoff';
33
+
34
+ export interface AIRunEvalExpectedGate {
35
+ key: string;
36
+ status?: string;
37
+ }
38
+
39
+ export interface AIRunEvalExpected {
40
+ outcome: AIRunOutcomeLabel;
41
+ failureClass?: AIRunFailureClass;
42
+ nextActionIncludes?: string;
43
+ gates?: AIRunEvalExpectedGate[];
44
+ }
45
+
46
+ export interface AIRunEvalFixture {
47
+ id: string;
48
+ title: string;
49
+ source: AIRunSource;
50
+ run: AIRun;
51
+ expected: AIRunEvalExpected;
52
+ tags: string[];
53
+ }
54
+
55
+ export interface AIRunEvalResult {
56
+ id: string;
57
+ title: string;
58
+ source: AIRunSource;
59
+ passed: boolean;
60
+ actualOutcome: AIRunOutcomeLabel;
61
+ expectedOutcome: AIRunOutcomeLabel;
62
+ actualFailureClass: AIRunFailureClass;
63
+ expectedFailureClass?: AIRunFailureClass;
64
+ failures: string[];
65
+ tags: string[];
66
+ }
67
+
68
+ export interface AIRunEvalSummary {
69
+ passed: boolean;
70
+ total: number;
71
+ passedCount: number;
72
+ failedCount: number;
73
+ results: AIRunEvalResult[];
74
+ failuresByTag: Record<string, number>;
75
+ outcomes: Record<string, number>;
76
+ }
77
+
78
+ export interface AIRunDatasetExport {
79
+ generatedAt: string;
80
+ totalRuns: number;
81
+ summary: {
82
+ bySource: Record<string, number>;
83
+ byOutcome: Record<string, number>;
84
+ byFailureClass: Record<string, number>;
85
+ estimatedUsd: number;
86
+ totalTokens: number;
87
+ };
88
+ runs: AIRun[];
89
+ trainingExamples: AIRunTrainingExample[];
90
+ }
91
+
92
+ export interface AIRunDatasetExportOptions {
93
+ redact?: boolean;
94
+ includeRuns?: boolean;
95
+ maxEvidenceItems?: number;
96
+ now?: Date | string;
97
+ }
98
+
99
+ export interface AIRunRetryPolicyInput {
100
+ currentRun: AIRun;
101
+ previousRun?: AIRun;
102
+ newEvidenceCount?: number;
103
+ unchangedFailureLimit?: number;
104
+ sameFailureCount?: number;
105
+ historicalAcceptanceRate?: number;
106
+ estimatedNextRetryCostUsd?: number;
107
+ minRetryExpectedValue?: number;
108
+ }
109
+
110
+ export interface AIRunRetryDecision {
111
+ action: AIRunRetryAction;
112
+ failureClass: AIRunFailureClass;
113
+ repeatedFailure: boolean;
114
+ reason: string;
115
+ nextAction: string;
116
+ retryExpectedValue?: number;
117
+ }
118
+
119
+ function cleanText(value: any, max = 1000): string {
120
+ return String(value || '').replace(/\s+/g, ' ').trim().slice(0, max);
121
+ }
122
+
123
+ function countBy<T extends string>(values: T[]): Record<string, number> {
124
+ const result: Record<string, number> = {};
125
+ for (const value of values) {
126
+ result[value] = (result[value] || 0) + 1;
127
+ }
128
+ return result;
129
+ }
130
+
131
+ function isoNow(value?: Date | string): string {
132
+ if (value instanceof Date) {
133
+ return value.toISOString();
134
+ }
135
+ const parsed = value ? new Date(value) : new Date();
136
+ if (Number.isFinite(parsed.getTime())) {
137
+ return parsed.toISOString();
138
+ }
139
+ return new Date().toISOString();
140
+ }
141
+
142
+ function addUnique(values: string[], value: any, max = 1000): void {
143
+ const normalized = cleanText(value, max);
144
+ if (normalized && !values.includes(normalized)) {
145
+ values.push(normalized);
146
+ }
147
+ }
148
+
149
+ export function classifyAIRunFailureClass(run: AIRun): AIRunFailureClass {
150
+ if (run.outcome === 'accepted') {
151
+ return 'none';
152
+ }
153
+ if (run.outcome === 'qa_infra_failed') {
154
+ return 'infra';
155
+ }
156
+ if (run.outcome === 'build_failed') {
157
+ return 'compile';
158
+ }
159
+ if (run.outcome === 'release_blocked') {
160
+ return 'release';
161
+ }
162
+ if (run.outcome === 'false_pass') {
163
+ return 'false_pass';
164
+ }
165
+ if (run.outcome === 'manual_handoff') {
166
+ return 'manual';
167
+ }
168
+ if (run.outcome === 'stopped') {
169
+ return 'stopped';
170
+ }
171
+ if (run.source === 'ai_assistant' && (run.outcome === 'rejected' || run.outcome === 'qa_incomplete')) {
172
+ return 'assistant_correctness';
173
+ }
174
+ if (run.qa?.outcome === 'compile_failed') {
175
+ return 'compile';
176
+ }
177
+ if (run.qa?.outcome === 'route_failed') {
178
+ return 'route';
179
+ }
180
+ if (run.qa?.outcome === 'route_only_pass' || run.qa?.outcome === 'incomplete') {
181
+ return 'business';
182
+ }
183
+ if (run.qa?.outcome === 'business_assertion_failed') {
184
+ return 'business';
185
+ }
186
+ if (run.outcome === 'qa_incomplete') {
187
+ return 'business';
188
+ }
189
+ if (run.outcome === 'rejected') {
190
+ return 'business';
191
+ }
192
+ return 'unknown';
193
+ }
194
+
195
+ export function evaluateAIRunFixture(fixture: AIRunEvalFixture): AIRunEvalResult {
196
+ const failures: string[] = [];
197
+ const actualFailureClass = classifyAIRunFailureClass(fixture.run);
198
+ if (fixture.run.outcome !== fixture.expected.outcome) {
199
+ failures.push(`Expected outcome ${fixture.expected.outcome}, got ${fixture.run.outcome}.`);
200
+ }
201
+ if (fixture.expected.failureClass && actualFailureClass !== fixture.expected.failureClass) {
202
+ failures.push(`Expected failure class ${fixture.expected.failureClass}, got ${actualFailureClass}.`);
203
+ }
204
+ if (fixture.expected.nextActionIncludes) {
205
+ const expectedText = fixture.expected.nextActionIncludes.toLowerCase();
206
+ const actualText = cleanText(fixture.run.nextAction, 2000).toLowerCase();
207
+ if (!actualText.includes(expectedText)) {
208
+ failures.push(`Expected next action to include "${fixture.expected.nextActionIncludes}", got "${fixture.run.nextAction || ''}".`);
209
+ }
210
+ }
211
+ const gatesByKey: Record<string, string> = {};
212
+ for (const gate of fixture.run.gates || []) {
213
+ gatesByKey[gate.key] = gate.status;
214
+ }
215
+ for (const expectedGate of fixture.expected.gates || []) {
216
+ if (!gatesByKey[expectedGate.key]) {
217
+ failures.push(`Expected gate ${expectedGate.key} to be present.`);
218
+ }
219
+ else if (expectedGate.status && gatesByKey[expectedGate.key] !== expectedGate.status) {
220
+ failures.push(`Expected gate ${expectedGate.key} status ${expectedGate.status}, got ${gatesByKey[expectedGate.key]}.`);
221
+ }
222
+ }
223
+ return {
224
+ id: fixture.id,
225
+ title: fixture.title,
226
+ source: fixture.source,
227
+ passed: failures.length === 0,
228
+ actualOutcome: fixture.run.outcome,
229
+ expectedOutcome: fixture.expected.outcome,
230
+ actualFailureClass,
231
+ expectedFailureClass: fixture.expected.failureClass,
232
+ failures,
233
+ tags: fixture.tags
234
+ };
235
+ }
236
+
237
+ export function evaluateAIRunFixtures(fixtures: AIRunEvalFixture[] = AI_RUN_SEED_EVAL_FIXTURES): AIRunEvalSummary {
238
+ const results = fixtures.map((fixture) => evaluateAIRunFixture(fixture));
239
+ const failuresByTag: Record<string, number> = {};
240
+ for (const result of results) {
241
+ if (result.passed) {
242
+ continue;
243
+ }
244
+ for (const tag of result.tags) {
245
+ failuresByTag[tag] = (failuresByTag[tag] || 0) + 1;
246
+ }
247
+ }
248
+ const outcomes = countBy(results.map((result) => result.actualOutcome));
249
+ const passedCount = results.filter((result) => result.passed).length;
250
+ return {
251
+ passed: passedCount === results.length,
252
+ total: results.length,
253
+ passedCount,
254
+ failedCount: results.length - passedCount,
255
+ results,
256
+ failuresByTag,
257
+ outcomes
258
+ };
259
+ }
260
+
261
+ export function buildAIRunTrainingExampleFromRun(run: AIRun, maxEvidenceItems = 30): AIRunTrainingExample {
262
+ const evidence: string[] = [];
263
+ for (const gate of run.gates || []) {
264
+ addUnique(evidence, `${gate.key}:${gate.status}: ${gate.reason}`, 1600);
265
+ }
266
+ for (const event of run.events || []) {
267
+ addUnique(evidence, `${event.type}:${event.category || ''}: ${event.message || ''}`, 1400);
268
+ if (evidence.length >= maxEvidenceItems) {
269
+ break;
270
+ }
271
+ }
272
+ if (evidence.length < maxEvidenceItems) {
273
+ for (const assertion of run.qa?.businessAssertions || []) {
274
+ addUnique(evidence, `assertion:${assertion.status}: ${assertion.assertion} observed=${assertion.observed || assertion.dataProof || assertion.message || ''}`, 1600);
275
+ if (evidence.length >= maxEvidenceItems) {
276
+ break;
277
+ }
278
+ }
279
+ }
280
+ return {
281
+ runId: run.id || run.sourceIds.jobId || run.sourceIds.ticketId || run.sourceIds.appId || run.sourceIds.conversationId || `${run.source}:unknown`,
282
+ source: run.source,
283
+ inputSummary: [
284
+ `source=${run.source}`,
285
+ `title=${run.title || ''}`,
286
+ `status=${run.status || ''}`,
287
+ `phase=${run.phase || ''}`,
288
+ `ids=${JSON.stringify(run.sourceIds || {})}`
289
+ ].join(' | '),
290
+ actionSummary: [
291
+ `outcome=${run.outcome}`,
292
+ `failureClass=${classifyAIRunFailureClass(run)}`,
293
+ `nextAction=${run.nextAction || ''}`
294
+ ].join(' | '),
295
+ outcome: run.outcome,
296
+ evidence: evidence.slice(0, maxEvidenceItems),
297
+ cost: run.cost,
298
+ metadata: {
299
+ warnings: run.warnings || [],
300
+ gateCount: (run.gates || []).length,
301
+ eventCount: (run.events || []).length,
302
+ qaOutcome: run.qa?.outcome
303
+ }
304
+ };
305
+ }
306
+
307
+ export function buildAIRunDatasetExport(runs: AIRun[], options: AIRunDatasetExportOptions = {}): AIRunDatasetExport {
308
+ const generatedAt = isoNow(options.now);
309
+ const trainingExamples = runs.map((run) => {
310
+ const example = buildAIRunTrainingExampleFromRun(run, options.maxEvidenceItems || 30);
311
+ return options.redact === false ? example : redactAIRunTrainingExample(example);
312
+ });
313
+ const estimatedUsd = runs.reduce((sum, run) => sum + (Number(run.cost?.estimatedUsd) || 0), 0);
314
+ const totalTokens = runs.reduce((sum, run) => sum + (Number(run.cost?.totalTokens) || 0), 0);
315
+ return {
316
+ generatedAt,
317
+ totalRuns: runs.length,
318
+ summary: {
319
+ bySource: countBy(runs.map((run) => run.source)),
320
+ byOutcome: countBy(runs.map((run) => run.outcome)),
321
+ byFailureClass: countBy(runs.map((run) => classifyAIRunFailureClass(run))),
322
+ estimatedUsd: Number(estimatedUsd.toFixed(6)),
323
+ totalTokens
324
+ },
325
+ runs: options.includeRuns === false ? [] : runs,
326
+ trainingExamples
327
+ };
328
+ }
329
+
330
+ export function decideAIRunRetry(input: AIRunRetryPolicyInput): AIRunRetryDecision {
331
+ const failureClass = classifyAIRunFailureClass(input.currentRun);
332
+ const previousFailureClass = input.previousRun ? classifyAIRunFailureClass(input.previousRun) : undefined;
333
+ const sameFailureCount = Number(input.sameFailureCount || 0);
334
+ const unchangedFailureLimit = Number(input.unchangedFailureLimit || 2);
335
+ const repeatedFailure = previousFailureClass === failureClass && (Number(input.newEvidenceCount || 0) <= 0 || sameFailureCount >= unchangedFailureLimit);
336
+ let retryExpectedValue: number | undefined;
337
+ if (input.historicalAcceptanceRate !== undefined && input.estimatedNextRetryCostUsd !== undefined) {
338
+ retryExpectedValue = Number((Number(input.historicalAcceptanceRate) - Number(input.estimatedNextRetryCostUsd)).toFixed(6));
339
+ }
340
+ if (input.currentRun.outcome === 'accepted') {
341
+ return {
342
+ action: 'none',
343
+ failureClass,
344
+ repeatedFailure: false,
345
+ reason: 'Run is already accepted.',
346
+ nextAction: 'No retry required.',
347
+ retryExpectedValue
348
+ };
349
+ }
350
+ if (failureClass === 'manual') {
351
+ return {
352
+ action: 'manual_handoff',
353
+ failureClass,
354
+ repeatedFailure,
355
+ reason: 'Run is marked for manual handoff.',
356
+ nextAction: input.currentRun.nextAction || 'Ask an operator to resolve the run.',
357
+ retryExpectedValue
358
+ };
359
+ }
360
+ if (failureClass === 'stopped') {
361
+ return {
362
+ action: 'stop',
363
+ failureClass,
364
+ repeatedFailure,
365
+ reason: 'Run was stopped before accepted evidence was recorded.',
366
+ nextAction: input.currentRun.nextAction || 'Do not spend another model cycle unless the request is resumed.',
367
+ retryExpectedValue
368
+ };
369
+ }
370
+ if (repeatedFailure) {
371
+ return {
372
+ action: 'stop',
373
+ failureClass,
374
+ repeatedFailure,
375
+ reason: 'The same failure class repeated with no new evidence. Stop model loops until the evidence changes.',
376
+ nextAction: input.currentRun.nextAction || 'Inspect the failing gate before retrying.',
377
+ retryExpectedValue
378
+ };
379
+ }
380
+ if (retryExpectedValue !== undefined && retryExpectedValue < Number(input.minRetryExpectedValue || 0)) {
381
+ return {
382
+ action: 'stop',
383
+ failureClass,
384
+ repeatedFailure,
385
+ reason: 'Historical retry expected value is below the configured threshold.',
386
+ nextAction: input.currentRun.nextAction || 'Do not retry without new evidence or a cheaper targeted repair.',
387
+ retryExpectedValue
388
+ };
389
+ }
390
+ if (failureClass === 'infra') {
391
+ return {
392
+ action: 'retry_infra_repair',
393
+ failureClass,
394
+ repeatedFailure,
395
+ reason: 'QA infrastructure failed before business validation.',
396
+ nextAction: input.currentRun.nextAction || 'Repair browser, settings, Mongo, ports, or startup before model repair.',
397
+ retryExpectedValue
398
+ };
399
+ }
400
+ if (failureClass === 'compile') {
401
+ return {
402
+ action: 'retry_build_repair',
403
+ failureClass,
404
+ repeatedFailure,
405
+ reason: 'Compile/build evidence failed or was stale.',
406
+ nextAction: input.currentRun.nextAction || 'Repair build before browser QA.',
407
+ retryExpectedValue
408
+ };
409
+ }
410
+ if (failureClass === 'route') {
411
+ return {
412
+ action: 'retry_route_repair',
413
+ failureClass,
414
+ repeatedFailure,
415
+ reason: 'Route probe failed before business proof.',
416
+ nextAction: input.currentRun.nextAction || 'Repair route/auth/startup and rerun the exact probe.',
417
+ retryExpectedValue
418
+ };
419
+ }
420
+ if (failureClass === 'release') {
421
+ return {
422
+ action: 'retry_release_repair',
423
+ failureClass,
424
+ repeatedFailure,
425
+ reason: 'Business proof exists but deploy, publish, or sample-data gates block release.',
426
+ nextAction: input.currentRun.nextAction || 'Repair release gates without another broad model planning loop.',
427
+ retryExpectedValue
428
+ };
429
+ }
430
+ if (failureClass === 'business' || failureClass === 'false_pass' || failureClass === 'assistant_correctness') {
431
+ return {
432
+ action: 'retry_business_repair',
433
+ failureClass,
434
+ repeatedFailure,
435
+ reason: 'Business or assistant correctness proof failed or is missing.',
436
+ nextAction: input.currentRun.nextAction || 'Repair the exact failing workflow/query and rerun the deterministic assertion.',
437
+ retryExpectedValue
438
+ };
439
+ }
440
+ return {
441
+ action: 'manual_handoff',
442
+ failureClass,
443
+ repeatedFailure,
444
+ reason: 'Run lacks enough normalized evidence to choose a safe retry lane.',
445
+ nextAction: input.currentRun.nextAction || 'Ingest more run evidence before retrying.',
446
+ retryExpectedValue
447
+ };
448
+ }
449
+
450
+ const supportAccepted004131 = buildAIRun({
451
+ id: 'support-004131',
452
+ source: 'support_ticket',
453
+ sourceIds: { ticketNumber: '004131', ticketId: 'ticket-004131' },
454
+ title: '004131 accepted support fix',
455
+ status: 'Resolved',
456
+ phase: 'COMPLETE',
457
+ events: [{ type: 'git_commit', message: 'Fix support workflow and verified before/action/after proof.' }],
458
+ qa: buildAIQaRun({
459
+ compile: { status: 'pass', artifactPath: '.build-output/build-server.log' },
460
+ routeProbes: [{ route: '/support/004131', status: 'pass', screenshot: 'qa-artifacts/004131-after.jpg' }],
461
+ businessAssertions: [{
462
+ assertion: 'Before/action/after workflow proves the ticket fix.',
463
+ status: 'pass',
464
+ action: 'Run the ticket workflow against seeded data.',
465
+ expected: 'The corrected state is visible.',
466
+ observed: 'The corrected state is visible after the action.',
467
+ artifactPaths: ['qa-artifacts/004131-proof.json']
468
+ }]
469
+ }),
470
+ explicitAccepted: true,
471
+ terminal: true
472
+ });
473
+
474
+ const supportBuildFailed004333 = buildAIRun({
475
+ id: 'support-004333',
476
+ source: 'support_ticket',
477
+ sourceIds: { ticketNumber: '004333', ticketId: 'ticket-004333' },
478
+ title: '004333 compile failure',
479
+ status: 'Running',
480
+ phase: 'QA',
481
+ events: [{ type: 'log', message: 'Angular build failed before browser QA.' }],
482
+ qa: buildAIQaRun({
483
+ compile: { status: 'fail', artifactPath: '.build-output/build-client.log', message: 'TypeScript compile failed.' }
484
+ })
485
+ });
486
+
487
+ const supportInfraFailed004341 = buildAIRun({
488
+ id: 'support-004341',
489
+ source: 'support_ticket',
490
+ sourceIds: { ticketNumber: '004341', ticketId: 'ticket-004341' },
491
+ title: '004341 missing Puppeteer',
492
+ status: 'Running',
493
+ phase: 'QA',
494
+ events: [{ type: 'qa_infra', message: 'Puppeteer module could not be loaded.' }],
495
+ qa: buildAIQaRun({
496
+ infraChecks: [{ name: 'puppeteer_require', status: 'blocked', message: 'Cannot find module puppeteer.' }]
497
+ })
498
+ });
499
+
500
+ const supportFalsePass004421 = buildAIRun({
501
+ id: 'support-004421',
502
+ source: 'support_ticket',
503
+ sourceIds: { ticketNumber: '004421', ticketId: 'ticket-004421' },
504
+ title: '004421 route-only support QA',
505
+ status: 'Passed',
506
+ phase: 'QA',
507
+ events: [{ type: 'scorecard', message: 'Scorecard passed after route loaded.' }],
508
+ qa: buildAIQaRun({
509
+ infraChecks: [{ name: 'chrome_launch', status: 'pass' }],
510
+ compile: { status: 'pass' },
511
+ routeProbes: [{ route: '/support/004421', status: 'pass', screenshot: 'qa-artifacts/004421-route.jpg' }]
512
+ }),
513
+ scorecardPassed: true
514
+ });
515
+
516
+ const supportBusinessFailed004423 = buildAIRun({
517
+ id: 'support-004423',
518
+ source: 'support_ticket',
519
+ sourceIds: { ticketNumber: '004423', ticketId: 'ticket-004423' },
520
+ title: '004423 business assertion failed',
521
+ status: 'Running',
522
+ phase: 'QA',
523
+ events: [{ type: 'qa_business_assertion', message: 'The expected workflow state did not change.' }],
524
+ qa: buildAIQaRun({
525
+ compile: { status: 'pass' },
526
+ routeProbes: [{ route: '/support/004423', status: 'pass' }],
527
+ businessAssertions: [{
528
+ assertion: 'Ticket workflow changes the requested field.',
529
+ status: 'fail',
530
+ expected: 'Field updates after save.',
531
+ observed: 'Field stayed unchanged.'
532
+ }]
533
+ })
534
+ });
535
+
536
+ const supportStaleBuild004430 = buildAIRun({
537
+ id: 'support-004430',
538
+ source: 'support_ticket',
539
+ sourceIds: { ticketNumber: '004430', ticketId: 'ticket-004430' },
540
+ title: '004430 stale build evidence',
541
+ status: 'Running',
542
+ phase: 'QA',
543
+ events: [{ type: 'qa_compile', message: 'Build log predates the final code diff.' }],
544
+ qa: buildAIQaRun({
545
+ compile: { status: 'stale', staleEvidence: true, artifactPath: '.build-output/build-client.log' }
546
+ })
547
+ });
548
+
549
+ const cryptoPortfolioAccepted = buildAIRun({
550
+ id: 'aicoder-crypto-v6-golden',
551
+ source: 'aicoder_app',
552
+ sourceIds: { appId: 'crypto-v6-golden', jobId: 'crypto-job-golden' },
553
+ title: 'Crypto Portfolio Tracker V6 Golden',
554
+ status: 'Passed',
555
+ phase: 'COMPLETE',
556
+ events: [{ type: 'scorecard', message: 'Quality scorecard passed with workflow proof.' }],
557
+ qa: buildAIQaRun({
558
+ compile: { status: 'pass' },
559
+ routeProbes: [{ route: '/portfolio', status: 'pass', screenshot: 'qa-artifacts/crypto-dashboard.jpg' }],
560
+ businessAssertions: [{
561
+ assertion: 'Portfolio dashboard calculates seeded crypto holdings.',
562
+ status: 'pass',
563
+ dataProof: 'Seeded BTC and ETH holdings render totals, allocation, and change.'
564
+ }]
565
+ }),
566
+ scorecardPassed: true,
567
+ deployStatus: 'pass',
568
+ publishStatus: 'published',
569
+ sampleDataStatus: 'pass',
570
+ terminal: true
571
+ });
572
+
573
+ const layflatReleaseBlocked = buildAIRun({
574
+ id: 'aicoder-layflat-pressure-optimizer',
575
+ source: 'aicoder_app',
576
+ sourceIds: { appId: 'layflat-pressure-optimizer', jobId: 'layflat-job' },
577
+ title: 'Layflat Pressure Optimizer',
578
+ status: 'Passed',
579
+ phase: 'COMPLETE',
580
+ events: [{ type: 'scorecard', message: 'Scorecard passed but sample data/publish gate failed.' }],
581
+ qa: buildAIQaRun({
582
+ compile: { status: 'pass' },
583
+ routeProbes: [{ route: '/optimizer', status: 'pass', screenshot: 'qa-artifacts/layflat-route.jpg' }],
584
+ businessAssertions: [{
585
+ assertion: 'Pressure optimizer computes a layflat hose result.',
586
+ status: 'pass',
587
+ dataProof: 'A seeded hose diameter and flow rate produce PSI loss.'
588
+ }]
589
+ }),
590
+ scorecardPassed: true,
591
+ deployStatus: 'pass',
592
+ publishStatus: 'publish failed',
593
+ sampleDataStatus: 'empty seed collections',
594
+ terminal: true
595
+ });
596
+
597
+ const assistantWrongDateWindow = buildAIRun({
598
+ id: 'assistant-wrong-month-window',
599
+ source: 'ai_assistant',
600
+ sourceIds: { conversationId: 'assistant-date-window' },
601
+ title: 'Assistant wrong month/date-window answer',
602
+ status: 'Closed',
603
+ phase: 'ANSWERED',
604
+ events: [{ type: 'assistant_message', message: 'Answered with the wrong month for today-sensitive invoice data.' }],
605
+ qa: buildAIQaRun({
606
+ businessAssertions: [{
607
+ assertion: 'Assistant date window uses the actual current date.',
608
+ status: 'fail',
609
+ expected: 'Use June 2026 for current-month windows.',
610
+ observed: 'Used a stale month.'
611
+ }]
612
+ }),
613
+ rejected: true,
614
+ terminal: true
615
+ });
616
+
617
+ const assistantIllegalProjection = buildAIRun({
618
+ id: 'assistant-illegal-mongo-projection',
619
+ source: 'ai_assistant',
620
+ sourceIds: { conversationId: 'assistant-positional-projection' },
621
+ title: 'Assistant illegal Mongo positional projection',
622
+ status: 'Closed',
623
+ phase: 'ANSWERED',
624
+ events: [{ type: 'assistant_message', message: 'Mongo query used an illegal positional projection shape.' }],
625
+ qa: buildAIQaRun({
626
+ businessAssertions: [{
627
+ assertion: 'Assistant avoids illegal Mongo positional projection.',
628
+ status: 'fail',
629
+ expected: 'Use legal aggregation or field projection shape.',
630
+ observed: 'Used invalid positional projection.'
631
+ }]
632
+ }),
633
+ rejected: true,
634
+ terminal: true
635
+ });
636
+
637
+ const qaMissingPuppeteer = buildAIRun({
638
+ id: 'qa-missing-puppeteer',
639
+ source: 'qa_runner',
640
+ sourceIds: { jobId: 'qa-missing-puppeteer' },
641
+ title: 'QA runner missing Puppeteer',
642
+ status: 'Running',
643
+ phase: 'PREFLIGHT',
644
+ events: [{ type: 'qa_infra', message: 'Puppeteer failed to require.' }],
645
+ qa: buildAIQaRun({
646
+ infraChecks: [{ name: 'puppeteer_require', status: 'blocked', message: 'Cannot find module puppeteer.' }]
647
+ })
648
+ });
649
+
650
+ const qaBadChromePath = buildAIRun({
651
+ id: 'qa-bad-chrome-path',
652
+ source: 'qa_runner',
653
+ sourceIds: { jobId: 'qa-bad-chrome-path' },
654
+ title: 'QA runner bad Chrome path',
655
+ status: 'Running',
656
+ phase: 'PREFLIGHT',
657
+ events: [{ type: 'qa_infra', message: 'Chrome executable path was missing.' }],
658
+ qa: buildAIQaRun({
659
+ infraChecks: [{ name: 'chrome_executable', status: 'fail', message: 'Chrome executable not found.', path: '/bad/chrome' }]
660
+ })
661
+ });
662
+
663
+ const qaCompileFailure = buildAIRun({
664
+ id: 'qa-compile-failure',
665
+ source: 'qa_runner',
666
+ sourceIds: { jobId: 'qa-compile-failure' },
667
+ title: 'QA runner compile failure',
668
+ status: 'Running',
669
+ phase: 'COMPILE',
670
+ events: [{ type: 'qa_compile', message: 'Compile failed before browser QA.' }],
671
+ qa: buildAIQaRun({
672
+ compile: { status: 'fail', command: 'npm run build', artifactPath: '.build-output/build.log' }
673
+ })
674
+ });
675
+
676
+ const qaRouteOnlyPass = buildAIRun({
677
+ id: 'qa-route-only-pass',
678
+ source: 'qa_runner',
679
+ sourceIds: { jobId: 'qa-route-only-pass' },
680
+ title: 'QA runner route-only pass',
681
+ status: 'Passed',
682
+ phase: 'BROWSER_QA',
683
+ events: [{ type: 'qa_route_probe', message: 'Route loaded but no business proof exists.' }],
684
+ qa: buildAIQaRun({
685
+ compile: { status: 'pass' },
686
+ routeProbes: [{ route: '/dashboard', status: 'pass', screenshot: 'qa-artifacts/dashboard.jpg' }]
687
+ }),
688
+ scorecardPassed: true
689
+ });
690
+
691
+ const qaShellOnlyPage = buildAIRun({
692
+ id: 'qa-shell-only-page',
693
+ source: 'qa_runner',
694
+ sourceIds: { jobId: 'qa-shell-only-page' },
695
+ title: 'QA runner shell-only page',
696
+ status: 'Running',
697
+ phase: 'BROWSER_QA',
698
+ events: [{ type: 'qa_route_probe', message: 'Shell-only route loaded.' }],
699
+ qa: buildAIQaRun({
700
+ compile: { status: 'pass' },
701
+ routeProbes: [{ route: '/dashboard', status: 'pass', shellOnly: true, screenshot: 'qa-artifacts/shell.jpg' }]
702
+ })
703
+ });
704
+
705
+ const qaEmptyData = buildAIRun({
706
+ id: 'qa-empty-data',
707
+ source: 'qa_runner',
708
+ sourceIds: { jobId: 'qa-empty-data' },
709
+ title: 'QA runner empty data',
710
+ status: 'Failed',
711
+ phase: 'BROWSER_QA',
712
+ events: [{ type: 'qa_business_assertion', message: 'Workflow rendered empty data.' }],
713
+ qa: buildAIQaRun({
714
+ compile: { status: 'pass' },
715
+ routeProbes: [{ route: '/invoices', status: 'pass' }],
716
+ businessAssertions: [{
717
+ assertion: 'Invoice dashboard renders non-empty meaningful data.',
718
+ status: 'fail',
719
+ expected: 'At least one meaningful invoice row.',
720
+ observed: 'Empty table.'
721
+ }]
722
+ }),
723
+ terminal: true
724
+ });
725
+
726
+ const qaPublishFailureAfterScorecard = buildAIRun({
727
+ id: 'qa-scorecard-pass-publish-failure',
728
+ source: 'qa_runner',
729
+ sourceIds: { jobId: 'qa-publish-failure' },
730
+ title: 'QA scorecard pass followed by publish failure',
731
+ status: 'Passed',
732
+ phase: 'RELEASE',
733
+ events: [{ type: 'publish', message: 'Scorecard passed but publish failed.' }],
734
+ qa: buildAIQaRun({
735
+ compile: { status: 'pass' },
736
+ routeProbes: [{ route: '/app', status: 'pass' }],
737
+ businessAssertions: [{
738
+ assertion: 'Primary app workflow runs.',
739
+ status: 'pass',
740
+ dataProof: 'Workflow action returned expected state.'
741
+ }]
742
+ }),
743
+ scorecardPassed: true,
744
+ publishStatus: 'publish failed',
745
+ sampleDataStatus: 'pass'
746
+ });
747
+
748
+ export const AI_RUN_SEED_EVAL_FIXTURES: AIRunEvalFixture[] = [
749
+ {
750
+ id: 'support-004131',
751
+ title: 'Support 004131 accepted proof',
752
+ source: 'support_ticket',
753
+ run: supportAccepted004131,
754
+ expected: { outcome: 'accepted', failureClass: 'none', gates: [{ key: 'qa_business_assertion', status: 'pass' }] },
755
+ tags: ['support', 'accepted', 'business_assertion']
756
+ },
757
+ {
758
+ id: 'support-004333',
759
+ title: 'Support 004333 compile failure',
760
+ source: 'support_ticket',
761
+ run: supportBuildFailed004333,
762
+ expected: { outcome: 'build_failed', failureClass: 'compile', nextActionIncludes: 'compile' },
763
+ tags: ['support', 'compile']
764
+ },
765
+ {
766
+ id: 'support-004341',
767
+ title: 'Support 004341 Puppeteer infra failure',
768
+ source: 'support_ticket',
769
+ run: supportInfraFailed004341,
770
+ expected: { outcome: 'qa_infra_failed', failureClass: 'infra', nextActionIncludes: 'browser' },
771
+ tags: ['support', 'infra', 'puppeteer']
772
+ },
773
+ {
774
+ id: 'support-004421',
775
+ title: 'Support 004421 route-only false pass',
776
+ source: 'support_ticket',
777
+ run: supportFalsePass004421,
778
+ expected: { outcome: 'false_pass', failureClass: 'false_pass', gates: [{ key: 'qa_business_assertion', status: 'blocked' }] },
779
+ tags: ['support', 'route_only', 'false_pass']
780
+ },
781
+ {
782
+ id: 'support-004423',
783
+ title: 'Support 004423 business assertion failed',
784
+ source: 'support_ticket',
785
+ run: supportBusinessFailed004423,
786
+ expected: { outcome: 'qa_incomplete', failureClass: 'business', nextActionIncludes: 'assertion' },
787
+ tags: ['support', 'business_assertion']
788
+ },
789
+ {
790
+ id: 'support-004430',
791
+ title: 'Support 004430 stale build evidence',
792
+ source: 'support_ticket',
793
+ run: supportStaleBuild004430,
794
+ expected: { outcome: 'build_failed', failureClass: 'compile', nextActionIncludes: 'build' },
795
+ tags: ['support', 'compile', 'stale_build']
796
+ },
797
+ {
798
+ id: 'aicoder-crypto-v6-golden',
799
+ title: 'AICoder Crypto Portfolio Tracker V6 Golden',
800
+ source: 'aicoder_app',
801
+ run: cryptoPortfolioAccepted,
802
+ expected: { outcome: 'accepted', failureClass: 'none', gates: [{ key: 'qa_business_assertion', status: 'pass' }] },
803
+ tags: ['aicoder', 'crypto', 'accepted']
804
+ },
805
+ {
806
+ id: 'aicoder-layflat-pressure-optimizer',
807
+ title: 'AICoder Layflat Pressure Optimizer release blocked',
808
+ source: 'aicoder_app',
809
+ run: layflatReleaseBlocked,
810
+ expected: { outcome: 'release_blocked', failureClass: 'release', gates: [{ key: 'release', status: 'fail' }] },
811
+ tags: ['aicoder', 'layflat', 'release_blocked', 'sample_data']
812
+ },
813
+ {
814
+ id: 'assistant-wrong-month-window',
815
+ title: 'Assistant wrong month/date-window answer',
816
+ source: 'ai_assistant',
817
+ run: assistantWrongDateWindow,
818
+ expected: { outcome: 'rejected', failureClass: 'assistant_correctness' },
819
+ tags: ['assistant', 'date_window']
820
+ },
821
+ {
822
+ id: 'assistant-illegal-mongo-projection',
823
+ title: 'Assistant illegal Mongo positional projection',
824
+ source: 'ai_assistant',
825
+ run: assistantIllegalProjection,
826
+ expected: { outcome: 'rejected', failureClass: 'assistant_correctness' },
827
+ tags: ['assistant', 'mongo_query']
828
+ },
829
+ {
830
+ id: 'qa-missing-puppeteer',
831
+ title: 'QA missing Puppeteer',
832
+ source: 'qa_runner',
833
+ run: qaMissingPuppeteer,
834
+ expected: { outcome: 'qa_infra_failed', failureClass: 'infra' },
835
+ tags: ['qa_runner', 'infra', 'puppeteer']
836
+ },
837
+ {
838
+ id: 'qa-bad-chrome-path',
839
+ title: 'QA bad Chrome path',
840
+ source: 'qa_runner',
841
+ run: qaBadChromePath,
842
+ expected: { outcome: 'qa_infra_failed', failureClass: 'infra' },
843
+ tags: ['qa_runner', 'infra', 'chrome']
844
+ },
845
+ {
846
+ id: 'qa-compile-failure',
847
+ title: 'QA compile failure',
848
+ source: 'qa_runner',
849
+ run: qaCompileFailure,
850
+ expected: { outcome: 'build_failed', failureClass: 'compile' },
851
+ tags: ['qa_runner', 'compile']
852
+ },
853
+ {
854
+ id: 'qa-route-only-pass',
855
+ title: 'QA route-only pass',
856
+ source: 'qa_runner',
857
+ run: qaRouteOnlyPass,
858
+ expected: { outcome: 'false_pass', failureClass: 'false_pass' },
859
+ tags: ['qa_runner', 'route_only', 'false_pass']
860
+ },
861
+ {
862
+ id: 'qa-shell-only-page',
863
+ title: 'QA shell-only page',
864
+ source: 'qa_runner',
865
+ run: qaShellOnlyPage,
866
+ expected: { outcome: 'qa_incomplete', failureClass: 'route' },
867
+ tags: ['qa_runner', 'route', 'shell_only']
868
+ },
869
+ {
870
+ id: 'qa-empty-data',
871
+ title: 'QA empty data',
872
+ source: 'qa_runner',
873
+ run: qaEmptyData,
874
+ expected: { outcome: 'rejected', failureClass: 'business' },
875
+ tags: ['qa_runner', 'empty_data', 'business_assertion']
876
+ },
877
+ {
878
+ id: 'qa-scorecard-pass-publish-failure',
879
+ title: 'QA scorecard pass followed by publish failure',
880
+ source: 'qa_runner',
881
+ run: qaPublishFailureAfterScorecard,
882
+ expected: { outcome: 'release_blocked', failureClass: 'release' },
883
+ tags: ['qa_runner', 'release_blocked', 'publish']
884
+ }
885
+ ];