@resolveio/server-lib 22.3.221 → 22.3.222

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 (745) hide show
  1. package/ai/assistant-core-heuristics.d.ts +11 -0
  2. package/ai/assistant-core-heuristics.js +356 -0
  3. package/ai/assistant-core-heuristics.js.map +1 -0
  4. package/ai/resolveio-platform-intelligence-memory-corpus.d.ts +3 -0
  5. package/ai/resolveio-platform-intelligence-memory-corpus.js +214 -0
  6. package/ai/resolveio-platform-intelligence-memory-corpus.js.map +1 -0
  7. package/ai/resolveio-platform-intelligence-memory.d.ts +20 -0
  8. package/ai/resolveio-platform-intelligence-memory.js +341 -0
  9. package/ai/resolveio-platform-intelligence-memory.js.map +1 -0
  10. package/{src/ai/resolveio-platform-intelligence-types.ts → ai/resolveio-platform-intelligence-types.d.ts} +15 -20
  11. package/ai/resolveio-platform-intelligence-types.js +4 -0
  12. package/ai/resolveio-platform-intelligence-types.js.map +1 -0
  13. package/ai/resolveio-platform-intelligence.d.ts +6 -0
  14. package/ai/resolveio-platform-intelligence.js +463 -0
  15. package/ai/resolveio-platform-intelligence.js.map +1 -0
  16. package/client-server-app.d.ts +1 -0
  17. package/client-server-app.js +68 -0
  18. package/client-server-app.js.map +1 -0
  19. package/collections/ai-run.collection.d.ts +3 -0
  20. package/collections/ai-run.collection.js +170 -0
  21. package/collections/ai-run.collection.js.map +1 -0
  22. package/collections/ai-terminal-conversation.collection.d.ts +2 -0
  23. package/collections/ai-terminal-conversation.collection.js +140 -0
  24. package/collections/ai-terminal-conversation.collection.js.map +1 -0
  25. package/collections/ai-terminal-issue-report.collection.d.ts +2 -0
  26. package/collections/ai-terminal-issue-report.collection.js +148 -0
  27. package/collections/ai-terminal-issue-report.collection.js.map +1 -0
  28. package/collections/ai-terminal-message.collection.d.ts +2 -0
  29. package/collections/ai-terminal-message.collection.js +121 -0
  30. package/collections/ai-terminal-message.collection.js.map +1 -0
  31. package/collections/app-setting.collection.d.ts +3 -0
  32. package/collections/app-setting.collection.js +103 -0
  33. package/collections/app-setting.collection.js.map +1 -0
  34. package/collections/app-status.collection.d.ts +3 -0
  35. package/collections/app-status.collection.js +57 -0
  36. package/collections/app-status.collection.js.map +1 -0
  37. package/collections/communication-metric.collection.d.ts +2 -0
  38. package/collections/communication-metric.collection.js +133 -0
  39. package/collections/communication-metric.collection.js.map +1 -0
  40. package/collections/counter.collection.d.ts +3 -0
  41. package/collections/counter.collection.js +56 -0
  42. package/collections/counter.collection.js.map +1 -0
  43. package/collections/cron-job-history.collection.d.ts +3 -0
  44. package/collections/cron-job-history.collection.js +137 -0
  45. package/collections/cron-job-history.collection.js.map +1 -0
  46. package/collections/cron-job.collection.d.ts +3 -0
  47. package/collections/cron-job.collection.js +92 -0
  48. package/collections/cron-job.collection.js.map +1 -0
  49. package/collections/customer-notification.collection.d.ts +3 -0
  50. package/collections/customer-notification.collection.js +130 -0
  51. package/collections/customer-notification.collection.js.map +1 -0
  52. package/collections/customer-portal-password.collection.d.ts +3 -0
  53. package/collections/customer-portal-password.collection.js +75 -0
  54. package/collections/customer-portal-password.collection.js.map +1 -0
  55. package/collections/email-history.collection.d.ts +3 -0
  56. package/collections/email-history.collection.js +134 -0
  57. package/collections/email-history.collection.js.map +1 -0
  58. package/collections/email-verified.collection.d.ts +3 -0
  59. package/collections/email-verified.collection.js +62 -0
  60. package/collections/email-verified.collection.js.map +1 -0
  61. package/collections/file.collection.d.ts +3 -0
  62. package/collections/file.collection.js +74 -0
  63. package/collections/file.collection.js.map +1 -0
  64. package/collections/flag-update.collection.d.ts +3 -0
  65. package/collections/flag-update.collection.js +57 -0
  66. package/collections/flag-update.collection.js.map +1 -0
  67. package/collections/flag.collection.d.ts +3 -0
  68. package/collections/flag.collection.js +57 -0
  69. package/collections/flag.collection.js.map +1 -0
  70. package/collections/log-method-latency.collection.d.ts +3 -0
  71. package/collections/log-method-latency.collection.js +77 -0
  72. package/collections/log-method-latency.collection.js.map +1 -0
  73. package/collections/log-subscription.collection.d.ts +3 -0
  74. package/collections/log-subscription.collection.js +80 -0
  75. package/collections/log-subscription.collection.js.map +1 -0
  76. package/collections/log.collection.d.ts +3 -0
  77. package/collections/log.collection.js +93 -0
  78. package/collections/log.collection.js.map +1 -0
  79. package/collections/logged-in-users.collection.d.ts +3 -0
  80. package/collections/logged-in-users.collection.js +67 -0
  81. package/collections/logged-in-users.collection.js.map +1 -0
  82. package/collections/monitor-cpu.collection.d.ts +3 -0
  83. package/collections/monitor-cpu.collection.js +65 -0
  84. package/collections/monitor-cpu.collection.js.map +1 -0
  85. package/collections/monitor-function.collection.d.ts +3 -0
  86. package/collections/monitor-function.collection.js +74 -0
  87. package/collections/monitor-function.collection.js.map +1 -0
  88. package/collections/monitor-memory.collection.d.ts +3 -0
  89. package/collections/monitor-memory.collection.js +77 -0
  90. package/collections/monitor-memory.collection.js.map +1 -0
  91. package/collections/monitor-mongo.collection.d.ts +3 -0
  92. package/collections/monitor-mongo.collection.js +71 -0
  93. package/collections/monitor-mongo.collection.js.map +1 -0
  94. package/collections/notification.collection.d.ts +3 -0
  95. package/collections/notification.collection.js +57 -0
  96. package/collections/notification.collection.js.map +1 -0
  97. package/collections/openai-usage-ledger.collection.d.ts +2 -0
  98. package/collections/openai-usage-ledger.collection.js +188 -0
  99. package/collections/openai-usage-ledger.collection.js.map +1 -0
  100. package/collections/report-builder-dashboard-builder.collection.d.ts +3 -0
  101. package/collections/report-builder-dashboard-builder.collection.js +109 -0
  102. package/collections/report-builder-dashboard-builder.collection.js.map +1 -0
  103. package/collections/report-builder-library.collection.d.ts +3 -0
  104. package/collections/report-builder-library.collection.js +87 -0
  105. package/collections/report-builder-library.collection.js.map +1 -0
  106. package/collections/report-builder-report.collection.d.ts +4 -0
  107. package/collections/report-builder-report.collection.js +184 -0
  108. package/collections/report-builder-report.collection.js.map +1 -0
  109. package/collections/user-group.collection.d.ts +4 -0
  110. package/collections/user-group.collection.js +89 -0
  111. package/collections/user-group.collection.js.map +1 -0
  112. package/collections/user-guide.collection.d.ts +3 -0
  113. package/collections/user-guide.collection.js +57 -0
  114. package/collections/user-guide.collection.js.map +1 -0
  115. package/collections/user.collection.d.ts +4 -0
  116. package/collections/user.collection.js +180 -0
  117. package/collections/user.collection.js.map +1 -0
  118. package/cron/cron.d.ts +14 -0
  119. package/cron/cron.js +216 -0
  120. package/cron/cron.js.map +1 -0
  121. package/fixtures/cron-jobs.d.ts +1 -0
  122. package/fixtures/cron-jobs.js +150 -0
  123. package/fixtures/cron-jobs.js.map +1 -0
  124. package/fixtures/init.d.ts +1 -0
  125. package/fixtures/init.js +91 -0
  126. package/fixtures/init.js.map +1 -0
  127. package/http/auth.d.ts +2 -0
  128. package/http/auth.js +951 -0
  129. package/http/auth.js.map +1 -0
  130. package/http/health.d.ts +1 -0
  131. package/http/health.js +11 -0
  132. package/http/health.js.map +1 -0
  133. package/http/home.d.ts +1 -0
  134. package/http/home.js +134 -0
  135. package/http/home.js.map +1 -0
  136. package/http/slow-query-publication.d.ts +2 -0
  137. package/http/slow-query-publication.js +99 -0
  138. package/http/slow-query-publication.js.map +1 -0
  139. package/index.d.ts +1 -0
  140. package/index.js +19 -0
  141. package/index.js.map +1 -0
  142. package/managers/ai-assistant-codex-manager.manager.d.ts +67 -0
  143. package/managers/ai-assistant-codex-manager.manager.js +1113 -0
  144. package/managers/ai-assistant-codex-manager.manager.js.map +1 -0
  145. package/managers/ai-run-evidence.manager.d.ts +36 -0
  146. package/managers/ai-run-evidence.manager.js +377 -0
  147. package/managers/ai-run-evidence.manager.js.map +1 -0
  148. package/managers/communication-metric.manager.d.ts +16 -0
  149. package/managers/communication-metric.manager.js +134 -0
  150. package/managers/communication-metric.manager.js.map +1 -0
  151. package/managers/cron.manager.d.ts +20 -0
  152. package/managers/cron.manager.js +534 -0
  153. package/managers/cron.manager.js.map +1 -0
  154. package/managers/customer-notification-content.manager.d.ts +55 -0
  155. package/managers/customer-notification-content.manager.js +158 -0
  156. package/managers/customer-notification-content.manager.js.map +1 -0
  157. package/managers/diagnostic-manager-bootstrap.d.ts +9 -0
  158. package/managers/diagnostic-manager-bootstrap.js +260 -0
  159. package/managers/diagnostic-manager-bootstrap.js.map +1 -0
  160. package/managers/error-auto-fix.manager.d.ts +149 -0
  161. package/managers/error-auto-fix.manager.js +3064 -0
  162. package/managers/error-auto-fix.manager.js.map +1 -0
  163. package/managers/local-log.manager.d.ts +18 -0
  164. package/managers/local-log.manager.js +88 -0
  165. package/managers/local-log.manager.js.map +1 -0
  166. package/managers/method.manager.d.ts +84 -0
  167. package/managers/method.manager.js +1964 -0
  168. package/managers/method.manager.js.map +1 -0
  169. package/managers/mongo.manager.d.ts +224 -0
  170. package/managers/mongo.manager.js +5000 -0
  171. package/managers/mongo.manager.js.map +1 -0
  172. package/managers/monitor.manager.d.ts +70 -0
  173. package/managers/monitor.manager.js +550 -0
  174. package/managers/monitor.manager.js.map +1 -0
  175. package/managers/openai-usage-ledger.manager.d.ts +30 -0
  176. package/managers/openai-usage-ledger.manager.js +142 -0
  177. package/managers/openai-usage-ledger.manager.js.map +1 -0
  178. package/managers/slow-query-verifier.manager.d.ts +144 -0
  179. package/managers/slow-query-verifier.manager.js +3857 -0
  180. package/managers/slow-query-verifier.manager.js.map +1 -0
  181. package/managers/slow-query.manager.d.ts +28 -0
  182. package/managers/slow-query.manager.js +468 -0
  183. package/managers/slow-query.manager.js.map +1 -0
  184. package/managers/subscription.manager.d.ts +169 -0
  185. package/managers/subscription.manager.js +3434 -0
  186. package/managers/subscription.manager.js.map +1 -0
  187. package/managers/websocket.manager.d.ts +73 -0
  188. package/managers/websocket.manager.js +673 -0
  189. package/managers/websocket.manager.js.map +1 -0
  190. package/managers/worker-dispatcher.manager.d.ts +120 -0
  191. package/managers/worker-dispatcher.manager.js +1266 -0
  192. package/managers/worker-dispatcher.manager.js.map +1 -0
  193. package/managers/worker-server.manager.d.ts +35 -0
  194. package/managers/worker-server.manager.js +582 -0
  195. package/managers/worker-server.manager.js.map +1 -0
  196. package/methods/accounts.d.ts +2 -0
  197. package/methods/accounts.js +624 -0
  198. package/methods/accounts.js.map +1 -0
  199. package/methods/ai-terminal.d.ts +458 -0
  200. package/methods/ai-terminal.js +27991 -0
  201. package/methods/ai-terminal.js.map +1 -0
  202. package/methods/app-settings.d.ts +2 -0
  203. package/methods/app-settings.js +169 -0
  204. package/methods/app-settings.js.map +1 -0
  205. package/methods/aws.d.ts +2 -0
  206. package/methods/aws.js +877 -0
  207. package/methods/aws.js.map +1 -0
  208. package/methods/collections.d.ts +2 -0
  209. package/methods/collections.js +719 -0
  210. package/methods/collections.js.map +1 -0
  211. package/methods/counters.d.ts +2 -0
  212. package/methods/counters.js +113 -0
  213. package/methods/counters.js.map +1 -0
  214. package/methods/cron-jobs.d.ts +2 -0
  215. package/methods/cron-jobs.js +2475 -0
  216. package/methods/cron-jobs.js.map +1 -0
  217. package/methods/customer-notifications.d.ts +2 -0
  218. package/methods/customer-notifications.js +528 -0
  219. package/methods/customer-notifications.js.map +1 -0
  220. package/methods/diagnostics.d.ts +2 -0
  221. package/methods/diagnostics.js +703 -0
  222. package/methods/diagnostics.js.map +1 -0
  223. package/methods/flag-updates.d.ts +2 -0
  224. package/methods/flag-updates.js +8 -0
  225. package/methods/flag-updates.js.map +1 -0
  226. package/methods/flags.d.ts +2 -0
  227. package/methods/flags.js +8 -0
  228. package/methods/flags.js.map +1 -0
  229. package/methods/logs.d.ts +2 -0
  230. package/methods/logs.js +751 -0
  231. package/methods/logs.js.map +1 -0
  232. package/methods/mongo-explorer.d.ts +2 -0
  233. package/methods/mongo-explorer.js +1808 -0
  234. package/methods/mongo-explorer.js.map +1 -0
  235. package/methods/monitor.d.ts +2 -0
  236. package/methods/monitor.js +543 -0
  237. package/methods/monitor.js.map +1 -0
  238. package/methods/pdf.d.ts +2 -0
  239. package/methods/pdf.js +1216 -0
  240. package/methods/pdf.js.map +1 -0
  241. package/methods/publications.d.ts +1 -0
  242. package/methods/publications.js +183 -0
  243. package/methods/publications.js.map +1 -0
  244. package/methods/report-builder.d.ts +2 -0
  245. package/methods/report-builder.js +3094 -0
  246. package/methods/report-builder.js.map +1 -0
  247. package/methods/support.d.ts +2 -0
  248. package/methods/support.js +430 -0
  249. package/methods/support.js.map +1 -0
  250. package/models/ai-run.model.d.ts +19 -0
  251. package/models/ai-run.model.js +4 -0
  252. package/models/ai-run.model.js.map +1 -0
  253. package/models/ai-terminal-conversation.model.d.ts +17 -0
  254. package/models/ai-terminal-conversation.model.js +4 -0
  255. package/models/ai-terminal-conversation.model.js.map +1 -0
  256. package/models/ai-terminal-issue-report.model.d.ts +19 -0
  257. package/models/ai-terminal-issue-report.model.js +4 -0
  258. package/models/ai-terminal-issue-report.model.js.map +1 -0
  259. package/models/ai-terminal-message.model.d.ts +22 -0
  260. package/models/ai-terminal-message.model.js +4 -0
  261. package/models/ai-terminal-message.model.js.map +1 -0
  262. package/models/app-setting.model.d.ts +16 -0
  263. package/models/app-setting.model.js +4 -0
  264. package/models/app-setting.model.js.map +1 -0
  265. package/{src/models/app-status.model.ts → models/app-status.model.d.ts} +2 -3
  266. package/models/app-status.model.js +4 -0
  267. package/models/app-status.model.js.map +1 -0
  268. package/{src/models/billing-logged-in-users.model.ts → models/billing-logged-in-users.model.d.ts} +4 -5
  269. package/models/billing-logged-in-users.model.js +4 -0
  270. package/models/billing-logged-in-users.model.js.map +1 -0
  271. package/models/collection-document.model.d.ts +21 -0
  272. package/models/collection-document.model.js +4 -0
  273. package/models/collection-document.model.js.map +1 -0
  274. package/models/communication-metric.model.d.ts +20 -0
  275. package/models/communication-metric.model.js +4 -0
  276. package/models/communication-metric.model.js.map +1 -0
  277. package/{src/models/counter.model.ts → models/counter.model.d.ts} +3 -4
  278. package/models/counter.model.js +4 -0
  279. package/models/counter.model.js.map +1 -0
  280. package/models/cron-job-history.model.d.ts +15 -0
  281. package/models/cron-job-history.model.js +4 -0
  282. package/models/cron-job-history.model.js.map +1 -0
  283. package/models/cron-job.model.d.ts +14 -0
  284. package/models/cron-job.model.js +4 -0
  285. package/models/cron-job.model.js.map +1 -0
  286. package/models/customer-notification.model.d.ts +26 -0
  287. package/models/customer-notification.model.js +4 -0
  288. package/models/customer-notification.model.js.map +1 -0
  289. package/models/customer-portal-password.model.d.ts +11 -0
  290. package/models/customer-portal-password.model.js +4 -0
  291. package/models/customer-portal-password.model.js.map +1 -0
  292. package/models/dialog.model.d.ts +23 -0
  293. package/models/dialog.model.js +4 -0
  294. package/models/dialog.model.js.map +1 -0
  295. package/models/email-history.model.d.ts +32 -0
  296. package/{src/models/email-history.model.ts → models/email-history.model.js} +4 -36
  297. package/models/email-history.model.js.map +1 -0
  298. package/{src/models/email-verified.model.ts → models/email-verified.model.d.ts} +5 -6
  299. package/models/email-verified.model.js +4 -0
  300. package/models/email-verified.model.js.map +1 -0
  301. package/{src/models/file.model.ts → models/file.model.d.ts} +7 -8
  302. package/models/file.model.js +4 -0
  303. package/models/file.model.js.map +1 -0
  304. package/{src/models/flag-update.model.ts → models/flag-update.model.d.ts} +3 -4
  305. package/models/flag-update.model.js +4 -0
  306. package/models/flag-update.model.js.map +1 -0
  307. package/{src/models/flag.model.ts → models/flag.model.d.ts} +3 -4
  308. package/models/flag.model.js +4 -0
  309. package/models/flag.model.js.map +1 -0
  310. package/models/log-method-latency.model.d.ts +10 -0
  311. package/models/log-method-latency.model.js +4 -0
  312. package/models/log-method-latency.model.js.map +1 -0
  313. package/{src/models/log-subscription.model.ts → models/log-subscription.model.d.ts} +9 -11
  314. package/models/log-subscription.model.js +4 -0
  315. package/models/log-subscription.model.js.map +1 -0
  316. package/models/log.model.d.ts +17 -0
  317. package/models/log.model.js +4 -0
  318. package/models/log.model.js.map +1 -0
  319. package/{src/models/logged-in-users.model.ts → models/logged-in-users.model.d.ts} +5 -6
  320. package/models/logged-in-users.model.js +4 -0
  321. package/models/logged-in-users.model.js.map +1 -0
  322. package/{src/models/method-response.model.ts → models/method-response.model.d.ts} +6 -7
  323. package/models/method-response.model.js +4 -0
  324. package/models/method-response.model.js.map +1 -0
  325. package/models/method.model.d.ts +26 -0
  326. package/models/method.model.js +4 -0
  327. package/models/method.model.js.map +1 -0
  328. package/{src/models/monitor-cpu.model.ts → models/monitor-cpu.model.d.ts} +7 -9
  329. package/models/monitor-cpu.model.js +4 -0
  330. package/models/monitor-cpu.model.js.map +1 -0
  331. package/models/monitor-function.model.d.ts +14 -0
  332. package/models/monitor-function.model.js +4 -0
  333. package/models/monitor-function.model.js.map +1 -0
  334. package/models/monitor-memory.model.d.ts +15 -0
  335. package/models/monitor-memory.model.js +4 -0
  336. package/models/monitor-memory.model.js.map +1 -0
  337. package/models/monitor-mongo.model.d.ts +13 -0
  338. package/models/monitor-mongo.model.js +4 -0
  339. package/models/monitor-mongo.model.js.map +1 -0
  340. package/{src/models/notification.model.ts → models/notification.model.d.ts} +4 -6
  341. package/models/notification.model.js +4 -0
  342. package/models/notification.model.js.map +1 -0
  343. package/models/openai-usage-ledger.model.d.ts +30 -0
  344. package/models/openai-usage-ledger.model.js +4 -0
  345. package/models/openai-usage-ledger.model.js.map +1 -0
  346. package/models/pagination.model.d.ts +11 -0
  347. package/models/pagination.model.js +28 -0
  348. package/models/pagination.model.js.map +1 -0
  349. package/models/permission.model.d.ts +12 -0
  350. package/models/permission.model.js +4 -0
  351. package/models/permission.model.js.map +1 -0
  352. package/models/report-builder-dashboard-builder.model.d.ts +25 -0
  353. package/models/report-builder-dashboard-builder.model.js +4 -0
  354. package/models/report-builder-dashboard-builder.model.js.map +1 -0
  355. package/models/report-builder-library.model.d.ts +17 -0
  356. package/models/report-builder-library.model.js +4 -0
  357. package/models/report-builder-library.model.js.map +1 -0
  358. package/models/report-builder-report.model.d.ts +121 -0
  359. package/models/report-builder-report.model.js +4 -0
  360. package/models/report-builder-report.model.js.map +1 -0
  361. package/models/report-builder.model.d.ts +61 -0
  362. package/models/report-builder.model.js +4 -0
  363. package/models/report-builder.model.js.map +1 -0
  364. package/models/select-data-label.model.d.ts +9 -0
  365. package/models/select-data-label.model.js +4 -0
  366. package/models/select-data-label.model.js.map +1 -0
  367. package/models/server-message.model.d.ts +32 -0
  368. package/models/server-message.model.js +4 -0
  369. package/models/server-message.model.js.map +1 -0
  370. package/models/slow-query-report.model.d.ts +23 -0
  371. package/models/slow-query-report.model.js +4 -0
  372. package/models/slow-query-report.model.js.map +1 -0
  373. package/models/subscription.model.d.ts +31 -0
  374. package/models/subscription.model.js +4 -0
  375. package/models/subscription.model.js.map +1 -0
  376. package/models/support-ticket.model.d.ts +87 -0
  377. package/models/support-ticket.model.js +4 -0
  378. package/models/support-ticket.model.js.map +1 -0
  379. package/models/user-group.model.d.ts +20 -0
  380. package/models/user-group.model.js +4 -0
  381. package/models/user-group.model.js.map +1 -0
  382. package/{src/models/user-guide.model.ts → models/user-guide.model.d.ts} +4 -5
  383. package/models/user-guide.model.js +4 -0
  384. package/models/user-guide.model.js.map +1 -0
  385. package/models/user.model.d.ts +84 -0
  386. package/models/user.model.js +4 -0
  387. package/models/user.model.js.map +1 -0
  388. package/package.json +1 -1
  389. package/private/images/ResolveIO.png +0 -0
  390. package/public_api.js +127 -0
  391. package/public_api.js.map +1 -0
  392. package/publications/ai-terminal.d.ts +1 -0
  393. package/publications/ai-terminal.js +122 -0
  394. package/publications/ai-terminal.js.map +1 -0
  395. package/publications/app-settings.d.ts +2 -0
  396. package/publications/app-settings.js +28 -0
  397. package/publications/app-settings.js.map +1 -0
  398. package/publications/app-status.d.ts +2 -0
  399. package/publications/app-status.js +16 -0
  400. package/publications/app-status.js.map +1 -0
  401. package/publications/cron-jobs.d.ts +2 -0
  402. package/publications/cron-jobs.js +88 -0
  403. package/publications/cron-jobs.js.map +1 -0
  404. package/publications/customer-notifications.d.ts +2 -0
  405. package/publications/customer-notifications.js +161 -0
  406. package/publications/customer-notifications.js.map +1 -0
  407. package/publications/files.d.ts +2 -0
  408. package/publications/files.js +36 -0
  409. package/publications/files.js.map +1 -0
  410. package/publications/flags-update.d.ts +2 -0
  411. package/publications/flags-update.js +22 -0
  412. package/publications/flags-update.js.map +1 -0
  413. package/publications/flags.d.ts +2 -0
  414. package/publications/flags.js +22 -0
  415. package/publications/flags.js.map +1 -0
  416. package/publications/logs.d.ts +2 -0
  417. package/publications/logs.js +164 -0
  418. package/publications/logs.js.map +1 -0
  419. package/publications/notifications.d.ts +2 -0
  420. package/publications/notifications.js +16 -0
  421. package/publications/notifications.js.map +1 -0
  422. package/publications/report-builder-dashboard-builders.d.ts +2 -0
  423. package/publications/report-builder-dashboard-builders.js +42 -0
  424. package/publications/report-builder-dashboard-builders.js.map +1 -0
  425. package/publications/report-builder-libraries.d.ts +2 -0
  426. package/publications/report-builder-libraries.js +90 -0
  427. package/publications/report-builder-libraries.js.map +1 -0
  428. package/publications/report-builder-reports.d.ts +2 -0
  429. package/publications/report-builder-reports.js +50 -0
  430. package/publications/report-builder-reports.js.map +1 -0
  431. package/publications/super-admin.d.ts +2 -0
  432. package/publications/super-admin.js +16 -0
  433. package/publications/super-admin.js.map +1 -0
  434. package/publications/user-groups.d.ts +1 -0
  435. package/publications/user-groups.js +16 -0
  436. package/publications/user-groups.js.map +1 -0
  437. package/publications/user-guides.d.ts +1 -0
  438. package/publications/user-guides.js +16 -0
  439. package/publications/user-guides.js.map +1 -0
  440. package/resolveio-server-app.d.ts +70 -0
  441. package/resolveio-server-app.js +801 -0
  442. package/resolveio-server-app.js.map +1 -0
  443. package/server-app.d.ts +228 -0
  444. package/server-app.js +3566 -0
  445. package/server-app.js.map +1 -0
  446. package/services/codex-client.d.ts +128 -0
  447. package/services/codex-client.js +1629 -0
  448. package/services/codex-client.js.map +1 -0
  449. package/services/openai-client.d.ts +46 -0
  450. package/services/openai-client.js +318 -0
  451. package/services/openai-client.js.map +1 -0
  452. package/types/error-report.d.ts +25 -0
  453. package/types/error-report.js +4 -0
  454. package/types/error-report.js.map +1 -0
  455. package/types/slow-query-report.d.ts +27 -0
  456. package/types/slow-query-report.js +6 -0
  457. package/types/slow-query-report.js.map +1 -0
  458. package/util/ai-qa-policy.d.ts +124 -0
  459. package/util/ai-qa-policy.js +736 -0
  460. package/util/ai-qa-policy.js.map +1 -0
  461. package/util/ai-run-evidence-adapters.d.ts +109 -0
  462. package/util/ai-run-evidence-adapters.js +7234 -0
  463. package/util/ai-run-evidence-adapters.js.map +1 -0
  464. package/util/ai-run-evidence-dashboard.d.ts +88 -0
  465. package/util/ai-run-evidence-dashboard.js +343 -0
  466. package/util/ai-run-evidence-dashboard.js.map +1 -0
  467. package/util/ai-run-evidence-eval.d.ts +86 -0
  468. package/util/ai-run-evidence-eval.js +1018 -0
  469. package/util/ai-run-evidence-eval.js.map +1 -0
  470. package/util/ai-run-evidence.d.ts +244 -0
  471. package/util/ai-run-evidence.js +1096 -0
  472. package/util/ai-run-evidence.js.map +1 -0
  473. package/util/ai-runner-artifacts.d.ts +82 -0
  474. package/util/ai-runner-artifacts.js +713 -0
  475. package/util/ai-runner-artifacts.js.map +1 -0
  476. package/util/ai-runner-manager-autopilot.d.ts +210 -0
  477. package/util/ai-runner-manager-autopilot.js +642 -0
  478. package/util/ai-runner-manager-autopilot.js.map +1 -0
  479. package/util/ai-runner-manager-policy.d.ts +807 -0
  480. package/util/ai-runner-manager-policy.js +3501 -0
  481. package/util/ai-runner-manager-policy.js.map +1 -0
  482. package/util/ai-runner-qa-auth.d.ts +5 -0
  483. package/util/ai-runner-qa-auth.js +839 -0
  484. package/util/ai-runner-qa-auth.js.map +1 -0
  485. package/util/ai-runner-qa-tools.d.ts +26 -0
  486. package/util/ai-runner-qa-tools.js +3520 -0
  487. package/util/ai-runner-qa-tools.js.map +1 -0
  488. package/util/aicoder-runner-v6.d.ts +426 -0
  489. package/util/aicoder-runner-v6.js +2464 -0
  490. package/util/aicoder-runner-v6.js.map +1 -0
  491. package/util/common.d.ts +31 -0
  492. package/util/common.js +683 -0
  493. package/util/common.js.map +1 -0
  494. package/util/customer-portal-password.d.ts +13 -0
  495. package/util/customer-portal-password.js +209 -0
  496. package/util/customer-portal-password.js.map +1 -0
  497. package/util/error-reporter.d.ts +52 -0
  498. package/util/error-reporter.js +326 -0
  499. package/util/error-reporter.js.map +1 -0
  500. package/util/error-tracking.d.ts +13 -0
  501. package/util/error-tracking.js +120 -0
  502. package/util/error-tracking.js.map +1 -0
  503. package/util/openai-usage-cost.d.ts +6 -0
  504. package/util/openai-usage-cost.js +103 -0
  505. package/util/openai-usage-cost.js.map +1 -0
  506. package/util/report-builder-unwinds.d.ts +15 -0
  507. package/util/report-builder-unwinds.js +156 -0
  508. package/util/report-builder-unwinds.js.map +1 -0
  509. package/util/runner-process-janitor.d.ts +27 -0
  510. package/util/runner-process-janitor.js +208 -0
  511. package/util/runner-process-janitor.js.map +1 -0
  512. package/util/schema-report-builder.d.ts +6 -0
  513. package/util/schema-report-builder.js +481 -0
  514. package/util/schema-report-builder.js.map +1 -0
  515. package/util/slow-query-reporter.d.ts +28 -0
  516. package/util/slow-query-reporter.js +226 -0
  517. package/util/slow-query-reporter.js.map +1 -0
  518. package/util/subscription-dependency-context.d.ts +34 -0
  519. package/util/subscription-dependency-context.js +1283 -0
  520. package/util/subscription-dependency-context.js.map +1 -0
  521. package/util/support-runner-v5.d.ts +1426 -0
  522. package/util/support-runner-v5.js +7643 -0
  523. package/util/support-runner-v5.js.map +1 -0
  524. package/util/tokenizer.d.ts +5 -0
  525. package/util/tokenizer.js +41 -0
  526. package/util/tokenizer.js.map +1 -0
  527. package/workers/codex-runner.worker.d.ts +1 -0
  528. package/workers/codex-runner.worker.js +192 -0
  529. package/workers/codex-runner.worker.js.map +1 -0
  530. package/.nodemon.json +0 -5
  531. package/.vscode/settings.json +0 -21
  532. package/AGENTS.md +0 -195
  533. package/README.md +0 -22
  534. package/build_package.sh +0 -5
  535. package/compileDTS.pl +0 -64
  536. package/docs/ai-assistant-nightly-eval.md +0 -65
  537. package/docs/ai-assistant-preflight-checklist.md +0 -23
  538. package/docs/ai-assistant-report-builder-bridge-playbook.md +0 -115
  539. package/eslint-plugin-custom/index.js +0 -7
  540. package/eslint-plugin-custom/rules/no-filter-zero-index.js +0 -44
  541. package/eslint.config.js +0 -103
  542. package/gulpfile.js +0 -216
  543. package/methodAndPublicationListGenerator.py +0 -375
  544. package/mongodbensurers.js +0 -2
  545. package/mongostop.js +0 -3
  546. package/scripts/cleanup-bypassed-callmethod-logs.js +0 -616
  547. package/settings.development.json +0 -25
  548. package/settings.development.redacted.json +0 -25
  549. package/src/.env +0 -12
  550. package/src/ai/assistant-core-heuristics.ts +0 -379
  551. package/src/ai/resolveio-platform-intelligence-memory-corpus.ts +0 -185
  552. package/src/ai/resolveio-platform-intelligence-memory.ts +0 -325
  553. package/src/ai/resolveio-platform-intelligence.ts +0 -462
  554. package/src/client-server-app.ts +0 -12
  555. package/src/collections/ai-run.collection.ts +0 -117
  556. package/src/collections/ai-terminal-conversation.collection.ts +0 -91
  557. package/src/collections/ai-terminal-issue-report.collection.ts +0 -99
  558. package/src/collections/ai-terminal-message.collection.ts +0 -77
  559. package/src/collections/app-setting.collection.ts +0 -104
  560. package/src/collections/app-status.collection.ts +0 -58
  561. package/src/collections/communication-metric.collection.ts +0 -84
  562. package/src/collections/counter.collection.ts +0 -56
  563. package/src/collections/cron-job-history.collection.ts +0 -94
  564. package/src/collections/cron-job.collection.ts +0 -92
  565. package/src/collections/customer-notification.collection.ts +0 -131
  566. package/src/collections/customer-portal-password.collection.ts +0 -76
  567. package/src/collections/email-history.collection.ts +0 -134
  568. package/src/collections/email-verified.collection.ts +0 -62
  569. package/src/collections/file.collection.ts +0 -74
  570. package/src/collections/flag-update.collection.ts +0 -57
  571. package/src/collections/flag.collection.ts +0 -57
  572. package/src/collections/log-method-latency.collection.ts +0 -77
  573. package/src/collections/log-subscription.collection.ts +0 -80
  574. package/src/collections/log.collection.ts +0 -93
  575. package/src/collections/logged-in-users.collection.ts +0 -67
  576. package/src/collections/monitor-cpu.collection.ts +0 -65
  577. package/src/collections/monitor-function.collection.ts +0 -74
  578. package/src/collections/monitor-memory.collection.ts +0 -77
  579. package/src/collections/monitor-mongo.collection.ts +0 -71
  580. package/src/collections/notification.collection.ts +0 -57
  581. package/src/collections/openai-usage-ledger.collection.ts +0 -131
  582. package/src/collections/report-builder-dashboard-builder.collection.ts +0 -109
  583. package/src/collections/report-builder-library.collection.ts +0 -89
  584. package/src/collections/report-builder-report.collection.ts +0 -184
  585. package/src/collections/user-group.collection.ts +0 -89
  586. package/src/collections/user-guide.collection.ts +0 -57
  587. package/src/collections/user.collection.ts +0 -181
  588. package/src/cron/cron.ts +0 -117
  589. package/src/fixtures/cron-jobs.ts +0 -95
  590. package/src/fixtures/init.ts +0 -35
  591. package/src/http/auth.ts +0 -818
  592. package/src/http/health.ts +0 -7
  593. package/src/http/home.ts +0 -90
  594. package/src/http/slow-query-publication.ts +0 -49
  595. package/src/index.ts +0 -1
  596. package/src/managers/ai-assistant-codex-manager.manager.ts +0 -1131
  597. package/src/managers/ai-run-evidence.manager.ts +0 -264
  598. package/src/managers/communication-metric.manager.ts +0 -82
  599. package/src/managers/cron.manager.ts +0 -333
  600. package/src/managers/customer-notification-content.manager.ts +0 -236
  601. package/src/managers/diagnostic-manager-bootstrap.ts +0 -165
  602. package/src/managers/error-auto-fix.manager.ts +0 -2767
  603. package/src/managers/local-log.manager.ts +0 -113
  604. package/src/managers/method.manager.ts +0 -1857
  605. package/src/managers/mongo.manager.ts +0 -4575
  606. package/src/managers/monitor.manager.ts +0 -507
  607. package/src/managers/openai-usage-ledger.manager.ts +0 -112
  608. package/src/managers/slow-query-verifier.manager.ts +0 -3590
  609. package/src/managers/slow-query.manager.ts +0 -519
  610. package/src/managers/subscription.manager.ts +0 -3128
  611. package/src/managers/websocket.manager.ts +0 -746
  612. package/src/managers/worker-dispatcher.manager.ts +0 -1360
  613. package/src/managers/worker-server.manager.ts +0 -536
  614. package/src/methods/accounts.ts +0 -532
  615. package/src/methods/ai-terminal.ts +0 -29070
  616. package/src/methods/app-settings.ts +0 -114
  617. package/src/methods/aws.ts +0 -649
  618. package/src/methods/collections.ts +0 -641
  619. package/src/methods/counters.ts +0 -69
  620. package/src/methods/cron-jobs.ts +0 -2614
  621. package/src/methods/customer-notifications.ts +0 -458
  622. package/src/methods/diagnostics.ts +0 -616
  623. package/src/methods/flag-updates.ts +0 -7
  624. package/src/methods/flags.ts +0 -7
  625. package/src/methods/logs.ts +0 -657
  626. package/src/methods/mongo-explorer.ts +0 -1880
  627. package/src/methods/monitor.ts +0 -540
  628. package/src/methods/pdf.ts +0 -1236
  629. package/src/methods/publications.ts +0 -129
  630. package/src/methods/report-builder.ts +0 -3300
  631. package/src/methods/support.ts +0 -335
  632. package/src/models/ai-run.model.ts +0 -27
  633. package/src/models/ai-terminal-conversation.model.ts +0 -19
  634. package/src/models/ai-terminal-issue-report.model.ts +0 -21
  635. package/src/models/ai-terminal-message.model.ts +0 -24
  636. package/src/models/app-setting.model.ts +0 -17
  637. package/src/models/collection-document.model.ts +0 -24
  638. package/src/models/communication-metric.model.ts +0 -23
  639. package/src/models/cron-job-history.model.ts +0 -16
  640. package/src/models/cron-job.model.ts +0 -15
  641. package/src/models/customer-notification.model.ts +0 -28
  642. package/src/models/customer-portal-password.model.ts +0 -12
  643. package/src/models/dialog.model.ts +0 -25
  644. package/src/models/log-method-latency.model.ts +0 -11
  645. package/src/models/log.model.ts +0 -19
  646. package/src/models/method.model.ts +0 -25
  647. package/src/models/monitor-function.model.ts +0 -16
  648. package/src/models/monitor-memory.model.ts +0 -17
  649. package/src/models/monitor-mongo.model.ts +0 -15
  650. package/src/models/openai-usage-ledger.model.ts +0 -56
  651. package/src/models/pagination.model.ts +0 -35
  652. package/src/models/permission.model.ts +0 -14
  653. package/src/models/report-builder-dashboard-builder.model.ts +0 -29
  654. package/src/models/report-builder-library.model.ts +0 -20
  655. package/src/models/report-builder-report.model.ts +0 -136
  656. package/src/models/report-builder.model.ts +0 -68
  657. package/src/models/select-data-label.model.ts +0 -9
  658. package/src/models/server-message.model.ts +0 -31
  659. package/src/models/slow-query-report.model.ts +0 -23
  660. package/src/models/subscription.model.ts +0 -73
  661. package/src/models/support-ticket.model.ts +0 -104
  662. package/src/models/user-group.model.ts +0 -24
  663. package/src/models/user.model.ts +0 -96
  664. package/src/private/images/ResolveIO.png +0 -0
  665. package/src/publications/ai-terminal.ts +0 -73
  666. package/src/publications/app-settings.ts +0 -25
  667. package/src/publications/app-status.ts +0 -13
  668. package/src/publications/cron-jobs.ts +0 -40
  669. package/src/publications/customer-notifications.ts +0 -101
  670. package/src/publications/files.ts +0 -33
  671. package/src/publications/flags-update.ts +0 -19
  672. package/src/publications/flags.ts +0 -19
  673. package/src/publications/logs.ts +0 -163
  674. package/src/publications/notifications.ts +0 -13
  675. package/src/publications/report-builder-dashboard-builders.ts +0 -39
  676. package/src/publications/report-builder-libraries.ts +0 -41
  677. package/src/publications/report-builder-reports.ts +0 -47
  678. package/src/publications/super-admin.ts +0 -13
  679. package/src/publications/user-groups.ts +0 -12
  680. package/src/publications/user-guides.ts +0 -12
  681. package/src/resolveio-server-app.ts +0 -617
  682. package/src/server-app.ts +0 -3354
  683. package/src/services/codex-client.ts +0 -1231
  684. package/src/services/openai-client.ts +0 -265
  685. package/src/types/error-report.ts +0 -26
  686. package/src/types/js-tiktoken.d.ts +0 -11
  687. package/src/types/slow-query-report.ts +0 -28
  688. package/src/util/ai-qa-policy.ts +0 -925
  689. package/src/util/ai-run-evidence-adapters.ts +0 -8347
  690. package/src/util/ai-run-evidence-dashboard.ts +0 -323
  691. package/src/util/ai-run-evidence-eval.ts +0 -1057
  692. package/src/util/ai-run-evidence.ts +0 -1430
  693. package/src/util/ai-runner-artifacts.ts +0 -586
  694. package/src/util/ai-runner-manager-autopilot.ts +0 -961
  695. package/src/util/ai-runner-manager-policy.ts +0 -5011
  696. package/src/util/ai-runner-qa-auth.ts +0 -838
  697. package/src/util/ai-runner-qa-tools.ts +0 -3536
  698. package/src/util/aicoder-runner-v6.ts +0 -3121
  699. package/src/util/common.ts +0 -649
  700. package/src/util/customer-portal-password.ts +0 -183
  701. package/src/util/error-reporter.ts +0 -332
  702. package/src/util/error-tracking.ts +0 -79
  703. package/src/util/openai-usage-cost.ts +0 -114
  704. package/src/util/report-builder-unwinds.ts +0 -180
  705. package/src/util/runner-process-janitor.ts +0 -219
  706. package/src/util/schema-report-builder.ts +0 -448
  707. package/src/util/slow-query-reporter.ts +0 -216
  708. package/src/util/subscription-dependency-context.ts +0 -1096
  709. package/src/util/support-runner-v5.ts +0 -10040
  710. package/src/util/tokenizer.ts +0 -38
  711. package/src/workers/codex-runner.worker.ts +0 -142
  712. package/start_server.sh +0 -5
  713. package/tests/ai-assistant-corpus-build.ts +0 -484
  714. package/tests/ai-assistant-corpus-replay-e2e.ts +0 -774
  715. package/tests/ai-assistant-data-parity-e2e.ts +0 -1989
  716. package/tests/ai-assistant-eval-triage.ts +0 -831
  717. package/tests/ai-assistant-openai-e2e.ts +0 -1061
  718. package/tests/ai-assistant-openai-git-e2e.ts +0 -155
  719. package/tests/ai-assistant-preflight-matrix.ts +0 -215
  720. package/tests/ai-assistant-routing-eval.test.ts +0 -585
  721. package/tests/ai-assistant-snf-live-eval.ts +0 -975
  722. package/tests/ai-assistant-utils.test.ts +0 -4834
  723. package/tests/ai-manager-autopilot-snapshot.test.ts +0 -193
  724. package/tests/ai-manager-recovery-checkpoint.test.ts +0 -1383
  725. package/tests/ai-run-eval.test.ts +0 -132
  726. package/tests/ai-run-evidence.test.ts +0 -3773
  727. package/tests/ai-runner-contract.test.ts +0 -515
  728. package/tests/aicoder-runner-v6.test.ts +0 -822
  729. package/tests/error-reporter.test.ts +0 -145
  730. package/tests/method-publication-generator.test.ts +0 -46
  731. package/tests/report-builder-linking.test.ts +0 -79
  732. package/tests/resolveio-platform-intelligence.test.ts +0 -352
  733. package/tests/server-app-cron-owner.test.ts +0 -127
  734. package/tests/subscription-connect-race.test.ts +0 -158
  735. package/tests/subscription-dependency-context.test.ts +0 -324
  736. package/tests/subscription-manager-collection-tracking.test.ts +0 -86
  737. package/tests/subscription-manager-invalidation.test.ts +0 -86
  738. package/tests/support-runner-v5.test.ts +0 -3201
  739. package/tsconfig.json +0 -34
  740. /package/{src/private → private}/email-templates/enrollment.html +0 -0
  741. /package/{src/private → private}/email-templates/forgot-password.html +0 -0
  742. /package/{src/private → private}/email-templates/support-ticket-deleted.html +0 -0
  743. /package/{src/private → private}/email-templates/support-ticket-modified.html +0 -0
  744. /package/{src/private → private}/email-templates/support-ticket.html +0 -0
  745. /package/{src/public_api.ts → public_api.d.ts} +0 -0
