agentic-qe 3.9.36 → 3.10.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/skills/skills-manifest.json +1 -1
- package/CHANGELOG.md +75 -0
- package/assets/skills/skills-manifest.json +1 -1
- package/dist/cli/bundle.js +5 -5
- package/dist/cli/chunks/adapter-WTE6UVGP.js +2 -0
- package/dist/cli/chunks/{agent-booster-wasm-L6D36M77.js → agent-booster-wasm-5UDM2PWG.js} +2 -2
- package/dist/cli/chunks/{agent-handler-3JNKP4OI.js → agent-handler-JSYER5YC.js} +2 -2
- package/dist/cli/chunks/{agent-memory-branch-QBRBX7O4.js → agent-memory-branch-T2SAHI4F.js} +2 -2
- package/dist/cli/chunks/aqe-learning-engine-LCLEBU7D.js +2 -0
- package/dist/cli/chunks/{audit-M4W43TXQ.js → audit-HIBRVGXG.js} +2 -2
- package/dist/cli/chunks/base-73I73HBF.js +2 -0
- package/dist/cli/chunks/{hnswlib-node-NN6GB2YD.js → better-sqlite3-Y6GX6CGB.js} +2 -2
- package/dist/cli/chunks/{brain-handler-WQN7C55Z.js → brain-handler-N6AWIMXG.js} +3 -3
- package/dist/cli/chunks/{branch-enumerator-BOTGLI7M.js → branch-enumerator-VYQGBVEJ.js} +2 -2
- package/dist/cli/chunks/{browser-ZFZCR7LP.js → browser-2X4WKZPT.js} +2 -2
- package/dist/cli/chunks/browser-workflow-2NSV5O6W.js +2 -0
- package/dist/cli/chunks/{chunk-FSDUNGYM.js → chunk-27ACATRH.js} +2 -2
- package/dist/cli/chunks/{chunk-SJ3SHZUC.js → chunk-2GL4GH52.js} +4 -4
- package/dist/cli/chunks/{chunk-F5IVWV2P.js → chunk-2POXDKUB.js} +1 -1
- package/dist/cli/chunks/chunk-3BO7EKGO.js +12 -0
- package/dist/cli/chunks/{chunk-BUVY7IGM.js → chunk-3OSCWD7Z.js} +1 -1
- package/dist/cli/chunks/{chunk-GW7HWFWQ.js → chunk-3QULDB7K.js} +1 -1
- package/dist/cli/chunks/{chunk-PYCYZYIL.js → chunk-3U77XX6J.js} +4 -4
- package/dist/cli/chunks/{chunk-EXBJCDFM.js → chunk-4NQ6KANC.js} +2 -2
- package/dist/cli/chunks/{chunk-6M44C43I.js → chunk-4UUDFWOP.js} +2 -2
- package/dist/cli/chunks/{chunk-FYJE4QLL.js → chunk-4WYGUTSF.js} +2 -2
- package/dist/cli/chunks/{chunk-SCBWRKPE.js → chunk-55JPAF56.js} +1 -1
- package/dist/cli/chunks/{chunk-TU2PSEDW.js → chunk-5QJDH4Z5.js} +2 -2
- package/dist/cli/chunks/{chunk-YMB4YVFX.js → chunk-5RQT7EJP.js} +3 -3
- package/dist/cli/chunks/{chunk-X6UGFKHW.js → chunk-5UOV7T36.js} +2 -2
- package/dist/cli/chunks/{chunk-KI6RXKP4.js → chunk-66GIKUI2.js} +2 -2
- package/dist/cli/chunks/{chunk-BI54GWTK.js → chunk-6F3WJOU2.js} +2 -2
- package/dist/cli/chunks/{chunk-OO2JHVMS.js → chunk-6H5MRVJS.js} +3 -3
- package/dist/cli/chunks/{chunk-O5JNHH2D.js → chunk-6HCHW5TS.js} +2 -2
- package/dist/cli/chunks/{chunk-JD3VV2BD.js → chunk-6MONUYQ5.js} +2 -2
- package/dist/cli/chunks/{chunk-RDXIRE2I.js → chunk-7Y54QZKF.js} +2 -2
- package/dist/cli/chunks/{chunk-P7IOH7L4.js → chunk-7ZIRDBXH.js} +1 -1
- package/dist/cli/chunks/{chunk-AWC7G2D3.js → chunk-AFFYJSW2.js} +2 -2
- package/dist/cli/chunks/{chunk-I7BXATQ6.js → chunk-ALCQRJDY.js} +2 -2
- package/dist/cli/chunks/{chunk-VENEJ3UI.js → chunk-BQT4J3BD.js} +2 -2
- package/dist/cli/chunks/{chunk-5OAAJUGO.js → chunk-BQX5QDU5.js} +1 -1
- package/dist/cli/chunks/{chunk-CJQT3MYN.js → chunk-BTIVIWIG.js} +1 -1
- package/dist/cli/chunks/{chunk-6M2POFDF.js → chunk-BXCS55GB.js} +1 -1
- package/dist/cli/chunks/{chunk-MJJAHA2T.js → chunk-C5QESAYA.js} +1 -1
- package/dist/cli/chunks/{chunk-NYU4YD5V.js → chunk-CU4IUJ2K.js} +2 -2
- package/dist/cli/chunks/{chunk-LPVRFVSC.js → chunk-DQJJS4AX.js} +2 -2
- package/dist/cli/chunks/{chunk-GFMSAL5Y.js → chunk-DQLEZBWV.js} +2 -2
- package/dist/cli/chunks/{chunk-5SYH5QMQ.js → chunk-DXV6NRG3.js} +2 -2
- package/dist/cli/chunks/{chunk-EAMKH35X.js → chunk-DY7IRNE2.js} +1 -1
- package/dist/cli/chunks/{chunk-4R3WXD4U.js → chunk-F363JJUI.js} +1 -1
- package/dist/cli/chunks/{chunk-JFDNNXIX.js → chunk-FCSJ7GIZ.js} +2 -2
- package/dist/cli/chunks/{chunk-QMUTKI34.js → chunk-FEBXP74Y.js} +1 -1
- package/dist/cli/chunks/{chunk-EXUT2LCP.js → chunk-FQ5FT7IE.js} +1 -1
- package/dist/cli/chunks/{chunk-MEQ4OPSL.js → chunk-FX4SYT6Y.js} +3 -3
- package/dist/cli/chunks/{chunk-ZK6GXL5J.js → chunk-G2HA2O3R.js} +2 -2
- package/dist/cli/chunks/{chunk-TCDGJYM2.js → chunk-GPKZ4MMH.js} +1 -1
- package/dist/cli/chunks/{chunk-66636UWH.js → chunk-GXCD7GNH.js} +2 -2
- package/dist/cli/chunks/{chunk-CAGRQR2U.js → chunk-HD5NQDOL.js} +2 -2
- package/dist/cli/chunks/{chunk-5ZTY5JJX.js → chunk-HD6CZBZV.js} +2 -2
- package/dist/cli/chunks/{chunk-JA7YARLP.js → chunk-HIWBW4IQ.js} +1 -1
- package/dist/cli/chunks/{chunk-YUFUGGXY.js → chunk-HZPXOAFW.js} +2 -2
- package/dist/cli/chunks/{chunk-3CIQ6CQ4.js → chunk-I4E6CLC4.js} +2 -2
- package/dist/cli/chunks/{chunk-FK4B2HIW.js → chunk-I4T4JPR2.js} +1 -1
- package/dist/cli/chunks/{chunk-X6IEQVSF.js → chunk-IBXNBLGM.js} +2 -2
- package/dist/cli/chunks/{chunk-GLI5EN6O.js → chunk-IQNR662U.js} +2 -2
- package/dist/cli/chunks/{chunk-YKZ3ZJWT.js → chunk-J5RJYFRM.js} +2 -2
- package/dist/cli/chunks/{chunk-27FNROZ2.js → chunk-JCKX2LEJ.js} +9 -9
- package/dist/cli/chunks/{chunk-IMP43AXO.js → chunk-JKVNZASH.js} +2 -2
- package/dist/cli/chunks/{chunk-Z5A2ENBC.js → chunk-JUICZG3T.js} +2 -2
- package/dist/cli/chunks/{chunk-MFPVS2KP.js → chunk-KCHFF4IE.js} +9 -9
- package/dist/cli/chunks/{chunk-TG44VKO3.js → chunk-KDFW7MVM.js} +2 -2
- package/dist/cli/chunks/{chunk-O4C3JEOR.js → chunk-KNL3QWVA.js} +2 -2
- package/dist/cli/chunks/{chunk-ZBY4HSHR.js → chunk-KOSKGZK4.js} +2 -2
- package/dist/cli/chunks/{chunk-G7YDYXQH.js → chunk-KYLJERZ3.js} +2 -2
- package/dist/cli/chunks/{chunk-7ZCDG3IM.js → chunk-L2AIES7X.js} +1 -1
- package/dist/cli/chunks/{chunk-6DACR7QY.js → chunk-L3IFZ4IX.js} +2 -2
- package/dist/cli/chunks/{chunk-2AANIKDG.js → chunk-L4N6PTIC.js} +2 -2
- package/dist/cli/chunks/{chunk-BNFW4LMD.js → chunk-LDMG4372.js} +2 -2
- package/dist/cli/chunks/{chunk-QH7K2UPP.js → chunk-LQ3TA22E.js} +2 -2
- package/dist/cli/chunks/{chunk-EDG4NEET.js → chunk-LRISVDVO.js} +1 -1
- package/dist/cli/chunks/{chunk-XNXFEMWT.js → chunk-LXHA55EB.js} +1 -1
- package/dist/cli/chunks/{chunk-AJ2VFSLX.js → chunk-LYVFC7C7.js} +2 -2
- package/dist/cli/chunks/{chunk-U6QAKKNB.js → chunk-M3M7HXDH.js} +2 -2
- package/dist/cli/chunks/{chunk-PY4B37U3.js → chunk-M4HDBRVJ.js} +1 -1
- package/dist/cli/chunks/{chunk-6BHUKCLI.js → chunk-M73IL7FA.js} +2 -2
- package/dist/cli/chunks/{chunk-F57OUXHJ.js → chunk-MF3XRML3.js} +2 -2
- package/dist/cli/chunks/{chunk-NKA3X6VT.js → chunk-MJBXQXSX.js} +1 -1
- package/dist/cli/chunks/{chunk-D5CLABLM.js → chunk-NLCUQMUR.js} +2 -2
- package/dist/cli/chunks/{chunk-IF4ZZ2HD.js → chunk-NT4PI5HI.js} +2 -2
- package/dist/cli/chunks/{chunk-74DA4P5K.js → chunk-NWHSEXHA.js} +1 -1
- package/dist/cli/chunks/{chunk-Y4ERDIPP.js → chunk-O3NAUNFC.js} +2 -2
- package/dist/cli/chunks/{chunk-AH3UC4IV.js → chunk-OGT45MZN.js} +2 -2
- package/dist/cli/chunks/{chunk-HOZNVDFF.js → chunk-OKGK7DBT.js} +2 -2
- package/dist/cli/chunks/{chunk-U7B4WCBY.js → chunk-OUJJ34JH.js} +1 -1
- package/dist/cli/chunks/{chunk-P4VQTIJE.js → chunk-OWMGD7FO.js} +3 -3
- package/dist/cli/chunks/{chunk-PGRDHDEJ.js → chunk-P6XYFDXN.js} +1 -1
- package/dist/cli/chunks/{chunk-NMHULQAV.js → chunk-PNDO4W4L.js} +2 -2
- package/dist/cli/chunks/{chunk-MAHLTWGV.js → chunk-QL3U5VSM.js} +2 -2
- package/dist/cli/chunks/{chunk-RCU5L7FF.js → chunk-QU54GUEA.js} +2 -2
- package/dist/cli/chunks/{chunk-OLBYILKU.js → chunk-QWBO76AU.js} +2 -2
- package/dist/cli/chunks/{chunk-QYUWWTE3.js → chunk-RARSTEUO.js} +1 -1
- package/dist/cli/chunks/{chunk-PUZAIRMY.js → chunk-RF6QKV7M.js} +2 -2
- package/dist/cli/chunks/{chunk-7TO7NTLT.js → chunk-RGONSQ44.js} +8 -8
- package/dist/cli/chunks/{chunk-A3TOJ4KN.js → chunk-RH3PHCJT.js} +2 -2
- package/dist/cli/chunks/{chunk-5M63H6RY.js → chunk-S33246T4.js} +1 -1
- package/dist/cli/chunks/{chunk-ESIE3MT5.js → chunk-S4CNA6Z5.js} +3 -3
- package/dist/cli/chunks/{chunk-GWLLNJ64.js → chunk-SCYF5CQA.js} +1 -1
- package/dist/cli/chunks/{chunk-DTJHO3WI.js → chunk-SGONA5GS.js} +2 -2
- package/dist/cli/chunks/{chunk-CLATNP57.js → chunk-T7DLX3LS.js} +3 -3
- package/dist/cli/chunks/{chunk-QAGAEAKM.js → chunk-TEJPHJMW.js} +2 -2
- package/dist/cli/chunks/{chunk-W2DF6FNE.js → chunk-TR7BZLB6.js} +1 -1
- package/dist/cli/chunks/{chunk-L3JJ52N6.js → chunk-U56TIYGP.js} +2 -2
- package/dist/cli/chunks/{chunk-TOZ6WUAB.js → chunk-UCIJCRPB.js} +2 -2
- package/dist/cli/chunks/{chunk-AH3TKDVW.js → chunk-UCXQQCIP.js} +2 -2
- package/dist/cli/chunks/{chunk-5MSZREOD.js → chunk-UE3XXKLN.js} +2 -2
- package/dist/cli/chunks/{chunk-556GYKN5.js → chunk-UGX4EHT5.js} +2 -2
- package/dist/cli/chunks/{chunk-2EWOYVH3.js → chunk-URVDWF2Y.js} +2 -2
- package/dist/cli/chunks/{chunk-DCXFHBHS.js → chunk-V5TRAL57.js} +2 -2
- package/dist/cli/chunks/{chunk-LIE24NRL.js → chunk-VEOQH4W6.js} +2 -2
- package/dist/cli/chunks/{chunk-AY2LLGZN.js → chunk-VMJXNTJT.js} +4 -4
- package/dist/cli/chunks/{chunk-FZA674BT.js → chunk-VTIXFHZR.js} +2 -2
- package/dist/cli/chunks/{chunk-GAC4MD6S.js → chunk-VTO5O7DA.js} +1 -1
- package/dist/cli/chunks/{chunk-G6Q66YLG.js → chunk-W6U7SIIK.js} +3 -3
- package/dist/cli/chunks/{chunk-CSDGFQKW.js → chunk-WC6KZDPM.js} +2 -2
- package/dist/cli/chunks/{chunk-2KMCRASK.js → chunk-WG6I7YF3.js} +1 -1
- package/dist/cli/chunks/{chunk-TK7TGVVQ.js → chunk-WLLE54TA.js} +1 -1
- package/dist/cli/chunks/{chunk-HHGZ4LXC.js → chunk-WVCIZIKH.js} +1 -1
- package/dist/cli/chunks/{chunk-NKBCAW27.js → chunk-X4U5NYB6.js} +1 -1
- package/dist/cli/chunks/chunk-X73CRYF4.js +2 -0
- package/dist/cli/chunks/{chunk-5ECOD4O6.js → chunk-XFMSHTXG.js} +1 -1
- package/dist/cli/chunks/{chunk-LUFY3GGI.js → chunk-XFUU2RCA.js} +2 -2
- package/dist/cli/chunks/{chunk-QXM3PRVR.js → chunk-Y4I5JBOL.js} +2 -2
- package/dist/cli/chunks/{chunk-C2JK5O55.js → chunk-YHNEBCYQ.js} +2 -2
- package/dist/cli/chunks/{chunk-5RPHV7Y3.js → chunk-YYDHTBHE.js} +1 -1
- package/dist/cli/chunks/{chunk-DKBBMZWB.js → chunk-Z2SCTEZD.js} +2 -2
- package/dist/cli/chunks/{chunk-CK5TGFII.js → chunk-Z6JLPPAY.js} +1 -1
- package/dist/cli/chunks/{chunk-TXSVZYFA.js → chunk-ZCNVFULO.js} +2 -2
- package/dist/cli/chunks/{chunk-YE42UTLT.js → chunk-ZFBMBCKN.js} +2 -2
- package/dist/cli/chunks/{chunk-BGD65PL4.js → chunk-ZYZWBNKT.js} +1 -1
- package/dist/cli/chunks/{ci-YA6SQ3PU.js → ci-7TR4NQ5I.js} +2 -2
- package/dist/cli/chunks/{ci-output-KKHXCQI4.js → ci-output-SLTICF3O.js} +2 -2
- package/dist/cli/chunks/{circuit-breaker-RTBCXGKA.js → circuit-breaker-7GVVTMBY.js} +2 -2
- package/dist/cli/chunks/{claude-flow-setup-CRV3Y6LO.js → claude-flow-setup-TYCWYEMM.js} +2 -2
- package/dist/cli/chunks/client-7GB4WWUD.js +2 -0
- package/dist/cli/chunks/{cline-installer-IS2VLXQS.js → cline-installer-ESIAJOLK.js} +2 -2
- package/dist/cli/chunks/{code-3CSNTK5O.js → code-I42JGOVI.js} +2 -2
- package/dist/cli/chunks/{code-index-extractor-P2YXEJGV.js → code-index-extractor-2CCXPCQW.js} +2 -2
- package/dist/cli/chunks/{codex-installer-QGDV2CAQ.js → codex-installer-HEZRDNUT.js} +2 -2
- package/dist/cli/chunks/{completions-TYECEYHY.js → completions-44HLIZGI.js} +2 -2
- package/dist/cli/chunks/{complexity-analyzer-GA5KSFF2.js → complexity-analyzer-SOCSFDVO.js} +2 -2
- package/dist/cli/chunks/{continuedev-installer-NW5Y4ZMI.js → continuedev-installer-Q7O4HLIM.js} +2 -2
- package/dist/cli/chunks/{copilot-installer-E5BIBYG6.js → copilot-installer-GIWCVLCS.js} +2 -2
- package/dist/cli/chunks/{cost-tracker-JLSEY4ID.js → cost-tracker-G7BONKEV.js} +2 -2
- package/dist/cli/chunks/{coverage-4TH275AN.js → coverage-5TWVP7KY.js} +3 -3
- package/dist/cli/chunks/cross-domain-router-7HQ74TLE.js +2 -0
- package/dist/cli/chunks/{cursor-installer-4SXSE5YT.js → cursor-installer-43EQZSB5.js} +2 -2
- package/dist/cli/chunks/{daemon-U6MP4P6S.js → daemon-QQZE4BU2.js} +4 -4
- package/dist/cli/chunks/{daemon-7T4RZQH6.js → daemon-ZXHFRDKG.js} +3 -3
- package/dist/cli/chunks/{dag-attention-scheduler-DT2V46XR.js → dag-attention-scheduler-GOZAVAZQ.js} +2 -2
- package/dist/cli/chunks/{detect-WHSTB4QT.js → detect-X777GVJ4.js} +2 -2
- package/dist/cli/chunks/{dist-node-4LC2RJXW.js → dist-node-EZZK46TB.js} +2 -2
- package/dist/cli/chunks/{domain-handler-A2LOOU7Y.js → domain-handler-ZT32DKYY.js} +2 -2
- package/dist/cli/chunks/{domain-transfer-4RJTMB3Y.js → domain-transfer-LHQVSLJW.js} +2 -2
- package/dist/cli/chunks/dream-G5SEFHI4.js +2 -0
- package/dist/cli/chunks/{embed-and-insert-pattern-PR3KTT24.js → embed-and-insert-pattern-XFYPPWG7.js} +2 -2
- package/dist/cli/chunks/{eval-2HRBMOOB.js → eval-V4NYJZUZ.js} +2 -2
- package/dist/cli/chunks/{experience-capture-middleware-X46IYOSD.js → experience-capture-middleware-HXX2W4GL.js} +3 -3
- package/dist/cli/chunks/{fast-paths-LYYYU362.js → fast-paths-RBPWQSFJ.js} +2 -2
- package/dist/cli/chunks/{feature-flags-TKDXIHOH.js → feature-flags-INJJZBMN.js} +2 -2
- package/dist/cli/chunks/{feature-flags-RNAMQPUN.js → feature-flags-NX5EXRO3.js} +2 -2
- package/dist/cli/chunks/{file-discovery-MKGGMDIW.js → file-discovery-SNFSG6NK.js} +2 -2
- package/dist/cli/chunks/{fleet-OY4IBCZG.js → fleet-6SDN4UWE.js} +3 -3
- package/dist/cli/chunks/{gnn-wrapper-G5OGHVAQ.js → gnn-wrapper-2JDRTDDK.js} +2 -2
- package/dist/cli/chunks/{heartbeat-handler-N7IUATSD.js → heartbeat-handler-QLK6E7KA.js} +4 -4
- package/dist/cli/chunks/heartbeat-scheduler-NG7BY3FR.js +2 -0
- package/dist/cli/chunks/hnsw-adapter-TDSLUI7K.js +2 -0
- package/dist/cli/chunks/hnsw-index-OWLQSOQH.js +2 -0
- package/dist/cli/chunks/{hnsw-legacy-bridge-TMCMZDVF.js → hnsw-legacy-bridge-Q2ZEZQKB.js} +2 -2
- package/dist/cli/chunks/{better-sqlite3-SPABZYYQ.js → hnswlib-node-TA4DZV62.js} +2 -2
- package/dist/cli/chunks/{hooks-5QDXEZ25.js → hooks-D4YENHO2.js} +10 -10
- package/dist/cli/chunks/{hybrid-router-IY62NN7G.js → hybrid-router-URU2XLBD.js} +2 -2
- package/dist/cli/chunks/{hypergraph-engine-QQYKS2F3.js → hypergraph-engine-G72U446M.js} +2 -2
- package/dist/cli/chunks/{hypergraph-handler-YXFNXMRF.js → hypergraph-handler-TRZ5FDRH.js} +3 -3
- package/dist/cli/chunks/impact-analyzer-NMTN75KA.js +2 -0
- package/dist/cli/chunks/{init-handler-SFFSDGEF.js → init-handler-3ZD4GCT4.js} +6 -6
- package/dist/cli/chunks/init-wizard-SHBFYGBV.js +2 -0
- package/dist/cli/chunks/kernel-7KVY2JGO.js +2 -0
- package/dist/cli/chunks/{kilocode-installer-QFRYXQYY.js → kilocode-installer-AXSIW3XW.js} +2 -2
- package/dist/cli/chunks/{kiro-installer-7L2EYEOR.js → kiro-installer-JQGIFWBK.js} +2 -2
- package/dist/cli/chunks/knowledge-graph-V4G5J5B7.js +2 -0
- package/dist/cli/chunks/{learning-7TVVL5UH.js → learning-SPO7TGWX.js} +3 -3
- package/dist/cli/chunks/{llm-router-S3HHVPH4.js → llm-router-G6N2OKDA.js} +4 -4
- package/dist/cli/chunks/{load-Y46RO7BF.js → load-XIDDK64U.js} +2 -2
- package/dist/cli/chunks/load-test-N4RNPLG4.js +2 -0
- package/dist/cli/chunks/{mcp-PYNP2S5O.js → mcp-3JXRGXO4.js} +2 -2
- package/dist/cli/chunks/{memory-DAVXW5OP.js → memory-A66KRS2P.js} +5 -5
- package/dist/cli/chunks/memory-backend-HPGJ5YDQ.js +2 -0
- package/dist/cli/chunks/{memory-handlers-6COHVON7.js → memory-handlers-K33YVCVQ.js} +2 -2
- package/dist/cli/chunks/{multi-model-executor-7ECJRCM3.js → multi-model-executor-XCDGUVCE.js} +2 -2
- package/dist/cli/chunks/{opencode-installer-H7QOONUC.js → opencode-installer-GELXWLF2.js} +2 -2
- package/dist/cli/chunks/{orchestrator-TSJ2F3MG.js → orchestrator-CCS3K6NH.js} +5 -5
- package/dist/cli/chunks/{pipeline-SXR4MRY7.js → pipeline-Z5C72H5S.js} +2 -2
- package/dist/cli/chunks/{platform-7NOS56VD.js → platform-4AK7XJ3Y.js} +2 -2
- package/dist/cli/chunks/{plugin-VLSWBGJN.js → plugin-7RYBIZI7.js} +2 -2
- package/dist/cli/chunks/{prime-radiant-advanced-wasm-7ZHSOP7H.js → prime-radiant-advanced-wasm-E5PARKRX.js} +2 -2
- package/dist/cli/chunks/protocol-executor-GNVWUJUP.js +2 -0
- package/dist/cli/chunks/{protocol-handler-LWNYDM4D.js → protocol-handler-R6QJQFNL.js} +2 -2
- package/dist/cli/chunks/{prove-JYFW3OBB.js → prove-7ESQ2YAL.js} +2 -2
- package/dist/cli/chunks/{provider-manager-VPS4W7KG.js → provider-manager-HV55NIIO.js} +2 -2
- package/dist/cli/chunks/qe-reasoning-bank-DDSBHO6D.js +2 -0
- package/dist/cli/chunks/{quality-FCAOFXZ2.js → quality-4UE345QA.js} +2 -2
- package/dist/cli/chunks/queen-coordinator-BQJ5O63C.js +2 -0
- package/dist/cli/chunks/real-embeddings-TYIVN3N5.js +2 -0
- package/dist/cli/chunks/{roocode-installer-ZVGJSAWD.js → roocode-installer-2KOANC47.js} +2 -2
- package/dist/cli/chunks/router-C2RKWB7J.js +2 -0
- package/dist/cli/chunks/routing-feedback-RHATTSJ6.js +2 -0
- package/dist/cli/chunks/{routing-handler-AGDHK3A2.js → routing-handler-JFEYTN7T.js} +2 -2
- package/dist/cli/chunks/{ruvector-commands-UGZINDCN.js → ruvector-commands-KSLSZRJX.js} +2 -2
- package/dist/cli/chunks/{rvf-dual-writer-PW7H6G4V.js → rvf-dual-writer-EPBL226J.js} +2 -2
- package/dist/cli/chunks/{rvf-migration-adapter-ZKOTVCHJ.js → rvf-migration-adapter-25KSI6SF.js} +2 -2
- package/dist/cli/chunks/{rvf-migration-coordinator-SCBEMOP3.js → rvf-migration-coordinator-2XBYHPZP.js} +2 -2
- package/dist/cli/chunks/rvf-native-adapter-QG4CXHLL.js +2 -0
- package/dist/cli/chunks/safe-db-A4KQ2IDB.js +2 -0
- package/dist/cli/chunks/schedule-O7MLASQT.js +2 -0
- package/dist/cli/chunks/scheduler-HT7RNYQ2.js +2 -0
- package/dist/cli/chunks/{security-H7QX46VA.js → security-4XWYKI4O.js} +3 -3
- package/dist/cli/chunks/{shared-rvf-adapter-LWYHWJIA.js → shared-rvf-adapter-WRZ3HGDQ.js} +2 -2
- package/dist/cli/chunks/{shared-rvf-dual-writer-P2U424FB.js → shared-rvf-dual-writer-DX2N5STR.js} +2 -2
- package/dist/cli/chunks/sqlite-persistence-4NNKJ6CQ.js +2 -0
- package/dist/cli/chunks/{status-handler-UNX3RA3S.js → status-handler-V75OSXMQ.js} +2 -2
- package/dist/cli/chunks/{structural-health-65YV3M5E.js → structural-health-TLX3JHZ6.js} +2 -2
- package/dist/cli/chunks/{sync-OZ7CHYYO.js → sync-DXZFMVZQ.js} +2 -2
- package/dist/cli/chunks/{sync-B4O3NDJ6.js → sync-KGBEXUF7.js} +2 -2
- package/dist/cli/chunks/{task-handler-NIG3USPG.js → task-handler-T3OJ6R7H.js} +2 -2
- package/dist/cli/chunks/{task-handlers-Z2PI7BTO.js → task-handlers-NJYR54AS.js} +3 -3
- package/dist/cli/chunks/{test-MNLYS3WS.js → test-KMVDNNQA.js} +4 -4
- package/dist/cli/chunks/{test-scheduling-VCL6D6T7.js → test-scheduling-R5EQ2XGV.js} +3 -3
- package/dist/cli/chunks/{token-bootstrap-DGMEU3W4.js → token-bootstrap-PFKVV3RO.js} +2 -2
- package/dist/cli/chunks/{token-usage-IXTYAV5K.js → token-usage-ZLOGA6LR.js} +2 -2
- package/dist/cli/chunks/{transformers-5CWLXT2M.js → transformers-TNPSPQI3.js} +2 -2
- package/dist/cli/chunks/{tree-sitter-wasm-parser-W3FKJLJG.js → tree-sitter-wasm-parser-A2EEB5BF.js} +2 -2
- package/dist/cli/chunks/{types-NVOCAZCQ.js → types-DIXPI4NR.js} +2 -2
- package/dist/cli/chunks/unified-memory-CMNJVHOJ.js +2 -0
- package/dist/cli/chunks/unified-memory-hnsw-JQLU2KI6.js +2 -0
- package/dist/cli/chunks/unified-persistence-I25TEDIU.js +2 -0
- package/dist/cli/chunks/{upgrade-VJYD4U4X.js → upgrade-LX5KP6VO.js} +2 -2
- package/dist/cli/chunks/{validate-CAKTCZ3T.js → validate-3L6F7M36.js} +2 -2
- package/dist/cli/chunks/{validate-swarm-H24JHUTN.js → validate-swarm-FD42ZKAQ.js} +2 -2
- package/dist/cli/chunks/{vibium-247XN6V3.js → vibium-GSBSJR53.js} +2 -2
- package/dist/cli/chunks/visual-security-AJJIEV5V.js +2 -0
- package/dist/cli/chunks/{web-tree-sitter-3DOMHLRH.js → web-tree-sitter-TXHMO4BW.js} +2 -2
- package/dist/cli/chunks/{windsurf-installer-S2MOA5TQ.js → windsurf-installer-3EUZ6RD3.js} +2 -2
- package/dist/cli/chunks/witness-chain-762QQBTN.js +2 -0
- package/dist/cli/chunks/{witness-chain-CKLVPFLG.js → witness-chain-ONAUEJ4M.js} +2 -2
- package/dist/cli/chunks/{workflow-GU3IV2OD.js → workflow-E7A6BV4C.js} +4 -4
- package/dist/cli/chunks/workflow-orchestrator-ZGPYISKY.js +2 -0
- package/dist/cli/chunks/{wrappers-74Y4EKW3.js → wrappers-AHHAQJM3.js} +2 -2
- package/dist/learning/embedder-endpoint-client.d.ts +133 -0
- package/dist/learning/embedder-endpoint-client.js +426 -0
- package/dist/learning/embedder-identity-store.d.ts +30 -0
- package/dist/learning/embedder-identity-store.js +136 -0
- package/dist/learning/qe-reasoning-bank.js +11 -3
- package/dist/learning/real-embeddings.d.ts +28 -0
- package/dist/learning/real-embeddings.js +130 -19
- package/dist/learning/sqlite-persistence.js +16 -3
- package/dist/mcp/bundle.js +399 -389
- package/package.json +1 -1
- package/dist/cli/chunks/adapter-MISKG4JY.js +0 -2
- package/dist/cli/chunks/aqe-learning-engine-NDLBNM6C.js +0 -2
- package/dist/cli/chunks/base-OMDJAHGF.js +0 -2
- package/dist/cli/chunks/browser-workflow-XUG5Z5CJ.js +0 -2
- package/dist/cli/chunks/chunk-USLHYNYG.js +0 -2
- package/dist/cli/chunks/chunk-ZYPSXPQ5.js +0 -2
- package/dist/cli/chunks/client-VXJRAW3W.js +0 -2
- package/dist/cli/chunks/cross-domain-router-AKHC7TFO.js +0 -2
- package/dist/cli/chunks/dream-FPWIC7KF.js +0 -2
- package/dist/cli/chunks/heartbeat-scheduler-WHGMTRT7.js +0 -2
- package/dist/cli/chunks/hnsw-adapter-IA2M5KDH.js +0 -2
- package/dist/cli/chunks/hnsw-index-UBXTXXLQ.js +0 -2
- package/dist/cli/chunks/impact-analyzer-6PVCOS33.js +0 -2
- package/dist/cli/chunks/init-wizard-XHP5C6RD.js +0 -2
- package/dist/cli/chunks/kernel-YM5PY5SS.js +0 -2
- package/dist/cli/chunks/knowledge-graph-LTUOUHO7.js +0 -2
- package/dist/cli/chunks/load-test-CYCAQI3F.js +0 -2
- package/dist/cli/chunks/memory-backend-RW2OPAJU.js +0 -2
- package/dist/cli/chunks/protocol-executor-CREUYOBZ.js +0 -2
- package/dist/cli/chunks/qe-reasoning-bank-J4DLHRJY.js +0 -2
- package/dist/cli/chunks/queen-coordinator-MGLNSTPY.js +0 -2
- package/dist/cli/chunks/real-embeddings-LE6YXNPZ.js +0 -2
- package/dist/cli/chunks/router-CXGPFUT2.js +0 -2
- package/dist/cli/chunks/routing-feedback-MZ73LFBP.js +0 -2
- package/dist/cli/chunks/rvf-native-adapter-T6JBPHTE.js +0 -2
- package/dist/cli/chunks/safe-db-DS4SKPYB.js +0 -2
- package/dist/cli/chunks/schedule-H2Q7XWAK.js +0 -2
- package/dist/cli/chunks/scheduler-PMZMKQIF.js +0 -2
- package/dist/cli/chunks/sqlite-persistence-ONKEAMTQ.js +0 -2
- package/dist/cli/chunks/unified-memory-PNHI6I3R.js +0 -2
- package/dist/cli/chunks/unified-memory-hnsw-CDV3UMBD.js +0 -2
- package/dist/cli/chunks/unified-persistence-FMCHCEZV.js +0 -2
- package/dist/cli/chunks/visual-security-3WRJQDUY.js +0 -2
- package/dist/cli/chunks/witness-chain-5ZKCKNRJ.js +0 -2
- package/dist/cli/chunks/workflow-orchestrator-OBSFY7YK.js +0 -2
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.
|
|
2
|
-
import{a as p,c as h}from"./chunk-
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{a as p,c as h}from"./chunk-SGONA5GS.js";import"./chunk-5UOV7T36.js";import{S as A,a as u,b as f,c as d}from"./chunk-KOSKGZK4.js";import{a as y}from"./chunk-55JPAF56.js";A();h();import{Command as S}from"commander";import e from"chalk";var F=[{name:"hnswlib-node",flag:"useNativeHNSW",fallback:"ProgressiveHnswBackend"},{name:"prime-radiant-advanced-wasm",flag:"useCoherenceGate",fallback:"Word-frequency heuristics"},{name:"@ruvector/sona",flag:"useSONAThreeLoop",fallback:"TypeScript MicroLoRA/EWC++"}],D={useQESONA:"Self-Optimizing Neural Architecture",useQEFlashAttention:"SIMD-accelerated attention computation",useQEGNNIndex:"Differentiable search and HNSW indexing",logMigrationMetrics:"Log migration metrics during rollout",useNativeHNSW:"Native HNSW backend (hnswlib-node, C++ Hnswlib reference)",useTemporalCompression:"Temporal tensor compression (ADR-085)",useMetadataFiltering:"SIMD-accelerated metadata filtering",useDeterministicDither:"Cross-platform deterministic dithering",useNeuralRouting:"Neural model routing via FastGRNN (ADR-082)",useSONAThreeLoop:"SONA Three-Loop Engine (Task 2.2)",useCrossDomainTransfer:"Cross-domain transfer learning (ADR-084)",useHnswHealthMonitor:"HNSW health monitor (Task 3.4)",useRegretTracking:"Regret tracking & learning health (Task 2.4)",useCoherenceGate:"Sheaf-gated coherence validation (ADR-083, Task 3.1)",useWitnessChain:"SHA-256 hash-chained witness records (Task 3.1)",useCNNVisualRegression:"CNN visual regression testing (Task 4.3)",useDAGAttention:"DAG attention for test scheduling (Task 4.2)",useCoherenceActionGate:"Coherence-gated agent actions (ADR-083, Task 3.2)",useReasoningQEC:"Reasoning QEC error correction (Task 4.5)",useRVFPatternStore:"RVF-backed PatternStore with persistent HNSW (ADR-066)",useAgentMemoryBranching:"Agent memory branching via RVF COW (ADR-067)",useUnifiedHnsw:"Unified HNSW provider replacing 3 legacy impls (ADR-071)",rvfMigrationStage:"RVF migration stage 0-4: sqlite\u2192hybrid\u2192dual\u2192rvf-primary (ADR-072)",useHDCFingerprinting:"HDC pattern fingerprinting (R1, ADR-087)",useCusumDriftDetection:"CUSUM drift detection (R2, ADR-087)",useDeltaEventSourcing:"Delta event sourcing (R3, ADR-087)",useEwcPlusPlusRegularization:"EWC++ regularization (ADR-087)",useGraphMAEEmbeddings:"GraphMAE self-supervised embeddings (R4, ADR-087)",useHopfieldMemory:"Modern Hopfield memory (R5, ADR-087)",useColdTierGNN:"Cold-tier GNN training (R6, ADR-087)",useMetaLearningEnhancements:"Meta-learning enhancements (R7, ADR-087)",useSublinearSolver:"Sublinear PageRank solver (R8, ADR-087)",useSpectralSparsification:"Spectral graph sparsification (R9, ADR-087)",useReservoirReplay:"Reservoir replay with coherence gating (R10, ADR-087)",useEpropOnlineLearning:"E-prop online learning, RL algorithm #10 (R11, ADR-087)",useGrangerCausality:"Granger causality for test failure prediction (R12, ADR-087)",useCognitiveRouting:"Cognitive routing with predictive delta compression (R13, ADR-087)",useHyperbolicHnsw:"Hyperbolic HNSW with Poincare ball embeddings (R14, ADR-087)"},m={performance:{useNativeHNSW:!0,useTemporalCompression:!0,useDeterministicDither:!0},experimental:{useQESONA:!0,useQEFlashAttention:!0,useQEGNNIndex:!0,logMigrationMetrics:!0,useNativeHNSW:!0,useTemporalCompression:!0,useMetadataFiltering:!0,useDeterministicDither:!0,useNeuralRouting:!0},safe:{useQESONA:!0,useQEFlashAttention:!0,useQEGNNIndex:!0,logMigrationMetrics:!0,useNativeHNSW:!1,useTemporalCompression:!1,useMetadataFiltering:!1,useDeterministicDither:!1,useNeuralRouting:!1}},g=Object.keys(u);function b(o){try{return y.resolve(o),!0}catch{return!1}}function v(o,s){return u[o]===s}function i(o,s){return o.padEnd(s)}function N(o){return o<1024?`${o}B`:o<1024*1024?`${(o/1024).toFixed(1)}KB`:o<1024*1024*1024?`${(o/(1024*1024)).toFixed(1)}MB`:`${(o/(1024*1024*1024)).toFixed(2)}GB`}function k(o){return g.includes(o)}function C(o){return o in m}function T(){let o=f();console.log(""),console.log(e.bold.blue("RuVector Integration Status:")),console.log(e.cyan(" Native Packages:"));for(let t of F){let a=b(t.name)?e.green("installed"):e.gray(`not installed (fallback: ${t.fallback})`);console.log(` ${i(t.name+":",30)} ${a}`)}console.log(""),console.log(e.cyan(" Feature Flags:"));for(let t of g){let r=o[t],a=v(t,r),n=typeof r=="number"?e.cyan(String(r)):r?e.green("true"):e.gray("false"),l=a?e.gray(" (default)"):e.yellow(" (modified)");console.log(` ${i(t+":",30)} ${n}${l}`)}let s=p.listIndexes();if(s.length>0){console.log(""),console.log(e.cyan(" HNSW Memory Usage:"));let t=0,r=0;for(let a of s){let n=p.get(a);if(n){let l=n.size(),c=n.dimensions(),R=l*c*4*3;t+=l,r+=R,console.log(` ${i(a+":",20)} ${e.white(String(l))} vectors, ${e.white(c)}d, ~${e.white(N(R))}`)}}console.log(e.gray(` ${"\u2500".repeat(50)}`)),console.log(` ${i("Total:",20)} ${e.bold.white(String(t))} vectors, ~${e.bold.white(N(r))}`)}else console.log(""),console.log(e.cyan(" HNSW Memory Usage:")),console.log(e.gray(" No active indexes (indexes are created on first use)"));o.useTemporalCompression&&(console.log(""),console.log(e.cyan(" Temporal Compression:")),console.log(e.gray(" Hot tier: 8-bit quantization (frequently accessed patterns)")),console.log(e.gray(" Warm tier: 5-bit quantization (moderately accessed patterns)")),console.log(e.gray(" Cold tier: 3-bit quantization (rarely accessed patterns)")),console.log(e.gray(" Estimated memory savings: 40-60% for cold patterns"))),console.log("")}function x(o){if(o.profile){if(!C(o.profile)){console.log(""),console.log(e.red(` Unknown profile: ${o.profile}`)),console.log(e.gray(` Valid profiles: ${Object.keys(m).join(", ")}`)),console.log(""),process.exit(1);return}let t=m[o.profile];d(t),console.log(""),console.log(e.bold.blue(`Setting ${o.profile} profile:`));for(let[r,a]of Object.entries(t)){let n=a?e.green("true"):e.gray("false");console.log(` ${i(r+":",30)} ${n}`)}console.log("");return}if(o.set){let t=o.set.indexOf("=");if(t<=0){console.log(""),console.log(e.red(" Invalid format. Use: --set flagName=true|false")),console.log(""),process.exit(1);return}let r=o.set.substring(0,t),a=o.set.substring(t+1);if(!k(r)){console.log(""),console.log(e.red(` Unknown flag: ${r}`)),console.log(e.gray(` Valid flags: ${g.join(", ")}`)),console.log(""),process.exit(1);return}if(a!=="true"&&a!=="false"){console.log(""),console.log(e.red(` Invalid value: ${a}. Use true or false.`)),console.log(""),process.exit(1);return}let n=a==="true";d({[r]:n});let l=n?e.green("true"):e.gray("false");console.log(""),console.log(e.green(` Set ${r} = ${l}`)),console.log("");return}let s=f();console.log(""),console.log(e.bold.blue("RuVector Feature Flags:")),console.log(""),console.log(e.bold(" "+i("Flag",28)+i("Value",10)+"Description")),console.log(e.gray(" "+"-".repeat(78)));for(let t of g){let r=s[t],a=v(t,r),n=typeof r=="number"?e.cyan(String(r)):r?e.green("true"):e.gray("false"),l=a?"":e.yellow(" *"),c=D[t];console.log(" "+i(t,28)+i(String(r),10)+e.gray(c)+l)}console.log(""),console.log(e.gray(" * = modified from default")),console.log(""),console.log(e.gray(" Profiles: performance, experimental, safe")),console.log(e.gray(" Usage:")),console.log(e.gray(" aqe ruvector flags --set useNativeHNSW=true")),console.log(e.gray(" aqe ruvector flags --profile=performance")),console.log("")}function E(){let o=new S("ruvector").description("RuVector integration management").addHelpText("after",`
|
|
3
3
|
Examples:
|
|
4
4
|
$ aqe ruvector status Show native packages and flags
|
|
5
5
|
$ aqe ruvector flags List all feature flags
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.
|
|
2
|
-
import{a,b}from"./chunk-
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{a,b}from"./chunk-V5TRAL57.js";import"./chunk-55JPAF56.js";export{a as RvfDualWriter,b as createDualWriter};
|
package/dist/cli/chunks/{rvf-migration-adapter-ZKOTVCHJ.js → rvf-migration-adapter-25KSI6SF.js}
RENAMED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.
|
|
2
|
-
import{a,b}from"./chunk-
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{a,b}from"./chunk-HIWBW4IQ.js";import"./chunk-55JPAF56.js";export{b as RvfMigrationAdapter,a as STAGE_NAMES};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.
|
|
2
|
-
import{a as m,b as p}from"./chunk-
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{a as m,b as p}from"./chunk-HIWBW4IQ.js";import"./chunk-55JPAF56.js";var v={sampleSize:50,windowDurationMs:6048e5,compactionThreshold:.3,scoreTolerance:.05},l=class{config;db=null;rvfStore=null;history=[];constructor(t){this.config={...v,...t}}setSqliteDb(t){this.db=t}setRvfStore(t){this.rvfStore=t}runCheck(){let t={timestamp:Date.now(),samplesChecked:0,divergences:0,divergenceRate:0,details:[],deadSpaceRatio:null,compactionTriggered:!1};if(!this.db||!this.rvfStore)return this.history.push(t),t;let e=this.getSampleIds(this.config.sampleSize);if(t.samplesChecked=e.length,e.length===0)return this.history.push(t),t;for(let a of e){let n=this.getSqliteEmbedding(a);if(!n){t.divergences++,t.details.push({patternId:a,issue:"missing-in-sqlite"});continue}try{let i=this.rvfStore.search(n,1);i.length===0?(t.divergences++,t.details.push({patternId:a,issue:"missing-in-rvf"})):i[0].id!==a&&i[0].score<.99&&(t.divergences++,t.details.push({patternId:a,issue:"score-mismatch",rvfScore:i[0].score}))}catch{t.divergences++,t.details.push({patternId:a,issue:"missing-in-rvf"})}}t.divergenceRate=t.samplesChecked>0?t.divergences/t.samplesChecked:0;try{let n=this.rvfStore.status().deadSpaceRatio;t.deadSpaceRatio=n??null,n!=null&&n>this.config.compactionThreshold&&(this.triggerCompaction(),t.compactionTriggered=!0)}catch{}return this.history.push(t),this.pruneHistory(),t}getRollingDivergenceRate(){let t=Date.now()-this.config.windowDurationMs,e=this.history.filter(i=>i.timestamp>=t);if(e.length===0)return 0;let a=e.reduce((i,r)=>i+r.samplesChecked,0),n=e.reduce((i,r)=>i+r.divergences,0);return a>0?n/a:0}getCheckCount(){let t=Date.now()-this.config.windowDurationMs;return this.history.filter(e=>e.timestamp>=t).length}getHistory(){let t=Date.now()-this.config.windowDurationMs;return this.history.filter(e=>e.timestamp>=t)}getSampleIds(t){if(!this.db)return[];try{return this.db.prepare("SELECT pattern_id FROM qe_pattern_embeddings ORDER BY RANDOM() LIMIT ?").all(t).map(a=>a.pattern_id)}catch{return[]}}getSqliteEmbedding(t){if(!this.db)return null;try{let e=this.db.prepare("SELECT embedding, dimension FROM qe_pattern_embeddings WHERE pattern_id = ?").get(t);return e?new Float32Array(e.embedding.buffer,e.embedding.byteOffset,e.dimension):null}catch{return null}}triggerCompaction(){try{this.rvfStore.compact?.()}catch{}}pruneHistory(){let t=Date.now()-this.config.windowDurationMs;this.history=this.history.filter(e=>e.timestamp>=t)}};var S={maxDivergenceRate2to3:1e-4,maxReadLatencyRatio2to3:2,maxFallbacks3to4:0,maxWriteLatencyRatio3to4:1.5,minChecksRequired:10},g=class{config;witnessChain=null;constructor(t){this.config={...S,...t}}setWitnessChain(t){this.witnessChain=t}evaluate(t,e,a){let n=Math.min(t+1,4);if(t>=4)return{canPromote:!1,currentStage:t,targetStage:4,checks:[],summary:"Already at maximum stage (4: RVF primary)"};if(t<2)return{canPromote:!0,currentStage:t,targetStage:n,checks:[],summary:`Stage ${t}\u2192${n} has no automated gates \u2014 manual promotion allowed`};let i=[];if(t===2){let s=e.getRollingDivergenceRate(),o=e.getCheckCount();i.push({name:"consistency-checks-count",passed:o>=this.config.minChecksRequired,actual:`${o} checks`,threshold:`>= ${this.config.minChecksRequired} checks`}),i.push({name:"divergence-rate",passed:s<=this.config.maxDivergenceRate2to3,actual:`${(s*100).toFixed(4)}%`,threshold:`<= ${(this.config.maxDivergenceRate2to3*100).toFixed(4)}%`});let c=a.sqliteReadLatencyAvgMs>0?a.rvfReadLatencyAvgMs/a.sqliteReadLatencyAvgMs:0;i.push({name:"read-latency-ratio",passed:c<=this.config.maxReadLatencyRatio2to3||a.rvfReadLatencyAvgMs===0,actual:`${c.toFixed(2)}x`,threshold:`<= ${this.config.maxReadLatencyRatio2to3}x`})}if(t===3){i.push({name:"fallback-count",passed:a.fallbacksUsed<=this.config.maxFallbacks3to4,actual:`${a.fallbacksUsed} fallbacks`,threshold:`<= ${this.config.maxFallbacks3to4} fallbacks`});let s=a.sqliteWriteLatencyAvgMs??a.sqliteReadLatencyAvgMs,o=a.rvfWriteLatencyAvgMs??a.rvfReadLatencyAvgMs,c=s>0?o/s:0;i.push({name:"write-latency-ratio",passed:c<=this.config.maxWriteLatencyRatio3to4||o===0,actual:`${c.toFixed(2)}x`,threshold:`<= ${this.config.maxWriteLatencyRatio3to4}x`})}let r=i.length>0&&i.every(s=>s.passed),u=i.filter(s=>!s.passed).map(s=>s.name);return{canPromote:r,currentStage:t,targetStage:n,checks:i,summary:r?`All gates passed \u2014 safe to promote to stage ${n}`:`Blocked: ${u.join(", ")} failed`}}promote(t,e,a,n=!1){let i=this.evaluate(t,e,a);if(!i.canPromote&&!n)return this.recordWitness("QUALITY_GATE_FAIL",{action:"stage-promotion-blocked",from:t,to:i.targetStage,failedChecks:i.checks.filter(u=>!u.passed),summary:i.summary}),{promoted:!1,newStage:t,result:i};let r=i.targetStage;return this.recordWitness("QUALITY_GATE_PASS",{action:n?"stage-promotion-forced":"stage-promotion-approved",from:t,to:r,checks:i.checks,forced:n,summary:i.summary}),{promoted:!0,newStage:r,result:i}}recordWitness(t,e){try{this.witnessChain?.append(t,e,"rvf-stage-gate")}catch{}}};var d=null,f=class h{adapter;validator;gate;currentStage;initialized=!1;constructor(t){this.currentStage=t?.stage??1,this.adapter=new p({stage:this.currentStage,rvfPath:t?.rvfPath??".agentic-qe/patterns.rvf",dimensions:t?.dimensions??384,enableFallback:!0}),this.validator=new l({sampleSize:50,windowDurationMs:10080*60*1e3,compactionThreshold:.3,scoreTolerance:.05}),this.gate=new g({minChecksRequired:10})}attachSqliteDb(t){this.adapter.setSqliteDb(t),this.validator.setSqliteDb(t)}attachRvfStore(t){this.adapter.setRvfStore(t),this.validator.setRvfStore(t)}attachWitnessChain(t){this.gate.setWitnessChain(t)}async initialize(){if(!this.initialized){if(this.currentStage===1)try{let{getRvfMigrationStage:t}=await import("./feature-flags-INJJZBMN.js"),e=t();this.currentStage=e,this.adapter.setStage(e)}catch{}try{let{UnifiedMemoryManager:t}=await import("./unified-memory-CMNJVHOJ.js"),e=t.getInstance();await e.initialize();let a=e.getDatabase();a&&this.attachSqliteDb(a)}catch{}try{let{getSharedRvfAdapter:t}=await import("./shared-rvf-adapter-WRZ3HGDQ.js"),e=t();e&&this.attachRvfStore(e)}catch{}try{let{WitnessChain:t}=await import("./witness-chain-762QQBTN.js"),e=new t;await e.initialize(),this.attachWitnessChain(e)}catch{}this.initialized=!0}}getStatus(){let t=this.adapter.getMetrics(),e=this.adapter.status(),a=this.validator.getHistory(),n=this.gate.evaluate(this.currentStage,this.validator,t);return{stage:this.currentStage,stageName:m[this.currentStage],metrics:t,consistencyHistory:{totalChecks:this.validator.getCheckCount(),rollingDivergenceRate:this.validator.getRollingDivergenceRate(),lastCheck:a.length>0?a[a.length-1]:null},gateEvaluation:n,engineStatus:{sqliteVectorCount:e.sqlite.vectorCount,rvfAvailable:e.rvf!==null,rvfVectorCount:e.rvf?.totalVectors??null,rvfDeadSpaceRatio:e.rvf?.deadSpaceRatio??null}}}runConsistencyCheck(){return this.validator.runCheck()}evaluateGate(){return this.gate.evaluate(this.currentStage,this.validator,this.adapter.getMetrics())}promote(t=!1){let e=this.currentStage,{promoted:a,newStage:n,result:i}=this.gate.promote(this.currentStage,this.validator,this.adapter.getMetrics(),t);return a&&(this.currentStage=n,this.adapter.setStage(n)),{promoted:a,previousStage:e,newStage:n,result:i}}write(t,e){return this.adapter.write(t,e)}search(t,e){return this.adapter.search(t,e)}getAdapter(){return this.adapter}static getInstance(t){return d||(d=new h(t)),d}static resetInstance(){d=null}};export{f as RvfMigrationCoordinator};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{a,b,c,d,f as e}from"./chunk-DXV6NRG3.js";import"./chunk-55JPAF56.js";e();export{a as createRvfStore,d as isRvfNativeAvailable,b as openRvfStore,c as openRvfStoreReadonly};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{a,b}from"./chunk-ZCNVFULO.js";import"./chunk-QU54GUEA.js";import"./chunk-55JPAF56.js";b();export{a as openDatabase};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{a}from"./chunk-L4N6PTIC.js";import"./chunk-6MONUYQ5.js";import"./chunk-LQ3TA22E.js";import"./chunk-UE3XXKLN.js";import"./chunk-TEJPHJMW.js";import"./chunk-OKGK7DBT.js";import"./chunk-X73CRYF4.js";import"./chunk-BQT4J3BD.js";import"./chunk-KNL3QWVA.js";import"./chunk-MJBXQXSX.js";import"./chunk-ZCNVFULO.js";import"./chunk-QU54GUEA.js";import"./chunk-O3NAUNFC.js";import"./chunk-I4E6CLC4.js";import"./chunk-NT4PI5HI.js";import"./chunk-66GIKUI2.js";import"./chunk-SGONA5GS.js";import"./chunk-5UOV7T36.js";import"./chunk-KOSKGZK4.js";import"./chunk-55JPAF56.js";export{a as TestScheduleTool};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{a,b,c,d}from"./chunk-VTIXFHZR.js";import"./chunk-DQLEZBWV.js";import"./chunk-OKGK7DBT.js";import"./chunk-FEBXP74Y.js";import"./chunk-KNL3QWVA.js";import"./chunk-55JPAF56.js";export{a as PersistentScheduler,b as createPersistentScheduler,d as createScheduleEntry,c as generateScheduleId};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.
|
|
2
|
-
import{b as h}from"./chunk-
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{b as h}from"./chunk-FQ5FT7IE.js";import{c as g,d as f,e as S,i as w}from"./chunk-XFMSHTXG.js";import"./chunk-55JPAF56.js";import{Command as b}from"commander";import e from"chalk";function P(v,a,k){return new b("security").description("Security scanning and URL validation").option("--sast","Run SAST scan").option("--dast","Run DAST scan").option("--compliance <frameworks>","Check compliance (gdpr,hipaa,soc2)","").option("--url-validate <url>","Validate a URL for security threats and PII exposure").option("--no-pii","Disable PII scanning when using --url-validate").option("-t, --target <path>","Target directory to scan",".").option("-F, --format <format>","Output format (text|json|sarif|markdown)","text").option("-o, --output <path>","Write output to file").action(async r=>{if(await k()){if(r.urlValidate){try{let o=r.format,u=r.urlValidate;o==="text"&&console.log(e.blue(`
|
|
3
3
|
Validating URL: ${u}
|
|
4
|
-
`));let{VisualSecurityTool:y}=await import("./visual-security-
|
|
4
|
+
`));let{VisualSecurityTool:y}=await import("./visual-security-AJJIEV5V.js"),c=await new y().invoke({url:u,enablePII:r.pii!==!1});if(c.success&&c.data){let t=c.data;if(o==="json")g(f(t),r.output);else{if(t.urlSecurity.valid)console.log(e.green(" URL Security: CLEAN"));else{console.log(e.red(` URL Security: ${t.urlSecurity.issues.length} issue(s) (risk: ${t.urlSecurity.riskLevel})`));for(let s of t.urlSecurity.issues){let i=s.severity==="critical"?e.red:s.severity==="high"?e.yellow:e.gray;console.log(i(` [${s.severity}] ${s.type}: ${s.description}`))}}if(t.piiExposure.scanned)if(t.piiExposure.found){console.log(e.red(`
|
|
5
5
|
PII Exposure: ${t.piiExposure.types.length} type(s) found in URL`));for(let s of t.piiExposure.details)console.log(e.yellow(` [${s.type}] in ${s.location}: ${s.masked}`))}else console.log(e.green(`
|
|
6
6
|
PII Exposure: none detected`));console.log(`
|
|
7
7
|
${t.summary}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.
|
|
2
|
-
import{a,b,c,d,e,f,h as g}from"./chunk-
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{a,b,c,d,e,f,h as g}from"./chunk-VEOQH4W6.js";import"./chunk-DXV6NRG3.js";import"./chunk-55JPAF56.js";g();export{a as __setSharedRvfAdapterForTests,d as compactSharedRvfAdapter,c as decideCompactionFromStatus,b as getSharedRvfAdapter,f as resetSharedRvfAdapter,e as runBootCompactGuard};
|
package/dist/cli/chunks/{shared-rvf-dual-writer-P2U424FB.js → shared-rvf-dual-writer-DX2N5STR.js}
RENAMED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.
|
|
2
|
-
import{a,b,c,d}from"./chunk-
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{a,b,c,d}from"./chunk-IQNR662U.js";import"./chunk-55JPAF56.js";export{c as getSharedMigrationAdapter,a as getSharedRvfDualWriter,b as getSharedRvfDualWriterSync,d as resetSharedRvfDualWriter};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{b as a,c as b,d as c,e as d}from"./chunk-KCHFF4IE.js";import"./chunk-3BO7EKGO.js";import"./chunk-UE3XXKLN.js";import"./chunk-TEJPHJMW.js";import"./chunk-OKGK7DBT.js";import"./chunk-X73CRYF4.js";import"./chunk-BQT4J3BD.js";import"./chunk-KNL3QWVA.js";import"./chunk-MJBXQXSX.js";import"./chunk-ZCNVFULO.js";import"./chunk-QU54GUEA.js";import"./chunk-O3NAUNFC.js";import"./chunk-I4E6CLC4.js";import"./chunk-NT4PI5HI.js";import"./chunk-66GIKUI2.js";import"./chunk-SGONA5GS.js";import"./chunk-5UOV7T36.js";import"./chunk-KOSKGZK4.js";import"./chunk-55JPAF56.js";export{a as DEFAULT_SQLITE_CONFIG,c as SQLitePatternStore,d as createSQLitePatternStore,b as hashEmbedding};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.
|
|
2
|
-
import{a as m,c as y}from"./chunk-
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{a as m,c as y}from"./chunk-WVCIZIKH.js";import{c as g,d as h}from"./chunk-XFMSHTXG.js";import"./chunk-55JPAF56.js";import t from"chalk";var p=class{name="status";description="Show system status";cleanupAndExit;ensureInitialized;constructor(o,n){this.cleanupAndExit=o,this.ensureInitialized=n}register(o,n){o.command("status").description(this.description).option("-v, --verbose","Show detailed status").option("-F, --format <format>","Output format (text|json)","text").option("-o, --output <path>","Write output to file").action(async a=>{await this.executeStatus(a,n)})}async executeStatus(o,n){if(await this.ensureInitialized())try{let a=n.queen.getHealth(),e=n.queen.getMetrics();if((o.format||"text")==="json"){let s={};if(o.verbose)for(let[i,l]of a.domainHealth)s[i]={status:l.status,agents:l.agents,errors:l.errors.length};g(h({status:a.status,uptime:e.uptime,workStealing:a.workStealingActive,agents:{total:a.totalAgents,active:a.activeAgents,utilization:e.agentUtilization},tasks:{received:e.tasksReceived,completed:e.tasksCompleted,failed:e.tasksFailed,pending:a.pendingTasks,running:a.runningTasks,stolen:e.tasksStolen},coordination:{protocols:e.protocolsExecuted,workflows:e.workflowsExecuted},...o.verbose?{domains:s}:{},issues:a.issues}),o.output),await this.cleanupAndExit(0);return}if(console.log(t.blue(`
|
|
3
3
|
AQE v3 Status
|
|
4
4
|
`)),console.log(` Status: ${m(a.status)}`),console.log(` Uptime: ${t.cyan(y(e.uptime))}`),console.log(` Work Stealing: ${a.workStealingActive?t.green("active"):t.gray("inactive")}`),console.log(t.blue(`
|
|
5
5
|
Agents:`)),console.log(` Total: ${t.cyan(a.totalAgents)}`),console.log(` Active: ${t.yellow(a.activeAgents)}`),console.log(` Utilization: ${t.cyan((e.agentUtilization*100).toFixed(1))}%`),console.log(t.blue(`
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.
|
|
2
|
-
import{a as l}from"./chunk-
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{a as l}from"./chunk-GXCD7GNH.js";import"./chunk-LXHA55EB.js";import"./chunk-WLLE54TA.js";import"./chunk-KOSKGZK4.js";import"./chunk-55JPAF56.js";var s={healthyThreshold:.4,warningThreshold:.2,maxHistoryEntries:100,enableLogging:!1},n=class{config;minCutService;history=[];constructor(t){this.config={...s,...t},this.minCutService=l()}computeFleetHealth(t){if(t.length===0)return this.emptyFleetResult();let r=this.minCutService.buildTaskGraphFromTopology(t);return this.computeFleetHealthFromGraph(r,t.length)}computeFleetHealthFromGraph(t,r){if(t.nodes.length===0)return this.emptyFleetResult();let e=this.minCutService.getStructuralHealth(t),o=this.determineStatus(e.normalizedLambda),a={lambda:e.lambda,healthy:e.healthy,weakPoints:e.weakPoints,normalizedLambda:e.normalizedLambda,riskScore:e.riskScore,status:o,suggestions:e.suggestions,measuredAt:new Date};return this.addHistoryEntry({lambda:e.lambda,healthy:e.healthy,weakPointCount:e.weakPoints.length,agentCount:r??t.nodes.length,timestamp:a.measuredAt}),this.config.enableLogging&&this.logHealth(a),a}getTrend(){if(this.history.length<2)return"stable";let t=Math.min(5,this.history.length),r=this.history.slice(-t),e=r[0].lambda,a=r[r.length-1].lambda-e;return Math.abs(a)<.05?"stable":a>0?"improving":"degrading"}getHistory(t){let r=[...this.history];return t!==void 0&&t<r.length?r.slice(-t):r}clearHistory(){this.history.length=0}getMinCutService(){return this.minCutService}determineStatus(t){return t>=this.config.healthyThreshold?"healthy":t>=this.config.warningThreshold?"warning":"critical"}addHistoryEntry(t){this.history.push(t),this.history.length>this.config.maxHistoryEntries&&this.history.splice(0,this.history.length-this.config.maxHistoryEntries)}emptyFleetResult(){return{lambda:0,healthy:!1,weakPoints:[],normalizedLambda:0,riskScore:1,status:"empty",suggestions:["No agents in fleet. Spawn agents to build a topology."],measuredAt:new Date}}logHealth(t){console.error(`[StructuralHealth] Status: ${t.status} | Lambda: ${t.normalizedLambda.toFixed(3)} | Weak points: ${t.weakPoints.length} | Risk: ${(t.riskScore*100).toFixed(0)}%`)}};function d(i){return new n(i)}export{s as DEFAULT_STRUCTURAL_HEALTH_CONFIG,n as StructuralHealthMonitor,d as createStructuralHealthMonitor};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.
|
|
2
|
-
import{c as r,s as g,t as m,u as p,x as b,y as h}from"./chunk-
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{c as r,s as g,t as m,u as p,x as b,y as h}from"./chunk-LDMG4372.js";import{a as y}from"./chunk-DY7IRNE2.js";import"./chunk-M4HDBRVJ.js";import"./chunk-UE3XXKLN.js";import"./chunk-TEJPHJMW.js";import"./chunk-OKGK7DBT.js";import"./chunk-X73CRYF4.js";import"./chunk-BQT4J3BD.js";import{a,c as S}from"./chunk-KNL3QWVA.js";import"./chunk-MJBXQXSX.js";import"./chunk-ZCNVFULO.js";import"./chunk-QU54GUEA.js";import"./chunk-O3NAUNFC.js";import"./chunk-I4E6CLC4.js";import"./chunk-NT4PI5HI.js";import"./chunk-66GIKUI2.js";import"./chunk-SGONA5GS.js";import"./chunk-5UOV7T36.js";import"./chunk-KOSKGZK4.js";import"./chunk-55JPAF56.js";import{Command as v}from"commander";import e from"chalk";import d from"ora";S();import*as f from"fs";import*as i from"path";import{fileURLToPath as $}from"url";var C=$(import.meta.url),R=i.dirname(C);function w(){let n=new v("sync").description("Sync local learning data to cloud PostgreSQL");return n.option("--full","Run full sync instead of incremental").option("-e, --env <environment>","Environment identifier",process.env.AQE_ENV||"devpod").option("--dry-run","Preview sync without making changes").option("-v, --verbose","Enable verbose output").option("--since <date>","Sync changes since date (ISO 8601)").option("--sources <sources>","Comma-separated list of sources to sync").action(async l=>{let o={environment:l.env,verbose:l.verbose,sync:{...r.sync,dryRun:l.dryRun}};if(l.sources){let s=l.sources.split(",").map(c=>c.trim());o.sync.sources=r.sync.sources.filter(c=>s.includes(c.name))}let t=d("Initializing sync agent...").start();try{let s;if(l.full)t.text="Running full sync...",s=await m(o);else{let c=l.since?new Date(l.since):void 0;t.text="Running incremental sync...",s=await p(c,o)}t.stop(),E(s)}catch(s){t.fail(`Sync failed: ${a(s)}`),process.exit(1)}}),n.command("pull").description("Pull cloud learning data into local SQLite database").option("-f, --full","Full pull (all cloud data)").option("-e, --env <environment>","Pull only data from specific environment","all").option("--tables <tables>","Comma-separated list of tables to pull").option("--dry-run","Preview pull without writing to local DB").option("--target <path>","Custom target SQLite database path").option("--since <date>","Pull changes since date (ISO 8601)").option("-v, --verbose","Enable verbose output").action(async l=>{let o={environment:l.env,verbose:l.verbose,dryRun:l.dryRun,targetDb:l.target};l.tables&&(o.tables=l.tables.split(",").map(s=>s.trim()));let t=d("Initializing pull sync agent...").start();try{let s;if(l.full)t.text="Pulling all data from cloud...",s=await b(o);else{let c=l.since?new Date(l.since):void 0;t.text=`Pulling ${c?"changes since "+c.toISOString():"incremental changes (last 24h)"}...`,s=await h(c,o)}t.stop(),D(s)}catch(s){t.fail(`Pull failed: ${a(s)}`),process.exit(1)}}),n.command("status").description("Show sync status and data source information").option("-e, --env <environment>","Environment identifier",process.env.AQE_ENV||"devpod").action(async l=>{let o=d("Checking sync status...").start();try{let t=g({environment:l.env,verbose:!1});await t.initialize();let s=await t.getStatus();await t.close(),o.stop(),P(s)}catch(t){o.fail(`Failed to get status: ${a(t)}`),process.exit(1)}}),n.command("verify").description("Verify sync integrity between local and cloud").option("-e, --env <environment>","Environment identifier",process.env.AQE_ENV||"devpod").action(async l=>{let o=d("Verifying sync integrity...").start();try{let t=g({environment:l.env,verbose:!1});await t.initialize(),o.text="Connecting to cloud...";let s=await t.verify();await t.close(),o.stop(),I(s)}catch(t){o.fail(`Verification failed: ${a(t)}`),process.exit(1)}}),n.command("init").description("Initialize cloud schema (requires GCP credentials)").option("--dry-run","Print schema without executing").option("-o, --output <file>","Save schema to file").action(async l=>{let o=[i.join(R,"../../sync/schema/cloud-schema.sql")],t=y(import.meta.url);t&&(o.push(i.join(t,"src/sync/schema/cloud-schema.sql")),o.push(i.join(t,"dist/sync/schema/cloud-schema.sql"))),o.push(i.join(process.cwd(),"src/sync/schema/cloud-schema.sql"));let s;for(let u of o)try{s=f.readFileSync(u,"utf-8");break}catch{}if(!s)throw new Error(`Could not locate cloud-schema.sql. Searched: ${o.join(", ")}`);if(l.output){f.writeFileSync(l.output,s),console.log(e.green(`Schema saved to ${l.output}`));return}if(l.dryRun){console.log(e.cyan(`
|
|
3
3
|
=== Cloud Schema ===
|
|
4
4
|
`)),console.log(s),console.log(e.yellow(`
|
|
5
5
|
Dry run - no changes made`));return}let c=d("Initializing cloud schema...").start();try{let u=g({verbose:!0});c.info("Schema initialization requires cloud connection"),c.info("Run with --output to save schema, then apply manually"),await u.close()}catch(u){c.fail(`Init failed: ${a(u)}`),process.exit(1)}}),n.command("config").description("Show or modify sync configuration").option("--show","Show current configuration").option("--sources","List configured data sources").action(async l=>{if(l.sources){console.log(e.cyan(`
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.
|
|
2
|
-
import{A,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z}from"./chunk-
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{A,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z}from"./chunk-LDMG4372.js";import"./chunk-M4HDBRVJ.js";import"./chunk-UE3XXKLN.js";import"./chunk-TEJPHJMW.js";import"./chunk-OKGK7DBT.js";import"./chunk-X73CRYF4.js";import"./chunk-BQT4J3BD.js";import"./chunk-KNL3QWVA.js";import"./chunk-MJBXQXSX.js";import"./chunk-ZCNVFULO.js";import"./chunk-QU54GUEA.js";import"./chunk-O3NAUNFC.js";import"./chunk-I4E6CLC4.js";import"./chunk-NT4PI5HI.js";import"./chunk-66GIKUI2.js";import"./chunk-SGONA5GS.js";import"./chunk-5UOV7T36.js";import"./chunk-KOSKGZK4.js";import"./chunk-55JPAF56.js";export{r as CloudSyncAgent,a as DEFAULT_PULL_CONFIG,c as DEFAULT_SYNC_CONFIG,j as DirectConnectionManager,h as IAPTunnelManager,f as JSONReader,n as PostgresReader,l as PostgresWriter,v as PullSyncAgent,d as SQLiteReader,p as SQLiteWriter,z as SyncEmbeddingGenerator,b as TYPE_MAPPING,k as createConnectionManager,g as createJSONReader,o as createPostgresReader,m as createPostgresWriter,w as createPullSyncAgent,e as createSQLiteReader,q as createSQLiteWriter,s as createSyncAgent,A as createSyncEmbeddingGenerator,i as createTunnelManager,x as pullFromCloud,y as pullIncrementalFromCloud,u as syncIncrementalToCloud,t as syncToCloud};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.
|
|
2
|
-
import{b as y}from"./chunk-
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{b as y}from"./chunk-27ACATRH.js";import"./chunk-M73IL7FA.js";import{a as m,b}from"./chunk-WVCIZIKH.js";import{c as p,d as g}from"./chunk-XFMSHTXG.js";import{c as T}from"./chunk-OKGK7DBT.js";import"./chunk-55JPAF56.js";import a from"chalk";var f=class{name="task";description="Manage QE tasks";cleanupAndExit;ensureInitialized;constructor(o,e){this.cleanupAndExit=o,this.ensureInitialized=e}register(o,e){let s=o.command("task").description(this.description);s.command("submit <type>").description("Submit a task to the Queen Coordinator").option("-p, --priority <priority>","Task priority (p0|p1|p2|p3)","p1").option("-d, --domain <domain>","Target domain").option("-t, --timeout <ms>","Task timeout in ms","300000").option("--payload <json>","Task payload as JSON","{}").option("--wait","Wait for task completion with progress").option("--no-progress","Disable progress indicator").action(async(t,i)=>{await this.executeSubmit(t,i,e)}),s.command("list").description("List all tasks").option("-s, --status <status>","Filter by status").option("-p, --priority <priority>","Filter by priority").option("-d, --domain <domain>","Filter by domain").option("-F, --format <format>","Output format (text|json)","text").option("-o, --output <path>","Write output to file").action(async t=>{await this.executeList(t,e)}),s.command("cancel <taskId>").description("Cancel a task").action(async t=>{await this.executeCancel(t,e)}),s.command("status <taskId>").description("Get task status").option("-F, --format <format>","Output format (text|json)","text").option("-o, --output <path>","Write output to file").action(async(t,i)=>{await this.executeTaskStatus(t,i,e)})}async executeSubmit(o,e,s){if(await this.ensureInitialized())try{let t=o,i=T(e.payload,"payload"),r=e.domain?[e.domain]:[];console.log(a.blue(`
|
|
3
3
|
Submitting task: ${t}
|
|
4
4
|
`));let d=e.progress!==!1?y(`Submitting ${t} task`):null,n=await s.queen.submitTask({type:t,priority:e.priority,targetDomains:r,payload:i,timeout:parseInt(e.timeout,10)});if(d&&(n.success?d.succeed("Task submitted successfully"):d.fail("Failed to submit task")),n.success){if(console.log(a.cyan(` ID: ${n.value}`)),console.log(a.gray(` Type: ${t}`)),console.log(a.gray(` Priority: ${e.priority}`)),e.wait){console.log("");let w=n.value,c=y("Waiting for task completion"),h=parseInt(e.timeout,10),S=Date.now(),l=!1;for(;!l&&Date.now()-S<h;){let u=s.queen.getTaskStatus(w);u&&(u.status==="completed"?(c.succeed("Task completed successfully"),l=!0):u.status==="failed"?(c.fail(`Task failed: ${u.error||"Unknown error"}`),l=!0):c.spinner.text=`Task ${u.status}... (${Math.round((Date.now()-S)/1e3)}s)`),l||await new Promise(A=>setTimeout(A,500))}l||c.fail("Task timed out")}}else console.log(a.red(` Error: ${n.error.message}`));console.log("")}catch(t){console.error(a.red(`
|
|
5
5
|
Failed to submit task:`),t),await this.cleanupAndExit(1)}}async executeList(o,e){if(await this.ensureInitialized())try{let s=e.queen.listTasks({status:o.status,priority:o.priority,domain:o.domain});if((o.format||"text")==="json"){let i=s.map(r=>({taskId:r.taskId,type:r.task.type,status:r.status,priority:r.task.priority,domain:r.assignedDomain||null,startedAt:r.startedAt?.toISOString()||null}));p(g(i),o.output);return}if(console.log(a.blue(`
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.
|
|
2
|
-
import{a as j,b as R,c as m,d as p}from"./chunk-27FNROZ2.js";import"./chunk-CLATNP57.js";import"./chunk-CSDGFQKW.js";import{a as B}from"./chunk-AH3UC4IV.js";import"./chunk-CAGRQR2U.js";import"./chunk-W2DF6FNE.js";import"./chunk-P7IOH7L4.js";import"./chunk-MAHLTWGV.js";import"./chunk-66636UWH.js";import"./chunk-O5JNHH2D.js";import"./chunk-NMHULQAV.js";import"./chunk-AH3TKDVW.js";import"./chunk-TOZ6WUAB.js";import"./chunk-YKZ3ZJWT.js";import"./chunk-LUFY3GGI.js";import"./chunk-X6IEQVSF.js";import"./chunk-2AANIKDG.js";import"./chunk-OLBYILKU.js";import"./chunk-JFDNNXIX.js";import"./chunk-5RPHV7Y3.js";import"./chunk-7ZCDG3IM.js";import"./chunk-BI54GWTK.js";import"./chunk-G7YDYXQH.js";import"./chunk-F5IVWV2P.js";import{b as E}from"./chunk-556GYKN5.js";import"./chunk-NKBCAW27.js";import"./chunk-7TO7NTLT.js";import"./chunk-GWLLNJ64.js";import"./chunk-6M2POFDF.js";import"./chunk-XNXFEMWT.js";import"./chunk-G6Q66YLG.js";import"./chunk-5M63H6RY.js";import"./chunk-QXM3PRVR.js";import"./chunk-5ZTY5JJX.js";import"./chunk-D5CLABLM.js";import"./chunk-PUZAIRMY.js";import"./chunk-QYUWWTE3.js";import"./chunk-2EWOYVH3.js";import"./chunk-ESIE3MT5.js";import"./chunk-2KMCRASK.js";import"./chunk-AWC7G2D3.js";import"./chunk-5OAAJUGO.js";import"./chunk-YUFUGGXY.js";import"./chunk-Z5A2ENBC.js";import"./chunk-GW7HWFWQ.js";import"./chunk-TCDGJYM2.js";import"./chunk-LPVRFVSC.js";import"./chunk-MEQ4OPSL.js";import"./chunk-FYJE4QLL.js";import"./chunk-YMB4YVFX.js";import"./chunk-RDXIRE2I.js";import"./chunk-AY2LLGZN.js";import"./chunk-F57OUXHJ.js";import"./chunk-GLI5EN6O.js";import"./chunk-NYU4YD5V.js";import"./chunk-TG44VKO3.js";import"./chunk-P4VQTIJE.js";import"./chunk-TU2PSEDW.js";import"./chunk-IMP43AXO.js";import"./chunk-ZK6GXL5J.js";import"./chunk-OO2JHVMS.js";import"./chunk-SJ3SHZUC.js";import"./chunk-MJJAHA2T.js";import"./chunk-C2JK5O55.js";import"./chunk-TK7TGVVQ.js";import"./chunk-BUVY7IGM.js";import"./chunk-4R3WXD4U.js";import"./chunk-LIE24NRL.js";import"./chunk-AJ2VFSLX.js";import"./chunk-L3JJ52N6.js";import"./chunk-DCXFHBHS.js";import"./chunk-JD3VV2BD.js";import"./chunk-QH7K2UPP.js";import"./chunk-A3TOJ4KN.js";import"./chunk-MFPVS2KP.js";import"./chunk-USLHYNYG.js";import{k as I,o as F}from"./chunk-5MSZREOD.js";import"./chunk-QAGAEAKM.js";import"./chunk-HOZNVDFF.js";import"./chunk-5SYH5QMQ.js";import"./chunk-I7BXATQ6.js";import"./chunk-ZYPSXPQ5.js";import"./chunk-VENEJ3UI.js";import"./chunk-QMUTKI34.js";import{a as u,c as M}from"./chunk-O4C3JEOR.js";import"./chunk-NKA3X6VT.js";import"./chunk-6M44C43I.js";import"./chunk-TXSVZYFA.js";import"./chunk-RCU5L7FF.js";import"./chunk-Y4ERDIPP.js";import"./chunk-3CIQ6CQ4.js";import"./chunk-IF4ZZ2HD.js";import"./chunk-KI6RXKP4.js";import"./chunk-DTJHO3WI.js";import"./chunk-X6UGFKHW.js";import"./chunk-ZBY4HSHR.js";import"./chunk-SCBWRKPE.js";var L={enableLearning:!0,enableRouting:!0,enableGuidance:!0,enableTrajectories:!0,enableExperienceReplay:!0,autoStoreExperiences:!0,minQualityThreshold:.6},P=class n{static instance=null;static initPromise=null;config;enhancedAdapter;disposed=!1;patternsLoaded=!1;qualityThresholdsFromPatterns=null;tasksRecorded=0;successfulTasks=0;failedTasks=0;patternsStored=0;routingRequests=0;activeTrajectories=new Map;constructor(e,t){this.config=e,this.enhancedAdapter=t}static async getInstance(e){if(n.instance&&!n.instance.disposed)return n.instance;if(n.initPromise)return n.initPromise;n.initPromise=n.create(e);try{return n.instance=await n.initPromise,n.instance}finally{n.initPromise=null}}static async create(e){let t={...L,...e},r=j({enableTrajectories:t.enableTrajectories,enableExperienceReplay:t.enableExperienceReplay,enablePatternEvolution:!0,autoStoreExperiences:t.autoStoreExperiences,autoConsolidate:!0});await r.initialize();let s=new n(t,r);return await s.loadPatternsFromLoader(),await s.seedInitialPatternsIfNeeded(),console.error("[ReasoningBankService] Initialized with EnhancedReasoningBankAdapter (trajectory + experience + evolution)"),s}async loadPatternsFromLoader(){try{let t=await B().getQualityGateThresholds();if(t){this.qualityThresholdsFromPatterns=t,this.patternsLoaded=!0,console.error("[ReasoningBankService] Loaded quality thresholds from PatternLoader",{tiers:Object.keys(t)});return}console.error("[ReasoningBankService] PatternLoader returned no thresholds, using defaults")}catch(e){console.error("[ReasoningBankService] Failed to load patterns from PatternLoader, using defaults",{error:e instanceof Error?e.message:"Unknown error"})}this.patternsLoaded=!1}async seedInitialPatternsIfNeeded(){try{let e=await this.enhancedAdapter.getStats();if(e.reasoningBank.totalPatterns>0){console.error(`[ReasoningBankService] Found ${e.reasoningBank.totalPatterns} existing patterns, skipping seed`);return}console.error("[ReasoningBankService] Seeding initial QE patterns...");let t=(s,a="string",i=!1)=>({name:s,type:a,required:i,description:`${s} parameter`}),r=[{patternType:"test-template",name:"unit-test-generation",description:"Generate comprehensive unit tests for TypeScript/JavaScript modules",domain:"test-generation",template:{type:"workflow",content:"Analyze module exports, identify edge cases, generate Jest/Vitest tests with proper mocking",variables:[t("modulePath"),t("framework")]},context:{tags:["unit","typescript","jest","vitest"]}},{patternType:"coverage-strategy",name:"coverage-gap-analysis",description:"Identify untested code paths and recommend targeted tests",domain:"coverage-analysis",template:{type:"workflow",content:"Parse coverage report, identify uncovered branches, prioritize by risk, generate recommendations",variables:[t("coveragePath"),t("threshold","number")]},context:{tags:["coverage","analysis","risk"]}},{patternType:"test-template",name:"integration-test-generation",description:"Generate integration tests for API endpoints and service interactions",domain:"test-generation",template:{type:"workflow",content:"Identify API contracts, generate request/response tests, validate error handling",variables:[t("apiPath"),t("framework")]},context:{tags:["integration","api","contract"]}},{patternType:"flaky-fix",name:"flaky-test-remediation",description:"Detect and fix flaky tests through pattern analysis",domain:"test-execution",template:{type:"workflow",content:"Analyze test history, identify timing/race conditions, apply stabilization patterns",variables:[t("testPath"),t("retryCount","number")]},context:{tags:["flaky","stability","retry"]}},{patternType:"error-handling",name:"security-vulnerability-scan",description:"Scan code for security vulnerabilities using OWASP patterns",domain:"security-compliance",template:{type:"workflow",content:"Run SAST analysis, check for injection risks, validate authentication/authorization",variables:[t("targetPath"),t("severity")]},context:{tags:["security","owasp","sast"]}}];for(let s of r)try{await this.enhancedAdapter.storePattern(s),this.patternsStored++}catch(a){console.error(`[ReasoningBankService] Failed to seed pattern ${s.name}:`,a)}console.error(`[ReasoningBankService] Seeded ${r.length} initial patterns`)}catch(e){console.error("[ReasoningBankService] Failed to seed patterns:",e)}}getPatternsLoaded(){return this.patternsLoaded}getQualityThresholdsFromPatterns(){return this.qualityThresholdsFromPatterns}async startTaskTrajectory(e,t,r={}){if(!this.config.enableTrajectories||this.disposed)return e;try{let s=await this.enhancedAdapter.startTaskTrajectory(t,r);return this.activeTrajectories.set(e,s),console.error(`[ReasoningBankService] Started trajectory: task=${e} trajectory=${s}`),s}catch(s){return console.error("[ReasoningBankService] Failed to start trajectory:",s),e}}async recordTrajectoryStep(e,t,r,s){if(!this.config.enableTrajectories||this.disposed)return;let a=this.activeTrajectories.get(e);if(!a){console.error(`[ReasoningBankService] No active trajectory for task ${e}`);return}try{await this.enhancedAdapter.recordTaskStep(a,t,r,s)}catch(i){console.error("[ReasoningBankService] Failed to record trajectory step:",i)}}async endTaskTrajectory(e,t,r){if(!this.config.enableTrajectories||this.disposed)return null;let s=this.activeTrajectories.get(e);if(!s)return console.error(`[ReasoningBankService] No active trajectory for task ${e}`),null;try{let a=await this.enhancedAdapter.endTaskTrajectory(s,t,r);return this.activeTrajectories.delete(e),console.error(`[ReasoningBankService] Ended trajectory: task=${e} success=${t} steps=${a.steps.length} quality=${a.metrics.averageQuality.toFixed(2)}`),a}catch(a){return console.error("[ReasoningBankService] Failed to end trajectory:",a),this.activeTrajectories.delete(e),null}}getActiveTrajectoryId(e){return this.activeTrajectories.get(e)}async recordTaskOutcome(e){if(!(!this.config.enableLearning||this.disposed)){this.tasksRecorded++,e.success?this.successfulTasks++:this.failedTasks++;try{let t={patternId:`task-${e.taskId}`,success:e.success,metrics:{executionTimeMs:e.executionTimeMs,testsPassed:e.metrics?.testsPassed,testsFailed:e.metrics?.testsGenerated?e.metrics.testsGenerated-(e.metrics.testsPassed||0):void 0,coverageImprovement:e.metrics?.coverageImprovement},feedback:e.error};await this.enhancedAdapter.recordPatternOutcome(t),e.success&&(e.qualityScore||.5)>=this.config.minQualityThreshold&&(await this.storeTaskPattern(e),this.patternsStored++),e.agentId&&await this.updateAgentPerformanceFromOutcome(e),console.error(`[ReasoningBankService] Recorded outcome: task=${e.taskId} success=${e.success} quality=${e.qualityScore?.toFixed(2)||"N/A"}`)}catch(t){throw console.error("[ReasoningBankService] Failed to record outcome:",t),t}}}async updateAgentPerformanceFromOutcome(e){if(e.agentId)try{E(e.agentId,{success:e.success,executionTimeMs:e.executionTimeMs,qualityScore:e.qualityScore}),console.error(`[ReasoningBankService] Updated agent performance: agent=${e.agentId} success=${e.success} duration=${e.executionTimeMs}ms`)}catch(t){console.error("[ReasoningBankService] Failed to update agent performance:",t)}}async storeTaskPattern(e){try{let t=[e.taskType,e.domain||"general",e.agentId?`agent:${e.agentId}`:void 0,e.modelTier?`tier:${e.modelTier}`:void 0,e.executionTimeMs?`duration:${e.executionTimeMs}ms`:void 0].filter(r=>r!==void 0);await this.enhancedAdapter.storePattern({patternType:"test-template",name:`${e.taskType}-${e.domain||"general"}`,description:e.task,template:{type:"workflow",content:e.task,variables:[]},context:{tags:t}})}catch(t){console.error("[ReasoningBankService] Failed to store pattern:",t)}}async getRoutingRecommendation(e){if(!this.config.enableRouting||this.disposed)return this.createFallbackRouting(e);this.routingRequests++;try{let t=await this.enhancedAdapter.routeTaskWithExperience(e);if(!t.success)return console.error("[ReasoningBankService] Routing returned error:",t.error),this.createFallbackRouting(e);let r=t.value;return r.experienceGuidance&&console.error(`[ReasoningBankService] Experience guidance: strategy="${r.experienceGuidance.recommendedStrategy}" confidence=${r.experienceGuidance.confidence.toFixed(2)} tokenSavings=${r.experienceGuidance.estimatedTokenSavings}`),console.error(`[ReasoningBankService] Routing: task="${e.task.slice(0,50)}..." -> agent=${r.recommendedAgent} confidence=${r.confidence.toFixed(2)}`),r}catch(t){return console.error("[ReasoningBankService] Routing failed:",t),this.createFallbackRouting(e)}}async getExperienceGuidance(e,t){if(!this.config.enableExperienceReplay||this.disposed)return null;try{return await this.enhancedAdapter.getExperienceGuidance(e,t)}catch(r){return console.error("[ReasoningBankService] Failed to get experience guidance:",r),null}}async getTaskGuidance(e,t){if(!this.config.enableGuidance||this.disposed)return[];try{let r=await this.enhancedAdapter.routeTaskWithExperience({task:e,domain:t});return r.success?r.value.guidance:[]}catch(r){return console.error("[ReasoningBankService] Guidance failed:",r),[]}}async searchPatterns(e,t){if(this.disposed)return[];try{let r=await this.enhancedAdapter.searchPatterns(e,{limit:t?.limit||10,domain:t?.domain});return r.success?r.value.map(s=>s.pattern):(console.error("[ReasoningBankService] Search returned error:",r.error),[])}catch(r){return console.error("[ReasoningBankService] Search failed:",r),[]}}async getStats(){let e=await this.enhancedAdapter.getStats();return{service:{tasksRecorded:this.tasksRecorded,successfulTasks:this.successfulTasks,failedTasks:this.failedTasks,successRate:this.tasksRecorded>0?this.successfulTasks/this.tasksRecorded:0,patternsStored:this.patternsStored,routingRequests:this.routingRequests,patternsLoaded:this.patternsLoaded,activeTrajectories:this.activeTrajectories.size},reasoningBank:e.reasoningBank,adapter:e.adapter}}createFallbackRouting(e){return{recommendedAgent:"qe-test-architect",confidence:.5,alternatives:[],domains:e.domain?[e.domain]:["test-generation"],patterns:[],guidance:[],reasoning:"Fallback routing - ReasoningBank unavailable",latencyMs:0}}isHealthy(){return!this.disposed}async dispose(){this.disposed||(this.disposed=!0,await this.enhancedAdapter.dispose(),this.activeTrajectories.clear(),n.instance=null,console.error("[ReasoningBankService] Disposed"))}static reset(){n.instance&&n.instance.dispose(),n.instance=null,n.initPromise=null}};async function y(n){return P.getInstance(n)}async function C(n,e,t){return(await y()).startTaskTrajectory(n,e,t)}async function v(n,e,t){return(await y()).endTaskTrajectory(n,e,t)}F();var Q="claude-haiku-4-5-20251001",G=200,U=5;async function O(){let n=process.env.ANTHROPIC_API_KEY;if(!n)return;let e=(process.env.ANTHROPIC_BASE_URL??"https://api.anthropic.com").replace(/\/$/,""),t=I();if(!t.isInitialized())return;let r=t.getDatabase();if(!r.prepare("PRAGMA table_info(qe_trajectories)").all().some(c=>c.name==="feedback"))return;let a=r.prepare(`
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{a as j,b as R,c as m,d as p}from"./chunk-JCKX2LEJ.js";import"./chunk-T7DLX3LS.js";import"./chunk-WC6KZDPM.js";import{a as B}from"./chunk-OGT45MZN.js";import"./chunk-HD5NQDOL.js";import"./chunk-TR7BZLB6.js";import"./chunk-7ZIRDBXH.js";import"./chunk-QL3U5VSM.js";import"./chunk-GXCD7GNH.js";import"./chunk-6HCHW5TS.js";import"./chunk-PNDO4W4L.js";import"./chunk-UCXQQCIP.js";import"./chunk-UCIJCRPB.js";import"./chunk-J5RJYFRM.js";import"./chunk-XFUU2RCA.js";import"./chunk-IBXNBLGM.js";import"./chunk-L4N6PTIC.js";import"./chunk-QWBO76AU.js";import"./chunk-FCSJ7GIZ.js";import"./chunk-YYDHTBHE.js";import"./chunk-L2AIES7X.js";import"./chunk-6F3WJOU2.js";import"./chunk-KYLJERZ3.js";import"./chunk-2POXDKUB.js";import{b as E}from"./chunk-UGX4EHT5.js";import"./chunk-X4U5NYB6.js";import"./chunk-RGONSQ44.js";import"./chunk-SCYF5CQA.js";import"./chunk-BXCS55GB.js";import"./chunk-LXHA55EB.js";import"./chunk-W6U7SIIK.js";import"./chunk-S33246T4.js";import"./chunk-Y4I5JBOL.js";import"./chunk-HD6CZBZV.js";import"./chunk-NLCUQMUR.js";import"./chunk-RF6QKV7M.js";import"./chunk-RARSTEUO.js";import"./chunk-URVDWF2Y.js";import"./chunk-S4CNA6Z5.js";import"./chunk-WG6I7YF3.js";import"./chunk-AFFYJSW2.js";import"./chunk-BQX5QDU5.js";import"./chunk-HZPXOAFW.js";import"./chunk-JUICZG3T.js";import"./chunk-3QULDB7K.js";import"./chunk-GPKZ4MMH.js";import"./chunk-DQJJS4AX.js";import"./chunk-FX4SYT6Y.js";import"./chunk-4WYGUTSF.js";import"./chunk-5RQT7EJP.js";import"./chunk-7Y54QZKF.js";import"./chunk-VMJXNTJT.js";import"./chunk-MF3XRML3.js";import"./chunk-IQNR662U.js";import"./chunk-CU4IUJ2K.js";import"./chunk-KDFW7MVM.js";import"./chunk-OWMGD7FO.js";import"./chunk-5QJDH4Z5.js";import"./chunk-JKVNZASH.js";import"./chunk-G2HA2O3R.js";import"./chunk-6H5MRVJS.js";import"./chunk-2GL4GH52.js";import"./chunk-C5QESAYA.js";import"./chunk-YHNEBCYQ.js";import"./chunk-WLLE54TA.js";import"./chunk-3OSCWD7Z.js";import"./chunk-F363JJUI.js";import"./chunk-VEOQH4W6.js";import"./chunk-LYVFC7C7.js";import"./chunk-U56TIYGP.js";import"./chunk-V5TRAL57.js";import"./chunk-6MONUYQ5.js";import"./chunk-LQ3TA22E.js";import"./chunk-RH3PHCJT.js";import"./chunk-KCHFF4IE.js";import"./chunk-3BO7EKGO.js";import{k as I,o as F}from"./chunk-UE3XXKLN.js";import"./chunk-TEJPHJMW.js";import"./chunk-OKGK7DBT.js";import"./chunk-DXV6NRG3.js";import"./chunk-ALCQRJDY.js";import"./chunk-X73CRYF4.js";import"./chunk-BQT4J3BD.js";import"./chunk-FEBXP74Y.js";import{a as u,c as M}from"./chunk-KNL3QWVA.js";import"./chunk-MJBXQXSX.js";import"./chunk-4UUDFWOP.js";import"./chunk-ZCNVFULO.js";import"./chunk-QU54GUEA.js";import"./chunk-O3NAUNFC.js";import"./chunk-I4E6CLC4.js";import"./chunk-NT4PI5HI.js";import"./chunk-66GIKUI2.js";import"./chunk-SGONA5GS.js";import"./chunk-5UOV7T36.js";import"./chunk-KOSKGZK4.js";import"./chunk-55JPAF56.js";var L={enableLearning:!0,enableRouting:!0,enableGuidance:!0,enableTrajectories:!0,enableExperienceReplay:!0,autoStoreExperiences:!0,minQualityThreshold:.6},P=class n{static instance=null;static initPromise=null;config;enhancedAdapter;disposed=!1;patternsLoaded=!1;qualityThresholdsFromPatterns=null;tasksRecorded=0;successfulTasks=0;failedTasks=0;patternsStored=0;routingRequests=0;activeTrajectories=new Map;constructor(e,t){this.config=e,this.enhancedAdapter=t}static async getInstance(e){if(n.instance&&!n.instance.disposed)return n.instance;if(n.initPromise)return n.initPromise;n.initPromise=n.create(e);try{return n.instance=await n.initPromise,n.instance}finally{n.initPromise=null}}static async create(e){let t={...L,...e},r=j({enableTrajectories:t.enableTrajectories,enableExperienceReplay:t.enableExperienceReplay,enablePatternEvolution:!0,autoStoreExperiences:t.autoStoreExperiences,autoConsolidate:!0});await r.initialize();let s=new n(t,r);return await s.loadPatternsFromLoader(),await s.seedInitialPatternsIfNeeded(),console.error("[ReasoningBankService] Initialized with EnhancedReasoningBankAdapter (trajectory + experience + evolution)"),s}async loadPatternsFromLoader(){try{let t=await B().getQualityGateThresholds();if(t){this.qualityThresholdsFromPatterns=t,this.patternsLoaded=!0,console.error("[ReasoningBankService] Loaded quality thresholds from PatternLoader",{tiers:Object.keys(t)});return}console.error("[ReasoningBankService] PatternLoader returned no thresholds, using defaults")}catch(e){console.error("[ReasoningBankService] Failed to load patterns from PatternLoader, using defaults",{error:e instanceof Error?e.message:"Unknown error"})}this.patternsLoaded=!1}async seedInitialPatternsIfNeeded(){try{let e=await this.enhancedAdapter.getStats();if(e.reasoningBank.totalPatterns>0){console.error(`[ReasoningBankService] Found ${e.reasoningBank.totalPatterns} existing patterns, skipping seed`);return}console.error("[ReasoningBankService] Seeding initial QE patterns...");let t=(s,a="string",i=!1)=>({name:s,type:a,required:i,description:`${s} parameter`}),r=[{patternType:"test-template",name:"unit-test-generation",description:"Generate comprehensive unit tests for TypeScript/JavaScript modules",domain:"test-generation",template:{type:"workflow",content:"Analyze module exports, identify edge cases, generate Jest/Vitest tests with proper mocking",variables:[t("modulePath"),t("framework")]},context:{tags:["unit","typescript","jest","vitest"]}},{patternType:"coverage-strategy",name:"coverage-gap-analysis",description:"Identify untested code paths and recommend targeted tests",domain:"coverage-analysis",template:{type:"workflow",content:"Parse coverage report, identify uncovered branches, prioritize by risk, generate recommendations",variables:[t("coveragePath"),t("threshold","number")]},context:{tags:["coverage","analysis","risk"]}},{patternType:"test-template",name:"integration-test-generation",description:"Generate integration tests for API endpoints and service interactions",domain:"test-generation",template:{type:"workflow",content:"Identify API contracts, generate request/response tests, validate error handling",variables:[t("apiPath"),t("framework")]},context:{tags:["integration","api","contract"]}},{patternType:"flaky-fix",name:"flaky-test-remediation",description:"Detect and fix flaky tests through pattern analysis",domain:"test-execution",template:{type:"workflow",content:"Analyze test history, identify timing/race conditions, apply stabilization patterns",variables:[t("testPath"),t("retryCount","number")]},context:{tags:["flaky","stability","retry"]}},{patternType:"error-handling",name:"security-vulnerability-scan",description:"Scan code for security vulnerabilities using OWASP patterns",domain:"security-compliance",template:{type:"workflow",content:"Run SAST analysis, check for injection risks, validate authentication/authorization",variables:[t("targetPath"),t("severity")]},context:{tags:["security","owasp","sast"]}}];for(let s of r)try{await this.enhancedAdapter.storePattern(s),this.patternsStored++}catch(a){console.error(`[ReasoningBankService] Failed to seed pattern ${s.name}:`,a)}console.error(`[ReasoningBankService] Seeded ${r.length} initial patterns`)}catch(e){console.error("[ReasoningBankService] Failed to seed patterns:",e)}}getPatternsLoaded(){return this.patternsLoaded}getQualityThresholdsFromPatterns(){return this.qualityThresholdsFromPatterns}async startTaskTrajectory(e,t,r={}){if(!this.config.enableTrajectories||this.disposed)return e;try{let s=await this.enhancedAdapter.startTaskTrajectory(t,r);return this.activeTrajectories.set(e,s),console.error(`[ReasoningBankService] Started trajectory: task=${e} trajectory=${s}`),s}catch(s){return console.error("[ReasoningBankService] Failed to start trajectory:",s),e}}async recordTrajectoryStep(e,t,r,s){if(!this.config.enableTrajectories||this.disposed)return;let a=this.activeTrajectories.get(e);if(!a){console.error(`[ReasoningBankService] No active trajectory for task ${e}`);return}try{await this.enhancedAdapter.recordTaskStep(a,t,r,s)}catch(i){console.error("[ReasoningBankService] Failed to record trajectory step:",i)}}async endTaskTrajectory(e,t,r){if(!this.config.enableTrajectories||this.disposed)return null;let s=this.activeTrajectories.get(e);if(!s)return console.error(`[ReasoningBankService] No active trajectory for task ${e}`),null;try{let a=await this.enhancedAdapter.endTaskTrajectory(s,t,r);return this.activeTrajectories.delete(e),console.error(`[ReasoningBankService] Ended trajectory: task=${e} success=${t} steps=${a.steps.length} quality=${a.metrics.averageQuality.toFixed(2)}`),a}catch(a){return console.error("[ReasoningBankService] Failed to end trajectory:",a),this.activeTrajectories.delete(e),null}}getActiveTrajectoryId(e){return this.activeTrajectories.get(e)}async recordTaskOutcome(e){if(!(!this.config.enableLearning||this.disposed)){this.tasksRecorded++,e.success?this.successfulTasks++:this.failedTasks++;try{let t={patternId:`task-${e.taskId}`,success:e.success,metrics:{executionTimeMs:e.executionTimeMs,testsPassed:e.metrics?.testsPassed,testsFailed:e.metrics?.testsGenerated?e.metrics.testsGenerated-(e.metrics.testsPassed||0):void 0,coverageImprovement:e.metrics?.coverageImprovement},feedback:e.error};await this.enhancedAdapter.recordPatternOutcome(t),e.success&&(e.qualityScore||.5)>=this.config.minQualityThreshold&&(await this.storeTaskPattern(e),this.patternsStored++),e.agentId&&await this.updateAgentPerformanceFromOutcome(e),console.error(`[ReasoningBankService] Recorded outcome: task=${e.taskId} success=${e.success} quality=${e.qualityScore?.toFixed(2)||"N/A"}`)}catch(t){throw console.error("[ReasoningBankService] Failed to record outcome:",t),t}}}async updateAgentPerformanceFromOutcome(e){if(e.agentId)try{E(e.agentId,{success:e.success,executionTimeMs:e.executionTimeMs,qualityScore:e.qualityScore}),console.error(`[ReasoningBankService] Updated agent performance: agent=${e.agentId} success=${e.success} duration=${e.executionTimeMs}ms`)}catch(t){console.error("[ReasoningBankService] Failed to update agent performance:",t)}}async storeTaskPattern(e){try{let t=[e.taskType,e.domain||"general",e.agentId?`agent:${e.agentId}`:void 0,e.modelTier?`tier:${e.modelTier}`:void 0,e.executionTimeMs?`duration:${e.executionTimeMs}ms`:void 0].filter(r=>r!==void 0);await this.enhancedAdapter.storePattern({patternType:"test-template",name:`${e.taskType}-${e.domain||"general"}`,description:e.task,template:{type:"workflow",content:e.task,variables:[]},context:{tags:t}})}catch(t){console.error("[ReasoningBankService] Failed to store pattern:",t)}}async getRoutingRecommendation(e){if(!this.config.enableRouting||this.disposed)return this.createFallbackRouting(e);this.routingRequests++;try{let t=await this.enhancedAdapter.routeTaskWithExperience(e);if(!t.success)return console.error("[ReasoningBankService] Routing returned error:",t.error),this.createFallbackRouting(e);let r=t.value;return r.experienceGuidance&&console.error(`[ReasoningBankService] Experience guidance: strategy="${r.experienceGuidance.recommendedStrategy}" confidence=${r.experienceGuidance.confidence.toFixed(2)} tokenSavings=${r.experienceGuidance.estimatedTokenSavings}`),console.error(`[ReasoningBankService] Routing: task="${e.task.slice(0,50)}..." -> agent=${r.recommendedAgent} confidence=${r.confidence.toFixed(2)}`),r}catch(t){return console.error("[ReasoningBankService] Routing failed:",t),this.createFallbackRouting(e)}}async getExperienceGuidance(e,t){if(!this.config.enableExperienceReplay||this.disposed)return null;try{return await this.enhancedAdapter.getExperienceGuidance(e,t)}catch(r){return console.error("[ReasoningBankService] Failed to get experience guidance:",r),null}}async getTaskGuidance(e,t){if(!this.config.enableGuidance||this.disposed)return[];try{let r=await this.enhancedAdapter.routeTaskWithExperience({task:e,domain:t});return r.success?r.value.guidance:[]}catch(r){return console.error("[ReasoningBankService] Guidance failed:",r),[]}}async searchPatterns(e,t){if(this.disposed)return[];try{let r=await this.enhancedAdapter.searchPatterns(e,{limit:t?.limit||10,domain:t?.domain});return r.success?r.value.map(s=>s.pattern):(console.error("[ReasoningBankService] Search returned error:",r.error),[])}catch(r){return console.error("[ReasoningBankService] Search failed:",r),[]}}async getStats(){let e=await this.enhancedAdapter.getStats();return{service:{tasksRecorded:this.tasksRecorded,successfulTasks:this.successfulTasks,failedTasks:this.failedTasks,successRate:this.tasksRecorded>0?this.successfulTasks/this.tasksRecorded:0,patternsStored:this.patternsStored,routingRequests:this.routingRequests,patternsLoaded:this.patternsLoaded,activeTrajectories:this.activeTrajectories.size},reasoningBank:e.reasoningBank,adapter:e.adapter}}createFallbackRouting(e){return{recommendedAgent:"qe-test-architect",confidence:.5,alternatives:[],domains:e.domain?[e.domain]:["test-generation"],patterns:[],guidance:[],reasoning:"Fallback routing - ReasoningBank unavailable",latencyMs:0}}isHealthy(){return!this.disposed}async dispose(){this.disposed||(this.disposed=!0,await this.enhancedAdapter.dispose(),this.activeTrajectories.clear(),n.instance=null,console.error("[ReasoningBankService] Disposed"))}static reset(){n.instance&&n.instance.dispose(),n.instance=null,n.initPromise=null}};async function y(n){return P.getInstance(n)}async function C(n,e,t){return(await y()).startTaskTrajectory(n,e,t)}async function v(n,e,t){return(await y()).endTaskTrajectory(n,e,t)}F();var Q="claude-haiku-4-5-20251001",G=200,U=5;async function O(){let n=process.env.ANTHROPIC_API_KEY;if(!n)return;let e=(process.env.ANTHROPIC_BASE_URL??"https://api.anthropic.com").replace(/\/$/,""),t=I();if(!t.isInitialized())return;let r=t.getDatabase();if(!r.prepare("PRAGMA table_info(qe_trajectories)").all().some(c=>c.name==="feedback"))return;let a=r.prepare(`
|
|
3
3
|
SELECT id, task, agent, domain, success
|
|
4
4
|
FROM qe_trajectories
|
|
5
5
|
WHERE feedback IS NULL AND ended_at IS NOT NULL
|
|
6
6
|
ORDER BY ended_at DESC
|
|
7
7
|
LIMIT ?
|
|
8
8
|
`).all(U);if(a.length===0)return;let i=r.prepare("UPDATE qe_trajectories SET feedback = ? WHERE id = ?");for(let c of a)try{let o=await z(c,n,e);o&&i.run(JSON.stringify(o),c.id)}catch{}}async function z(n,e,t){let r=["You are a quality engineering judge scoring a completed task trajectory.","",`Task: ${n.task.slice(0,400)}`,`Agent: ${n.agent??"unknown"}`,`Domain: ${n.domain??"general"}`,`Outcome: ${n.success?"success":"failure"}`,"",'Respond ONLY with JSON: {"quality": 0..1, "reasoning": "\u2264120 chars", "improvement": "\u2264120 chars or omit"}.'].join(`
|
|
9
|
-
`),s=await fetch(`${t}/v1/messages`,{method:"POST",headers:{"content-type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"},body:JSON.stringify({model:Q,max_tokens:G,messages:[{role:"user",content:r}]})});if(!s.ok)return null;let i=(await s.json()).content?.[0]?.text;if(!i)return null;let c=i.match(/\{[\s\S]*\}/);if(!c)return null;try{let o=JSON.parse(c[0]);return typeof o.quality!="number"||typeof o.reasoning!="string"?null:{quality:Math.max(0,Math.min(1,o.quality)),reasoning:o.reasoning.slice(0,200),improvement:typeof o.improvement=="string"?o.improvement.slice(0,200):void 0}}catch{return null}}M();var N={"ideation-assessment":"qcsd-ideation-swarm"};async function ae(n){if(!p())return{success:!1,error:"Fleet not initialized. Call fleet_init first."};let{queen:e}=m();try{let t=await e.submitTask({type:n.type,priority:n.priority||"p1",targetDomains:n.targetDomains||[],payload:n.payload||{},timeout:n.timeout||3e5});if(!t.success)return{success:!1,error:t.error.message};let r=e.getTaskStatus(t.value);return{success:!0,data:{taskId:t.value,type:n.type,priority:n.priority||"p1",status:r?.status==="running"?"pending":"queued",assignedDomain:r?.assignedDomain}}}catch(t){return{success:!1,error:`Failed to submit task: ${u(t)}`}}}async function oe(n){if(!p())return{success:!1,error:"Fleet not initialized. Call fleet_init first."};let{queen:e}=m();try{let t=e.listTasks({status:n.status,priority:n.priority,domain:n.domain});return{success:!0,data:(typeof n.limit=="number"?t.slice(0,n.limit):t).map(a=>({taskId:a.taskId,type:a.task.type,status:a.status,priority:a.task.priority,assignedDomain:a.assignedDomain,assignedAgents:a.assignedAgents,result:a.result,error:a.error,createdAt:a.task.createdAt.toISOString(),startedAt:a.startedAt?.toISOString(),completedAt:a.completedAt?.toISOString(),duration:a.completedAt&&a.startedAt?a.completedAt.getTime()-a.startedAt.getTime():void 0}))}}catch(t){return{success:!1,error:`Failed to list tasks: ${u(t)}`}}}async function ce(n){if(!p())return{success:!1,error:"Fleet not initialized. Call fleet_init first."};let{queen:e}=m();try{let t=e.getTaskStatus(n.taskId);return t?{success:!0,data:{taskId:t.taskId,type:t.task.type,status:t.status,priority:t.task.priority,assignedDomain:t.assignedDomain,assignedAgents:t.assignedAgents,result:n.detailed?t.result:void 0,error:t.error,createdAt:t.task.createdAt.toISOString(),startedAt:t.startedAt?.toISOString(),completedAt:t.completedAt?.toISOString(),duration:t.completedAt&&t.startedAt?t.completedAt.getTime()-t.startedAt.getTime():void 0}}:{success:!1,error:`Task not found: ${n.taskId}`}}catch(t){return{success:!1,error:`Failed to get task status: ${u(t)}`}}}async function de(n){if(!p())return{success:!1,error:"Fleet not initialized. Call fleet_init first."};let{queen:e}=m();try{let t=await e.cancelTask(n.taskId);return t.success?{success:!0,data:{taskId:n.taskId,cancelled:!0}}:{success:!1,error:t.error.message}}catch(t){return{success:!1,error:`Failed to cancel task: ${u(t)}`}}}async function ue(n){if(!p())return{success:!1,error:"Fleet not initialized. Call fleet_init first."};let{queen:e,workflowOrchestrator:t}=m();try{let r=n.context?.project||q(n.task),s=n.priority==="critical"||/\b(security|vulnerability|cve|owasp|critical|production|exploit)\b/i.test(n.task),i=await(await R()).routeTask({task:n.task,codeContext:n.codeContext,filePaths:n.filePaths,manualTier:n.manualTier,isCritical:s,agentType:`qe-${r}`,domain:r,metadata:{inferredDomain:r,hasCodeContext:!!n.codeContext,fileCount:n.filePaths?.length}}),c=await y(),o=await c.getExperienceGuidance(n.task,n.context?.project),f=await c.searchPatterns(n.task,{limit:5,domain:n.context?.project??r}).catch(()=>[]),l=H(n.task),k=J(n.priority||"medium"),b=N[l];if(b&&t){console.log(`[TaskOrchestrate] Task type '${l}' has workflow '${b}' - executing workflow`);let d=n.task.match(/https?:\/\/[^\s]+/i),h=d?d[0]:void 0;h&&console.log(`[TaskOrchestrate] Detected URL for analysis: ${h}`);let $={targetId:n.context?.project||h||`task-${Date.now()}`,targetType:h?"website":"epic",description:n.task,acceptanceCriteria:n.context?.requirements||[],url:h,routing:{tier:i.decision.tier,modelId:i.modelId,executionStrategy:i.executionStrategy,complexity:i.decision.complexityAnalysis.overall},patternHints:f.length>0?f.map(T=>({patternId:T.id,name:T.name,description:T.description,confidence:T.confidence,similarity:T.qualityScore,canReuse:T.tier==="long-term"})):void 0},x=await t.executeWorkflow(b,$);return x.success?{success:!0,data:{taskId:x.value,type:l,priority:k,strategy:n.strategy||"adaptive",status:"workflow-started",message:`Workflow '${b}' started for task: ${n.task}`,routing:{tier:i.decision.tier,tierName:i.tierInfo.name,modelId:i.modelId,executionStrategy:i.executionStrategy,complexity:i.decision.complexityAnalysis.overall,confidence:i.decision.confidence,useAgentBooster:i.useAgentBooster,rationale:i.decision.rationale,decisionTimeMs:i.decision.metadata.decisionTimeMs}}}:{success:!1,error:`Workflow execution failed: ${x.error.message}`}}let g={description:n.task,strategy:n.strategy||"adaptive",maxAgents:n.maxAgents,context:n.context};l==="generate-tests"&&(g.sourceFiles=n.filePaths||[],g.sourceCode=n.codeContext||"",g.language=g.language||"typescript",g.testType=g.testType||"unit");let S=await e.submitTask({type:l,priority:k,targetDomains:[],payload:{...g,routing:{tier:i.decision.tier,modelId:i.modelId,executionStrategy:i.executionStrategy,useAgentBooster:i.useAgentBooster,agentBoosterTransform:i.decision.agentBoosterTransform,complexity:i.decision.complexityAnalysis.overall,confidence:i.decision.confidence},experienceGuidance:o?{strategy:o.recommendedStrategy,actions:o.suggestedActions,confidence:o.confidence,tokenSavings:o.estimatedTokenSavings}:void 0,patternHints:f.length>0?f.map(d=>({patternId:d.id,name:d.name,description:d.description,confidence:d.confidence,similarity:d.qualityScore,canReuse:d.tier==="long-term"})):void 0},timeout:6e5});if(!S.success)return{success:!1,error:S.error.message};let A=S.value;return await C(A,n.task,{agent:"queen-coordinator",domain:n.context?.project}),process.env.AQE_TRAJECTORY_JUDGE==="1"&&process.env.ANTHROPIC_API_KEY&&O().catch(d=>{console.warn("[TrajectoryJudge] failed:",d instanceof Error?d.message:d)}),{success:!0,data:{taskId:A,type:l,priority:k,strategy:n.strategy||"adaptive",status:"submitted",message:`Task orchestrated: ${n.task}${o?" (with experience guidance)":""}`,routing:{tier:i.decision.tier,tierName:i.tierInfo.name,modelId:i.modelId,executionStrategy:i.executionStrategy,complexity:i.decision.complexityAnalysis.overall,confidence:i.decision.confidence,useAgentBooster:i.useAgentBooster,rationale:i.decision.rationale,decisionTimeMs:i.decision.metadata.decisionTimeMs}}}}catch(r){return{success:!1,error:`Failed to orchestrate task: ${u(r)}`}}}async function le(n){try{let e=await R(),t=n.domain||q(n.task),r=n.isCritical??/\b(security|vulnerability|cve|owasp|critical|production|exploit)\b/i.test(n.task),s=await e.routeTask({task:n.task,codeContext:n.codeContext,filePaths:n.filePaths,manualTier:n.manualTier,isCritical:r,agentType:n.agentType||`qe-${t}`,domain:t,metadata:{inferredDomain:t,hasCodeContext:!!n.codeContext,fileCount:n.filePaths?.length}});return{success:!0,data:{tier:s.decision.tier,tierName:s.tierInfo.name,modelId:s.modelId,executionStrategy:s.executionStrategy,useAgentBooster:s.useAgentBooster,agentBoosterTransform:s.decision.agentBoosterTransform,complexity:{overall:s.decision.complexityAnalysis.overall,code:s.decision.complexityAnalysis.codeComplexity,reasoning:s.decision.complexityAnalysis.reasoningComplexity,scope:s.decision.complexityAnalysis.scopeComplexity},confidence:s.decision.confidence,rationale:s.decision.rationale,warnings:s.decision.warnings,budget:{allowed:s.decision.budgetDecision.allowed,wasDowngraded:s.decision.budgetDecision.wasDowngraded,estimatedCostUsd:s.decision.budgetDecision.estimatedCostUsd},decisionTimeMs:s.decision.metadata.decisionTimeMs}}}catch(e){return{success:!1,error:`Failed to route task: ${u(e)}`}}}async function ge(n){try{let e=await R(),t=e.getRoutingStats(),r=e.getMetrics(),s={stats:t,modelRouterMetrics:{totalDecisions:r.totalDecisions,avgDecisionTimeMs:r.avgDecisionTimeMs,agentBoosterStats:r.agentBoosterStats,budgetStats:r.budgetStats}};return n.includeLog&&(s.log=e.getRoutingLog(n.logLimit||100)),{success:!0,data:s}}catch(e){return{success:!1,error:`Failed to get routing metrics: ${u(e)}`}}}async function me(n){try{let{createRoutingFeedbackCollector:e}=await import("./routing-feedback-MZ73LFBP.js"),{getGlobalCostTracker:t}=await import("./cost-tracker-JLSEY4ID.js"),r=e(100);await r.initialize(),r.enableEconomicRouting({...n.taskComplexity!=null?{}:{}},t());let s=r.getEconomicReport();return s?{success:!0,data:{tierEfficiency:s.tierEfficiency.map(i=>({...i,qualityPerDollar:isFinite(i.qualityPerDollar)?i.qualityPerDollar:"Infinity"})),currentHourlyCostUsd:s.currentHourlyCostUsd,currentDailyCostUsd:s.currentDailyCostUsd,budgetRemaining:s.budgetRemaining,recommendation:s.recommendation,savingsOpportunity:s.savingsOpportunity}}:{success:!1,error:"Economic routing is not available"}}catch(e){return{success:!1,error:`Failed to get economic routing report: ${u(e)}`}}}function q(n){let e=n.toLowerCase();return/\b(security|vulnerabilit|cve|owasp|secret|credential|injection|xss|csrf)\b/.test(e)?"security-compliance":/\b(chaos|resilience|fault.?inject|disaster|failover)\b/.test(e)?"chaos-resilience":/\b(defect|bug.?predict|risk.?assess|mutation)\b/.test(e)?"defect-intelligence":/\b(coverage|uncovered|gap.?analy)\b/.test(e)?"coverage-analysis":/\b(quality|code.?review|maintain|tech.?debt)\b/.test(e)?"quality-assessment":/\b(contract|api.?compat|breaking.?change|pact)\b/.test(e)?"contract-testing":/\b(index|knowledge.?graph|semantic|code.?intel)\b/.test(e)?"code-intelligence":/\b(accessib|a11y|wcag|screen.?read)\b/.test(e)?"visual-accessibility":/\b(requirement|bdd|acceptance|user.?stor)\b/.test(e)?"requirements-validation":/\b(generat.*test|test.*generat|write.*test|create.*test)\b/.test(e)?"test-generation":/\b(run.*test|execut.*test)\b/.test(e)?"test-execution":"test-generation"}function H(n){let e=n.toLowerCase();return/run\s+(?:\w+\s+)*tests?/.test(e)||/execute\s+(?:\w+\s+)*tests?/.test(e)||e.includes("run tests")||e.includes("execute tests")?"execute-tests":e.includes("generate test")||e.includes("create test")||e.includes("write test")?"generate-tests":e.includes("coverage")||e.includes("uncovered")?"analyze-coverage":e.includes("quality")||e.includes("code quality")?"assess-quality":e.includes("defect")||e.includes("bug")||e.includes("predict")?"predict-defects":e.includes("requirement")||e.includes("bdd")||e.includes("acceptance")?"validate-requirements":e.includes("index")||e.includes("knowledge graph")||e.includes("semantic")?"index-code":e.includes("security")||e.includes("vulnerability")||e.includes("owasp")?"scan-security":e.includes("contract")||e.includes("api contract")||e.includes("pact")?"validate-contracts":e.includes("accessibility")||e.includes("a11y")||e.includes("wcag")?"test-accessibility":e.includes("chaos")||e.includes("resilience")||e.includes("fault")?"run-chaos":e.includes("learn")||e.includes("optimize")||e.includes("improve")?"optimize-learning":e.includes("ideation")||e.includes("quality criteria")||e.includes("htsm")||e.includes("qcsd")||e.includes("testability")||e.includes("pi planning")||e.includes("sprint planning")?"ideation-assessment":"generate-tests"}function J(n){switch(n){case"critical":return"p0";case"high":return"p1";case"medium":return"p2";case"low":return"p3";default:return"p1"}}async function pe(n){try{let e=await y(),t={taskId:n.taskId,task:n.task,taskType:n.taskType,success:n.success,executionTimeMs:n.executionTimeMs,agentId:n.agentId,domain:n.domain,modelTier:n.modelTier,qualityScore:n.qualityScore,error:n.error,metrics:n.metrics};await e.recordTaskOutcome(t);let r=n.success&&(n.qualityScore||.5)>=.6;return{success:!0,data:{recorded:!0,patternStored:r,message:r?`Outcome recorded and pattern stored for task ${n.taskId}`:`Outcome recorded for task ${n.taskId}`}}}catch(e){return{success:!1,error:`Failed to record task outcome: ${u(e)}`}}}async function ye(){try{let e=await(await y()).getStats();return{success:!0,data:{service:e.service,patterns:{totalPatterns:e.reasoningBank.totalPatterns,byDomain:e.reasoningBank.byDomain,byTier:e.reasoningBank.byTier,learningOutcomes:e.reasoningBank.learningOutcomes,patternSuccessRate:e.reasoningBank.patternSuccessRate},embeddings:{cacheSize:e.reasoningBank.embeddingCacheSize,dimension:e.reasoningBank.embeddingDimension,transformerAvailable:e.reasoningBank.transformerAvailable},performance:{avgRoutingLatencyMs:e.reasoningBank.avgRoutingLatencyMs,p95RoutingLatencyMs:e.reasoningBank.p95RoutingLatencyMs}}}}catch(n){return{success:!1,error:`Failed to get ReasoningBank stats: ${u(n)}`}}}var D=new Set;async function fe(n){if(!p())return{success:!1,error:"Fleet not initialized. Call fleet_init first."};let{queen:e}=m();try{let t=e.getTaskStatus(n.taskId);if(!t)return{success:!1,error:`Task not found: ${n.taskId}`};let r={taskId:t.taskId,type:t.task.type,status:t.status,priority:t.task.priority,assignedDomain:t.assignedDomain,assignedAgents:t.assignedAgents,result:n.detailed?t.result:void 0,error:t.error,createdAt:t.task.createdAt.toISOString(),startedAt:t.startedAt?.toISOString(),completedAt:t.completedAt?.toISOString(),duration:t.completedAt&&t.startedAt?t.completedAt.getTime()-t.startedAt.getTime():void 0};if((t.status==="completed"||t.status==="failed")&&!D.has(n.taskId)){D.add(n.taskId);try{let s=await y(),a=r.duration||0,i=t.status==="completed",c=t.task.payload||{},o=typeof c.description=="string"?c.description:t.task.type,f=c.routing,l=await v(n.taskId,i,t.error),k=l?.metrics.averageQuality??(i?.7:.3);await s.recordTaskOutcome({taskId:n.taskId,task:o,taskType:t.task.type,success:i,executionTimeMs:a,agentId:t.assignedAgents?.[0],domain:t.assignedDomain,modelTier:f?.tier,qualityScore:k,error:t.error,metrics:{testsGenerated:typeof t.result=="object"&&t.result?t.result.testsGenerated:void 0,testsPassed:typeof t.result=="object"&&t.result?t.result.testsPassed:void 0}}),console.error(`[TaskHandler] Recorded learning outcome: task=${n.taskId} success=${i} quality=${k.toFixed(2)} trajectorySteps=${l?.steps.length??0}`)}catch(s){console.error("[TaskHandler] Failed to record outcome:",s)}}return{success:!0,data:r}}catch(t){return{success:!1,error:`Failed to get task status: ${u(t)}`}}}var w=[];function ke(n){W(n);let e=n.subscribeToEventType("TaskCompleted",async r=>{let{taskId:s}=r.payload;s&&await v(s,!0).catch(()=>{})}),t=n.subscribeToEventType("TaskFailed",async r=>{let{taskId:s,error:a}=r.payload;s&&await v(s,!1,a).catch(()=>{})});w=[e,t]}function W(n){for(let e of w)n.unsubscribe(e);w=[]}export{le as handleModelRoute,ye as handleReasoningBankStats,me as handleRoutingEconomics,ge as handleRoutingMetrics,de as handleTaskCancel,oe as handleTaskList,ue as handleTaskOrchestrate,pe as handleTaskOutcomeRecord,ce as handleTaskStatus,fe as handleTaskStatusWithLearning,ae as handleTaskSubmit,ke as subscribeTrajectoryEvents,W as unsubscribeTrajectoryEvents};
|
|
9
|
+
`),s=await fetch(`${t}/v1/messages`,{method:"POST",headers:{"content-type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"},body:JSON.stringify({model:Q,max_tokens:G,messages:[{role:"user",content:r}]})});if(!s.ok)return null;let i=(await s.json()).content?.[0]?.text;if(!i)return null;let c=i.match(/\{[\s\S]*\}/);if(!c)return null;try{let o=JSON.parse(c[0]);return typeof o.quality!="number"||typeof o.reasoning!="string"?null:{quality:Math.max(0,Math.min(1,o.quality)),reasoning:o.reasoning.slice(0,200),improvement:typeof o.improvement=="string"?o.improvement.slice(0,200):void 0}}catch{return null}}M();var N={"ideation-assessment":"qcsd-ideation-swarm"};async function ae(n){if(!p())return{success:!1,error:"Fleet not initialized. Call fleet_init first."};let{queen:e}=m();try{let t=await e.submitTask({type:n.type,priority:n.priority||"p1",targetDomains:n.targetDomains||[],payload:n.payload||{},timeout:n.timeout||3e5});if(!t.success)return{success:!1,error:t.error.message};let r=e.getTaskStatus(t.value);return{success:!0,data:{taskId:t.value,type:n.type,priority:n.priority||"p1",status:r?.status==="running"?"pending":"queued",assignedDomain:r?.assignedDomain}}}catch(t){return{success:!1,error:`Failed to submit task: ${u(t)}`}}}async function oe(n){if(!p())return{success:!1,error:"Fleet not initialized. Call fleet_init first."};let{queen:e}=m();try{let t=e.listTasks({status:n.status,priority:n.priority,domain:n.domain});return{success:!0,data:(typeof n.limit=="number"?t.slice(0,n.limit):t).map(a=>({taskId:a.taskId,type:a.task.type,status:a.status,priority:a.task.priority,assignedDomain:a.assignedDomain,assignedAgents:a.assignedAgents,result:a.result,error:a.error,createdAt:a.task.createdAt.toISOString(),startedAt:a.startedAt?.toISOString(),completedAt:a.completedAt?.toISOString(),duration:a.completedAt&&a.startedAt?a.completedAt.getTime()-a.startedAt.getTime():void 0}))}}catch(t){return{success:!1,error:`Failed to list tasks: ${u(t)}`}}}async function ce(n){if(!p())return{success:!1,error:"Fleet not initialized. Call fleet_init first."};let{queen:e}=m();try{let t=e.getTaskStatus(n.taskId);return t?{success:!0,data:{taskId:t.taskId,type:t.task.type,status:t.status,priority:t.task.priority,assignedDomain:t.assignedDomain,assignedAgents:t.assignedAgents,result:n.detailed?t.result:void 0,error:t.error,createdAt:t.task.createdAt.toISOString(),startedAt:t.startedAt?.toISOString(),completedAt:t.completedAt?.toISOString(),duration:t.completedAt&&t.startedAt?t.completedAt.getTime()-t.startedAt.getTime():void 0}}:{success:!1,error:`Task not found: ${n.taskId}`}}catch(t){return{success:!1,error:`Failed to get task status: ${u(t)}`}}}async function de(n){if(!p())return{success:!1,error:"Fleet not initialized. Call fleet_init first."};let{queen:e}=m();try{let t=await e.cancelTask(n.taskId);return t.success?{success:!0,data:{taskId:n.taskId,cancelled:!0}}:{success:!1,error:t.error.message}}catch(t){return{success:!1,error:`Failed to cancel task: ${u(t)}`}}}async function ue(n){if(!p())return{success:!1,error:"Fleet not initialized. Call fleet_init first."};let{queen:e,workflowOrchestrator:t}=m();try{let r=n.context?.project||q(n.task),s=n.priority==="critical"||/\b(security|vulnerability|cve|owasp|critical|production|exploit)\b/i.test(n.task),i=await(await R()).routeTask({task:n.task,codeContext:n.codeContext,filePaths:n.filePaths,manualTier:n.manualTier,isCritical:s,agentType:`qe-${r}`,domain:r,metadata:{inferredDomain:r,hasCodeContext:!!n.codeContext,fileCount:n.filePaths?.length}}),c=await y(),o=await c.getExperienceGuidance(n.task,n.context?.project),f=await c.searchPatterns(n.task,{limit:5,domain:n.context?.project??r}).catch(()=>[]),l=H(n.task),k=J(n.priority||"medium"),b=N[l];if(b&&t){console.log(`[TaskOrchestrate] Task type '${l}' has workflow '${b}' - executing workflow`);let d=n.task.match(/https?:\/\/[^\s]+/i),h=d?d[0]:void 0;h&&console.log(`[TaskOrchestrate] Detected URL for analysis: ${h}`);let $={targetId:n.context?.project||h||`task-${Date.now()}`,targetType:h?"website":"epic",description:n.task,acceptanceCriteria:n.context?.requirements||[],url:h,routing:{tier:i.decision.tier,modelId:i.modelId,executionStrategy:i.executionStrategy,complexity:i.decision.complexityAnalysis.overall},patternHints:f.length>0?f.map(T=>({patternId:T.id,name:T.name,description:T.description,confidence:T.confidence,similarity:T.qualityScore,canReuse:T.tier==="long-term"})):void 0},x=await t.executeWorkflow(b,$);return x.success?{success:!0,data:{taskId:x.value,type:l,priority:k,strategy:n.strategy||"adaptive",status:"workflow-started",message:`Workflow '${b}' started for task: ${n.task}`,routing:{tier:i.decision.tier,tierName:i.tierInfo.name,modelId:i.modelId,executionStrategy:i.executionStrategy,complexity:i.decision.complexityAnalysis.overall,confidence:i.decision.confidence,useAgentBooster:i.useAgentBooster,rationale:i.decision.rationale,decisionTimeMs:i.decision.metadata.decisionTimeMs}}}:{success:!1,error:`Workflow execution failed: ${x.error.message}`}}let g={description:n.task,strategy:n.strategy||"adaptive",maxAgents:n.maxAgents,context:n.context};l==="generate-tests"&&(g.sourceFiles=n.filePaths||[],g.sourceCode=n.codeContext||"",g.language=g.language||"typescript",g.testType=g.testType||"unit");let S=await e.submitTask({type:l,priority:k,targetDomains:[],payload:{...g,routing:{tier:i.decision.tier,modelId:i.modelId,executionStrategy:i.executionStrategy,useAgentBooster:i.useAgentBooster,agentBoosterTransform:i.decision.agentBoosterTransform,complexity:i.decision.complexityAnalysis.overall,confidence:i.decision.confidence},experienceGuidance:o?{strategy:o.recommendedStrategy,actions:o.suggestedActions,confidence:o.confidence,tokenSavings:o.estimatedTokenSavings}:void 0,patternHints:f.length>0?f.map(d=>({patternId:d.id,name:d.name,description:d.description,confidence:d.confidence,similarity:d.qualityScore,canReuse:d.tier==="long-term"})):void 0},timeout:6e5});if(!S.success)return{success:!1,error:S.error.message};let A=S.value;return await C(A,n.task,{agent:"queen-coordinator",domain:n.context?.project}),process.env.AQE_TRAJECTORY_JUDGE==="1"&&process.env.ANTHROPIC_API_KEY&&O().catch(d=>{console.warn("[TrajectoryJudge] failed:",d instanceof Error?d.message:d)}),{success:!0,data:{taskId:A,type:l,priority:k,strategy:n.strategy||"adaptive",status:"submitted",message:`Task orchestrated: ${n.task}${o?" (with experience guidance)":""}`,routing:{tier:i.decision.tier,tierName:i.tierInfo.name,modelId:i.modelId,executionStrategy:i.executionStrategy,complexity:i.decision.complexityAnalysis.overall,confidence:i.decision.confidence,useAgentBooster:i.useAgentBooster,rationale:i.decision.rationale,decisionTimeMs:i.decision.metadata.decisionTimeMs}}}}catch(r){return{success:!1,error:`Failed to orchestrate task: ${u(r)}`}}}async function le(n){try{let e=await R(),t=n.domain||q(n.task),r=n.isCritical??/\b(security|vulnerability|cve|owasp|critical|production|exploit)\b/i.test(n.task),s=await e.routeTask({task:n.task,codeContext:n.codeContext,filePaths:n.filePaths,manualTier:n.manualTier,isCritical:r,agentType:n.agentType||`qe-${t}`,domain:t,metadata:{inferredDomain:t,hasCodeContext:!!n.codeContext,fileCount:n.filePaths?.length}});return{success:!0,data:{tier:s.decision.tier,tierName:s.tierInfo.name,modelId:s.modelId,executionStrategy:s.executionStrategy,useAgentBooster:s.useAgentBooster,agentBoosterTransform:s.decision.agentBoosterTransform,complexity:{overall:s.decision.complexityAnalysis.overall,code:s.decision.complexityAnalysis.codeComplexity,reasoning:s.decision.complexityAnalysis.reasoningComplexity,scope:s.decision.complexityAnalysis.scopeComplexity},confidence:s.decision.confidence,rationale:s.decision.rationale,warnings:s.decision.warnings,budget:{allowed:s.decision.budgetDecision.allowed,wasDowngraded:s.decision.budgetDecision.wasDowngraded,estimatedCostUsd:s.decision.budgetDecision.estimatedCostUsd},decisionTimeMs:s.decision.metadata.decisionTimeMs}}}catch(e){return{success:!1,error:`Failed to route task: ${u(e)}`}}}async function ge(n){try{let e=await R(),t=e.getRoutingStats(),r=e.getMetrics(),s={stats:t,modelRouterMetrics:{totalDecisions:r.totalDecisions,avgDecisionTimeMs:r.avgDecisionTimeMs,agentBoosterStats:r.agentBoosterStats,budgetStats:r.budgetStats}};return n.includeLog&&(s.log=e.getRoutingLog(n.logLimit||100)),{success:!0,data:s}}catch(e){return{success:!1,error:`Failed to get routing metrics: ${u(e)}`}}}async function me(n){try{let{createRoutingFeedbackCollector:e}=await import("./routing-feedback-RHATTSJ6.js"),{getGlobalCostTracker:t}=await import("./cost-tracker-G7BONKEV.js"),r=e(100);await r.initialize(),r.enableEconomicRouting({...n.taskComplexity!=null?{}:{}},t());let s=r.getEconomicReport();return s?{success:!0,data:{tierEfficiency:s.tierEfficiency.map(i=>({...i,qualityPerDollar:isFinite(i.qualityPerDollar)?i.qualityPerDollar:"Infinity"})),currentHourlyCostUsd:s.currentHourlyCostUsd,currentDailyCostUsd:s.currentDailyCostUsd,budgetRemaining:s.budgetRemaining,recommendation:s.recommendation,savingsOpportunity:s.savingsOpportunity}}:{success:!1,error:"Economic routing is not available"}}catch(e){return{success:!1,error:`Failed to get economic routing report: ${u(e)}`}}}function q(n){let e=n.toLowerCase();return/\b(security|vulnerabilit|cve|owasp|secret|credential|injection|xss|csrf)\b/.test(e)?"security-compliance":/\b(chaos|resilience|fault.?inject|disaster|failover)\b/.test(e)?"chaos-resilience":/\b(defect|bug.?predict|risk.?assess|mutation)\b/.test(e)?"defect-intelligence":/\b(coverage|uncovered|gap.?analy)\b/.test(e)?"coverage-analysis":/\b(quality|code.?review|maintain|tech.?debt)\b/.test(e)?"quality-assessment":/\b(contract|api.?compat|breaking.?change|pact)\b/.test(e)?"contract-testing":/\b(index|knowledge.?graph|semantic|code.?intel)\b/.test(e)?"code-intelligence":/\b(accessib|a11y|wcag|screen.?read)\b/.test(e)?"visual-accessibility":/\b(requirement|bdd|acceptance|user.?stor)\b/.test(e)?"requirements-validation":/\b(generat.*test|test.*generat|write.*test|create.*test)\b/.test(e)?"test-generation":/\b(run.*test|execut.*test)\b/.test(e)?"test-execution":"test-generation"}function H(n){let e=n.toLowerCase();return/run\s+(?:\w+\s+)*tests?/.test(e)||/execute\s+(?:\w+\s+)*tests?/.test(e)||e.includes("run tests")||e.includes("execute tests")?"execute-tests":e.includes("generate test")||e.includes("create test")||e.includes("write test")?"generate-tests":e.includes("coverage")||e.includes("uncovered")?"analyze-coverage":e.includes("quality")||e.includes("code quality")?"assess-quality":e.includes("defect")||e.includes("bug")||e.includes("predict")?"predict-defects":e.includes("requirement")||e.includes("bdd")||e.includes("acceptance")?"validate-requirements":e.includes("index")||e.includes("knowledge graph")||e.includes("semantic")?"index-code":e.includes("security")||e.includes("vulnerability")||e.includes("owasp")?"scan-security":e.includes("contract")||e.includes("api contract")||e.includes("pact")?"validate-contracts":e.includes("accessibility")||e.includes("a11y")||e.includes("wcag")?"test-accessibility":e.includes("chaos")||e.includes("resilience")||e.includes("fault")?"run-chaos":e.includes("learn")||e.includes("optimize")||e.includes("improve")?"optimize-learning":e.includes("ideation")||e.includes("quality criteria")||e.includes("htsm")||e.includes("qcsd")||e.includes("testability")||e.includes("pi planning")||e.includes("sprint planning")?"ideation-assessment":"generate-tests"}function J(n){switch(n){case"critical":return"p0";case"high":return"p1";case"medium":return"p2";case"low":return"p3";default:return"p1"}}async function pe(n){try{let e=await y(),t={taskId:n.taskId,task:n.task,taskType:n.taskType,success:n.success,executionTimeMs:n.executionTimeMs,agentId:n.agentId,domain:n.domain,modelTier:n.modelTier,qualityScore:n.qualityScore,error:n.error,metrics:n.metrics};await e.recordTaskOutcome(t);let r=n.success&&(n.qualityScore||.5)>=.6;return{success:!0,data:{recorded:!0,patternStored:r,message:r?`Outcome recorded and pattern stored for task ${n.taskId}`:`Outcome recorded for task ${n.taskId}`}}}catch(e){return{success:!1,error:`Failed to record task outcome: ${u(e)}`}}}async function ye(){try{let e=await(await y()).getStats();return{success:!0,data:{service:e.service,patterns:{totalPatterns:e.reasoningBank.totalPatterns,byDomain:e.reasoningBank.byDomain,byTier:e.reasoningBank.byTier,learningOutcomes:e.reasoningBank.learningOutcomes,patternSuccessRate:e.reasoningBank.patternSuccessRate},embeddings:{cacheSize:e.reasoningBank.embeddingCacheSize,dimension:e.reasoningBank.embeddingDimension,transformerAvailable:e.reasoningBank.transformerAvailable},performance:{avgRoutingLatencyMs:e.reasoningBank.avgRoutingLatencyMs,p95RoutingLatencyMs:e.reasoningBank.p95RoutingLatencyMs}}}}catch(n){return{success:!1,error:`Failed to get ReasoningBank stats: ${u(n)}`}}}var D=new Set;async function fe(n){if(!p())return{success:!1,error:"Fleet not initialized. Call fleet_init first."};let{queen:e}=m();try{let t=e.getTaskStatus(n.taskId);if(!t)return{success:!1,error:`Task not found: ${n.taskId}`};let r={taskId:t.taskId,type:t.task.type,status:t.status,priority:t.task.priority,assignedDomain:t.assignedDomain,assignedAgents:t.assignedAgents,result:n.detailed?t.result:void 0,error:t.error,createdAt:t.task.createdAt.toISOString(),startedAt:t.startedAt?.toISOString(),completedAt:t.completedAt?.toISOString(),duration:t.completedAt&&t.startedAt?t.completedAt.getTime()-t.startedAt.getTime():void 0};if((t.status==="completed"||t.status==="failed")&&!D.has(n.taskId)){D.add(n.taskId);try{let s=await y(),a=r.duration||0,i=t.status==="completed",c=t.task.payload||{},o=typeof c.description=="string"?c.description:t.task.type,f=c.routing,l=await v(n.taskId,i,t.error),k=l?.metrics.averageQuality??(i?.7:.3);await s.recordTaskOutcome({taskId:n.taskId,task:o,taskType:t.task.type,success:i,executionTimeMs:a,agentId:t.assignedAgents?.[0],domain:t.assignedDomain,modelTier:f?.tier,qualityScore:k,error:t.error,metrics:{testsGenerated:typeof t.result=="object"&&t.result?t.result.testsGenerated:void 0,testsPassed:typeof t.result=="object"&&t.result?t.result.testsPassed:void 0}}),console.error(`[TaskHandler] Recorded learning outcome: task=${n.taskId} success=${i} quality=${k.toFixed(2)} trajectorySteps=${l?.steps.length??0}`)}catch(s){console.error("[TaskHandler] Failed to record outcome:",s)}}return{success:!0,data:r}}catch(t){return{success:!1,error:`Failed to get task status: ${u(t)}`}}}var w=[];function ke(n){W(n);let e=n.subscribeToEventType("TaskCompleted",async r=>{let{taskId:s}=r.payload;s&&await v(s,!0).catch(()=>{})}),t=n.subscribeToEventType("TaskFailed",async r=>{let{taskId:s,error:a}=r.payload;s&&await v(s,!1,a).catch(()=>{})});w=[e,t]}function W(n){for(let e of w)n.unsubscribe(e);w=[]}export{le as handleModelRoute,ye as handleReasoningBankStats,me as handleRoutingEconomics,ge as handleRoutingMetrics,de as handleTaskCancel,oe as handleTaskList,ue as handleTaskOrchestrate,pe as handleTaskOutcomeRecord,ce as handleTaskStatus,fe as handleTaskStatusWithLearning,ae as handleTaskSubmit,ke as subscribeTrajectoryEvents,W as unsubscribeTrajectoryEvents};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.
|
|
2
|
-
import{b as y}from"./chunk-
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{b as y}from"./chunk-FQ5FT7IE.js";import{c as u,d as p,f as k,j as h}from"./chunk-XFMSHTXG.js";import"./chunk-55JPAF56.js";import{Command as F}from"commander";import e from"chalk";function U($,d,T){return new F("test").description("Test generation, execution, scheduling, and load testing").argument("<action>","Action (generate|execute|schedule|load)").argument("[target]","Target file or directory").option("-f, --framework <framework>","Test framework","vitest").option("-t, --type <type>","Test type (unit|integration|e2e)","unit").option("-F, --format <format>","Output format (text|json|junit|markdown)","text").option("-o, --output <path>","Write output to file").option("--git-ref <ref>","Git ref for schedule action (e.g., main, HEAD~3)").option("--no-git-aware","Disable git-aware test selection (schedule action)").option("--no-flaky","Disable flaky test tracking (schedule action)").option("--agents <count>","Target agent count for load action","10").option("--profile <profile>","Workload profile for load action (light|medium|heavy)","medium").option("--duration <ms>","Duration in ms for load action","30000").option("--real","Use real agents instead of mock (load action, requires fleet_init)").action(async(m,f,s)=>{if(await T())try{if(m==="generate"){console.log(e.blue(`
|
|
3
3
|
Generating tests for ${f||"current directory"}...
|
|
4
4
|
`));let l=await $.kernel.getDomainAPIAsync("test-generation");if(!l){console.log(e.red("Test generation domain not available"));return}let i=await import("path"),g=i.resolve(f||"."),a=y(g,{includeTests:!1});if(a.length===0){console.log(e.yellow("No source files found"));return}console.log(e.gray(` Found ${a.length} source files
|
|
5
5
|
`));let n=await l.generateTests({sourceFiles:a,testType:s.type,framework:s.framework,coverageTarget:80});if(n.success&&n.value){let t=n.value,c=s.format;if(c==="json")u(p(t),s.output);else if(c==="markdown"){let r=`# Test Generation Report
|
|
@@ -20,12 +20,12 @@ import{b as y}from"./chunk-EXUT2LCP.js";import{c as u,d as p,f as k,j as h}from"
|
|
|
20
20
|
`));let n=await l.runTests({testFiles:a,parallel:!0,retryCount:2});if(n.success&&n.value){let t=n.value,c=s.format;if(c==="json")u(p(t),s.output);else if(c==="junit")u(k(t),s.output);else if(c==="markdown")u(h(t),s.output);else{let o=t.passed+t.failed+t.skipped;console.log(e.green("Test run complete")),console.log(`
|
|
21
21
|
Results:`),console.log(` Total: ${e.white(o)}`),console.log(` Passed: ${e.green(t.passed)}`),console.log(` Failed: ${e.red(t.failed)}`),console.log(` Skipped: ${e.yellow(t.skipped)}`),console.log(` Duration: ${e.cyan(t.duration+"ms")}`)}t.failed>0&&await d(1);let r=t.passed+t.failed+t.skipped;r>0&&t.skipped/r>.2&&await d(2)}else console.log(e.red(`Failed: ${n.error?.message||"Unknown error"}`))}else if(m==="schedule"){let l=s.format;l==="text"&&console.log(e.blue(`
|
|
22
22
|
Running test schedule pipeline...
|
|
23
|
-
`));let{TestScheduleTool:i}=await import("./schedule-
|
|
23
|
+
`));let{TestScheduleTool:i}=await import("./schedule-O7MLASQT.js"),a=await new i().invoke({cwd:f||process.cwd(),gitRef:s.gitRef,useGitAware:s.gitAware!==!1,trackFlaky:s.flaky!==!1});if(a.success&&a.data){let n=a.data;if(l==="json")u(p(n),s.output);else{console.log(e.green(` Schedule complete
|
|
24
24
|
`)),console.log(` Phases: ${e.white(n.phases.length)}`);for(let t of n.phases){let c=t.failed===0?e.green:e.red;console.log(` ${e.cyan(t.phaseName)}: ${c(`${t.passed}/${t.totalTests} passed`)} (${t.durationMs}ms)`)}console.log(`
|
|
25
25
|
Git-aware: ${n.gitAware.enabled?e.green(`yes (${n.gitAware.selectedTests} selected)`):e.gray("disabled")}`),console.log(` Duration: ${e.cyan(n.totalDuration+"ms")}`),console.log(`
|
|
26
26
|
${n.summary}`)}}else console.log(e.red(`Failed: ${a.error||"Unknown error"}`))}else if(m==="load"){let l=s.format,i=parseInt(s.agents,10)||10,g=parseInt(s.duration,10)||3e4,a=s.profile,n=!s.real;l==="text"&&console.log(e.blue(`
|
|
27
27
|
Running load test: ${i} agents, ${a} profile, ${g}ms${n?" (mock)":" (real)"}...
|
|
28
|
-
`));let{LoadTestTool:t}=await import("./load-test-
|
|
28
|
+
`));let{LoadTestTool:t}=await import("./load-test-N4RNPLG4.js"),r=await new t().invoke({targetAgents:i,profile:a,durationMs:g,mockMode:n});if(r.success&&r.data){let o=r.data;if(l==="json")u(p(o),s.output);else{let w=o.passed?e.green:e.red;console.log(w(` Load test ${o.passed?"PASSED":"FAILED"}
|
|
29
29
|
`)),console.log(` Profile: ${e.cyan(o.profile)} (${o.mockMode?"mock":"real"})`),console.log(` Agents: ${e.white(o.targetAgents)}`),console.log(` Duration: ${e.cyan(o.duration+"ms")}`),console.log(` Bottlenecks: ${o.bottleneckCount>0?e.red(o.bottleneckCount):e.green("none")}`),o.report.hasCritical&&console.log(e.red(" CRITICAL bottlenecks detected!")),console.log(`
|
|
30
30
|
${o.summary}`)}o.passed||await d(1)}else console.log(e.red(`Failed: ${r.error||"Unknown error"}`))}else console.log(e.red(`
|
|
31
31
|
Unknown action: ${m}. Use: generate, execute, schedule, or load
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.
|
|
2
|
-
import{a as B,b as L}from"./chunk-
|
|
1
|
+
import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.10.0");process.exit(0)}
|
|
2
|
+
import{a as B,b as L}from"./chunk-LRISVDVO.js";import{b as R,d as $}from"./chunk-OKGK7DBT.js";import"./chunk-55JPAF56.js";var f=[{id:"unit",name:"Unit Tests",testTypes:["unit"],testPatterns:["**/*.test.ts","**/*.spec.ts","!**/*.integration.*","!**/*.e2e.*"],thresholds:{minPassRate:.99,maxFlakyRatio:.01,minCoverage:.8},parallelism:8,timeoutMs:6e4,failFast:!0},{id:"integration",name:"Integration Tests",testTypes:["integration","contract"],testPatterns:["**/*.integration.test.ts","**/*.integration.spec.ts"],thresholds:{minPassRate:.95,maxFlakyRatio:.05,minCoverage:.7},parallelism:4,timeoutMs:3e5,failFast:!1},{id:"e2e",name:"E2E Tests",testTypes:["e2e","visual"],testPatterns:["**/*.e2e.test.ts","**/*.e2e.spec.ts"],thresholds:{minPassRate:.9,maxFlakyRatio:.1,minCoverage:.5},parallelism:2,timeoutMs:6e5,failFast:!1}];var b=class{constructor(e,t={phases:f,failFast:!0,retryFailedPhases:!1,maxRetries:1}){this.executor=e;this.config=t}executor;config;state="idle";currentPhaseIndex=0;results=[];startTime;endTime;abortController;async run(){if(this.state==="running")throw new Error("Scheduler is already running");this.state="running",this.currentPhaseIndex=0,this.results=[],this.startTime=new Date,this.abortController=new AbortController;try{for(let e of this.config.phases){if(this.state==="paused"&&await this.waitForResume(),this.abortController.signal.aborted)break;let t=await this.executePhaseWithRetry(e);if(this.results.push(t),this.currentPhaseIndex++,this.config.onPhaseComplete?.(t),!t.success&&this.config.failFast){this.state="failed";break}}return this.endTime=new Date,this.state=this.results.every(e=>e.success)?"completed":"failed",this.config.onAllComplete?.(this.results),this.results}catch(e){throw this.state="failed",this.endTime=new Date,e}}async runPhase(e){let t=this.config.phases.find(s=>s.id===e);if(!t)throw new Error(`Phase not found: ${e}`);return this.executePhaseWithRetry(t)}pause(){this.state==="running"&&(this.state="paused")}resume(){this.state==="paused"&&(this.state="running")}async abort(){this.abortController?.abort(),await this.executor.abort(),this.state="idle"}getStats(){let e=this.startTime&&this.endTime?this.endTime.getTime()-this.startTime.getTime():this.startTime?Date.now()-this.startTime.getTime():void 0;return{state:this.state,currentPhaseIndex:this.currentPhaseIndex,totalPhases:this.config.phases.length,completedPhases:this.results.filter(t=>t.success).length,failedPhases:this.results.filter(t=>!t.success).length,results:[...this.results],startTime:this.startTime,endTime:this.endTime,durationMs:e}}async isReady(){return this.executor.isReady()}async executePhaseWithRetry(e){let t,s=this.config.retryFailedPhases?this.config.maxRetries:1;for(let r=1;r<=s;r++)try{if(t=await this.executor.execute(e),t.success||!this.config.retryFailedPhases)return t}catch(a){if(this.config.onError?.(a,e),r===s)return this.createErrorResult(e,a)}return t}createErrorResult(e,t){return{phaseId:e.id,phaseName:e.name,success:!1,passRate:0,flakyRatio:0,coverage:0,durationMs:0,totalTests:0,passed:0,failed:0,skipped:0,testResults:[],flakyTests:[],error:t.message}}waitForResume(){return new Promise(e=>{let t=()=>{this.state!=="paused"?e():setTimeout(t,100)};t()})}};function _(n,e){return new b(n,{phases:f,failFast:!0,retryFailedPhases:!1,maxRetries:1,...e})}function V(n,e){return n.passRate>=e.minPassRate&&n.flakyRatio<=e.maxFlakyRatio&&n.coverage>=e.minCoverage}$();import{spawn as j}from"child_process";var m=class{constructor(e={}){this.config=e}config;currentProcess=null;isAborted=!1;async execute(e,t){this.isAborted=!1;let s=Date.now();try{let r=this.buildArgs(e,t),a=await this.runVitest(r,e.timeoutMs),i=Date.now();return this.parseResult(e,a,i-s)}catch(r){let a=Date.now();return this.createErrorResult(e,r,a-s)}}async isReady(){try{return(await this.runCommand("npx",["vitest","--version"],5e3)).exitCode===0}catch{return!1}}getName(){return"vitest-executor"}async abort(){this.isAborted=!0,this.currentProcess&&(this.currentProcess.kill("SIGTERM"),this.currentProcess=null)}buildArgs(e,t){let s=["vitest","run","--reporter=json"];if(t&&t.length>0)s.push(...t);else for(let r of e.testPatterns)r.startsWith("!")?s.push("--exclude",r.slice(1)):s.push(r);return e.parallelism>0&&(s.push("--pool","threads"),s.push("--poolOptions.threads.maxThreads",String(e.parallelism))),e.failFast&&s.push("--bail","1"),s.push("--coverage"),s.push("--coverage.reporter",this.config.coverageReporter||"json"),this.config.coverageDir&&s.push("--coverage.reportsDirectory",this.config.coverageDir),this.config.extraArgs&&s.push(...this.config.extraArgs),s}async runVitest(e,t){let{stdout:s,exitCode:r}=await this.runCommand(this.config.vitestPath||"npx",e,t);try{let a=s.indexOf("{"),i=s.lastIndexOf("}");if(a===-1||i===-1)throw new Error("No JSON output from Vitest");let o=s.slice(a,i+1);return R(o)}catch{return{numTotalTestSuites:0,numPassedTestSuites:0,numFailedTestSuites:0,numTotalTests:0,numPassedTests:0,numFailedTests:0,numPendingTests:0,success:r===0,startTime:Date.now(),testResults:[]}}}runCommand(e,t,s){return new Promise((r,a)=>{let i="",o="",l=process.platform==="win32"&&e==="npx"?"npx.cmd":e;this.currentProcess=j(l,t,{cwd:this.config.cwd||process.cwd(),env:{...process.env,...this.config.env},shell:!1});let c=setTimeout(()=>{this.currentProcess?.kill("SIGTERM"),a(new Error(`Test execution timed out after ${s}ms`))},s);this.currentProcess.stdout?.on("data",u=>{i+=u.toString()}),this.currentProcess.stderr?.on("data",u=>{o+=u.toString()}),this.currentProcess.on("close",u=>{clearTimeout(c),this.currentProcess=null,this.isAborted?a(new Error("Test execution aborted")):r({stdout:i,stderr:o,exitCode:u??1})}),this.currentProcess.on("error",u=>{clearTimeout(c),this.currentProcess=null,a(u)})})}async parseResult(e,t,s){let r=[];for(let p of t.testResults)for(let h of p.assertionResults){let y={file:p.name,name:h.title,suite:h.ancestorTitles.join(" > "),passed:h.status==="passed",durationMs:h.duration||0,retries:0,error:h.failureMessages.join(`
|
|
3
3
|
`)||void 0};r.push(y)}let a=this.config.flakyTracker;a&&a.recordResults(r);let i=t.numTotalTests,o=t.numPassedTests,l=t.numFailedTests,c=t.numPendingTests,u=i>0?o/i:0,g=[],T=0;if(a){g=a.analyze().flakyTests.map(d=>d.testId);let h=new Set(r.map(d=>`${d.file}:${d.suite}:${d.name}`)),y=g.filter(d=>h.has(d));T=i>0?y.length/i:0}let P=await this.getCoverageFromReport(),w=u>=e.thresholds.minPassRate&&T<=e.thresholds.maxFlakyRatio&&P>=e.thresholds.minCoverage;return{phaseId:e.id,phaseName:e.name,success:w,passRate:u,flakyRatio:T,coverage:P,durationMs:s,totalTests:i,passed:o,failed:l,skipped:c,testResults:r,flakyTests:g}}async getCoverageFromReport(){try{let e=await import("fs/promises"),t=await import("path"),s=this.config.coverageDir||"coverage",r=t.join(this.config.cwd||process.cwd(),s,"coverage-summary.json"),a=await e.readFile(r,"utf-8");return(R(a).total?.lines?.pct??0)/100}catch{return 0}}createErrorResult(e,t,s){return{phaseId:e.id,phaseName:e.name,success:!1,passRate:0,flakyRatio:0,coverage:0,durationMs:s,totalTests:0,passed:0,failed:0,skipped:0,testResults:[],flakyTests:[],error:t.message}}};function z(n){return new m(n)}import{spawn as Q}from"child_process";import{resolve as W,dirname as J,basename as M}from"path";var Y=[{sourcePattern:/^src\/(.+)\.ts$/,toTestPaths:(n,e)=>{let t=n[1];return[`tests/unit/${t}.test.ts`,`tests/unit/${t}.spec.ts`,`tests/${t}.test.ts`,`tests/${t}.spec.ts`,`src/${t}.test.ts`,`src/${t}.spec.ts`]}},{sourcePattern:/^src\/(.+)\/index\.ts$/,toTestPaths:(n,e)=>{let t=n[1];return[`tests/unit/${t}.test.ts`,`tests/unit/${t}/index.test.ts`,`tests/unit/${t}.spec.ts`]}},{sourcePattern:/\.(test|spec)\.(ts|tsx|js|jsx)$/,toTestPaths:(n,e)=>[e]},{sourcePattern:/^(vitest\.config|jest\.config|tsconfig|package\.json)/,toTestPaths:()=>["**/*.test.ts","**/*.spec.ts"]}],v=class{constructor(e){this.config=e;if(!e.impactAnalyzer)throw new Error("GitAwareTestSelector requires impactAnalyzer. Use ImpactAnalyzerService from code-intelligence domain. NO FALLBACK TO PATTERN MATCHING - use real dependency analysis.");this.cwd=e.cwd||process.cwd(),this.baseRef=e.baseRef||"HEAD~1",this.mappingRules=e.mappingRules||Y,this.impactAnalyzer=e.impactAnalyzer}config;cwd;baseRef;mappingRules;impactAnalyzer;async selectAffectedTests(){try{let e=await this.getChangedFiles();if(e.length===0)return{changedFiles:[],selectedTests:[],mappings:[],runAllTests:!1};let{selectedTests:t,mappings:s,runAllTests:r,runAllReason:a}=await this.mapChangesToTests(e);return{changedFiles:e,selectedTests:[...new Set(t)],mappings:s,runAllTests:r,runAllReason:a}}catch(e){return{changedFiles:[],selectedTests:[],mappings:[],runAllTests:!0,runAllReason:`Git error: ${e.message}`}}}async selectTestsForFiles(e){let t=e.map(o=>({path:o,changeType:"modified"})),{selectedTests:s,mappings:r,runAllTests:a,runAllReason:i}=await this.mapChangesToTests(t);return{changedFiles:t,selectedTests:[...new Set(s)],mappings:r,runAllTests:a,runAllReason:i}}async getChangedFiles(){let t=(await this.git(["diff","--name-status",this.baseRef,"HEAD"])).trim().split(`
|
|
4
4
|
`).filter(Boolean),s=[];for(let r of t){let[a,...i]=r.split(" "),o=i.join(" "),l,c;switch(a[0]){case"A":l="added";break;case"M":l="modified";break;case"D":l="deleted";break;case"R":l="renamed",c=o;break;default:l="modified"}s.push({path:l==="renamed"&&i[1]||o,changeType:l,previousPath:c})}return s}async getMergeBase(e="main"){try{return(await this.git(["merge-base","HEAD",e])).trim()}catch{return(await this.git(["merge-base","HEAD","master"])).trim()}}async mapChangesToTests(e){let t=[],s=[],r=!1,a;for(let l of e)if(this.isConfigFile(l.path))return{selectedTests:[],mappings:[],runAllTests:!0,runAllReason:`Config file changed: ${l.path}`};let i=e.filter(l=>l.changeType!=="deleted"||this.config.includeDeletedFileTests).map(l=>l.path);if(i.length===0)return{selectedTests:[],mappings:[],runAllTests:!1};let o=await this.impactAnalyzer.getImpactedTests(i);if(!o.success){let l=o,c=l.error instanceof Error?l.error.message:String(l.error);return{selectedTests:[],mappings:[],runAllTests:!0,runAllReason:`Impact analysis failed: ${c}`}}if(o.value.length===0)return{selectedTests:[],mappings:[],runAllTests:!1};t.push(...o.value);for(let l of e){if(l.changeType==="deleted"&&!this.config.includeDeletedFileTests)continue;let c=o.value.filter(u=>u.includes(M(l.path,".ts").replace(/\.(tsx?|jsx?)$/,"")));c.length>0&&s.push({sourceFile:l.path,testFiles:c,confidence:.95})}return{selectedTests:t,mappings:s,runAllTests:r,runAllReason:a}}isConfigFile(e){return/^(vitest\.config|jest\.config|tsconfig|package\.json)/.test(e)}async findTestsHeuristically(e){let t=M(e,".ts").replace(/\.(tsx?|jsx?)$/,""),s=J(e),r=[`${s}/${t}.test.ts`,`${s}/${t}.spec.ts`,`${s}/__tests__/${t}.test.ts`,`tests/${s}/${t}.test.ts`,`tests/unit/${s.replace("src/","")}/${t}.test.ts`];return this.filterExistingFiles(r)}async filterExistingFiles(e){let t=await import("fs/promises"),s=[];for(let r of e)try{let a=W(this.cwd,r);await t.access(a),s.push(r)}catch(a){console.debug("[TestSelector] File access check failed:",a instanceof Error?a.message:a)}return s}git(e){return new Promise((t,s)=>{let r="",a="",i=Q("git",e,{cwd:this.cwd});i.stdout.on("data",o=>{r+=o.toString()}),i.stderr.on("data",o=>{a+=o.toString()}),i.on("close",o=>{o===0?t(r):s(new Error(`git ${e.join(" ")} failed: ${a}`))}),i.on("error",s)})}};function F(n){return new v(n)}async function q(n,e,t){let r=await F({impactAnalyzer:n,baseRef:e,cwd:t}).selectAffectedTests();return r.runAllTests?[]:r.selectedTests}$();var K={minRunsForFlakiness:5,flakinessThreshold:.1,maxRecentErrors:5,historyRetentionDays:30},A=class{records=new Map;config;constructor(e){this.config={...K,...e}}recordResult(e){let t=this.getTestId(e),s=this.getOrCreateRecord(t,e);s.totalRuns++,s.lastRun=new Date,e.passed?s.passCount++:(s.failCount++,e.error&&(s.recentErrors=[e.error,...s.recentErrors.slice(0,this.config.maxRecentErrors-1)])),e.retries>0&&e.passed&&(s.flakyCount++,s.lastFlaky=new Date),s.flakinessScore=this.calculateFlakiness(s)}recordResults(e){for(let t of e)this.recordResult(t)}getRecord(e){return this.records.get(e)}getFlakyTests(){return Array.from(this.records.values()).filter(e=>e.totalRuns>=this.config.minRunsForFlakiness&&e.flakinessScore>=this.config.flakinessThreshold)}isFlaky(e){let t=this.records.get(e);return t?t.totalRuns>=this.config.minRunsForFlakiness&&t.flakinessScore>=this.config.flakinessThreshold:!1}analyze(){let e=Array.from(this.records.values()),t=e.filter(l=>l.totalRuns>=this.config.minRunsForFlakiness&&l.flakinessScore>=this.config.flakinessThreshold),s=e.filter(l=>l.totalRuns>=this.config.minRunsForFlakiness&&l.flakyCount>0&&l.flakinessScore<this.config.flakinessThreshold),r=e.filter(l=>l.totalRuns<this.config.minRunsForFlakiness),a=e.filter(l=>l.totalRuns>=this.config.minRunsForFlakiness),i=a.length>0?t.length/a.length:0,o=this.calculateTrend(t);return{totalTests:e.length,flakyTests:t.sort((l,c)=>c.flakinessScore-l.flakinessScore),stabilizedTests:s,insufficientData:r,overallFlakiness:i,trend:o}}getQuarantineList(e=.3){return Array.from(this.records.values()).filter(t=>t.flakinessScore>=e).map(t=>t.testId)}pruneHistory(){let e=new Date;e.setDate(e.getDate()-this.config.historyRetentionDays);let t=0;for(let[s,r]of this.records)r.lastRun<e&&(this.records.delete(s),t++);return t}exportHistory(){return Array.from(this.records.values())}importHistory(e){for(let t of e){let s={...t,lastRun:new Date(t.lastRun),lastFlaky:t.lastFlaky?new Date(t.lastFlaky):void 0};this.records.set(t.testId,s)}}reset(){this.records.clear()}getTestId(e){return`${e.file}:${e.suite}:${e.name}`}getOrCreateRecord(e,t){let s=this.records.get(e);return s||(s={testId:e,file:t.file,name:t.name,totalRuns:0,passCount:0,failCount:0,flakyCount:0,flakinessScore:0,lastRun:new Date,recentErrors:[]},this.records.set(e,s)),s}calculateFlakiness(e){if(e.totalRuns<this.config.minRunsForFlakiness)return 0;let t=e.flakyCount/e.totalRuns,s=e.passCount/e.totalRuns,r=s>0&&s<1?Math.min(s,1-s)*2:0;return Math.min(1,t*3+r)}calculateTrend(e){if(e.length===0)return"stable";let s=Date.now()-10080*60*1e3,r=0,a=0;for(let i of e)i.lastFlaky&&(i.lastFlaky.getTime()>s?r++:a++);return r>a*1.5?"degrading":a>r*1.5?"improving":"stable"}};function S(n){return new A(n)}async function D(n,e){let t=S({...e,historyPath:n});try{let r=await(await import("fs/promises")).readFile(n,"utf-8"),a=R(r);t.importHistory(a)}catch(s){console.debug("[FlakyTracker] History load failed, starting fresh:",s instanceof Error?s.message:s)}return t}async function G(n,e){let t=await import("fs/promises"),s=n.exportHistory();await t.writeFile(e,JSON.stringify(s,null,2))}var X={enableAnnotations:!0,enableSummary:!0,enableOutputs:!0,maxAnnotations:10,includeFlakyWarnings:!0,includeCoverage:!0};function H(){let n=process.env;return n.GITHUB_ACTIONS==="true"?{isCI:!0,provider:"github-actions",branch:n.GITHUB_HEAD_REF||n.GITHUB_REF_NAME,commitSha:n.GITHUB_SHA,prNumber:n.GITHUB_EVENT_NAME==="pull_request"&&parseInt(n.GITHUB_REF?.split("/")[2]||"",10)||void 0,baseBranch:n.GITHUB_BASE_REF,buildUrl:`${n.GITHUB_SERVER_URL}/${n.GITHUB_REPOSITORY}/actions/runs/${n.GITHUB_RUN_ID}`}:n.GITLAB_CI==="true"?{isCI:!0,provider:"gitlab-ci",branch:n.CI_COMMIT_REF_NAME,commitSha:n.CI_COMMIT_SHA,prNumber:n.CI_MERGE_REQUEST_IID?parseInt(n.CI_MERGE_REQUEST_IID,10):void 0,baseBranch:n.CI_MERGE_REQUEST_TARGET_BRANCH_NAME,buildUrl:n.CI_JOB_URL}:n.JENKINS_URL?{isCI:!0,provider:"jenkins",branch:n.GIT_BRANCH||n.BRANCH_NAME,commitSha:n.GIT_COMMIT,prNumber:n.CHANGE_ID?parseInt(n.CHANGE_ID,10):void 0,baseBranch:n.CHANGE_TARGET,buildUrl:n.BUILD_URL}:n.CIRCLECI==="true"?{isCI:!0,provider:"circleci",branch:n.CIRCLE_BRANCH,commitSha:n.CIRCLE_SHA1,prNumber:n.CIRCLE_PULL_REQUEST?parseInt(n.CIRCLE_PULL_REQUEST.split("/").pop()||"",10):void 0,buildUrl:n.CIRCLE_BUILD_URL}:n.CI==="true"||n.CI==="1"?{isCI:!0,provider:"unknown"}:{isCI:!1}}var C=class{config;constructor(e){this.config={...X,...e}}generateOutput(e){let t=this.config.enableAnnotations?this.generateAnnotations(e):[],s=this.config.enableSummary?this.generateSummary(e):"",r=this.config.enableOutputs?this.generateOutputs(e):{};return{summary:s,annotations:t,outputs:r}}async writeOutput(e){let t=this.generateOutput(e),s=await import("fs/promises");for(let r of t.annotations)this.writeAnnotation(r);if(t.summary&&process.env.GITHUB_STEP_SUMMARY&&await s.appendFile(process.env.GITHUB_STEP_SUMMARY,t.summary),process.env.GITHUB_OUTPUT){let r=Object.entries(t.outputs).map(([a,i])=>`${a}=${i}`).join(`
|
|
5
5
|
`);await s.appendFile(process.env.GITHUB_OUTPUT,r+`
|
|
@@ -12,4 +12,4 @@ import{a as B,b as L}from"./chunk-EDG4NEET.js";import{b as R,d as $}from"./chunk
|
|
|
12
12
|
`);for(let i of r.slice(0,20))t.push(`#### ${i.suite} > ${i.name}`),t.push(`- **File**: \`${i.file}\``),i.error&&(t.push("```"),t.push(i.error.slice(0,500)),t.push("```")),t.push("");r.length>20&&t.push(`_... and ${r.length-20} more failures_`),t.push(`</details>
|
|
13
13
|
`)}let a=e.flatMap(i=>i.flakyTests);if(a.length>0&&this.config.includeFlakyWarnings){t.push(`### \u26A0\uFE0F Flaky Tests
|
|
14
14
|
`);for(let i of a.slice(0,10))t.push(`- \`${i}\``);t.push("")}return t.join(`
|
|
15
|
-
`)}generateOutputs(e){let t=e.reduce((o,l)=>o+l.totalTests,0),s=e.reduce((o,l)=>o+l.passed,0),r=e.reduce((o,l)=>o+l.failed,0),a=e.every(o=>o.success),i=e.length>0?e.reduce((o,l)=>o+l.coverage,0)/e.length:0;return{test_result:a?"success":"failure",total_tests:String(t),passed_tests:String(s),failed_tests:String(r),coverage_percent:String((i*100).toFixed(1)),phases_completed:String(e.length),phases_passed:String(e.filter(o=>o.success).length),has_flaky_tests:String(e.some(o=>o.flakyTests.length>0))}}writeAnnotation(e){let t=[`file=${e.file}`,`line=${e.line}`,`title=${e.title}`].join(",");console.log(`::${e.level} ${t}::${e.message}`)}extractLineNumber(e){if(!e)return;let t=e.match(/:(\d+):\d+/);return t?parseInt(t[1],10):void 0}formatDuration(e){return e<1e3?`${e}ms`:e<6e4?`${(e/1e3).toFixed(1)}s`:`${(e/6e4).toFixed(1)}m`}generateCoverageBar(e){let t=Math.round(e*10),s=10-t;return"\u2588".repeat(t)+"\u2591".repeat(s)}};function x(n){return new C(n)}async function Z(n,e){await x(e).writeOutput(n)}var E=class n{constructor(e,t,s,r,a,i){this.config=e;this.selector=t,this.executor=s,this.scheduler=r,this.flakyTracker=a,this.reporter=i,this.ciEnvironment=H()}config;selector;executor;scheduler;flakyTracker;reporter;ciEnvironment;static async create(e){let t=e.flakyHistoryPath?await D(e.flakyHistoryPath,e.flakyTracker):S(e.flakyTracker),s=new m({...e.vitest,cwd:e.cwd,flakyTracker:t}),{ImpactAnalyzerService:r}=await import("./impact-analyzer-
|
|
15
|
+
`)}generateOutputs(e){let t=e.reduce((o,l)=>o+l.totalTests,0),s=e.reduce((o,l)=>o+l.passed,0),r=e.reduce((o,l)=>o+l.failed,0),a=e.every(o=>o.success),i=e.length>0?e.reduce((o,l)=>o+l.coverage,0)/e.length:0;return{test_result:a?"success":"failure",total_tests:String(t),passed_tests:String(s),failed_tests:String(r),coverage_percent:String((i*100).toFixed(1)),phases_completed:String(e.length),phases_passed:String(e.filter(o=>o.success).length),has_flaky_tests:String(e.some(o=>o.flakyTests.length>0))}}writeAnnotation(e){let t=[`file=${e.file}`,`line=${e.line}`,`title=${e.title}`].join(",");console.log(`::${e.level} ${t}::${e.message}`)}extractLineNumber(e){if(!e)return;let t=e.match(/:(\d+):\d+/);return t?parseInt(t[1],10):void 0}formatDuration(e){return e<1e3?`${e}ms`:e<6e4?`${(e/1e3).toFixed(1)}s`:`${(e/6e4).toFixed(1)}m`}generateCoverageBar(e){let t=Math.round(e*10),s=10-t;return"\u2588".repeat(t)+"\u2591".repeat(s)}};function x(n){return new C(n)}async function Z(n,e){await x(e).writeOutput(n)}var E=class n{constructor(e,t,s,r,a,i){this.config=e;this.selector=t,this.executor=s,this.scheduler=r,this.flakyTracker=a,this.reporter=i,this.ciEnvironment=H()}config;selector;executor;scheduler;flakyTracker;reporter;ciEnvironment;static async create(e){let t=e.flakyHistoryPath?await D(e.flakyHistoryPath,e.flakyTracker):S(e.flakyTracker),s=new m({...e.vitest,cwd:e.cwd,flakyTracker:t}),{ImpactAnalyzerService:r}=await import("./impact-analyzer-NMTN75KA.js"),a=new r(e.memory),i=F({cwd:e.cwd,baseRef:e.baseRef,impactAnalyzer:a}),o=_(s,{...e.scheduler,phases:e.phases&&e.phases.length>0?e.phases:f}),l=x(e.reporter);return new n(e,i,s,o,t,l)}async run(){let e=Date.now(),t=[],s=this.config.runAllTests??!1,r=performance.now();if(!s){let p=await this.selector.selectAffectedTests();p.runAllTests?(s=!0,console.log(`[TestSchedulingPipeline] Running all tests: ${p.runAllReason}`)):p.selectedTests.length===0?(console.log("[TestSchedulingPipeline] No affected tests found, running all"),s=!0):(t=p.selectedTests,console.log(`[TestSchedulingPipeline] Selected ${t.length} affected tests`))}let a=performance.now()-r;if(this.config.useDAGAttention&&t.length>0)try{let{isDAGAttentionEnabled:p}=await import("./feature-flags-INJJZBMN.js");if(p()){let{createDAGAttentionScheduler:h}=await import("./dag-attention-scheduler-GOZAVAZQ.js"),y=h(),d=t.map(k=>({id:k,name:k,estimatedDuration:1e3,dependencies:[],priority:1,tags:[]})),N=y.schedule(d),I=[];for(let k of N.phases)I.push(...k.tests.map(O=>O.id));I.length>0&&(t=I)}}catch(p){process.env.DEBUG&&console.debug("[Pipeline] DAG attention scheduling skipped:",p instanceof Error?p.message:p)}let i=performance.now(),o;s?o=await this.scheduler.run():o=await this.runWithSelectedTests(t);let l=performance.now()-i,c=performance.now(),u=this.flakyTracker.analyze();this.config.flakyHistoryPath&&await G(this.flakyTracker,this.config.flakyHistoryPath);let g=performance.now()-c,T=performance.now();this.ciEnvironment.isCI&&await this.reporter.writeOutput(o);let P=performance.now()-T,w=Date.now()-e;return{phaseResults:o,selectedTests:t,ranAllTests:s,flakyAnalysis:u,ciEnvironment:this.ciEnvironment,totalDurationMs:w,stepLatencies:{selectionMs:a,executionMs:l,analysisMs:g,reportingMs:P}}}async runPhase(e){return this.scheduler.runPhase(e)}getFlakyTracker(){return this.flakyTracker}getSelector(){return this.selector}getStats(){return this.scheduler.getStats()}async abort(){await this.scheduler.abort()}async runWithSelectedTests(e){let t=[],s=this.config.phases??[];for(let r of s){let a=e.filter(i=>r.testPatterns.some(o=>o.startsWith("!")?!1:this.patternToRegex(o).test(i)));if(a.length>0){let i=await this.executor.execute(r,a);t.push(i)}}return t}patternToRegex(e){let t=e.replace(/[.+^${}()|[\]\\]/g,"\\$&").replace(/\*\*/g,".*").replace(/\*/g,"[^/]*");return new RegExp(t)}};async function U(n){return E.create(n)}async function ee(n){return(await U(n)).run()}export{B as DAGAttentionScheduler,f as DEFAULT_TEST_PHASES,A as FlakyTestTracker,v as GitAwareTestSelector,C as GitHubActionsReporter,b as PhaseScheduler,E as TestSchedulingPipeline,m as VitestPhaseExecutor,V as checkQualityThresholds,L as createDAGAttentionScheduler,S as createFlakyTracker,x as createGitHubActionsReporter,_ as createPhaseScheduler,U as createTestPipeline,F as createTestSelector,z as createVitestExecutor,H as detectCIEnvironment,q as getAffectedTests,D as loadFlakyTracker,Z as reportToGitHubActions,ee as runTestPipeline,G as saveFlakyTracker};
|