@resolveio/server-lib 22.3.124 → 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 (711) 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 +3 -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/{public_api.d.ts → src/public_api.ts} +7 -0
  153. package/src/publications/ai-terminal.ts +73 -0
  154. package/src/publications/app-settings.ts +25 -0
  155. package/src/publications/app-status.ts +13 -0
  156. package/src/publications/cron-jobs.ts +40 -0
  157. package/src/publications/customer-notifications.ts +101 -0
  158. package/src/publications/files.ts +33 -0
  159. package/src/publications/flags-update.ts +19 -0
  160. package/src/publications/flags.ts +19 -0
  161. package/src/publications/logs.ts +163 -0
  162. package/src/publications/notifications.ts +13 -0
  163. package/src/publications/report-builder-dashboard-builders.ts +39 -0
  164. package/src/publications/report-builder-libraries.ts +41 -0
  165. package/src/publications/report-builder-reports.ts +47 -0
  166. package/src/publications/super-admin.ts +13 -0
  167. package/src/publications/user-groups.ts +12 -0
  168. package/src/publications/user-guides.ts +12 -0
  169. package/src/resolveio-server-app.ts +617 -0
  170. package/src/server-app.ts +3354 -0
  171. package/src/services/codex-client.ts +1231 -0
  172. package/src/services/openai-client.ts +265 -0
  173. package/src/types/error-report.ts +26 -0
  174. package/src/types/js-tiktoken.d.ts +11 -0
  175. package/src/types/slow-query-report.ts +28 -0
  176. package/src/util/ai-qa-policy.ts +925 -0
  177. package/src/util/ai-run-evidence-adapters.ts +521 -0
  178. package/src/util/ai-run-evidence-dashboard.ts +271 -0
  179. package/src/util/ai-run-evidence-eval.ts +885 -0
  180. package/src/util/ai-run-evidence.ts +964 -0
  181. package/src/util/ai-runner-artifacts.ts +586 -0
  182. package/src/util/ai-runner-qa-auth.ts +821 -0
  183. package/src/util/ai-runner-qa-tools.ts +3045 -0
  184. package/src/util/aicoder-runner-v6.ts +526 -0
  185. package/src/util/common.ts +649 -0
  186. package/src/util/customer-portal-password.ts +183 -0
  187. package/src/util/error-reporter.ts +332 -0
  188. package/src/util/error-tracking.ts +79 -0
  189. package/src/util/openai-usage-cost.ts +114 -0
  190. package/src/util/report-builder-unwinds.ts +180 -0
  191. package/src/util/runner-process-janitor.ts +219 -0
  192. package/src/util/schema-report-builder.ts +448 -0
  193. package/src/util/slow-query-reporter.ts +216 -0
  194. package/src/util/subscription-dependency-context.ts +1096 -0
  195. package/src/util/support-runner-v5.ts +897 -0
  196. package/src/util/tokenizer.ts +38 -0
  197. package/src/workers/codex-runner.worker.ts +142 -0
  198. package/start_server.sh +5 -0
  199. package/tests/ai-assistant-corpus-build.ts +484 -0
  200. package/tests/ai-assistant-corpus-replay-e2e.ts +774 -0
  201. package/tests/ai-assistant-data-parity-e2e.ts +1989 -0
  202. package/tests/ai-assistant-eval-triage.ts +831 -0
  203. package/tests/ai-assistant-openai-e2e.ts +1061 -0
  204. package/tests/ai-assistant-openai-git-e2e.ts +155 -0
  205. package/tests/ai-assistant-preflight-matrix.ts +215 -0
  206. package/tests/ai-assistant-routing-eval.test.ts +560 -0
  207. package/tests/ai-assistant-snf-live-eval.ts +975 -0
  208. package/tests/ai-assistant-utils.test.ts +2968 -0
  209. package/tests/ai-run-eval.test.ts +88 -0
  210. package/tests/ai-run-evidence.test.ts +232 -0
  211. package/tests/ai-runner-contract.test.ts +488 -0
  212. package/tests/aicoder-runner-v6.test.ts +92 -0
  213. package/tests/error-reporter.test.ts +145 -0
  214. package/tests/method-publication-generator.test.ts +46 -0
  215. package/tests/report-builder-linking.test.ts +79 -0
  216. package/tests/resolveio-platform-intelligence.test.ts +352 -0
  217. package/tests/server-app-cron-owner.test.ts +127 -0
  218. package/tests/subscription-connect-race.test.ts +158 -0
  219. package/tests/subscription-dependency-context.test.ts +324 -0
  220. package/tests/subscription-manager-collection-tracking.test.ts +86 -0
  221. package/tests/subscription-manager-invalidation.test.ts +86 -0
  222. package/tests/support-runner-v5.test.ts +191 -0
  223. package/tsconfig.json +34 -0
  224. package/ai/assistant-core-heuristics.d.ts +0 -11
  225. package/ai/assistant-core-heuristics.js +0 -356
  226. package/ai/assistant-core-heuristics.js.map +0 -1
  227. package/ai/resolveio-platform-intelligence-memory-corpus.d.ts +0 -3
  228. package/ai/resolveio-platform-intelligence-memory-corpus.js +0 -214
  229. package/ai/resolveio-platform-intelligence-memory-corpus.js.map +0 -1
  230. package/ai/resolveio-platform-intelligence-memory.d.ts +0 -20
  231. package/ai/resolveio-platform-intelligence-memory.js +0 -341
  232. package/ai/resolveio-platform-intelligence-memory.js.map +0 -1
  233. package/ai/resolveio-platform-intelligence-types.js +0 -4
  234. package/ai/resolveio-platform-intelligence-types.js.map +0 -1
  235. package/ai/resolveio-platform-intelligence.d.ts +0 -6
  236. package/ai/resolveio-platform-intelligence.js +0 -463
  237. package/ai/resolveio-platform-intelligence.js.map +0 -1
  238. package/client-server-app.d.ts +0 -1
  239. package/client-server-app.js +0 -68
  240. package/client-server-app.js.map +0 -1
  241. package/collections/ai-terminal-conversation.collection.d.ts +0 -2
  242. package/collections/ai-terminal-conversation.collection.js +0 -140
  243. package/collections/ai-terminal-conversation.collection.js.map +0 -1
  244. package/collections/ai-terminal-issue-report.collection.d.ts +0 -2
  245. package/collections/ai-terminal-issue-report.collection.js +0 -148
  246. package/collections/ai-terminal-issue-report.collection.js.map +0 -1
  247. package/collections/ai-terminal-message.collection.d.ts +0 -2
  248. package/collections/ai-terminal-message.collection.js +0 -121
  249. package/collections/ai-terminal-message.collection.js.map +0 -1
  250. package/collections/app-setting.collection.d.ts +0 -3
  251. package/collections/app-setting.collection.js +0 -103
  252. package/collections/app-setting.collection.js.map +0 -1
  253. package/collections/app-status.collection.d.ts +0 -3
  254. package/collections/app-status.collection.js +0 -57
  255. package/collections/app-status.collection.js.map +0 -1
  256. package/collections/communication-metric.collection.d.ts +0 -2
  257. package/collections/communication-metric.collection.js +0 -133
  258. package/collections/communication-metric.collection.js.map +0 -1
  259. package/collections/counter.collection.d.ts +0 -3
  260. package/collections/counter.collection.js +0 -56
  261. package/collections/counter.collection.js.map +0 -1
  262. package/collections/cron-job-history.collection.d.ts +0 -3
  263. package/collections/cron-job-history.collection.js +0 -137
  264. package/collections/cron-job-history.collection.js.map +0 -1
  265. package/collections/cron-job.collection.d.ts +0 -3
  266. package/collections/cron-job.collection.js +0 -92
  267. package/collections/cron-job.collection.js.map +0 -1
  268. package/collections/customer-notification.collection.d.ts +0 -3
  269. package/collections/customer-notification.collection.js +0 -130
  270. package/collections/customer-notification.collection.js.map +0 -1
  271. package/collections/customer-portal-password.collection.d.ts +0 -3
  272. package/collections/customer-portal-password.collection.js +0 -75
  273. package/collections/customer-portal-password.collection.js.map +0 -1
  274. package/collections/email-history.collection.d.ts +0 -3
  275. package/collections/email-history.collection.js +0 -134
  276. package/collections/email-history.collection.js.map +0 -1
  277. package/collections/email-verified.collection.d.ts +0 -3
  278. package/collections/email-verified.collection.js +0 -62
  279. package/collections/email-verified.collection.js.map +0 -1
  280. package/collections/file.collection.d.ts +0 -3
  281. package/collections/file.collection.js +0 -74
  282. package/collections/file.collection.js.map +0 -1
  283. package/collections/flag-update.collection.d.ts +0 -3
  284. package/collections/flag-update.collection.js +0 -57
  285. package/collections/flag-update.collection.js.map +0 -1
  286. package/collections/flag.collection.d.ts +0 -3
  287. package/collections/flag.collection.js +0 -57
  288. package/collections/flag.collection.js.map +0 -1
  289. package/collections/log-method-latency.collection.d.ts +0 -3
  290. package/collections/log-method-latency.collection.js +0 -77
  291. package/collections/log-method-latency.collection.js.map +0 -1
  292. package/collections/log-subscription.collection.d.ts +0 -3
  293. package/collections/log-subscription.collection.js +0 -80
  294. package/collections/log-subscription.collection.js.map +0 -1
  295. package/collections/log.collection.d.ts +0 -3
  296. package/collections/log.collection.js +0 -93
  297. package/collections/log.collection.js.map +0 -1
  298. package/collections/logged-in-users.collection.d.ts +0 -3
  299. package/collections/logged-in-users.collection.js +0 -67
  300. package/collections/logged-in-users.collection.js.map +0 -1
  301. package/collections/monitor-cpu.collection.d.ts +0 -3
  302. package/collections/monitor-cpu.collection.js +0 -65
  303. package/collections/monitor-cpu.collection.js.map +0 -1
  304. package/collections/monitor-function.collection.d.ts +0 -3
  305. package/collections/monitor-function.collection.js +0 -74
  306. package/collections/monitor-function.collection.js.map +0 -1
  307. package/collections/monitor-memory.collection.d.ts +0 -3
  308. package/collections/monitor-memory.collection.js +0 -77
  309. package/collections/monitor-memory.collection.js.map +0 -1
  310. package/collections/monitor-mongo.collection.d.ts +0 -3
  311. package/collections/monitor-mongo.collection.js +0 -71
  312. package/collections/monitor-mongo.collection.js.map +0 -1
  313. package/collections/notification.collection.d.ts +0 -3
  314. package/collections/notification.collection.js +0 -57
  315. package/collections/notification.collection.js.map +0 -1
  316. package/collections/openai-usage-ledger.collection.d.ts +0 -2
  317. package/collections/openai-usage-ledger.collection.js +0 -124
  318. package/collections/openai-usage-ledger.collection.js.map +0 -1
  319. package/collections/report-builder-dashboard-builder.collection.d.ts +0 -3
  320. package/collections/report-builder-dashboard-builder.collection.js +0 -109
  321. package/collections/report-builder-dashboard-builder.collection.js.map +0 -1
  322. package/collections/report-builder-library.collection.d.ts +0 -3
  323. package/collections/report-builder-library.collection.js +0 -87
  324. package/collections/report-builder-library.collection.js.map +0 -1
  325. package/collections/report-builder-report.collection.d.ts +0 -4
  326. package/collections/report-builder-report.collection.js +0 -184
  327. package/collections/report-builder-report.collection.js.map +0 -1
  328. package/collections/user-group.collection.d.ts +0 -4
  329. package/collections/user-group.collection.js +0 -89
  330. package/collections/user-group.collection.js.map +0 -1
  331. package/collections/user-guide.collection.d.ts +0 -3
  332. package/collections/user-guide.collection.js +0 -57
  333. package/collections/user-guide.collection.js.map +0 -1
  334. package/collections/user.collection.d.ts +0 -4
  335. package/collections/user.collection.js +0 -180
  336. package/collections/user.collection.js.map +0 -1
  337. package/cron/cron.d.ts +0 -14
  338. package/cron/cron.js +0 -216
  339. package/cron/cron.js.map +0 -1
  340. package/fixtures/cron-jobs.d.ts +0 -1
  341. package/fixtures/cron-jobs.js +0 -150
  342. package/fixtures/cron-jobs.js.map +0 -1
  343. package/fixtures/init.d.ts +0 -1
  344. package/fixtures/init.js +0 -91
  345. package/fixtures/init.js.map +0 -1
  346. package/http/auth.d.ts +0 -2
  347. package/http/auth.js +0 -951
  348. package/http/auth.js.map +0 -1
  349. package/http/health.d.ts +0 -1
  350. package/http/health.js +0 -11
  351. package/http/health.js.map +0 -1
  352. package/http/home.d.ts +0 -1
  353. package/http/home.js +0 -134
  354. package/http/home.js.map +0 -1
  355. package/http/slow-query-publication.d.ts +0 -2
  356. package/http/slow-query-publication.js +0 -99
  357. package/http/slow-query-publication.js.map +0 -1
  358. package/index.d.ts +0 -1
  359. package/index.js +0 -19
  360. package/index.js.map +0 -1
  361. package/managers/ai-assistant-codex-manager.manager.d.ts +0 -67
  362. package/managers/ai-assistant-codex-manager.manager.js +0 -1113
  363. package/managers/ai-assistant-codex-manager.manager.js.map +0 -1
  364. package/managers/communication-metric.manager.d.ts +0 -16
  365. package/managers/communication-metric.manager.js +0 -134
  366. package/managers/communication-metric.manager.js.map +0 -1
  367. package/managers/cron.manager.d.ts +0 -20
  368. package/managers/cron.manager.js +0 -534
  369. package/managers/cron.manager.js.map +0 -1
  370. package/managers/customer-notification-content.manager.d.ts +0 -55
  371. package/managers/customer-notification-content.manager.js +0 -158
  372. package/managers/customer-notification-content.manager.js.map +0 -1
  373. package/managers/diagnostic-manager-bootstrap.d.ts +0 -9
  374. package/managers/diagnostic-manager-bootstrap.js +0 -260
  375. package/managers/diagnostic-manager-bootstrap.js.map +0 -1
  376. package/managers/error-auto-fix.manager.d.ts +0 -149
  377. package/managers/error-auto-fix.manager.js +0 -3064
  378. package/managers/error-auto-fix.manager.js.map +0 -1
  379. package/managers/local-log.manager.d.ts +0 -18
  380. package/managers/local-log.manager.js +0 -88
  381. package/managers/local-log.manager.js.map +0 -1
  382. package/managers/method.manager.d.ts +0 -84
  383. package/managers/method.manager.js +0 -1964
  384. package/managers/method.manager.js.map +0 -1
  385. package/managers/mongo.manager.d.ts +0 -224
  386. package/managers/mongo.manager.js +0 -5000
  387. package/managers/mongo.manager.js.map +0 -1
  388. package/managers/monitor.manager.d.ts +0 -70
  389. package/managers/monitor.manager.js +0 -550
  390. package/managers/monitor.manager.js.map +0 -1
  391. package/managers/openai-usage-ledger.manager.d.ts +0 -15
  392. package/managers/openai-usage-ledger.manager.js +0 -144
  393. package/managers/openai-usage-ledger.manager.js.map +0 -1
  394. package/managers/slow-query-verifier.manager.d.ts +0 -144
  395. package/managers/slow-query-verifier.manager.js +0 -3857
  396. package/managers/slow-query-verifier.manager.js.map +0 -1
  397. package/managers/slow-query.manager.d.ts +0 -28
  398. package/managers/slow-query.manager.js +0 -468
  399. package/managers/slow-query.manager.js.map +0 -1
  400. package/managers/subscription.manager.d.ts +0 -169
  401. package/managers/subscription.manager.js +0 -3434
  402. package/managers/subscription.manager.js.map +0 -1
  403. package/managers/websocket.manager.d.ts +0 -73
  404. package/managers/websocket.manager.js +0 -673
  405. package/managers/websocket.manager.js.map +0 -1
  406. package/managers/worker-dispatcher.manager.d.ts +0 -120
  407. package/managers/worker-dispatcher.manager.js +0 -1266
  408. package/managers/worker-dispatcher.manager.js.map +0 -1
  409. package/managers/worker-server.manager.d.ts +0 -35
  410. package/managers/worker-server.manager.js +0 -582
  411. package/managers/worker-server.manager.js.map +0 -1
  412. package/methods/accounts.d.ts +0 -2
  413. package/methods/accounts.js +0 -624
  414. package/methods/accounts.js.map +0 -1
  415. package/methods/ai-terminal.d.ts +0 -337
  416. package/methods/ai-terminal.js +0 -23166
  417. package/methods/ai-terminal.js.map +0 -1
  418. package/methods/app-settings.d.ts +0 -2
  419. package/methods/app-settings.js +0 -169
  420. package/methods/app-settings.js.map +0 -1
  421. package/methods/aws.d.ts +0 -2
  422. package/methods/aws.js +0 -877
  423. package/methods/aws.js.map +0 -1
  424. package/methods/collections.d.ts +0 -2
  425. package/methods/collections.js +0 -719
  426. package/methods/collections.js.map +0 -1
  427. package/methods/counters.d.ts +0 -2
  428. package/methods/counters.js +0 -113
  429. package/methods/counters.js.map +0 -1
  430. package/methods/cron-jobs.d.ts +0 -2
  431. package/methods/cron-jobs.js +0 -2475
  432. package/methods/cron-jobs.js.map +0 -1
  433. package/methods/customer-notifications.d.ts +0 -2
  434. package/methods/customer-notifications.js +0 -528
  435. package/methods/customer-notifications.js.map +0 -1
  436. package/methods/diagnostics.d.ts +0 -2
  437. package/methods/diagnostics.js +0 -703
  438. package/methods/diagnostics.js.map +0 -1
  439. package/methods/flag-updates.d.ts +0 -2
  440. package/methods/flag-updates.js +0 -8
  441. package/methods/flag-updates.js.map +0 -1
  442. package/methods/flags.d.ts +0 -2
  443. package/methods/flags.js +0 -8
  444. package/methods/flags.js.map +0 -1
  445. package/methods/logs.d.ts +0 -2
  446. package/methods/logs.js +0 -751
  447. package/methods/logs.js.map +0 -1
  448. package/methods/mongo-explorer.d.ts +0 -2
  449. package/methods/mongo-explorer.js +0 -1808
  450. package/methods/mongo-explorer.js.map +0 -1
  451. package/methods/monitor.d.ts +0 -2
  452. package/methods/monitor.js +0 -543
  453. package/methods/monitor.js.map +0 -1
  454. package/methods/pdf.d.ts +0 -2
  455. package/methods/pdf.js +0 -1216
  456. package/methods/pdf.js.map +0 -1
  457. package/methods/publications.d.ts +0 -1
  458. package/methods/publications.js +0 -183
  459. package/methods/publications.js.map +0 -1
  460. package/methods/report-builder.d.ts +0 -2
  461. package/methods/report-builder.js +0 -3094
  462. package/methods/report-builder.js.map +0 -1
  463. package/methods/support.d.ts +0 -2
  464. package/methods/support.js +0 -430
  465. package/methods/support.js.map +0 -1
  466. package/models/ai-terminal-conversation.model.d.ts +0 -17
  467. package/models/ai-terminal-conversation.model.js +0 -4
  468. package/models/ai-terminal-conversation.model.js.map +0 -1
  469. package/models/ai-terminal-issue-report.model.d.ts +0 -19
  470. package/models/ai-terminal-issue-report.model.js +0 -4
  471. package/models/ai-terminal-issue-report.model.js.map +0 -1
  472. package/models/ai-terminal-message.model.d.ts +0 -22
  473. package/models/ai-terminal-message.model.js +0 -4
  474. package/models/ai-terminal-message.model.js.map +0 -1
  475. package/models/app-setting.model.d.ts +0 -16
  476. package/models/app-setting.model.js +0 -4
  477. package/models/app-setting.model.js.map +0 -1
  478. package/models/app-status.model.js +0 -4
  479. package/models/app-status.model.js.map +0 -1
  480. package/models/billing-logged-in-users.model.js +0 -4
  481. package/models/billing-logged-in-users.model.js.map +0 -1
  482. package/models/collection-document.model.d.ts +0 -21
  483. package/models/collection-document.model.js +0 -4
  484. package/models/collection-document.model.js.map +0 -1
  485. package/models/communication-metric.model.d.ts +0 -20
  486. package/models/communication-metric.model.js +0 -4
  487. package/models/communication-metric.model.js.map +0 -1
  488. package/models/counter.model.js +0 -4
  489. package/models/counter.model.js.map +0 -1
  490. package/models/cron-job-history.model.d.ts +0 -15
  491. package/models/cron-job-history.model.js +0 -4
  492. package/models/cron-job-history.model.js.map +0 -1
  493. package/models/cron-job.model.d.ts +0 -14
  494. package/models/cron-job.model.js +0 -4
  495. package/models/cron-job.model.js.map +0 -1
  496. package/models/customer-notification.model.d.ts +0 -26
  497. package/models/customer-notification.model.js +0 -4
  498. package/models/customer-notification.model.js.map +0 -1
  499. package/models/customer-portal-password.model.d.ts +0 -11
  500. package/models/customer-portal-password.model.js +0 -4
  501. package/models/customer-portal-password.model.js.map +0 -1
  502. package/models/dialog.model.d.ts +0 -23
  503. package/models/dialog.model.js +0 -4
  504. package/models/dialog.model.js.map +0 -1
  505. package/models/email-history.model.d.ts +0 -32
  506. package/models/email-history.model.js.map +0 -1
  507. package/models/email-verified.model.js +0 -4
  508. package/models/email-verified.model.js.map +0 -1
  509. package/models/file.model.js +0 -4
  510. package/models/file.model.js.map +0 -1
  511. package/models/flag-update.model.js +0 -4
  512. package/models/flag-update.model.js.map +0 -1
  513. package/models/flag.model.js +0 -4
  514. package/models/flag.model.js.map +0 -1
  515. package/models/log-method-latency.model.d.ts +0 -10
  516. package/models/log-method-latency.model.js +0 -4
  517. package/models/log-method-latency.model.js.map +0 -1
  518. package/models/log-subscription.model.js +0 -4
  519. package/models/log-subscription.model.js.map +0 -1
  520. package/models/log.model.d.ts +0 -17
  521. package/models/log.model.js +0 -4
  522. package/models/log.model.js.map +0 -1
  523. package/models/logged-in-users.model.js +0 -4
  524. package/models/logged-in-users.model.js.map +0 -1
  525. package/models/method-response.model.js +0 -4
  526. package/models/method-response.model.js.map +0 -1
  527. package/models/method.model.d.ts +0 -26
  528. package/models/method.model.js +0 -4
  529. package/models/method.model.js.map +0 -1
  530. package/models/monitor-cpu.model.js +0 -4
  531. package/models/monitor-cpu.model.js.map +0 -1
  532. package/models/monitor-function.model.d.ts +0 -14
  533. package/models/monitor-function.model.js +0 -4
  534. package/models/monitor-function.model.js.map +0 -1
  535. package/models/monitor-memory.model.d.ts +0 -15
  536. package/models/monitor-memory.model.js +0 -4
  537. package/models/monitor-memory.model.js.map +0 -1
  538. package/models/monitor-mongo.model.d.ts +0 -13
  539. package/models/monitor-mongo.model.js +0 -4
  540. package/models/monitor-mongo.model.js.map +0 -1
  541. package/models/notification.model.js +0 -4
  542. package/models/notification.model.js.map +0 -1
  543. package/models/openai-usage-ledger.model.d.ts +0 -15
  544. package/models/openai-usage-ledger.model.js +0 -4
  545. package/models/openai-usage-ledger.model.js.map +0 -1
  546. package/models/pagination.model.d.ts +0 -11
  547. package/models/pagination.model.js +0 -28
  548. package/models/pagination.model.js.map +0 -1
  549. package/models/permission.model.d.ts +0 -12
  550. package/models/permission.model.js +0 -4
  551. package/models/permission.model.js.map +0 -1
  552. package/models/report-builder-dashboard-builder.model.d.ts +0 -25
  553. package/models/report-builder-dashboard-builder.model.js +0 -4
  554. package/models/report-builder-dashboard-builder.model.js.map +0 -1
  555. package/models/report-builder-library.model.d.ts +0 -17
  556. package/models/report-builder-library.model.js +0 -4
  557. package/models/report-builder-library.model.js.map +0 -1
  558. package/models/report-builder-report.model.d.ts +0 -121
  559. package/models/report-builder-report.model.js +0 -4
  560. package/models/report-builder-report.model.js.map +0 -1
  561. package/models/report-builder.model.d.ts +0 -61
  562. package/models/report-builder.model.js +0 -4
  563. package/models/report-builder.model.js.map +0 -1
  564. package/models/select-data-label.model.d.ts +0 -9
  565. package/models/select-data-label.model.js +0 -4
  566. package/models/select-data-label.model.js.map +0 -1
  567. package/models/server-message.model.d.ts +0 -32
  568. package/models/server-message.model.js +0 -4
  569. package/models/server-message.model.js.map +0 -1
  570. package/models/slow-query-report.model.d.ts +0 -23
  571. package/models/slow-query-report.model.js +0 -4
  572. package/models/slow-query-report.model.js.map +0 -1
  573. package/models/subscription.model.d.ts +0 -31
  574. package/models/subscription.model.js +0 -4
  575. package/models/subscription.model.js.map +0 -1
  576. package/models/support-ticket.model.d.ts +0 -87
  577. package/models/support-ticket.model.js +0 -4
  578. package/models/support-ticket.model.js.map +0 -1
  579. package/models/user-group.model.d.ts +0 -20
  580. package/models/user-group.model.js +0 -4
  581. package/models/user-group.model.js.map +0 -1
  582. package/models/user-guide.model.js +0 -4
  583. package/models/user-guide.model.js.map +0 -1
  584. package/models/user.model.d.ts +0 -84
  585. package/models/user.model.js +0 -4
  586. package/models/user.model.js.map +0 -1
  587. package/private/images/ResolveIO.png +0 -0
  588. package/public_api.js +0 -118
  589. package/public_api.js.map +0 -1
  590. package/publications/ai-terminal.d.ts +0 -1
  591. package/publications/ai-terminal.js +0 -122
  592. package/publications/ai-terminal.js.map +0 -1
  593. package/publications/app-settings.d.ts +0 -2
  594. package/publications/app-settings.js +0 -28
  595. package/publications/app-settings.js.map +0 -1
  596. package/publications/app-status.d.ts +0 -2
  597. package/publications/app-status.js +0 -16
  598. package/publications/app-status.js.map +0 -1
  599. package/publications/cron-jobs.d.ts +0 -2
  600. package/publications/cron-jobs.js +0 -88
  601. package/publications/cron-jobs.js.map +0 -1
  602. package/publications/customer-notifications.d.ts +0 -2
  603. package/publications/customer-notifications.js +0 -161
  604. package/publications/customer-notifications.js.map +0 -1
  605. package/publications/files.d.ts +0 -2
  606. package/publications/files.js +0 -36
  607. package/publications/files.js.map +0 -1
  608. package/publications/flags-update.d.ts +0 -2
  609. package/publications/flags-update.js +0 -22
  610. package/publications/flags-update.js.map +0 -1
  611. package/publications/flags.d.ts +0 -2
  612. package/publications/flags.js +0 -22
  613. package/publications/flags.js.map +0 -1
  614. package/publications/logs.d.ts +0 -2
  615. package/publications/logs.js +0 -164
  616. package/publications/logs.js.map +0 -1
  617. package/publications/notifications.d.ts +0 -2
  618. package/publications/notifications.js +0 -16
  619. package/publications/notifications.js.map +0 -1
  620. package/publications/report-builder-dashboard-builders.d.ts +0 -2
  621. package/publications/report-builder-dashboard-builders.js +0 -42
  622. package/publications/report-builder-dashboard-builders.js.map +0 -1
  623. package/publications/report-builder-libraries.d.ts +0 -2
  624. package/publications/report-builder-libraries.js +0 -90
  625. package/publications/report-builder-libraries.js.map +0 -1
  626. package/publications/report-builder-reports.d.ts +0 -2
  627. package/publications/report-builder-reports.js +0 -50
  628. package/publications/report-builder-reports.js.map +0 -1
  629. package/publications/super-admin.d.ts +0 -2
  630. package/publications/super-admin.js +0 -16
  631. package/publications/super-admin.js.map +0 -1
  632. package/publications/user-groups.d.ts +0 -1
  633. package/publications/user-groups.js +0 -16
  634. package/publications/user-groups.js.map +0 -1
  635. package/publications/user-guides.d.ts +0 -1
  636. package/publications/user-guides.js +0 -16
  637. package/publications/user-guides.js.map +0 -1
  638. package/resolveio-server-app.d.ts +0 -70
  639. package/resolveio-server-app.js +0 -801
  640. package/resolveio-server-app.js.map +0 -1
  641. package/server-app.d.ts +0 -228
  642. package/server-app.js +0 -3566
  643. package/server-app.js.map +0 -1
  644. package/services/codex-client.d.ts +0 -128
  645. package/services/codex-client.js +0 -1629
  646. package/services/codex-client.js.map +0 -1
  647. package/services/openai-client.d.ts +0 -46
  648. package/services/openai-client.js +0 -318
  649. package/services/openai-client.js.map +0 -1
  650. package/types/error-report.d.ts +0 -25
  651. package/types/error-report.js +0 -4
  652. package/types/error-report.js.map +0 -1
  653. package/types/slow-query-report.d.ts +0 -27
  654. package/types/slow-query-report.js +0 -6
  655. package/types/slow-query-report.js.map +0 -1
  656. package/util/ai-qa-policy.d.ts +0 -124
  657. package/util/ai-qa-policy.js +0 -736
  658. package/util/ai-qa-policy.js.map +0 -1
  659. package/util/ai-runner-artifacts.d.ts +0 -82
  660. package/util/ai-runner-artifacts.js +0 -713
  661. package/util/ai-runner-artifacts.js.map +0 -1
  662. package/util/ai-runner-qa-auth.d.ts +0 -5
  663. package/util/ai-runner-qa-auth.js +0 -822
  664. package/util/ai-runner-qa-auth.js.map +0 -1
  665. package/util/ai-runner-qa-tools.d.ts +0 -25
  666. package/util/ai-runner-qa-tools.js +0 -2910
  667. package/util/ai-runner-qa-tools.js.map +0 -1
  668. package/util/aicoder-runner-v6.d.ts +0 -168
  669. package/util/aicoder-runner-v6.js +0 -347
  670. package/util/aicoder-runner-v6.js.map +0 -1
  671. package/util/common.d.ts +0 -31
  672. package/util/common.js +0 -683
  673. package/util/common.js.map +0 -1
  674. package/util/customer-portal-password.d.ts +0 -13
  675. package/util/customer-portal-password.js +0 -209
  676. package/util/customer-portal-password.js.map +0 -1
  677. package/util/error-reporter.d.ts +0 -52
  678. package/util/error-reporter.js +0 -326
  679. package/util/error-reporter.js.map +0 -1
  680. package/util/error-tracking.d.ts +0 -13
  681. package/util/error-tracking.js +0 -120
  682. package/util/error-tracking.js.map +0 -1
  683. package/util/report-builder-unwinds.d.ts +0 -15
  684. package/util/report-builder-unwinds.js +0 -156
  685. package/util/report-builder-unwinds.js.map +0 -1
  686. package/util/runner-process-janitor.d.ts +0 -27
  687. package/util/runner-process-janitor.js +0 -208
  688. package/util/runner-process-janitor.js.map +0 -1
  689. package/util/schema-report-builder.d.ts +0 -6
  690. package/util/schema-report-builder.js +0 -481
  691. package/util/schema-report-builder.js.map +0 -1
  692. package/util/slow-query-reporter.d.ts +0 -28
  693. package/util/slow-query-reporter.js +0 -226
  694. package/util/slow-query-reporter.js.map +0 -1
  695. package/util/subscription-dependency-context.d.ts +0 -34
  696. package/util/subscription-dependency-context.js +0 -1283
  697. package/util/subscription-dependency-context.js.map +0 -1
  698. package/util/support-runner-v5.d.ts +0 -250
  699. package/util/support-runner-v5.js +0 -634
  700. package/util/support-runner-v5.js.map +0 -1
  701. package/util/tokenizer.d.ts +0 -5
  702. package/util/tokenizer.js +0 -41
  703. package/util/tokenizer.js.map +0 -1
  704. package/workers/codex-runner.worker.d.ts +0 -1
  705. package/workers/codex-runner.worker.js +0 -192
  706. package/workers/codex-runner.worker.js.map +0 -1
  707. /package/{private → src/private}/email-templates/enrollment.html +0 -0
  708. /package/{private → src/private}/email-templates/forgot-password.html +0 -0
  709. /package/{private → src/private}/email-templates/support-ticket-deleted.html +0 -0
  710. /package/{private → src/private}/email-templates/support-ticket-modified.html +0 -0
  711. /package/{private → src/private}/email-templates/support-ticket.html +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
+ ];