@@ -1,822 +0,0 @@
1
- import * as assert from 'node:assert/strict';
2
- import {
3
- buildResolveIOAICoderWorkflowProofCheckpoint,
4
- buildResolveIOAICoderWorkflowQaRowsFromJourneyContract,
5
- buildResolveIOAICoderV6DiagnoseFirstPrompt,
6
- collectResolveIOAICoderJourneyContractIssues,
7
- decideResolveIOAICoderV6Continuation,
8
- evaluateResolveIOAICoderWorkflowProofReadiness,
9
- extractResolveIOAICoderJourneyContractFromMarkdown,
10
- fingerprintResolveIOAICoderV6Blocker,
11
- initializeResolveIOAICoderV6State,
12
- recordResolveIOAICoderV6Step,
13
- validateResolveIOAICoderJourneyContract
14
- } from '../src/util/aicoder-runner-v6';
15
-
16
- const initialized = initializeResolveIOAICoderV6State({
17
- runKind: 'initial_builder',
18
- jobId: 'job-1',
19
- appId: 'app-1',
20
- title: 'Build crypto dashboard',
21
- description: 'Create a complete crypto trading dashboard.',
22
- branchName: 'ai/crypto-dashboard',
23
- now: '2026-06-07T12:00:00.000Z'
24
- });
25
-
26
- assert.equal(initialized.aiCoderRunnerVersion, 'v6');
27
- assert.equal(initialized.aiCoderV6SupervisorState.runKind, 'initial_builder');
28
- assert.equal(initialized.aiCoderV6SupervisorState.activeLane, 'plan');
29
- assert.equal(initialized.aiCoderV6LaneMemory.build.threadKey, 'aicoder:initial_builder:job-1:build');
30
- assert.equal(initialized.aiCoderV6Budget.maxRepeatedNoProgress, 2);
31
- assert.equal(initialized.aiCoderV6WorkflowMemory.journeyContractPath, 'docs/APP_JOURNEY_CONTRACT.md');
32
- assert.deepEqual(initialized.aiCoderV6RecoveryDispatchHistory, []);
33
- assert.equal(initialized.aiCoderV6RecoveryDirective, undefined);
34
-
35
- const validJourneyContract = {
36
- app_archetype: 'optimizer',
37
- primary_actor: 'Operations planner',
38
- primary_goal: 'Create a saved hose pressure recommendation for a field route.',
39
- primary_workflow_id: 'layflat-optimizer',
40
- first_screen: {
41
- route: '/dashboard/hub',
42
- purpose: 'Command center showing active scenarios and the recommended next optimizer action.',
43
- visible_cta: 'Start optimizer scenario',
44
- next_step: 'Open scenario assumptions with seeded route data.'
45
- },
46
- north_star_workflow: [{
47
- position: 'first',
48
- id: 'start-scenario',
49
- route: '/dashboard/hub',
50
- visible_cta: 'Start optimizer scenario',
51
- data_input_or_selection: 'Select the seeded North Field route scenario.',
52
- method_or_calculation: 'local calculation path optimizerScenarioDraft plus server method saveOptimizerScenarioDraft',
53
- expected_state_transition: 'Scenario assumptions panel opens with route, elevation, pump, and hose records loaded.',
54
- success_confirmation: 'Scenario ready badge appears.',
55
- next_step_destination: '/dashboard/hub?scenario=active'
56
- }, {
57
- position: 'next',
58
- id: 'run-optimizer',
59
- route: '/dashboard/hub',
60
- visible_cta: 'Run optimization',
61
- data_input_or_selection: 'Confirm pressure limit, terrain elevation, pump, and hose specs.',
62
- method_or_calculation: 'local calculation path runLayflatPressureOptimizer and server method saveOptimizerResult',
63
- expected_state_transition: 'Alternatives table and recommendation card update.',
64
- success_confirmation: 'Recommendation calculated badge appears.',
65
- next_step_destination: '/dashboard/hub?result=compare'
66
- }, {
67
- position: 'last',
68
- id: 'save-report',
69
- route: '/reports/optimizer',
70
- visible_cta: 'Save recommendation report',
71
- data_input_or_selection: 'Choose the recommended hose plan from the comparison table.',
72
- method_or_calculation: 'server method publishOptimizerRecommendation and report export path optimizerRecommendationPdf',
73
- expected_state_transition: 'Saved report row appears with export controls.',
74
- success_confirmation: 'Recommendation saved and report ready message appears.',
75
- final_result: 'Saved optimizer recommendation with exportable pressure report.'
76
- }],
77
- secondary_workflows: [
78
- { id: 'setup', route: '/manage/settings', purpose: 'Maintain pump and hose defaults.' },
79
- { id: 'report-export', route: '/reports/optimizer', purpose: 'Review and export saved recommendations.' },
80
- { id: 'recovery', route: '/dashboard/hub', purpose: 'Show empty and invalid pressure recovery states.' }
81
- ],
82
- screen_sequence: [{
83
- workflow_step_id: 'start-scenario',
84
- route: '/dashboard/hub',
85
- screen_purpose: 'Command center with seeded scenario, KPIs, next-up work queue, and embedded optimizer action.',
86
- visible_cta: 'Start optimizer scenario',
87
- action: 'Open scenario assumptions',
88
- method_or_calculation: 'local calculation path optimizerScenarioDraft',
89
- expected_next_state: 'Scenario assumptions are visible.',
90
- data_shown: 'Seeded route, elevation, pump, hose, and pressure-limit records.'
91
- }, {
92
- workflow_step_id: 'run-optimizer',
93
- route: '/dashboard/hub',
94
- screen_purpose: 'Run optimizer and compare alternatives.',
95
- visible_cta: 'Run optimization',
96
- action: 'Calculate pressure recommendation',
97
- method_or_calculation: 'local calculation path runLayflatPressureOptimizer',
98
- expected_next_state: 'Recommendation and alternatives update.',
99
- data_shown: 'Comparison table, pressure KPIs, and recommendation card.'
100
- }, {
101
- workflow_step_id: 'save-report',
102
- route: '/reports/optimizer',
103
- screen_purpose: 'Save and export recommendation report.',
104
- visible_cta: 'Save recommendation report',
105
- action: 'Persist recommendation report',
106
- method_or_calculation: 'server method publishOptimizerRecommendation',
107
- expected_next_state: 'Saved report row and export button visible.',
108
- data_shown: 'Saved recommendation, route assumptions, calculated pressure, and export status.'
109
- }],
110
- data_story: {
111
- seeded_scenario: 'North Field irrigation route with elevation changes, two pump options, and three hose alternatives.',
112
- records: ['North Field route', 'Pump A', 'Pump B', '4-inch layflat hose', '6-inch layflat hose'],
113
- relationships: ['Route uses pump options', 'Pump options feed hose alternatives', 'Optimization result belongs to scenario'],
114
- non_empty_states: ['Dashboard KPI cards show pressure, flow, and route length.', 'Reports table shows saved recommendation row.']
115
- },
116
- completion_states: [
117
- 'Recommendation card shows selected hose and pressure margin.',
118
- 'Report route lists saved recommendation with export action.'
119
- ],
120
- qa_assertions: [{
121
- id: 'login-hub',
122
- workflow_step_id: 'start-scenario',
123
- route: '/dashboard/hub',
124
- coverage_tags: ['login', 'hub_action', 'non_empty_data'],
125
- proof_kind: 'login',
126
- action: 'Login and land on dashboard hub.',
127
- expected_dom_or_data_proof: 'Hub shows seeded North Field scenario and non-empty KPI cards.'
128
- }, {
129
- id: 'primary-hub-action',
130
- workflow_step_id: 'start-scenario',
131
- route: '/dashboard/hub',
132
- coverage_tags: ['hub_action'],
133
- proof_kind: 'hub_action',
134
- action: 'Click Start optimizer scenario.',
135
- expected_dom_or_data_proof: 'Scenario assumptions panel opens with seeded route and pump records.'
136
- }, {
137
- id: 'workflow-completion',
138
- covers_workflow_step_ids: ['run-optimizer', 'save-report'],
139
- route: '/dashboard/hub',
140
- coverage_tags: ['workflow_completion', 'report_export'],
141
- proof_kind: 'report_export',
142
- action: 'Run optimization and save recommendation.',
143
- expected_dom_or_data_proof: 'Saved recommendation report row appears with calculated pressure result.'
144
- }, {
145
- id: 'mobile-viewport',
146
- covers_workflow_step_ids: ['start-scenario', 'run-optimizer', 'save-report'],
147
- route: '/dashboard/hub',
148
- coverage_tags: ['mobile', 'workflow_completion'],
149
- proof_kind: 'mobile',
150
- action: 'Repeat primary optimizer path at mobile viewport 390x844.',
151
- expected_dom_or_data_proof: 'Mobile hub shows non-empty scenario and recommendation controls.',
152
- viewport: '390x844 mobile'
153
- }, {
154
- id: 'empty-error-recovery',
155
- workflow_step_id: 'start-scenario',
156
- route: '/dashboard/hub',
157
- coverage_tags: ['recovery'],
158
- proof_kind: 'recovery',
159
- action: 'Clear scenario input and submit invalid pressure limit.',
160
- expected_dom_or_data_proof: 'Empty/error recovery message appears and Start optimizer scenario remains available.'
161
- }]
162
- };
163
-
164
- const validJourneyValidation = validateResolveIOAICoderJourneyContract(validJourneyContract);
165
- assert.equal(validJourneyValidation.valid, true);
166
- assert.equal(validJourneyValidation.primaryWorkflowId, 'layflat-optimizer');
167
- assert.equal(validJourneyValidation.workflowQaRows.length, 5);
168
- assert.equal(validJourneyValidation.workflowQaRows[2].stepId, 'workflow-completion');
169
- assert.equal(validJourneyValidation.workflowQaRows[2].workflowStepId, undefined);
170
- assert.deepEqual(validJourneyValidation.workflowQaRows[2].workflowStepIds, ['run-optimizer', 'save-report']);
171
- assert.equal(validJourneyValidation.workflowQaRows[2].acceptanceGate, 'aiqa_business_assertion');
172
- assert.equal(validJourneyValidation.workflowQaRows[2].proofKind, 'report_export');
173
- assert.deepEqual(validJourneyValidation.workflowQaRows[2].coverageTags, ['workflow_completion', 'report_export']);
174
- assert.ok(validJourneyValidation.workflowQaRows[2].requiredArtifacts?.some((artifact) => /saved output row proof|generated report\/export artifact/i.test(artifact)));
175
- assert.equal(validJourneyValidation.workflowQaRows[2].stateTransition?.assertion, 'Saved recommendation report row appears with calculated pressure result.');
176
- assert.equal(buildResolveIOAICoderWorkflowQaRowsFromJourneyContract(validJourneyContract)[0].workflowId, 'layflat-optimizer');
177
-
178
- const validJourneyMarkdown = `# App Journey Contract
179
-
180
- ## journey_contract
181
- \`\`\`json
182
- ${JSON.stringify(validJourneyContract, null, 2)}
183
- \`\`\`
184
- `;
185
- assert.equal(extractResolveIOAICoderJourneyContractFromMarkdown(validJourneyMarkdown)?.app_archetype, 'optimizer');
186
- assert.equal(validateResolveIOAICoderJourneyContract(validJourneyMarkdown).valid, true);
187
-
188
- const passingWorkflowQaRows = buildResolveIOAICoderWorkflowQaRowsFromJourneyContract(validJourneyContract).map((row) => ({
189
- ...row,
190
- status: 'pass',
191
- artifactPaths: [`qa-artifacts/${row.stepId || row.index}.json`]
192
- }));
193
- const passingWorkflowBusinessAssertions = passingWorkflowQaRows.map((row) => ({
194
- stepId: row.stepId,
195
- workflowId: row.workflowId,
196
- route: row.route,
197
- action: row.action,
198
- assertion: row.assertion || row.expectedState,
199
- status: 'pass',
200
- observed: `${row.stepId || row.index} produced the expected visible state in the north-star workflow.`,
201
- dataProof: `${row.stepId || row.index} has observed DOM/data proof from seeded Layflat records.`,
202
- artifactPaths: row.artifactPaths
203
- }));
204
- const workflowProofReady = evaluateResolveIOAICoderWorkflowProofReadiness({
205
- journeyContract: validJourneyContract,
206
- workflowQaRows: passingWorkflowQaRows,
207
- businessAssertions: passingWorkflowBusinessAssertions,
208
- routeProbes: [{ route: '/dashboard/hub', status: 'pass' }],
209
- scorecardPassed: true,
210
- deployStatus: 'pass',
211
- publishStatus: 'published',
212
- sampleDataStatus: 'pass',
213
- now: '2026-06-07T12:00:00.000Z'
214
- });
215
- assert.equal(workflowProofReady.ready, true);
216
- assert.equal(workflowProofReady.status, 'ready');
217
- assert.equal(workflowProofReady.passedWorkflowRows.length, 5);
218
- assert.equal(workflowProofReady.sampleDataReady, true);
219
- assert.match(workflowProofReady.workflowProofFingerprint, /^aicoder-workflow-proof-/);
220
- assert.match(workflowProofReady.artifactFingerprint, /^aicoder-workflow-artifacts-/);
221
- assert.equal(workflowProofReady.proofFreshness, 'fresh');
222
-
223
- const staleWorkflowProof = evaluateResolveIOAICoderWorkflowProofReadiness({
224
- journeyContract: validJourneyContract,
225
- workflowQaRows: passingWorkflowQaRows,
226
- businessAssertions: passingWorkflowBusinessAssertions,
227
- routeProbes: [{ route: '/dashboard/hub', status: 'pass' }],
228
- scorecardPassed: true,
229
- deployStatus: 'pass',
230
- publishStatus: 'published',
231
- sampleDataStatus: 'pass',
232
- previousWorkflowProofFingerprint: workflowProofReady.workflowProofFingerprint,
233
- now: '2026-06-07T12:03:00.000Z'
234
- });
235
- assert.equal(staleWorkflowProof.ready, false);
236
- assert.equal(staleWorkflowProof.status, 'stale_workflow_proof');
237
- assert.equal(staleWorkflowProof.proofFreshness, 'same_as_previous');
238
- assert.ok(staleWorkflowProof.nextAction.includes('Rerun workflow QA'));
239
-
240
- const routeOnlyWorkflowProof = evaluateResolveIOAICoderWorkflowProofReadiness({
241
- journeyContract: validJourneyContract,
242
- routeProbes: [{ route: '/dashboard/hub', status: 'pass' }],
243
- scorecardPassed: true
244
- });
245
- assert.equal(routeOnlyWorkflowProof.ready, false);
246
- assert.equal(routeOnlyWorkflowProof.status, 'route_only');
247
- assert.equal(routeOnlyWorkflowProof.scorecardOnly, true);
248
-
249
- const screenshotOnlyWorkflowProof = evaluateResolveIOAICoderWorkflowProofReadiness({
250
- journeyContract: validJourneyContract,
251
- workflowQaRows: passingWorkflowQaRows,
252
- businessAssertions: passingWorkflowBusinessAssertions.map((assertion) => ({
253
- ...assertion,
254
- observed: '',
255
- dataProof: '',
256
- artifactPaths: assertion.artifactPaths
257
- })),
258
- scorecardPassed: true,
259
- sampleDataStatus: 'pass'
260
- });
261
- assert.equal(screenshotOnlyWorkflowProof.ready, false);
262
- assert.equal(screenshotOnlyWorkflowProof.status, 'business_proof_weak');
263
- assert.ok(screenshotOnlyWorkflowProof.blockers.some((blocker) => /observed DOM\/data proof/i.test(blocker)));
264
-
265
- const weakWorkflowProofRows = buildResolveIOAICoderWorkflowQaRowsFromJourneyContract(validJourneyContract).map((row) => ({
266
- ...row,
267
- status: 'pass',
268
- artifactPaths: []
269
- }));
270
- const weakWorkflowProof = evaluateResolveIOAICoderWorkflowProofReadiness({
271
- journeyContract: validJourneyContract,
272
- workflowQaRows: weakWorkflowProofRows,
273
- businessAssertions: [{
274
- stepId: 'workflow-completion',
275
- workflowId: 'layflat-optimizer',
276
- route: '/dashboard/hub',
277
- assertion: 'Saved recommendation report row appears with calculated pressure result.',
278
- status: 'pass',
279
- dataProof: 'North Field seeded hose records produced saved optimizer recommendation pressure output.'
280
- }],
281
- scorecardPassed: true,
282
- sampleDataStatus: 'pass'
283
- });
284
- assert.equal(weakWorkflowProof.ready, false);
285
- assert.equal(weakWorkflowProof.status, 'business_proof_weak');
286
- assert.ok(weakWorkflowProof.blockers.some((blocker) => /missing required artifact proof|AIQaBusinessAssertion/i.test(blocker)));
287
-
288
- const partialWorkflowProof = evaluateResolveIOAICoderWorkflowProofReadiness({
289
- journeyContract: validJourneyContract,
290
- workflowQaRows: passingWorkflowQaRows.slice(0, 2),
291
- businessAssertions: passingWorkflowBusinessAssertions.slice(0, 2),
292
- sampleDataStatus: 'pass'
293
- });
294
- assert.equal(partialWorkflowProof.ready, false);
295
- assert.equal(partialWorkflowProof.status, 'workflow_qa_incomplete');
296
- assert.ok(partialWorkflowProof.missingWorkflowRows.length > 0);
297
-
298
- const releaseBlockedWorkflowProof = evaluateResolveIOAICoderWorkflowProofReadiness({
299
- journeyContract: validJourneyContract,
300
- workflowQaRows: passingWorkflowQaRows,
301
- businessAssertions: passingWorkflowBusinessAssertions,
302
- sampleDataStatus: 'pass',
303
- deployStatus: 'pass',
304
- publishStatus: 'publish failed'
305
- });
306
- assert.equal(releaseBlockedWorkflowProof.ready, false);
307
- assert.equal(releaseBlockedWorkflowProof.status, 'release_blocked');
308
- assert.ok(releaseBlockedWorkflowProof.releaseBlockers.some((blocker) => /publish/.test(blocker)));
309
-
310
- const missingOrderedWorkflowIssues = collectResolveIOAICoderJourneyContractIssues({
311
- ...validJourneyContract,
312
- north_star_workflow: validJourneyContract.north_star_workflow.slice(0, 2)
313
- }, { requireMarkdownEnvelope: false });
314
- assert.ok(missingOrderedWorkflowIssues.some((issue) => /first, next, and last/i.test(issue)));
315
-
316
- const ctaWithoutImplementationIssues = collectResolveIOAICoderJourneyContractIssues({
317
- ...validJourneyContract,
318
- north_star_workflow: validJourneyContract.north_star_workflow.map((step, index) => index === 1
319
- ? { ...step, method_or_calculation: '' }
320
- : step)
321
- }, { requireMarkdownEnvelope: false });
322
- assert.ok(ctaWithoutImplementationIssues.some((issue) => /server method, publication, local calculation/i.test(issue)));
323
-
324
- const linkOnlyHubIssues = collectResolveIOAICoderJourneyContractIssues({
325
- ...validJourneyContract,
326
- screen_sequence: validJourneyContract.screen_sequence.map((screen, index) => index === 0
327
- ? {
328
- route: '/dashboard/hub',
329
- screen_purpose: 'Command center link list.',
330
- visible_cta: 'Open optimizer page',
331
- action: 'Navigate to optimizer route',
332
- expected_next_state: 'Route opens.',
333
- data_shown: 'Links to pages.'
334
- }
335
- : screen)
336
- }, { requireMarkdownEnvelope: false });
337
- assert.ok(linkOnlyHubIssues.some((issue) => /link farm|navigate without changing workflow state/i.test(issue)));
338
-
339
- const disconnectedScreenIssues = collectResolveIOAICoderJourneyContractIssues({
340
- ...validJourneyContract,
341
- screen_sequence: validJourneyContract.screen_sequence.map((screen, index) => index === 1
342
- ? {
343
- workflow_step_id: 'unrelated-review-step',
344
- route: '/reports/summary',
345
- screen_purpose: 'Review unrelated summary data.',
346
- visible_cta: 'Review summary',
347
- action: 'Review unrelated summary output',
348
- method_or_calculation: 'local calculation path unrelatedSummary',
349
- expected_next_state: 'Summary panel updates.',
350
- data_shown: 'Unrelated summary rows.'
351
- }
352
- : screen)
353
- }, { requireMarkdownEnvelope: false });
354
- assert.ok(disconnectedScreenIssues.some((issue) => /screen_sequence\[1\].*north_star_workflow step/i.test(issue)));
355
- assert.ok(disconnectedScreenIssues.some((issue) => /north_star_workflow\[1\].*matching screen_sequence row/i.test(issue)));
356
-
357
- const weakDataStoryIssues = collectResolveIOAICoderJourneyContractIssues({
358
- ...validJourneyContract,
359
- data_story: {
360
- seeded_scenario: 'Short',
361
- records: [],
362
- relationships: [],
363
- non_empty_states: []
364
- }
365
- }, { requireMarkdownEnvelope: false });
366
- assert.ok(weakDataStoryIssues.some((issue) => /seeded records/i.test(issue)));
367
- assert.ok(weakDataStoryIssues.some((issue) => /non-empty dashboard/i.test(issue)));
368
-
369
- const routeOnlyQaIssues = collectResolveIOAICoderJourneyContractIssues({
370
- ...validJourneyContract,
371
- qa_assertions: [{
372
- id: 'route-load',
373
- route: '/dashboard/hub',
374
- action: 'Open route',
375
- expected_dom_or_data_proof: 'Route loaded'
376
- }]
377
- }, { requireMarkdownEnvelope: false });
378
- assert.ok(routeOnlyQaIssues.some((issue) => /workflow completion|business completion|mobile viewport|non-empty/i.test(issue)));
379
-
380
- const proseOnlyQaIssues = collectResolveIOAICoderJourneyContractIssues({
381
- ...validJourneyContract,
382
- qa_assertions: [{
383
- id: 'login-hub',
384
- route: '/dashboard/hub',
385
- action: 'Login and land on dashboard hub.',
386
- expected_dom_or_data_proof: 'Hub shows seeded North Field scenario and non-empty KPI cards.'
387
- }, {
388
- id: 'primary-hub-action',
389
- route: '/dashboard/hub',
390
- action: 'Click Start optimizer scenario.',
391
- expected_dom_or_data_proof: 'Scenario assumptions panel opens with seeded route and pump records.'
392
- }, {
393
- id: 'workflow-completion',
394
- route: '/dashboard/hub',
395
- action: 'Run optimization and save recommendation.',
396
- expected_dom_or_data_proof: 'Saved recommendation report row appears with calculated pressure result.'
397
- }, {
398
- id: 'mobile-viewport',
399
- route: '/dashboard/hub',
400
- action: 'Repeat primary optimizer path at mobile viewport 390x844.',
401
- expected_dom_or_data_proof: 'Mobile hub shows non-empty scenario and recommendation controls.',
402
- viewport: '390x844 mobile'
403
- }, {
404
- id: 'empty-error-recovery',
405
- route: '/dashboard/hub',
406
- action: 'Clear scenario input and submit invalid pressure limit.',
407
- expected_dom_or_data_proof: 'Empty/error recovery message appears and Start optimizer scenario remains available.'
408
- }]
409
- }, { requireMarkdownEnvelope: false });
410
- assert.ok(proseOnlyQaIssues.some((issue) => /coverage_tags|prose-only keyword/i.test(issue)));
411
-
412
- const disconnectedQaIssues = collectResolveIOAICoderJourneyContractIssues({
413
- ...validJourneyContract,
414
- qa_assertions: [{
415
- id: 'login-hub',
416
- route: '/dashboard/hub',
417
- coverage_tags: ['login', 'hub_action', 'non_empty_data'],
418
- proof_kind: 'login',
419
- action: 'Authenticate and confirm the dashboard shell is visible.',
420
- expected_dom_or_data_proof: 'Dashboard shell loaded with a title.'
421
- }, {
422
- id: 'primary-hub-action',
423
- route: '/dashboard/hub',
424
- coverage_tags: ['hub_action'],
425
- proof_kind: 'hub_action',
426
- action: 'Confirm a generic command exists.',
427
- expected_dom_or_data_proof: 'A command button is visible.'
428
- }, {
429
- id: 'workflow-completion',
430
- route: '/dashboard/hub',
431
- coverage_tags: ['workflow_completion', 'report_export'],
432
- proof_kind: 'report_export',
433
- action: 'Confirm a workflow finished.',
434
- expected_dom_or_data_proof: 'A generic success message is visible.'
435
- }, {
436
- id: 'mobile-viewport',
437
- route: '/dashboard/hub',
438
- coverage_tags: ['mobile', 'workflow_completion'],
439
- proof_kind: 'mobile',
440
- action: 'Open the mobile dashboard.',
441
- expected_dom_or_data_proof: 'Mobile shell is visible.',
442
- viewport: '390x844 mobile'
443
- }, {
444
- id: 'empty-error-recovery',
445
- route: '/dashboard/hub',
446
- coverage_tags: ['recovery'],
447
- proof_kind: 'recovery',
448
- action: 'Trigger generic validation.',
449
- expected_dom_or_data_proof: 'A generic error message is visible.'
450
- }]
451
- }, { requireMarkdownEnvelope: false });
452
- assert.ok(disconnectedQaIssues.some((issue) => /qa_assertions\[0\].*workflow_step_id|qa_assertions\[0\].*covers_workflow_step_ids/i.test(issue)));
453
- assert.ok(disconnectedQaIssues.some((issue) => /north_star_workflow\[1\].*covered by at least one qa_assertions row/i.test(issue)));
454
-
455
- const withBuildFailure = recordResolveIOAICoderV6Step(initialized, {
456
- lane: 'build',
457
- stepType: 'build',
458
- outcome: 'needs_repair',
459
- model: 'gpt-5.3-codex',
460
- threadKey: 'job-1:build',
461
- promptVersion: 'abc123',
462
- promptTokenEstimate: 1200,
463
- inputTokens: 1000,
464
- cachedInputTokens: 200,
465
- outputTokens: 300,
466
- summary: 'Angular build failed.',
467
- blocker: 'TS2304 line 42 cannot find name InvoiceModel',
468
- changedFiles: ['angular/app/dashboard/hub/dashboard-hub.component.ts'],
469
- artifactPaths: ['.dashboard-output/build-client.log'],
470
- now: '2026-06-07T12:01:00.000Z'
471
- });
472
-
473
- assert.equal(withBuildFailure.aiCoderV6SupervisorState.activeLane, 'build');
474
- assert.equal(withBuildFailure.aiCoderV6SupervisorState.activeStep, 'build');
475
- assert.equal(withBuildFailure.aiCoderV6LaneMemory.build.latestPromptVersion, 'abc123');
476
- assert.equal(withBuildFailure.aiCoderV6Budget.totalInputTokens, 1000);
477
- assert.equal(withBuildFailure.aiCoderV6Budget.totalCachedInputTokens, 200);
478
- assert.equal(withBuildFailure.aiCoderV6Budget.totalOutputTokens, 300);
479
- assert.equal(withBuildFailure.aiCoderV6StepHistory[0].blockerFingerprint, fingerprintResolveIOAICoderV6Blocker('TS2304 line 99 cannot find name InvoiceModel'));
480
- assert.equal(withBuildFailure.aiCoderV6RecoveryPlan?.recoveryClass, 'compile_repair');
481
- assert.equal(withBuildFailure.aiCoderV6RecoveryCheckpoint?.recoveryClass, 'compile_repair');
482
- assert.equal(withBuildFailure.aiCoderV6RecoveryAction?.checkpointId, withBuildFailure.aiCoderV6RecoveryCheckpoint?.checkpointId);
483
- const buildFailureDecision = decideResolveIOAICoderV6Continuation(withBuildFailure);
484
- assert.equal(buildFailureDecision.action, 'infra_retry');
485
- assert.equal(buildFailureDecision.reason, 'aicoder_v6_compile_repair_required');
486
- assert.equal(buildFailureDecision.recoveryPlan.recoveryClass, 'compile_repair');
487
- assert.equal(buildFailureDecision.recoveryPlan.productRepairAllowed, false);
488
- assert.ok(buildFailureDecision.recoveryPlan.requiredEvidence.includes('compile log artifact'));
489
- assert.equal(buildFailureDecision.recoveryCheckpoint.recoveryClass, 'compile_repair');
490
- assert.equal(buildFailureDecision.recoveryCheckpoint.productRepairAllowed, false);
491
- assert.equal(buildFailureDecision.workflowReadiness.status, 'compile_repair_only');
492
- assert.equal(buildFailureDecision.workflowReadiness.compileOnly, true);
493
- assert.equal(buildFailureDecision.workflowReadiness.canRunProductRepair, false);
494
- assert.equal(buildFailureDecision.nextActionContract.primaryCommand, 'repair_aicoder_compile_gate');
495
- assert.equal(buildFailureDecision.nextActionContract.costRisk, 'small_model_or_qa');
496
- assert.equal(buildFailureDecision.nextActionContract.canRunWithoutCodexMonitor, true);
497
- assert.ok(buildFailureDecision.nextActionContract.stopConditions.some((entry) => /compile failures stay in infra\/compile repair/i.test(entry)));
498
-
499
- const withWorkflowQa = recordResolveIOAICoderV6Step(initialized, {
500
- lane: 'qa',
501
- stepType: 'workflow_qa',
502
- outcome: 'pass',
503
- primaryWorkflowId: 'north-star',
504
- activeWorkflowStep: 'save-result',
505
- workflowQaRows: [{
506
- index: 1,
507
- workflowId: 'north-star',
508
- stepId: 'save-result',
509
- route: '/dashboard/hub',
510
- action: 'Save recommendation',
511
- assertion: 'Saved result appears in the recommendations table.',
512
- expectedState: 'Recommendation saved',
513
- status: 'pass',
514
- artifactPaths: ['.build-output/workflow-save-result.png']
515
- }],
516
- artifactPaths: ['.build-output/workflow-save-result.png'],
517
- businessProofArtifacts: ['.build-output/workflow-save-result-business-proof.json'],
518
- summary: 'North-star workflow QA passed.'
519
- });
520
-
521
- assert.equal(withWorkflowQa.aiCoderV6WorkflowMemory.primaryWorkflowId, 'north-star');
522
- assert.equal(withWorkflowQa.aiCoderV6WorkflowMemory.activeWorkflowStep, 'save-result');
523
- assert.equal(withWorkflowQa.aiCoderV6WorkflowMemory.completedWorkflowSteps.includes('save-result'), true);
524
- assert.equal(withWorkflowQa.aiCoderV6WorkflowMemory.workflowQaRows[0].route, '/dashboard/hub');
525
- assert.equal(withWorkflowQa.aiCoderV6WorkflowMemory.businessProofArtifacts.includes('.build-output/workflow-save-result-business-proof.json'), true);
526
- const workflowReadyDecision = decideResolveIOAICoderV6Continuation(withWorkflowQa);
527
- assert.equal(workflowReadyDecision.workflowReadiness.status, 'workflow_business_proof_ready');
528
- assert.equal(workflowReadyDecision.workflowReadiness.businessProofReady, true);
529
- assert.equal(workflowReadyDecision.workflowReadiness.canPublish, true);
530
- assert.equal(workflowReadyDecision.workflowReadiness.canPolishWowUi, true);
531
- assert.equal(workflowReadyDecision.workflowProofCheckpoint.status, 'ready_to_continue');
532
- assert.equal(workflowReadyDecision.workflowProofCheckpoint.blocksPublishUntilWorkflowProof, false);
533
- assert.equal(workflowReadyDecision.workflowProofCheckpoint.blocksWowUiUntilWorkflowProof, false);
534
- assert.equal(workflowReadyDecision.nextActionContract.primaryCommand, 'continue_aicoder_workflow');
535
- assert.equal(workflowReadyDecision.nextActionContract.workflowFirstSatisfied, true);
536
- assert.equal(workflowReadyDecision.nextActionContract.codexFallbackRequired, false);
537
- assert.equal(workflowReadyDecision.nextActionContract.decisionBasis.canPublish, true);
538
-
539
- let repeated = withBuildFailure;
540
- for (let index = 0; index < 3; index += 1) {
541
- repeated = recordResolveIOAICoderV6Step(repeated, {
542
- lane: 'build',
543
- stepType: 'build',
544
- outcome: 'needs_repair',
545
- summary: 'Angular build failed.',
546
- blocker: 'TS2304 line 77 cannot find name InvoiceModel',
547
- now: `2026-06-07T12:0${index + 2}:00.000Z`
548
- });
549
- }
550
-
551
- const repeatedDecision = decideResolveIOAICoderV6Continuation(repeated);
552
- assert.equal(repeatedDecision.action, 'park');
553
- assert.equal(repeatedDecision.reason, 'aicoder_v6_repeated_no_progress');
554
- assert.equal(repeatedDecision.recoveryPlan.recoveryClass, 'blocked_until_new_evidence');
555
- assert.equal(repeatedDecision.recoveryPlan.allowedAction, 'collect_new_evidence_only');
556
- assert.equal(repeatedDecision.recoveryCheckpoint.status, 'parked');
557
- assert.equal(repeatedDecision.recoveryCheckpoint.allowedAction, 'collect_new_evidence_only');
558
- assert.equal(repeatedDecision.recoveryEvidenceProbe.evidenceOnly, true);
559
- assert.equal(repeatedDecision.recoveryEvidenceProbe.productRepairAllowed, false);
560
- assert.ok(repeatedDecision.recoveryEvidenceProbe.steps.some((step) => step.kind === 'rerun_same_gate'));
561
- assert.equal(repeatedDecision.recoveryAction.mode, 'collect_evidence');
562
- assert.equal(repeatedDecision.recoveryAction.retryPolicy.requireNewEvidence, true);
563
- assert.equal(repeatedDecision.recoveryAction.productRepairAllowed, false);
564
- assert.equal(repeatedDecision.workflowReadiness.status, 'collect_new_evidence');
565
- assert.equal(repeatedDecision.workflowReadiness.sameFailureParked, true);
566
- assert.equal(repeatedDecision.workflowReadiness.canRunProductRepair, false);
567
- assert.equal(repeatedDecision.workflowProofCheckpoint.status, 'waiting_for_new_evidence');
568
- assert.equal(repeatedDecision.workflowProofCheckpoint.blocksPublishUntilWorkflowProof, true);
569
- assert.equal(repeatedDecision.workflowProofCheckpoint.blocksWowUiUntilWorkflowProof, true);
570
- assert.ok(repeatedDecision.workflowProofCheckpoint.requiredResetEvidence.some((entry) => /new workflow proof fingerprint|changed blocker fingerprint|fresh workflow QA artifact/i.test(entry)));
571
- assert.equal(repeated.aiCoderV6RecoveryPlan?.recoveryClass, 'blocked_until_new_evidence');
572
- assert.equal(repeated.aiCoderV6RecoveryCheckpoint?.status, 'parked');
573
- assert.equal(repeated.aiCoderV6RecoveryEvidenceProbe?.checkpointId, repeated.aiCoderV6RecoveryCheckpoint?.checkpointId);
574
-
575
- const newEvidenceRetry = recordResolveIOAICoderV6Step(withBuildFailure, {
576
- lane: 'build',
577
- stepType: 'build',
578
- outcome: 'needs_repair',
579
- failureClass: 'compile',
580
- summary: 'Angular build failed with the same root blocker after a targeted change.',
581
- blocker: 'TS2304 line 88 cannot find name InvoiceModel',
582
- evidenceHash: 'compile-log-after-import-fix',
583
- changedFiles: ['angular/app/dashboard/hub/dashboard-hub.component.ts'],
584
- artifactPaths: ['.dashboard-output/build-client-after-import.log']
585
- });
586
- assert.equal(newEvidenceRetry.aiCoderV6Budget.loopCount, 1);
587
- const newEvidenceDecision = decideResolveIOAICoderV6Continuation(newEvidenceRetry);
588
- assert.equal(newEvidenceDecision.action, 'infra_retry');
589
- assert.equal(newEvidenceDecision.recoveryPlan.recoveryClass, 'compile_repair');
590
- assert.equal(newEvidenceDecision.recoveryPlan.productRepairAllowed, false);
591
- assert.equal(newEvidenceDecision.workflowReadiness.status, 'compile_repair_only');
592
- assert.ok(newEvidenceDecision.recoveryPlan.loopResetEvidence.some((entry) => /same check now passes|new infra\/compile blocker hash/.test(entry)));
593
-
594
- const infraFailure = recordResolveIOAICoderV6Step(initialized, {
595
- lane: 'qa',
596
- stepType: 'workflow_qa',
597
- outcome: 'needs_repair',
598
- failureClass: 'infra',
599
- summary: 'Puppeteer could not launch Chrome.',
600
- blocker: 'Puppeteer could not launch Chrome from the configured executable path.'
601
- });
602
- const infraDecision = decideResolveIOAICoderV6Continuation(infraFailure);
603
- assert.equal(infraDecision.action, 'infra_retry');
604
- assert.equal(infraDecision.nextLane, 'qa');
605
- assert.equal(infraDecision.reason, 'aicoder_v6_infra_retry');
606
- assert.equal(infraDecision.recoveryPlan.recoveryClass, 'infra_repair');
607
- assert.equal(infraDecision.recoveryPlan.expensiveModelAllowed, false);
608
- assert.ok(infraDecision.recoveryPlan.forbiddenActions.some((action) => /product-code model repair/.test(action)));
609
- assert.equal(infraDecision.workflowReadiness.status, 'infra_repair_only');
610
- assert.equal(infraDecision.workflowReadiness.infraOnly, true);
611
- assert.equal(infraDecision.workflowReadiness.canRunProductRepair, false);
612
- assert.equal(infraDecision.nextActionContract.primaryCommand, 'repair_aicoder_infra_gate');
613
- assert.equal(infraDecision.nextActionContract.costRisk, 'small_model_or_qa');
614
- assert.equal(infraDecision.nextActionContract.decisionBasis.infraOnly, true);
615
-
616
- const journeyFailure = recordResolveIOAICoderV6Step(initialized, {
617
- lane: 'plan',
618
- stepType: 'journey_validation',
619
- outcome: 'needs_repair',
620
- summary: 'Journey contract is missing first/next/last steps.',
621
- blocker: 'docs/APP_JOURNEY_CONTRACT.md journey_contract.north_star_workflow has fewer than 3 ordered steps.'
622
- });
623
- const journeyDecision = decideResolveIOAICoderV6Continuation(journeyFailure);
624
- assert.equal(journeyDecision.action, 'retry_same_step');
625
- assert.equal(journeyDecision.nextLane, 'plan');
626
- assert.equal(journeyDecision.nextStep, 'journey_contract');
627
- assert.equal(journeyDecision.reason, 'aicoder_v6_journey_contract_repair_required');
628
- assert.equal(journeyDecision.recoveryPlan.recoveryClass, 'journey_contract_repair');
629
- assert.equal(journeyDecision.recoveryPlan.productRepairAllowed, false);
630
- assert.ok(journeyDecision.recoveryPlan.forbiddenActions.some((action) => /empty routes/.test(action)));
631
- assert.equal(journeyDecision.workflowReadiness.status, 'journey_contract_repair_required');
632
- assert.equal(journeyDecision.workflowReadiness.nextGate, 'journey_contract');
633
- assert.equal(journeyDecision.workflowReadiness.canRunProductRepair, false);
634
- assert.equal(journeyDecision.nextActionContract.action, 'retry_same_step');
635
- assert.equal(journeyDecision.nextActionContract.primaryCommand, 'repair_aicoder_journey_contract');
636
- assert.equal(journeyDecision.nextActionContract.safeToAutoRun, true);
637
- assert.equal(journeyDecision.nextActionContract.canRunWithoutCodexMonitor, true);
638
- assert.equal(journeyDecision.nextActionContract.decisionBasis.journeyContractReady, false);
639
- assert.ok(journeyDecision.nextActionContract.stopConditions.some((entry) => /APP_JOURNEY_CONTRACT\.md validates/i.test(entry)));
640
-
641
- const releaseFailure = recordResolveIOAICoderV6Step(withWorkflowQa, {
642
- lane: 'publish',
643
- stepType: 'test_deploy',
644
- outcome: 'needs_repair',
645
- summary: 'Test deploy failed after workflow QA passed.',
646
- blocker: 'CloudFront invalidation failed during test deploy.'
647
- });
648
- const releaseDecision = decideResolveIOAICoderV6Continuation(releaseFailure);
649
- assert.equal(releaseDecision.action, 'retry_same_step');
650
- assert.equal(releaseDecision.nextLane, 'publish');
651
- assert.equal(releaseDecision.nextStep, 'test_deploy');
652
- assert.equal(releaseDecision.reason, 'aicoder_v6_release_repair_required');
653
- assert.equal(releaseDecision.recoveryPlan.recoveryClass, 'release_repair');
654
- assert.equal(releaseDecision.recoveryPlan.expensiveModelAllowed, false);
655
- assert.ok(releaseDecision.recoveryPlan.forbiddenActions.some((action) => /scorecard only/.test(action)));
656
- assert.equal(releaseDecision.workflowReadiness.status, 'release_repair_required');
657
- assert.equal(releaseDecision.workflowReadiness.releaseBlocked, true);
658
- assert.equal(releaseDecision.workflowReadiness.canPublish, false);
659
- assert.equal(releaseDecision.workflowProofCheckpoint.status, 'waiting_for_release_gate');
660
- assert.equal(releaseDecision.workflowProofCheckpoint.blocksPublishUntilWorkflowProof, false);
661
- assert.equal(releaseDecision.workflowProofCheckpoint.blocksPublishUntilReleaseGate, true);
662
- assert.equal(releaseDecision.nextActionContract.primaryCommand, 'repair_aicoder_release_gate');
663
- assert.equal(releaseDecision.nextActionContract.costRisk, 'release_or_customer_send');
664
- assert.equal(releaseDecision.nextActionContract.decisionBasis.releaseBlocked, true);
665
- assert.equal(releaseDecision.nextActionContract.decisionBasis.hotfixCommitRequired, true);
666
- assert.equal(releaseDecision.nextActionContract.decisionBasis.liveHotfixBlockedUntilCommit, true);
667
- assert.deepEqual(releaseDecision.nextActionContract.requiredHotfixCommitProof, ['sourceCommitSha', 'githubCommitUrl', 'gitCommitStatus=passed', 'gitPushStatus=passed']);
668
- assert.ok(releaseDecision.nextActionContract.nextCommands.includes('prefer_hotfix_before_full_deploy'));
669
- assert.ok(releaseDecision.nextActionContract.nextCommands.indexOf('commit_and_push_hotfix_to_github') < releaseDecision.nextActionContract.nextCommands.indexOf('apply_live_hotfix_only_after_github_commit_proof'));
670
- assert.ok(releaseDecision.nextActionContract.stopConditions.some((entry) => /repeat a full publish\/deploy/i.test(entry)));
671
- assert.ok(releaseDecision.nextActionContract.stopConditions.some((entry) => /sourceCommitSha.*githubCommitUrl.*gitCommitStatus.*gitPushStatus/i.test(entry)));
672
-
673
- const routeOnlyWorkflowBundle = recordResolveIOAICoderV6Step(withWorkflowQa, {
674
- lane: 'qa',
675
- stepType: 'workflow_qa',
676
- outcome: 'needs_repair',
677
- failureClass: 'business',
678
- summary: 'Route loaded but workflow result was not saved.',
679
- blocker: 'Route-only browser proof: /dashboard/hub loaded without saved recommendation output.',
680
- evidenceHash: 'route-only-proof',
681
- artifactPaths: ['.build-output/route-loaded-only.png']
682
- });
683
- const routeOnlyWorkflowDecision = decideResolveIOAICoderV6Continuation(routeOnlyWorkflowBundle);
684
- assert.equal(routeOnlyWorkflowDecision.workflowReadiness.status, 'workflow_qa_required');
685
- assert.equal(routeOnlyWorkflowDecision.workflowReadiness.routeOnlyBlocked, true);
686
- assert.equal(routeOnlyWorkflowDecision.workflowProofCheckpoint.status, 'waiting_for_workflow_proof');
687
- assert.equal(routeOnlyWorkflowDecision.workflowProofCheckpoint.blocksPublishUntilWorkflowProof, true);
688
- assert.equal(routeOnlyWorkflowDecision.workflowProofCheckpoint.blocksWowUiUntilWorkflowProof, true);
689
- assert.equal(routeOnlyWorkflowDecision.nextActionContract.primaryCommand, 'run_aicoder_workflow_qa');
690
- assert.equal(routeOnlyWorkflowDecision.nextActionContract.costRisk, 'small_model_or_qa');
691
- assert.equal(routeOnlyWorkflowDecision.nextActionContract.decisionBasis.routeOnlyBlocked, true);
692
- assert.ok(routeOnlyWorkflowDecision.nextActionContract.stopConditions.some((entry) => /Route-only proof/i.test(entry)));
693
- assert.ok(routeOnlyWorkflowDecision.nextActionContract.forbiddenActions.some((entry) => /route-only proof/i.test(entry)));
694
-
695
- const directRouteOnlyCheckpoint = buildResolveIOAICoderWorkflowProofCheckpoint({
696
- status: 'workflow_qa_required',
697
- nextGate: 'workflow_qa',
698
- routeOnlyBlocked: true,
699
- journeyContractReady: true,
700
- businessProofReady: false,
701
- last: routeOnlyWorkflowBundle.aiCoderV6StepHistory[routeOnlyWorkflowBundle.aiCoderV6StepHistory.length - 1],
702
- workflowQaRows: routeOnlyWorkflowBundle.aiCoderV6WorkflowMemory.workflowQaRows,
703
- businessProofArtifacts: []
704
- });
705
- assert.equal(directRouteOnlyCheckpoint.blocksPublishUntilWorkflowProof, true);
706
- assert.ok(directRouteOnlyCheckpoint.requiredEvidence.some((entry) => /AIQaBusinessAssertion|saved\/calculated output/i.test(entry)));
707
-
708
- let pingPong = initialized;
709
- for (const blocker of ['Workflow save button is disabled', 'Workflow save button is enabled but does not persist', 'Workflow save button is disabled', 'Workflow save button is enabled but does not persist']) {
710
- pingPong = recordResolveIOAICoderV6Step(pingPong, {
711
- lane: 'qa',
712
- stepType: 'workflow_qa',
713
- outcome: 'needs_repair',
714
- failureClass: 'business',
715
- summary: blocker,
716
- blocker,
717
- evidenceHash: blocker
718
- });
719
- }
720
- const pingPongDecision = decideResolveIOAICoderV6Continuation(pingPong);
721
- assert.equal(pingPongDecision.action, 'park');
722
- assert.equal(pingPongDecision.reason, 'aicoder_v6_ping_pong_no_progress');
723
- assert.equal(pingPongDecision.recoveryPlan.recoveryClass, 'blocked_until_new_evidence');
724
- assert.ok(pingPongDecision.recoveryPlan.forbiddenActions.some((action) => /alternate between two failed patches/.test(action)));
725
-
726
- let terminalReplay = initializeResolveIOAICoderV6State({
727
- runKind: 'terminal_helper',
728
- jobId: 'terminal-job-1',
729
- appId: 'app-1',
730
- conversationId: 'conversation-1',
731
- title: 'Fix app dashboard save action',
732
- description: 'Terminal helper should recover from repeated dashboard save failures.',
733
- branchName: 'ai/terminal-dashboard-fix',
734
- now: '2026-06-07T12:20:00.000Z'
735
- });
736
- for (let index = 0; index < 3; index += 1) {
737
- terminalReplay = recordResolveIOAICoderV6Step(terminalReplay, {
738
- lane: 'repair',
739
- stepType: 'repair',
740
- outcome: 'needs_repair',
741
- failureClass: 'product_code',
742
- summary: 'Dashboard save action throws TypeError.',
743
- blocker: 'Dashboard save action throws TypeError cannot read property id.',
744
- evidenceHash: 'terminal-save-typeerror',
745
- artifactPaths: ['.terminal-output/save-typeerror.log']
746
- });
747
- }
748
- const terminalReplayDecision = decideResolveIOAICoderV6Continuation(terminalReplay);
749
- assert.equal(terminalReplayDecision.action, 'park');
750
- assert.equal(terminalReplayDecision.recoveryPlan.recoveryClass, 'blocked_until_new_evidence');
751
- assert.equal(terminalReplayDecision.recoveryPlan.allowedAction, 'collect_new_evidence_only');
752
- assert.ok(terminalReplayDecision.recoveryPlan.loopResetEvidence.some((evidence) => /new artifact path/.test(evidence)));
753
- assert.equal(terminalReplayDecision.recoveryCheckpoint.status, 'parked');
754
- assert.equal(terminalReplayDecision.recoveryCheckpoint.recoveryClass, 'blocked_until_new_evidence');
755
- assert.equal(terminalReplayDecision.recoveryEvidenceProbe.evidenceOnly, true);
756
- assert.ok(terminalReplayDecision.recoveryEvidenceProbe.acceptanceEvidence.some((evidence) => /new artifact path|changed evidence hash/i.test(evidence)));
757
- assert.equal(terminalReplayDecision.recoveryAction.mode, 'collect_evidence');
758
- assert.equal(terminalReplayDecision.recoveryAction.evidenceOnly, true);
759
- assert.ok(terminalReplayDecision.recoveryAction.successCriteria.some((evidence) => /new artifact path|changed evidence hash/i.test(evidence)));
760
-
761
- const terminalCompileFailure = recordResolveIOAICoderV6Step(initializeResolveIOAICoderV6State({
762
- runKind: 'terminal_helper',
763
- jobId: 'terminal-job-2',
764
- appId: 'app-1',
765
- conversationId: 'conversation-2',
766
- title: 'Fix app dashboard compile failure',
767
- description: 'Terminal helper should route app-dashboard compile failures to compile repair.',
768
- branchName: 'ai/terminal-compile-fix',
769
- now: '2026-06-07T12:26:00.000Z'
770
- }), {
771
- lane: 'build',
772
- stepType: 'build',
773
- outcome: 'needs_repair',
774
- failureClass: 'compile',
775
- summary: 'AI terminal dashboard build failed.',
776
- blocker: 'TS2304 cannot find name DashboardWidgetModel',
777
- evidenceHash: 'terminal-compile-before-import-fix',
778
- artifactPaths: ['.terminal-output/build-client.log'],
779
- now: '2026-06-07T12:27:00.000Z'
780
- });
781
- const terminalCompileDecision = decideResolveIOAICoderV6Continuation(terminalCompileFailure);
782
- assert.equal(terminalCompileDecision.action, 'infra_retry');
783
- assert.equal(terminalCompileDecision.reason, 'aicoder_v6_compile_repair_required');
784
- assert.equal(terminalCompileDecision.nextLane, 'build');
785
- assert.equal(terminalCompileDecision.nextStep, 'build');
786
- assert.equal(terminalCompileDecision.recoveryPlan.recoveryClass, 'compile_repair');
787
- assert.equal(terminalCompileDecision.recoveryPlan.productRepairAllowed, false);
788
- assert.equal(terminalCompileDecision.recoveryPlan.expensiveModelAllowed, false);
789
- assert.ok(terminalCompileDecision.recoveryPlan.forbiddenActions.some((action) => /product-code model repair|count this as product failure/i.test(action)));
790
- assert.equal(terminalCompileDecision.workflowReadiness.status, 'compile_repair_only');
791
-
792
- const prompt = buildResolveIOAICoderV6DiagnoseFirstPrompt({
793
- goal: 'Ship a full-featured app update',
794
- activeLane: 'repair',
795
- activeStep: 'repair',
796
- activeBlocker: 'Build failed',
797
- journeyContractPath: 'docs/APP_JOURNEY_CONTRACT.md',
798
- activeWorkflowStep: 'save-result',
799
- changedFiles: ['server/src/methods/invoices.ts'],
800
- artifactPaths: ['qa-artifacts/mobile.png']
801
- });
802
-
803
- assert.ok(prompt.some((line) => /Diagnose First/i.test(line)));
804
- assert.ok(prompt.some((line) => /Active lane: repair/i.test(line)));
805
- assert.ok(prompt.some((line) => /server\/src\/methods\/invoices\.ts/i.test(line)));
806
- assert.ok(prompt.some((line) => /Journey contract: docs\/APP_JOURNEY_CONTRACT\.md/i.test(line)));
807
-
808
- const budgeted = recordResolveIOAICoderV6Step(initialized, {
809
- lane: 'plan',
810
- stepType: 'plan',
811
- outcome: 'pass',
812
- promptTokenEstimate: 9000,
813
- summary: 'Large plan prompt.'
814
- });
815
-
816
- const budgetDecision = decideResolveIOAICoderV6Continuation(budgeted);
817
- assert.equal(budgetDecision.action, 'budget_stop');
818
- assert.equal(budgetDecision.recoveryPlan.recoveryClass, 'manual_handoff');
819
- assert.equal(budgetDecision.workflowReadiness.status, 'budget_stopped');
820
- assert.equal(budgetDecision.workflowReadiness.requiresHumanDecision, true);
821
-
822
- console.log('aicoder runner v6 tests passed');