agentic-qe 3.9.31 → 3.9.32
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 +88 -0
- package/assets/skills/skills-manifest.json +1 -1
- package/dist/cli/bundle.js +5 -5
- package/dist/cli/chunks/adapter-CDQOF5TF.js +2 -0
- package/dist/cli/chunks/{agent-booster-wasm-AQXZYWZY.js → agent-booster-wasm-WKS3E6KT.js} +2 -2
- package/dist/cli/chunks/{agent-handler-7N4ZPXCY.js → agent-handler-LYCAWE7S.js} +2 -2
- package/dist/cli/chunks/{agent-memory-branch-FLKF2JVX.js → agent-memory-branch-XF7IOMRK.js} +2 -2
- package/dist/cli/chunks/aqe-learning-engine-RZK22CJB.js +2 -0
- package/dist/cli/chunks/{audit-B4V4IKTA.js → audit-D2AY3HFP.js} +2 -2
- package/dist/cli/chunks/base-UGH6TVO4.js +2 -0
- package/dist/cli/chunks/{hnswlib-node-WENGW3YX.js → better-sqlite3-K2VWFDKT.js} +2 -2
- package/dist/cli/chunks/{brain-handler-OOXJ2KYY.js → brain-handler-NNW4TAO2.js} +3 -3
- package/dist/cli/chunks/{branch-enumerator-LFKFW3A4.js → branch-enumerator-OM5HNZKV.js} +2 -2
- package/dist/cli/chunks/{browser-F72IES2I.js → browser-Y2FU2NV4.js} +2 -2
- package/dist/cli/chunks/browser-workflow-SGOL3FCJ.js +2 -0
- package/dist/cli/chunks/{chunk-35SFAIXE.js → chunk-2L5GAOST.js} +2 -2
- package/dist/cli/chunks/{chunk-MAJ5QFVY.js → chunk-2XC4XVCI.js} +1 -1
- package/dist/cli/chunks/{chunk-QEJBJST4.js → chunk-2Z2IQBIJ.js} +1 -1
- package/dist/cli/chunks/{chunk-AKFRM4IO.js → chunk-33PGBYTC.js} +2 -2
- package/dist/cli/chunks/{chunk-W7XVEWKQ.js → chunk-3MHWBCSC.js} +1 -1
- package/dist/cli/chunks/{chunk-NBKM7NKX.js → chunk-3R4CMTWF.js} +2 -2
- package/dist/cli/chunks/{chunk-4N736EES.js → chunk-45N22VAB.js} +2 -2
- package/dist/cli/chunks/{chunk-3VKB4HVT.js → chunk-4H4PEZUX.js} +2 -2
- package/dist/cli/chunks/{chunk-CFLA2GBS.js → chunk-4VAZSCTZ.js} +2 -2
- package/dist/cli/chunks/{chunk-JF3U456G.js → chunk-5A6LBGRU.js} +2 -2
- package/dist/cli/chunks/{chunk-TYUIQSSF.js → chunk-5DSANX6S.js} +2 -2
- package/dist/cli/chunks/chunk-5R5WOLZM.js +5 -0
- package/dist/cli/chunks/{chunk-K6MFAVXK.js → chunk-5WR42V5O.js} +2 -2
- package/dist/cli/chunks/{chunk-PUSZ4NBY.js → chunk-5XY6SULI.js} +2 -2
- package/dist/cli/chunks/{chunk-VOOJDHLI.js → chunk-62UXGD5J.js} +3 -3
- package/dist/cli/chunks/{chunk-REJEFTWX.js → chunk-667I4RTC.js} +1 -1
- package/dist/cli/chunks/{chunk-KXRDQQGN.js → chunk-6EKXBWJD.js} +2 -2
- package/dist/cli/chunks/{chunk-CNKOIHF6.js → chunk-6R6QCGNU.js} +2 -2
- package/dist/cli/chunks/{chunk-YEZJE2ZW.js → chunk-6SYP7QX6.js} +4 -4
- package/dist/cli/chunks/{chunk-TLCCM2AF.js → chunk-6YGFAJ3X.js} +1 -1
- package/dist/cli/chunks/{chunk-KJAIE7SL.js → chunk-6ZG6TBWF.js} +4 -4
- package/dist/cli/chunks/{chunk-NLUBN642.js → chunk-7AISRWBS.js} +2 -2
- package/dist/cli/chunks/{chunk-LF5RO6WO.js → chunk-7IDPVSTF.js} +1 -1
- package/dist/cli/chunks/{chunk-VUL5HIKR.js → chunk-7PTW3M67.js} +2 -2
- package/dist/cli/chunks/{chunk-QGLWFZVQ.js → chunk-A4UNK5SY.js} +2 -2
- package/dist/cli/chunks/{chunk-JRIDPOEZ.js → chunk-A6VI5BZU.js} +4 -4
- package/dist/cli/chunks/{chunk-7OVVBBOZ.js → chunk-BBPOTFIY.js} +2 -2
- package/dist/cli/chunks/{chunk-AKJWBJDK.js → chunk-BDXEL3GM.js} +2 -2
- package/dist/cli/chunks/{chunk-GJSH4UZ3.js → chunk-BGRC4676.js} +3 -3
- package/dist/cli/chunks/{chunk-PSF6YQQM.js → chunk-BQML7B4W.js} +3 -3
- package/dist/cli/chunks/{chunk-VAIOZDG5.js → chunk-BV3SGEV7.js} +1 -1
- package/dist/cli/chunks/{chunk-XNJ6DIEW.js → chunk-DBE2LIYG.js} +2 -2
- package/dist/cli/chunks/{chunk-AQN6PDHI.js → chunk-DFY7F4TE.js} +1 -1
- package/dist/cli/chunks/{chunk-IRRGUXAU.js → chunk-EFEJLZDN.js} +1 -1
- package/dist/cli/chunks/{chunk-5G2L4XRU.js → chunk-ESNBKAT6.js} +2 -2
- package/dist/cli/chunks/{chunk-7UHRT5AX.js → chunk-EVSUZKD5.js} +2 -2
- package/dist/cli/chunks/{chunk-FUHPLXJX.js → chunk-FFBF5BLQ.js} +1 -1
- package/dist/cli/chunks/{chunk-N6P7ENG7.js → chunk-FIONYUVH.js} +2 -2
- package/dist/cli/chunks/{chunk-TJGIIGKL.js → chunk-FNQCWEVJ.js} +2 -2
- package/dist/cli/chunks/{chunk-NTVJKQ5S.js → chunk-FV2MU6CY.js} +2 -2
- package/dist/cli/chunks/{chunk-M6RVKGIP.js → chunk-FWEYOD3S.js} +2 -2
- package/dist/cli/chunks/{chunk-EAIPJSKH.js → chunk-G6AJMFWL.js} +3 -3
- package/dist/cli/chunks/{chunk-L7DNPOAQ.js → chunk-G6VVOUUF.js} +2 -2
- package/dist/cli/chunks/{chunk-BYHUGO73.js → chunk-G77CYF7H.js} +3 -3
- package/dist/cli/chunks/{chunk-EJXRBAQF.js → chunk-H7YKTJMY.js} +2 -2
- package/dist/cli/chunks/{chunk-CUSLB7MB.js → chunk-HGWQC7PR.js} +2 -2
- package/dist/cli/chunks/{chunk-XE4YKDIM.js → chunk-HHBFI3YA.js} +2 -2
- package/dist/cli/chunks/{chunk-PTOTOBOU.js → chunk-HPQZSXED.js} +1 -1
- package/dist/cli/chunks/{chunk-YN7HCVUP.js → chunk-HR6NX6DW.js} +2 -2
- package/dist/cli/chunks/{chunk-QITO7E7Y.js → chunk-I6Q6BPVH.js} +1 -1
- package/dist/cli/chunks/{chunk-L63KB63A.js → chunk-IGEZVFOM.js} +2 -2
- package/dist/cli/chunks/{chunk-ENCFLC44.js → chunk-IGQPGXP7.js} +2 -2
- package/dist/cli/chunks/{chunk-YMN4C32S.js → chunk-IJQJV7BC.js} +3 -3
- package/dist/cli/chunks/chunk-JDW6GN3A.js +2 -0
- package/dist/cli/chunks/{chunk-LRWRFKQH.js → chunk-JRYNHFZA.js} +1 -1
- package/dist/cli/chunks/{chunk-7V7TP242.js → chunk-KHZRNJ3A.js} +1 -1
- package/dist/cli/chunks/{chunk-PYYNY7RJ.js → chunk-LHDTXTS7.js} +1 -1
- package/dist/cli/chunks/{chunk-ONMJJ2C3.js → chunk-LI2IOJMM.js} +1 -1
- package/dist/cli/chunks/{heartbeat-scheduler-OH3SS7MH.js → chunk-LR5VW3OS.js} +2 -2
- package/dist/cli/chunks/{chunk-XY3WUGD3.js → chunk-LTSNDM5N.js} +2 -2
- package/dist/cli/chunks/{chunk-CQWZNVIM.js → chunk-M5PYPGBC.js} +2 -2
- package/dist/cli/chunks/{chunk-RTGNWRQI.js → chunk-MEHNT37H.js} +2 -2
- package/dist/cli/chunks/{chunk-ZG4EKPGV.js → chunk-MERMCKPG.js} +1 -1
- package/dist/cli/chunks/{chunk-JKKV5KKS.js → chunk-MIHQIAVK.js} +2 -2
- package/dist/cli/chunks/{chunk-RDJWUKIR.js → chunk-MMVSERJQ.js} +2 -2
- package/dist/cli/chunks/{chunk-5WWQLPB4.js → chunk-MQQANXFS.js} +2 -2
- package/dist/cli/chunks/{chunk-I3TFGMOQ.js → chunk-MTOHV22P.js} +1 -1
- package/dist/cli/chunks/{chunk-7RPEBKQZ.js → chunk-NVZHCAEB.js} +2 -2
- package/dist/cli/chunks/{chunk-52D3CYE5.js → chunk-NW5FYGDE.js} +2 -2
- package/dist/cli/chunks/{chunk-UIRTXM7C.js → chunk-NZRJWK5H.js} +61 -121
- package/dist/cli/chunks/chunk-O5NEZCTB.js +2 -0
- package/dist/cli/chunks/{chunk-YQJBE6NX.js → chunk-O5UGJ3OI.js} +2 -2
- package/dist/cli/chunks/{chunk-WB6TI6Q3.js → chunk-OK2TFTXP.js} +2 -2
- package/dist/cli/chunks/{chunk-NNF3GCGF.js → chunk-OKEHGXIS.js} +2 -2
- package/dist/cli/chunks/{chunk-5AMAJCZS.js → chunk-OKRY4LNE.js} +3 -3
- package/dist/cli/chunks/{chunk-NZQYNUGM.js → chunk-OMOGD2NN.js} +2 -2
- package/dist/cli/chunks/{chunk-X2FLWV5C.js → chunk-ONNTJXU7.js} +2 -2
- package/dist/cli/chunks/{chunk-MYCVU3D3.js → chunk-OPOGZAN5.js} +2 -2
- package/dist/cli/chunks/{chunk-ZBJRNCWX.js → chunk-PG5F2VHA.js} +2 -2
- package/dist/cli/chunks/{chunk-JMLOEW7Y.js → chunk-PHRMWRXA.js} +2 -2
- package/dist/cli/chunks/{chunk-N6SIKSCO.js → chunk-PIXUX2NR.js} +2 -2
- package/dist/cli/chunks/{chunk-IY4P35N3.js → chunk-PLGMPG7S.js} +2 -2
- package/dist/cli/chunks/{chunk-K37CNLQZ.js → chunk-PPS6VN24.js} +1 -1
- package/dist/cli/chunks/{chunk-XMMWYQJK.js → chunk-PQAYCK2U.js} +2 -2
- package/dist/cli/chunks/{chunk-SL4TAJOE.js → chunk-PS6ISBED.js} +2 -2
- package/dist/cli/chunks/{chunk-OXOXNAEZ.js → chunk-QPYNQSWD.js} +2 -2
- package/dist/cli/chunks/{chunk-62KYX5NH.js → chunk-QRTZ67BC.js} +2 -2
- package/dist/cli/chunks/{chunk-DUF733Z7.js → chunk-REW3W3ZW.js} +1 -1
- package/dist/cli/chunks/{chunk-T4DDCMKG.js → chunk-RHXYZ6AZ.js} +127 -127
- package/dist/cli/chunks/{chunk-VLAGWLHF.js → chunk-RZXAXWBD.js} +2 -2
- package/dist/cli/chunks/{chunk-XTWYCMAM.js → chunk-S4M7U6CZ.js} +2 -2
- package/dist/cli/chunks/{chunk-ROEIR3OD.js → chunk-SJETAUZA.js} +1 -1
- package/dist/cli/chunks/{chunk-47QIAHUJ.js → chunk-SLH7LFVY.js} +2 -2
- package/dist/cli/chunks/{chunk-XGBIXRKD.js → chunk-SRJ5N7LD.js} +2 -2
- package/dist/cli/chunks/{chunk-EKYPQ5DX.js → chunk-T5ADVYPH.js} +1 -1
- package/dist/cli/chunks/{chunk-7MXQV7RB.js → chunk-THYGFSTA.js} +2 -2
- package/dist/cli/chunks/{chunk-462MZLJB.js → chunk-TX2DBLTL.js} +1 -1
- package/dist/cli/chunks/{chunk-TVHWI77X.js → chunk-UJMGNO6L.js} +1 -1
- package/dist/cli/chunks/{chunk-YLEMSN46.js → chunk-UUQ3SOKM.js} +1 -1
- package/dist/cli/chunks/{chunk-ZWSRIJ2T.js → chunk-V5RLGPEW.js} +2 -2
- package/dist/cli/chunks/{chunk-CYUGE5ZQ.js → chunk-V6HM2BKJ.js} +1 -1
- package/dist/cli/chunks/{chunk-UIIEZMSM.js → chunk-V7I6FTLG.js} +1 -1
- package/dist/cli/chunks/{chunk-5M4F3PAL.js → chunk-V7ZBPSVG.js} +1 -1
- package/dist/cli/chunks/{chunk-VSKABN3B.js → chunk-VJL7DNUU.js} +2 -2
- package/dist/cli/chunks/{chunk-2NLZXG6V.js → chunk-VKCWWR6C.js} +1 -1
- package/dist/cli/chunks/chunk-VKNCMGOJ.js +29 -0
- package/dist/cli/chunks/{chunk-L4JTTPU7.js → chunk-W2VTHUDK.js} +2 -2
- package/dist/cli/chunks/{chunk-FOAWHNOP.js → chunk-W3JB3G7C.js} +2 -2
- package/dist/cli/chunks/{chunk-A424Z7LA.js → chunk-WQ4MT74X.js} +1 -1
- package/dist/cli/chunks/{chunk-GQFAVT2I.js → chunk-WTNM7NA4.js} +1 -1
- package/dist/cli/chunks/chunk-XB3SIYGU.js +62 -0
- package/dist/cli/chunks/{chunk-HHEIQHLQ.js → chunk-XCUNQ3FK.js} +2 -2
- package/dist/cli/chunks/{chunk-BMS7WFDB.js → chunk-XHQFVTFD.js} +1 -1
- package/dist/cli/chunks/{chunk-QMSDKKYG.js → chunk-YBUUAFKR.js} +1 -1
- package/dist/cli/chunks/{chunk-G2U7Q6V6.js → chunk-YJV6TTCW.js} +2 -2
- package/dist/cli/chunks/{chunk-GN7FUCJH.js → chunk-YUSGT2CU.js} +1 -1
- package/dist/cli/chunks/{chunk-JJRZOLDY.js → chunk-YUTSN5BK.js} +2 -2
- package/dist/cli/chunks/{chunk-G3YKCZWQ.js → chunk-YVMJTBXB.js} +3 -3
- package/dist/cli/chunks/chunk-YVQ4PR4H.js +2 -0
- package/dist/cli/chunks/{chunk-UNXUSYRL.js → chunk-Z2EDNMCQ.js} +2 -2
- package/dist/cli/chunks/{chunk-DMF4Z2M6.js → chunk-ZESMMAKZ.js} +2 -2
- package/dist/cli/chunks/{chunk-VA45HLBF.js → chunk-ZIVOT3B7.js} +2 -2
- package/dist/cli/chunks/{ci-LRTJSZHT.js → ci-NSF6OHB4.js} +2 -2
- package/dist/cli/chunks/{ci-output-LISCHUKD.js → ci-output-ZPDJ42U3.js} +2 -2
- package/dist/cli/chunks/{circuit-breaker-7PMP25KZ.js → circuit-breaker-Y2RUJDYG.js} +2 -2
- package/dist/cli/chunks/{claude-flow-setup-DOW4QVMC.js → claude-flow-setup-OH6G6KM2.js} +2 -2
- package/dist/cli/chunks/client-QQGRKAY7.js +2 -0
- package/dist/cli/chunks/{cline-installer-2NXQGW73.js → cline-installer-IHH4F27G.js} +2 -2
- package/dist/cli/chunks/{code-3X6RWAS7.js → code-SFAHWFTX.js} +2 -2
- package/dist/cli/chunks/{code-index-extractor-4ABP5WCP.js → code-index-extractor-GXECMOM2.js} +2 -2
- package/dist/cli/chunks/{codex-installer-V7PII6GL.js → codex-installer-UPMSAFCQ.js} +2 -2
- package/dist/cli/chunks/{completions-Y7LNQ63I.js → completions-5TX6LDHY.js} +2 -2
- package/dist/cli/chunks/{complexity-analyzer-XLYMAM6I.js → complexity-analyzer-J2ZR3XZB.js} +2 -2
- package/dist/cli/chunks/{continuedev-installer-GOT4TKNT.js → continuedev-installer-GWYZKB5A.js} +2 -2
- package/dist/cli/chunks/{copilot-installer-D6BAQVIO.js → copilot-installer-DQZMQWI7.js} +2 -2
- package/dist/cli/chunks/{cost-tracker-VT7C5Q52.js → cost-tracker-V7KIGCLZ.js} +2 -2
- package/dist/cli/chunks/{coverage-C62MRP4M.js → coverage-3X6LA2GZ.js} +3 -3
- package/dist/cli/chunks/cross-domain-router-3SHAGRVP.js +2 -0
- package/dist/cli/chunks/{cursor-installer-WAWSS2K2.js → cursor-installer-ENDG4JIU.js} +2 -2
- package/dist/cli/chunks/daemon-4XVAO7GT.js +16 -0
- package/dist/cli/chunks/daemon-TC65CQFK.js +10 -0
- package/dist/cli/chunks/{dag-attention-scheduler-SZIZWPV7.js → dag-attention-scheduler-JOSCDRZC.js} +2 -2
- package/dist/cli/chunks/{detect-AJX6NJEP.js → detect-KWZX3OMK.js} +2 -2
- package/dist/cli/chunks/{dist-node-E5X47QTY.js → dist-node-R4U2PJ47.js} +2 -2
- package/dist/cli/chunks/{domain-handler-FN3PIP45.js → domain-handler-BMYYZO2L.js} +2 -2
- package/dist/cli/chunks/{domain-transfer-N3TOJEMT.js → domain-transfer-MSDBBDLC.js} +2 -2
- package/dist/cli/chunks/dream-OCZK42FM.js +2 -0
- package/dist/cli/chunks/{embed-and-insert-pattern-PJI5TZKR.js → embed-and-insert-pattern-MFINPOLS.js} +2 -2
- package/dist/cli/chunks/{eval-OS54TDQU.js → eval-OER6UNUY.js} +2 -2
- package/dist/cli/chunks/{experience-capture-middleware-FBM4ANZW.js → experience-capture-middleware-F5I77ECG.js} +3 -3
- package/dist/cli/chunks/{fast-paths-2CVAAPQO.js → fast-paths-P3KT5DUQ.js} +2 -2
- package/dist/cli/chunks/{feature-flags-A5KFWVFC.js → feature-flags-5EBWQ5WU.js} +2 -2
- package/dist/cli/chunks/{feature-flags-GEXTW6OT.js → feature-flags-DYFZSQLV.js} +2 -2
- package/dist/cli/chunks/{file-discovery-KWLVC7KN.js → file-discovery-MOBVABSM.js} +2 -2
- package/dist/cli/chunks/{fleet-MNKH356S.js → fleet-J3R3NQNC.js} +3 -3
- package/dist/cli/chunks/{gnn-wrapper-ALTWYFVZ.js → gnn-wrapper-QD76SULF.js} +2 -2
- package/dist/cli/chunks/{heartbeat-handler-MBMEPEGW.js → heartbeat-handler-AJEWTPZ4.js} +4 -4
- package/dist/cli/chunks/heartbeat-scheduler-EAVZR6TJ.js +2 -0
- package/dist/cli/chunks/hnsw-adapter-BY4XB7FB.js +2 -0
- package/dist/cli/chunks/hnsw-index-657CZRG7.js +2 -0
- package/dist/cli/chunks/{hnsw-legacy-bridge-WTD5PR5V.js → hnsw-legacy-bridge-5VRM5N7K.js} +2 -2
- package/dist/cli/chunks/{better-sqlite3-NYOVLWBG.js → hnswlib-node-BWUH4OQT.js} +2 -2
- package/dist/cli/chunks/{hooks-ELHGEBFK.js → hooks-7PMVKQOE.js} +10 -10
- package/dist/cli/chunks/{hybrid-router-D6ZMIZCE.js → hybrid-router-2K2LW45J.js} +2 -2
- package/dist/cli/chunks/{hypergraph-engine-JOQ6TERZ.js → hypergraph-engine-2CQ735JO.js} +2 -2
- package/dist/cli/chunks/{hypergraph-handler-HX45YWWN.js → hypergraph-handler-AQ53GVIW.js} +3 -3
- package/dist/cli/chunks/impact-analyzer-GI6UVAMT.js +2 -0
- package/dist/cli/chunks/{init-handler-TNVU6NQ6.js → init-handler-ZOVJPAWO.js} +6 -6
- package/dist/cli/chunks/init-wizard-HOH577MH.js +2 -0
- package/dist/cli/chunks/kernel-JDYBG5GE.js +2 -0
- package/dist/cli/chunks/{kilocode-installer-YC5RJIY4.js → kilocode-installer-GWQCNLKI.js} +2 -2
- package/dist/cli/chunks/{kiro-installer-EAB26M55.js → kiro-installer-6KVES4MO.js} +2 -2
- package/dist/cli/chunks/knowledge-graph-RAQOWLG3.js +2 -0
- package/dist/cli/chunks/{learning-A2OB7D2B.js → learning-6XMNWXRT.js} +3 -3
- package/dist/cli/chunks/{llm-router-KEG6PA7C.js → llm-router-GS4AZJJC.js} +4 -4
- package/dist/cli/chunks/{load-D6ZDLVA3.js → load-FEMEQNE6.js} +2 -2
- package/dist/cli/chunks/load-test-3MEJ43U2.js +2 -0
- package/dist/cli/chunks/{mcp-ERJHZ6FN.js → mcp-6V2H7EXU.js} +2 -2
- package/dist/cli/chunks/{memory-GSRIJIVR.js → memory-YLGPOB2H.js} +5 -5
- package/dist/cli/chunks/memory-backend-2A47ZRGO.js +2 -0
- package/dist/cli/chunks/memory-handlers-UBTBC7D2.js +2 -0
- package/dist/cli/chunks/{multi-model-executor-GK3V7ERC.js → multi-model-executor-SL2EKAH2.js} +2 -2
- package/dist/cli/chunks/{opencode-installer-6TTN26RG.js → opencode-installer-ADOJVGNA.js} +2 -2
- package/dist/cli/chunks/{orchestrator-YVTSM6QW.js → orchestrator-O4IWW2VU.js} +5 -5
- package/dist/cli/chunks/{pipeline-EWLJCY5G.js → pipeline-5BD5YQNQ.js} +2 -2
- package/dist/cli/chunks/{platform-2ULHQQME.js → platform-HXSUOOJH.js} +2 -2
- package/dist/cli/chunks/{plugin-PYN2KOXA.js → plugin-HOLH5CUH.js} +2 -2
- package/dist/cli/chunks/{prime-radiant-advanced-wasm-IULCTOGZ.js → prime-radiant-advanced-wasm-PJTL7OLS.js} +2 -2
- package/dist/cli/chunks/protocol-executor-3FR7FBVM.js +2 -0
- package/dist/cli/chunks/{protocol-handler-FZYI2SBP.js → protocol-handler-K27YGLC7.js} +2 -2
- package/dist/cli/chunks/{prove-DN7S74SP.js → prove-MHCLHQQ6.js} +2 -2
- package/dist/cli/chunks/{provider-manager-FT3MCROB.js → provider-manager-3645PPXX.js} +2 -2
- package/dist/cli/chunks/qe-reasoning-bank-CHNYPYQW.js +2 -0
- package/dist/cli/chunks/{quality-ITBU6LGC.js → quality-NDE6EDOY.js} +2 -2
- package/dist/cli/chunks/queen-coordinator-J6ZRYTBX.js +2 -0
- package/dist/cli/chunks/{real-embeddings-PZUZ5RXJ.js → real-embeddings-VD3EVV3U.js} +2 -2
- package/dist/cli/chunks/{roocode-installer-2LMVZOUZ.js → roocode-installer-63Y45UUG.js} +2 -2
- package/dist/cli/chunks/router-23HRN2Z6.js +2 -0
- package/dist/cli/chunks/routing-feedback-R6A4B6ZG.js +2 -0
- package/dist/cli/chunks/{routing-handler-5RB73UCF.js → routing-handler-76XISU2E.js} +2 -2
- package/dist/cli/chunks/{ruvector-commands-VBN4APMG.js → ruvector-commands-AEKOZZHZ.js} +2 -2
- package/dist/cli/chunks/{rvf-dual-writer-BNY4AUWT.js → rvf-dual-writer-4DMUIZQF.js} +2 -2
- package/dist/cli/chunks/{rvf-migration-adapter-73MKPBGV.js → rvf-migration-adapter-YUTXFOZ3.js} +2 -2
- package/dist/cli/chunks/{rvf-migration-coordinator-SGVB7ZAZ.js → rvf-migration-coordinator-XJ5N2W37.js} +2 -2
- package/dist/cli/chunks/rvf-native-adapter-QINEJZM7.js +2 -0
- package/dist/cli/chunks/safe-db-YXMCSKFH.js +2 -0
- package/dist/cli/chunks/schedule-XVFD27P5.js +2 -0
- package/dist/cli/chunks/scheduler-NWH2IDEU.js +2 -0
- package/dist/cli/chunks/{security-XUH4H7R3.js → security-6YS6GQGO.js} +3 -3
- package/dist/cli/chunks/shared-rvf-adapter-FTZY35WI.js +2 -0
- package/dist/cli/chunks/{shared-rvf-dual-writer-GML4EDYF.js → shared-rvf-dual-writer-MH2Y65HA.js} +2 -2
- package/dist/cli/chunks/sqlite-persistence-BR6YJF5P.js +2 -0
- package/dist/cli/chunks/{status-handler-XI7GJF6Z.js → status-handler-57JQMPY5.js} +2 -2
- package/dist/cli/chunks/{structural-health-WPCYKOXV.js → structural-health-34D5VWRD.js} +2 -2
- package/dist/cli/chunks/sync-HJD2US5P.js +2 -0
- package/dist/cli/chunks/sync-TTQ6ZB5D.js +17 -0
- package/dist/cli/chunks/{task-handler-FZB55IEG.js → task-handler-4RF57637.js} +2 -2
- package/dist/cli/chunks/{task-handlers-EXZGFH7F.js → task-handlers-BRSK7HDE.js} +3 -3
- package/dist/cli/chunks/{test-XYRN4OVU.js → test-GMUW2VR3.js} +4 -4
- package/dist/cli/chunks/{test-scheduling-FLVOPGOT.js → test-scheduling-7LF24IFV.js} +3 -3
- package/dist/cli/chunks/{token-bootstrap-FDCFVRHM.js → token-bootstrap-VYT4RTHU.js} +2 -2
- package/dist/cli/chunks/{token-usage-MHNZF3DM.js → token-usage-NFNCPQGW.js} +2 -2
- package/dist/cli/chunks/{transformers-4CRVTMWY.js → transformers-GGD5GIEY.js} +2 -2
- package/dist/cli/chunks/{tree-sitter-wasm-parser-CI3V4AND.js → tree-sitter-wasm-parser-GKYG6NKT.js} +2 -2
- package/dist/cli/chunks/{types-RKCD4BNL.js → types-WJ3ZTRD5.js} +2 -2
- package/dist/cli/chunks/unified-memory-AT3Z4CY7.js +2 -0
- package/dist/cli/chunks/unified-memory-hnsw-6FOIGINN.js +2 -0
- package/dist/cli/chunks/unified-persistence-TCJB7MQS.js +2 -0
- package/dist/cli/chunks/{upgrade-463W7VKH.js → upgrade-IMBT4F6K.js} +2 -2
- package/dist/cli/chunks/{validate-LENSMEAY.js → validate-76OVF45Z.js} +2 -2
- package/dist/cli/chunks/{validate-swarm-4FEBNAWA.js → validate-swarm-HH2ZYWXA.js} +2 -2
- package/dist/cli/chunks/{vibium-TXNVIVWJ.js → vibium-74WQNDBX.js} +2 -2
- package/dist/cli/chunks/visual-security-IBAUX2K5.js +2 -0
- package/dist/cli/chunks/{web-tree-sitter-BZEGWID4.js → web-tree-sitter-W6RGE4SL.js} +2 -2
- package/dist/cli/chunks/{windsurf-installer-7AFXJTPU.js → windsurf-installer-7DMSFCA2.js} +2 -2
- package/dist/cli/chunks/{witness-chain-G6SUZOZG.js → witness-chain-BLZ4ZKAD.js} +2 -2
- package/dist/cli/chunks/witness-chain-GNNF23XU.js +2 -0
- package/dist/cli/chunks/{workflow-EVQPO6FH.js → workflow-RNSDKRZ4.js} +4 -4
- package/dist/cli/chunks/workflow-orchestrator-S2YONHGM.js +2 -0
- package/dist/cli/chunks/{wrappers-HR6RUDI2.js → wrappers-J7RXMIOY.js} +2 -2
- package/dist/domains/learning-optimization/services/learning-coordinator.js +37 -17
- package/dist/kernel/hybrid-backend.d.ts +17 -7
- package/dist/kernel/hybrid-backend.js +24 -10
- package/dist/kernel/interfaces.d.ts +21 -6
- package/dist/kernel/memory-backend.d.ts +5 -5
- package/dist/kernel/memory-backend.js +14 -7
- package/dist/mcp/bundle.js +447 -447
- package/dist/mcp/handlers/core-handlers.js +21 -0
- package/dist/workers/interfaces.d.ts +26 -0
- package/dist/workers/worker-manager.d.ts +15 -12
- package/dist/workers/worker-manager.js +11 -0
- package/dist/workers/workers/learning-consolidation.js +116 -89
- package/package.json +3 -1
- package/dist/cli/chunks/adapter-CI2GZYME.js +0 -2
- package/dist/cli/chunks/aqe-learning-engine-KNQKALLI.js +0 -2
- package/dist/cli/chunks/base-P7PRMQWY.js +0 -2
- package/dist/cli/chunks/browser-workflow-QUP4A763.js +0 -2
- package/dist/cli/chunks/chunk-5Z6PYYWK.js +0 -2
- package/dist/cli/chunks/chunk-RBDAHW2M.js +0 -2
- package/dist/cli/chunks/client-XF6SJO2C.js +0 -2
- package/dist/cli/chunks/cross-domain-router-J2OFPM6R.js +0 -2
- package/dist/cli/chunks/daemon-CP2ETHRF.js +0 -19
- package/dist/cli/chunks/dream-D5LD5SOZ.js +0 -2
- package/dist/cli/chunks/hnsw-adapter-M2MMM3N6.js +0 -2
- package/dist/cli/chunks/hnsw-index-JO7KNF7M.js +0 -2
- package/dist/cli/chunks/impact-analyzer-ROQL4J7P.js +0 -2
- package/dist/cli/chunks/init-wizard-4BDFZX4M.js +0 -2
- package/dist/cli/chunks/kernel-37Y63WKR.js +0 -2
- package/dist/cli/chunks/knowledge-graph-V3DX6ZCX.js +0 -2
- package/dist/cli/chunks/load-test-HPBA2CMT.js +0 -2
- package/dist/cli/chunks/memory-backend-DODDBB46.js +0 -2
- package/dist/cli/chunks/memory-handlers-MFLCRS7V.js +0 -2
- package/dist/cli/chunks/protocol-executor-D56OYMCJ.js +0 -2
- package/dist/cli/chunks/qe-reasoning-bank-KXROIEK7.js +0 -2
- package/dist/cli/chunks/queen-coordinator-XOGATERL.js +0 -2
- package/dist/cli/chunks/router-3EHNUCOM.js +0 -2
- package/dist/cli/chunks/routing-feedback-ZHKGET22.js +0 -2
- package/dist/cli/chunks/rvf-native-adapter-4YC5IQUW.js +0 -2
- package/dist/cli/chunks/safe-db-PLJRHQIC.js +0 -2
- package/dist/cli/chunks/schedule-7DGELVJE.js +0 -2
- package/dist/cli/chunks/scheduler-VWASEC2J.js +0 -2
- package/dist/cli/chunks/shared-rvf-adapter-DCVDY2XW.js +0 -2
- package/dist/cli/chunks/sqlite-persistence-CTEBGVOW.js +0 -2
- package/dist/cli/chunks/sync-SFKTCRZC.js +0 -23
- package/dist/cli/chunks/unified-memory-YDKXKW3D.js +0 -2
- package/dist/cli/chunks/unified-memory-hnsw-6N7YZCLR.js +0 -2
- package/dist/cli/chunks/unified-persistence-UTWLPUQI.js +0 -2
- package/dist/cli/chunks/visual-security-DGXSOFKD.js +0 -2
- package/dist/cli/chunks/witness-chain-VP4MF6EU.js +0 -2
- package/dist/cli/chunks/workflow-orchestrator-VXSYAKQY.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.9.
|
|
2
|
-
import{b as
|
|
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.9.32");process.exit(0)}
|
|
2
|
+
import{b as ft}from"./chunk-IJQJV7BC.js";import{b as yt,c as vt}from"./chunk-V5RLGPEW.js";import{a as Se}from"./chunk-SJETAUZA.js";import{a as ei,b as ti}from"./chunk-XB3SIYGU.js";import{a as ni}from"./chunk-45N22VAB.js";import{b as En}from"./chunk-7AISRWBS.js";import{a as Zr,b as X,c as B}from"./chunk-PS6ISBED.js";import{a as Jr}from"./chunk-LTSNDM5N.js";import{a as Sn}from"./chunk-Z2EDNMCQ.js";import{a as Xr}from"./chunk-MIHQIAVK.js";import{a as Yr}from"./chunk-W2VTHUDK.js";import{b as Wr}from"./chunk-OPOGZAN5.js";import{a as Kr}from"./chunk-PLGMPG7S.js";import{d as Tn}from"./chunk-W3JB3G7C.js";import{a as ht,b as Ar,c as xs,d as kr,e as Mr,f as Dr,g as Cn,h as Or,i as Fr,j as qr,k as Gr,l as $r,m as zr,n as Br,o as jr,p as Ur,q as Hr,r as Vr,s as Qr,t as Ce,u as Te}from"./chunk-RHXYZ6AZ.js";import{a as Lr,c as $e,d as Nr}from"./chunk-O5NEZCTB.js";import{a as fe}from"./chunk-T5ADVYPH.js";import{a as _r}from"./chunk-IGQPGXP7.js";import{c as oe,g as Ir}from"./chunk-G77CYF7H.js";import{s as xr}from"./chunk-A6VI5BZU.js";import{a as se,b as ae}from"./chunk-HR6NX6DW.js";import{h as gt}from"./chunk-62UXGD5J.js";import{a as yn}from"./chunk-6SYP7QX6.js";import{c as vn,d as bn}from"./chunk-ZIVOT3B7.js";import{d as ie}from"./chunk-LHDTXTS7.js";import{b as F,f as P}from"./chunk-BDXEL3GM.js";import{c as Pr}from"./chunk-XCUNQ3FK.js";import{b as be}from"./chunk-S4M7U6CZ.js";import{k as z,o as te}from"./chunk-THYGFSTA.js";import{b as x,d as j}from"./chunk-OK2TFTXP.js";import{a as wr}from"./chunk-YVQ4PR4H.js";import{c as dt,d as ye,e as fn}from"./chunk-OMOGD2NN.js";import{a as Er,b as I,c as N}from"./chunk-EFEJLZDN.js";import{a as w,b as G,c as k}from"./chunk-5WR42V5O.js";import{i as $}from"./chunk-WTNM7NA4.js";import{a as Rr,b as Rs}from"./chunk-4VAZSCTZ.js";import{a as J,c as Z,d as Ge}from"./chunk-MQQANXFS.js";import{a as mt}from"./chunk-YJV6TTCW.js";import{R as Ps,S as pt,b as ve}from"./chunk-33PGBYTC.js";import{a as Ss,c as Es,e as ws,g as Sr}from"./chunk-XHQFVTFD.js";var Ti={};ws(Ti,{DEFAULT_QEC_CONFIG:()=>bi,ReasoningQEC:()=>Lt,createReasoningQEC:()=>Ci,processReasoning:()=>Qa});async function Va(){return vi?yi!==null:(yi=null,vi=!0,!1)}function Ci(u){return new Lt(u)}function Qa(u,e){return Ci(e).process(u)}var Vn,bi,Ua,Ha,yi,vi,Lt,Si=Es(()=>{"use strict";fn();pt();Vn=ye("ReasoningQEC"),bi={minPaths:3,confidenceThreshold:.5,majorityThreshold:.5,useNativeBackend:!0,votingMethod:"weighted"},Ua={"test-generation":["specification-driven","boundary-analysis","mutation-testing"],"security-audit":["threat-modeling","attack-surface","defense-in-depth"],"defect-triage":["root-cause-analysis","impact-assessment","risk-prioritization"]},Ha=["analytical","empirical","heuristic"],yi=null,vi=!1;Lt=class{config;nativeAvailable=!1;constructor(e={}){this.config={...bi,...e}}async initialize(){if(this.config.useNativeBackend){let e=ve();(e.useQEFlashAttention||e.useQEGNNIndex)&&(this.nativeAvailable=await Va())}}generatePaths(e){let t=Math.max(this.config.minPaths,3),n=Ua[e.type]??Ha,r=[];for(let i=0;i<t;i++){let s=n[i%n.length],a=this.generatePathSteps(e,i,s),o=this.deriveConclusion(a,s),l=this.calculatePathConfidence(a);r.push({id:i,steps:a,conclusion:o,confidence:l})}return Vn.debug(`Generated ${r.length} reasoning paths for problem type: ${e.type}`),r}extractSyndromes(e){if(e.length<2)return[];let t=[],n=Math.max(...e.map(i=>i.steps.length));for(let i=0;i<n;i++){let s=new Map;for(let l of e){let c=l.steps[i];if(!c)continue;let d=s.get(c.conclusion)??[];d.push(l.id),s.set(c.conclusion,d)}if(s.size<=1)continue;let a=[...s.entries()].map(([l,c])=>c.map(d=>({pathId:d,conclusion:l}))).flat(),o=this.classifySyndromeSeverity(s,e.length);t.push({stepIndex:i,disagreements:a,severity:o})}let r=new Map;for(let i of e){let s=r.get(i.conclusion)??[];s.push(i.id),r.set(i.conclusion,s)}if(r.size>1){let i=[...r.entries()].map(([a,o])=>o.map(l=>({pathId:l,conclusion:a}))).flat(),s=this.classifySyndromeSeverity(r,e.length);t.push({stepIndex:-1,disagreements:i,severity:s})}return Vn.debug(`Extracted ${t.length} syndromes: ${t.filter(i=>i.severity==="critical").length} critical, ${t.filter(i=>i.severity==="major").length} major, ${t.filter(i=>i.severity==="minor").length} minor`),t}correctErrors(e,t){if(e.length===0)return{steps:[],conclusion:"",confidence:0,corrections:[],syndromeCount:t.length};let n=new Set(t.filter(c=>c.stepIndex>=0).map(c=>c.stepIndex)),r=Math.max(...e.map(c=>c.steps.length)),i=[],s=[];for(let c=0;c<r;c++)if(n.has(c)){let{step:d,correction:m}=this.correctStep(e,c);i.push(d),m&&s.push(m)}else{let d=e[0].steps[c];d&&i.push({...d})}let a=this.correctConclusion(e),o=this.calculateCorrectedConfidence(e,t),l={steps:i,conclusion:a,confidence:o,corrections:s,syndromeCount:t.length};return Vn.debug(`Error correction applied: ${s.length} corrections, confidence: ${o.toFixed(3)}`),l}validate(e){let t=[];e.confidence<this.config.confidenceThreshold&&t.push({stepIndex:-1,type:"low-confidence",description:`Overall confidence ${e.confidence.toFixed(3)} is below threshold ${this.config.confidenceThreshold}`});for(let i of e.steps)i.evidence.length===0&&t.push({stepIndex:i.index,type:"inconsistent-evidence",description:`Step ${i.index} has no supporting evidence`});e.syndromeCount>0&&e.confidence<.3&&t.push({stepIndex:-1,type:"all-divergent",description:`${e.syndromeCount} syndromes with confidence ${e.confidence.toFixed(3)} suggests all paths diverged significantly`});for(let i of e.corrections)i.reason.includes("no clear majority")&&t.push({stepIndex:i.stepIndex,type:"no-majority",description:`Step ${i.stepIndex}: ${i.reason}`});let n=t.length===0,r=n?e.confidence:e.confidence*(1-t.length*.1);return{valid:n,confidence:Math.max(0,r),issues:t}}process(e){let t=this.generatePaths(e),n=this.extractSyndromes(t),r=this.correctErrors(t,n),i=this.validate(r);return{paths:t,syndromes:n,corrected:r,validation:i}}getConfig(){return{...this.config}}isNativeAvailable(){return this.nativeAvailable}generatePathSteps(e,t,n){return e.steps.map((r,i)=>{let s=this.generateStepConclusion(r,n,e.context,t),a=this.gatherEvidence(r,n,e.context);return{index:i,description:`[${n}] ${r}`,conclusion:s,evidence:a}})}generateStepConclusion(e,t,n,r){let i=Object.keys(n).sort(),s={0:l=>l.length>0?`Focused on ${l[0]}`:"Primary analysis",1:l=>l.length>1?`Focused on ${l[l.length-1]}`:"Secondary analysis",2:l=>l.length>0?`Cross-referencing ${l.join(" and ")}`:"Holistic analysis"},o=(s[r%3]??s[0])(i);return`[${t}] ${e}: ${o}`}gatherEvidence(e,t,n){let r=[];r.push(`Analysis via ${t}: ${e}`);for(let[i,s]of Object.entries(n))(typeof s=="string"||typeof s=="number"||typeof s=="boolean")&&r.push(`Context[${i}]: ${String(s)}`);return r}deriveConclusion(e,t){if(e.length===0)return`No conclusion (${t})`;let n=e[e.length-1];return`${t}: ${n.conclusion}`}calculatePathConfidence(e){if(e.length===0)return 0;let t=e.reduce((n,r)=>n+r.evidence.length,0)/e.length;return Math.min(1,.5+t*.1)}classifySyndromeSeverity(e,t){let n=Math.max(...[...e.values()].map(r=>r.length));return n>=Math.ceil(t*2/3)?"minor":n>=Math.ceil(t/2)?"major":"critical"}correctStep(e,t){let n=new Map,r=new Map,i=this.config.votingMethod==="weighted";for(let p of e){let h=p.steps[t];if(!h)continue;let f=n.get(h.conclusion)??0,v=i?p.confidence:1;n.set(h.conclusion,f+v),r.set(h.conclusion,h)}if(n.size===0)return{step:{index:t,description:`Step ${t} (no data)`,conclusion:"",evidence:[]},correction:null};let s=[...n.entries()].sort((p,h)=>h[1]-p[1]||p[0].localeCompare(h[0])),[a,o]=s[0],l=r.get(a),c=new Set;for(let p of e){let h=p.steps[t];if(h)for(let f of h.evidence)c.add(f)}let d={index:t,description:l.description,conclusion:a,evidence:[...c]},m=e[0].steps[t]?.conclusion,g=null;if(m&&m!==a){let p=e.filter(C=>C.steps[t]).length,h=[...n.values()].reduce((C,b)=>C+b,0),v=o/h>this.config.majorityThreshold;g={stepIndex:t,original:m,corrected:a,reason:v?`${i?"Weighted vote":"Majority vote"} (${o.toFixed(2)}/${h.toFixed(2)} weight from ${p} paths)`:`Selected highest ${i?"weight":"count"} (${o.toFixed(2)}/${h.toFixed(2)}), no clear majority`}}return{step:d,correction:g}}correctConclusion(e){let t=new Map,n=this.config.votingMethod==="weighted";for(let i of e){let s=t.get(i.conclusion)??0,a=n?i.confidence:1;t.set(i.conclusion,s+a)}return[...t.entries()].sort((i,s)=>s[1]-i[1]||i[0].localeCompare(s[0]))[0]?.[0]??""}calculateCorrectedConfidence(e,t){let n=e.reduce((l,c)=>l+c.confidence,0)/e.length,r=t.filter(l=>l.severity==="critical").length,i=t.filter(l=>l.severity==="major").length,s=t.filter(l=>l.severity==="minor").length,a=r*.2+i*.1+s*.03,o=t.length===0?.1:0;return Math.max(0,Math.min(1,n-a+o))}}});te();j();var Qs={maxStepsPerTrajectory:100,autoEndTimeoutMs:1800*1e3,minQualityThreshold:.5,recentBufferSize:100},bt=class{config;unifiedMemory=null;db=null;prepared=new Map;initialized=!1;activeTrajectories=new Map;recentTrajectories;stats={trajectoriesStarted:0,trajectoriesCompleted:0,trajectoriesAbandoned:0,totalStepsRecorded:0,averageQuality:0,totalQualitySum:0};constructor(e={}){this.config={...Qs,...e},this.recentTrajectories=new fe(this.config.recentBufferSize)}async initialize(){this.initialized||(this.unifiedMemory=z(),await this.unifiedMemory.initialize(),this.db=this.unifiedMemory.getDatabase(),this.ensureSchema(),this.prepareStatements(),await this.loadRecentTrajectories(),this.cleanupOrphanedTrajectories(),this.initialized=!0,console.log("[TrajectoryTracker] Initialized"))}cleanupOrphanedTrajectories(){if(this.db)try{let e=this.db.prepare(`
|
|
3
3
|
UPDATE qe_trajectories
|
|
4
4
|
SET success = 0,
|
|
5
5
|
ended_at = datetime('now'),
|
|
@@ -59,69 +59,9 @@ import{b as bt,c as Ct}from"./chunk-ZWSRIJ2T.js";import{a as Se}from"./chunk-ROE
|
|
|
59
59
|
WHERE domain = ? AND success = 1
|
|
60
60
|
ORDER BY ended_at DESC
|
|
61
61
|
LIMIT ?
|
|
62
|
-
`))}async loadRecentTrajectories(){let e=this.prepared.get("getRecentTrajectories");if(!e)return;let t=e.all(this.config.recentBufferSize);for(let n of t){let r=await this.rowToTrajectory(n);r&&this.recentTrajectories.push(r)}console.log(`[TrajectoryTracker] Loaded ${t.length} recent trajectories`)}async startTrajectory(e,t={}){this.ensureInitialized();let n
|
|
62
|
+
`))}async loadRecentTrajectories(){let e=this.prepared.get("getRecentTrajectories");if(!e)return;let t=e.all(this.config.recentBufferSize);for(let n of t){let r=await this.rowToTrajectory(n);r&&this.recentTrajectories.push(r)}console.log(`[TrajectoryTracker] Loaded ${t.length} recent trajectories`)}async startTrajectory(e,t={}){this.ensureInitialized();let n=$(),r=new Date;this.activeTrajectories.set(n,{id:n,task:e,agent:t.agent,domain:t.domain,steps:[],startedAt:r,context:t.context});let i=this.prepared.get("insertTrajectory");return i&&i.run(n,e,t.agent||null,t.domain||null,r.toISOString(),t.context?JSON.stringify(t.context):null),this.stats.trajectoriesStarted++,setTimeout(()=>{this.activeTrajectories.has(n)&&(console.warn(`[TrajectoryTracker] Auto-ending abandoned trajectory: ${n}`),this.endTrajectory(n,!1,"Abandoned - timeout").catch(console.error),this.stats.trajectoriesAbandoned++)},this.config.autoEndTimeoutMs),n}async recordStep(e,t,n,r={}){this.ensureInitialized();let i=this.activeTrajectories.get(e);if(!i)throw new Error(`Trajectory not found or already ended: ${e}`);if(i.steps.length>=this.config.maxStepsPerTrajectory)throw new Error(`Maximum steps (${this.config.maxStepsPerTrajectory}) exceeded for trajectory`);let s=$(),a=r.quality??this.calculateStepQuality(n),o={id:s,action:t,result:n,quality:a,durationMs:r.durationMs??0,timestamp:new Date,context:r.context,tokensUsed:r.tokensUsed};i.steps.push(o);let l=this.prepared.get("insertStep");l&&l.run(s,e,i.steps.length-1,t,n.outcome,a,r.durationMs??0,r.tokensUsed??null,n.data?JSON.stringify(n.data):null,n.error??null,n.metrics?JSON.stringify(n.metrics):null,r.context?JSON.stringify(r.context):null),this.stats.totalStepsRecorded++,this.stats.totalQualitySum+=a,this.stats.averageQuality=this.stats.totalQualitySum/this.stats.totalStepsRecorded}async endTrajectory(e,t,n){this.ensureInitialized();let r=this.activeTrajectories.get(e);if(!r)throw new Error(`Trajectory not found or already ended: ${e}`);let i=new Date,s=this.calculateMetrics(r.steps),a;t&&s.averageQuality>=this.config.minQualityThreshold?a="success":t?a="partial":a="failure";let o={id:e,task:r.task,agent:r.agent,domain:r.domain,steps:r.steps,outcome:a,metrics:s,startedAt:r.startedAt,endedAt:i,feedback:n},l=this.prepared.get("updateTrajectory");return l&&l.run(i.toISOString(),t?1:0,JSON.stringify(r.steps),JSON.stringify({metrics:s,context:r.context}),null,n??null,null,e),this.activeTrajectories.delete(e),this.recentTrajectories.push(o),this.stats.trajectoriesCompleted++,o}async getTrajectory(e){this.ensureInitialized();let t=this.activeTrajectories.get(e);if(t)return{id:t.id,task:t.task,agent:t.agent,domain:t.domain,steps:t.steps,outcome:"partial",metrics:this.calculateMetrics(t.steps),startedAt:t.startedAt};let n=this.prepared.get("getTrajectory");if(!n)return null;let r=n.get(e);return r?this.rowToTrajectory(r):null}async getSuccessfulTrajectories(e,t=10){this.ensureInitialized();let n=this.prepared.get("getTrajectoryByDomain");if(!n)return[];let r=n.all(e,t),i=[];for(let s of r){let a=await this.rowToTrajectory(s);a&&i.push(a)}return i}async findSimilarTrajectories(e,t=5){this.ensureInitialized();let n=e.toLowerCase().split(/\s+/).filter(s=>s.length>3);return this.recentTrajectories.toArray().map(s=>{let a=s.task.toLowerCase(),o=n.filter(l=>a.includes(l)).length;return{trajectory:s,score:o/n.length}}).filter(s=>s.score>.2).sort((s,a)=>a.score-s.score).slice(0,t).map(s=>s.trajectory)}getStats(){return{...this.stats,activeTrajectories:this.activeTrajectories.size,recentBufferSize:this.recentTrajectories.length}}async cleanup(e=30){if(this.ensureInitialized(),!this.db)return 0;let t=new Date;return t.setDate(t.getDate()-e),this.db.prepare(`
|
|
63
63
|
DELETE FROM qe_trajectories WHERE ended_at < ?
|
|
64
|
-
`).run(t.toISOString()).changes}async dispose(){this.activeTrajectories.clear(),this.recentTrajectories.clear(),this.prepared.clear(),this.db=null,this.unifiedMemory=null,this.initialized=!1,console.log("[TrajectoryTracker] Disposed")}ensureInitialized(){if(!this.initialized)throw new Error("TrajectoryTracker not initialized. Call initialize() first.")}calculateStepQuality(e){switch(e.outcome){case"success":return 1;case"partial":return .6;case"skipped":return .5;case"failure":return 0;default:return .5}}calculateMetrics(e){if(e.length===0)return{totalDurationMs:0,successfulSteps:0,failedSteps:0,averageQuality:0,totalTokensUsed:0,efficiencyScore:0};let t=0,n=0,r=0,i=0,s=0;for(let c of e)t+=c.durationMs,i+=c.quality,s+=c.tokensUsed??0,c.result.outcome==="success"?n++:c.result.outcome==="failure"&&r++;let a=i/e.length,l=n/e.length*a;return{totalDurationMs:t,successfulSteps:n,failedSteps:r,averageQuality:a,totalTokensUsed:s,efficiencyScore:l}}async rowToTrajectory(e){if(!e)return null;let t=this.prepared.get("getSteps"),n=[];if(t)n=t.all(e.id).map(a=>({id:a.id,action:a.action,result:{outcome:a.outcome,data:a.result_data?
|
|
65
|
-
SELECT id, task, domain, quality, success, application_count,
|
|
66
|
-
consolidation_count, reuse_success_count, reuse_failure_count,
|
|
67
|
-
embedding, embedding_dimension, started_at
|
|
68
|
-
FROM captured_experiences
|
|
69
|
-
WHERE domain = ? AND consolidated_into IS NULL AND embedding IS NOT NULL
|
|
70
|
-
ORDER BY quality DESC
|
|
71
|
-
`).all(e);if(t.length<2)return 0;let n=new Ee({dimension:384,M:16,efConstruction:200,efSearch:100,metric:"cosine"}),r=new Map,i=0;for(let d of t)if(d.embedding&&d.embedding_dimension){let m=this.bufferToFloatArray(d.embedding,d.embedding_dimension),p=i++;r.set(p,d.id);let g={vector:m,dimension:384,namespace:"experiences",text:d.id,timestamp:Date.now(),quantization:"none",metadata:{}};n.addEmbedding(g,p)}let s=new Set,a=0,o=this.db.prepare("UPDATE captured_experiences SET consolidated_into = ? WHERE id = ?"),l=this.db.prepare(`
|
|
72
|
-
UPDATE captured_experiences
|
|
73
|
-
SET consolidation_count = consolidation_count + ?,
|
|
74
|
-
quality = MIN(1.0, quality + ?),
|
|
75
|
-
quality_updated_at = datetime('now')
|
|
76
|
-
WHERE id = ?
|
|
77
|
-
`),c=this.db.prepare(`
|
|
78
|
-
INSERT INTO experience_consolidation_log (id, domain, action, source_ids, target_id, details, created_at)
|
|
79
|
-
VALUES (?, ?, ?, ?, ?, ?, datetime('now'))
|
|
80
|
-
`);for(let d of t){if(a>=this.config.maxMergesPerRun)break;if(s.has(d.id)||!d.embedding||!d.embedding_dimension)continue;let p={vector:this.bufferToFloatArray(d.embedding,d.embedding_dimension),dimension:384,namespace:"experiences",text:d.id,timestamp:Date.now(),quantization:"none",metadata:{}},g=n.search(p,{limit:6,namespace:"experiences"}),h=[];for(let{id:f,distance:v}of g){if(a>=this.config.maxMergesPerRun)break;let y=r.get(f);if(!y||y===d.id||s.has(y)||1-v<this.config.mergeSimilarityThreshold)continue;let b=t.find(E=>E.id===y);b&&b.quality<=d.quality&&b.application_count===0&&(s.add(y),h.push(y),a++)}h.length>0&&this.db.transaction(()=>{for(let y of h)o.run(d.id,y);let v=this.config.mergeQualityBoost*h.length;l.run(h.length,v,d.id),c.run(L(),e,"merge",JSON.stringify(h),d.id,JSON.stringify({count:h.length,boost:v}))})()}return n.clearIndex("experiences"),a}reinforceQuality(e){let t=this.db.prepare(`
|
|
81
|
-
SELECT ce.id, ce.quality, ce.consolidation_count,
|
|
82
|
-
ce.reuse_success_count, ce.reuse_failure_count,
|
|
83
|
-
COALESCE(app.total, 0) as app_total,
|
|
84
|
-
COALESCE(app.successes, 0) as app_successes
|
|
85
|
-
FROM captured_experiences ce
|
|
86
|
-
LEFT JOIN (
|
|
87
|
-
SELECT experience_id,
|
|
88
|
-
COUNT(*) as total,
|
|
89
|
-
SUM(CASE WHEN success = 1 THEN 1 ELSE 0 END) as successes
|
|
90
|
-
FROM experience_applications
|
|
91
|
-
GROUP BY experience_id
|
|
92
|
-
) app ON app.experience_id = ce.id
|
|
93
|
-
WHERE ce.domain = ? AND ce.consolidated_into IS NULL
|
|
94
|
-
AND (app.total > 0 OR ce.reuse_success_count > 0 OR ce.reuse_failure_count > 0)
|
|
95
|
-
`).all(e);if(t.length===0)return 0;let n=this.db.prepare(`
|
|
96
|
-
UPDATE captured_experiences
|
|
97
|
-
SET quality = ?, quality_updated_at = datetime('now')
|
|
98
|
-
WHERE id = ?
|
|
99
|
-
`),r=0;return this.db.transaction(()=>{for(let s of t){let a=s.app_total+s.reuse_success_count+s.reuse_failure_count,o=s.app_successes+s.reuse_success_count,l=a>0?o/a:0,c=Math.min(s.consolidation_count,10)/10,d=Math.min(1,.4*s.quality+.4*l+.2*c);Math.abs(d-s.quality)>.01&&(n.run(d,s.id),r++)}})(),r}archiveValueless(e){let t=new Date;t.setDate(t.getDate()-this.config.archiveMinAgeDays);let n=t.toISOString().replace("T"," ").slice(0,19),r=this.db.prepare(`
|
|
100
|
-
UPDATE captured_experiences
|
|
101
|
-
SET consolidated_into = 'archived'
|
|
102
|
-
WHERE domain = ?
|
|
103
|
-
AND consolidated_into IS NULL
|
|
104
|
-
AND quality < ?
|
|
105
|
-
AND application_count = 0
|
|
106
|
-
AND success = 0
|
|
107
|
-
AND consolidation_count = 1
|
|
108
|
-
AND started_at < ?
|
|
109
|
-
`).run(e,this.config.archiveQualityThreshold,n);if(r.changes>0)try{this.db.prepare(`
|
|
110
|
-
INSERT INTO experience_consolidation_log (id, domain, action, source_ids, details, created_at)
|
|
111
|
-
VALUES (?, ?, 'archive', '[]', ?, datetime('now'))
|
|
112
|
-
`).run(L(),e,JSON.stringify({count:r.changes}))}catch{}return r.changes}hardDeleteExcess(e,t){let n=t-this.config.hardThreshold;if(n<=0)return 0;let i=this.db.prepare(`
|
|
113
|
-
UPDATE captured_experiences
|
|
114
|
-
SET consolidated_into = 'archived'
|
|
115
|
-
WHERE id IN (
|
|
116
|
-
SELECT id FROM captured_experiences
|
|
117
|
-
WHERE domain = ? AND consolidated_into IS NULL AND application_count = 0
|
|
118
|
-
ORDER BY quality ASC, started_at ASC
|
|
119
|
-
LIMIT ?
|
|
120
|
-
)
|
|
121
|
-
`).run(e,n).changes;if(i>0){try{this.db.prepare(`
|
|
122
|
-
INSERT INTO experience_consolidation_log (id, domain, action, source_ids, details, created_at)
|
|
123
|
-
VALUES (?, ?, 'safety-valve-archive', '[]', ?, datetime('now'))
|
|
124
|
-
`).run(L(),e,JSON.stringify({count:i,currentCount:t,hardThreshold:this.config.hardThreshold,note:"soft-archive replacement for legacy hard-delete safety valve"}))}catch{}console.warn(`[ExperienceConsolidator] Safety valve: soft-archived ${i} from ${e} (was ${t}, threshold ${this.config.hardThreshold})`)}return i}ensureInitialized(){if(!this.initialized||!this.db)throw new Error("ExperienceConsolidator not initialized. Call initialize() first.")}bufferToFloatArray(e,t){let n=[];for(let r=0;r<t;r++)n.push(e.readFloatLE(r*4));return n}};ht();var na={minQualityThreshold:.6,maxExperiencesPerDomain:500,similarityThreshold:.7,topK:5,embedding:{modelName:"Xenova/all-MiniLM-L6-v2",quantized:!0},autoPrune:!0,pruneThreshold:.3},wt=class{config;unifiedMemory=null;db=null;prepared=new Map;initialized=!1;hnswIndex;idToExperienceId=new Map;experienceIdToHnswId=new Map;nextHnswId=0;recentExperiences;reservoirBuffer=null;stats={experiencesStored:0,experiencesApplied:0,totalTokensSaved:0,avgSimilarityOnRetrieval:0,totalRetrievals:0};constructor(e={}){this.config={...na,...e},this.recentExperiences=new fe(100),this.hnswIndex=new Ee({dimension:384,M:16,efConstruction:200,efSearch:100,metric:"cosine"})}async initialize(){this.initialized||(this.unifiedMemory=$(),await this.unifiedMemory.initialize(),this.db=this.unifiedMemory.getDatabase(),this.ensureSchema(),this.prepareStatements(),await this.loadEmbeddingIndex(),(async()=>{try{if(!this.db)return;let e=this.db.prepare(`
|
|
64
|
+
`).run(t.toISOString()).changes}async dispose(){this.activeTrajectories.clear(),this.recentTrajectories.clear(),this.prepared.clear(),this.db=null,this.unifiedMemory=null,this.initialized=!1,console.log("[TrajectoryTracker] Disposed")}ensureInitialized(){if(!this.initialized)throw new Error("TrajectoryTracker not initialized. Call initialize() first.")}calculateStepQuality(e){switch(e.outcome){case"success":return 1;case"partial":return .6;case"skipped":return .5;case"failure":return 0;default:return .5}}calculateMetrics(e){if(e.length===0)return{totalDurationMs:0,successfulSteps:0,failedSteps:0,averageQuality:0,totalTokensUsed:0,efficiencyScore:0};let t=0,n=0,r=0,i=0,s=0;for(let c of e)t+=c.durationMs,i+=c.quality,s+=c.tokensUsed??0,c.result.outcome==="success"?n++:c.result.outcome==="failure"&&r++;let a=i/e.length,l=n/e.length*a;return{totalDurationMs:t,successfulSteps:n,failedSteps:r,averageQuality:a,totalTokensUsed:s,efficiencyScore:l}}async rowToTrajectory(e){if(!e)return null;let t=this.prepared.get("getSteps"),n=[];if(t)n=t.all(e.id).map(a=>({id:a.id,action:a.action,result:{outcome:a.outcome,data:a.result_data?x(a.result_data):void 0,error:a.error_message??void 0,metrics:a.metrics_json?x(a.metrics_json):void 0},quality:a.quality,durationMs:a.duration_ms,timestamp:new Date(a.timestamp),context:a.context_json?x(a.context_json):void 0,tokensUsed:a.tokens_used??void 0}));else if(e.steps_json)try{n=x(e.steps_json)}catch{n=[]}let i=(e.metadata_json?x(e.metadata_json):{}).metrics??this.calculateMetrics(n);return{id:e.id,task:e.task,agent:e.agent??void 0,domain:e.domain,steps:n,outcome:e.success===1?"success":e.success===0?"failure":"partial",metrics:i,startedAt:new Date(e.started_at),endedAt:e.ended_at?new Date(e.ended_at):void 0,feedback:e.feedback??void 0,embedding:e.embedding?this.bufferToFloatArray(e.embedding):void 0,relatedPatternIds:e.related_patterns?x(e.related_patterns):void 0}}bufferToFloatArray(e){let t=e.length/4,n=[];for(let r=0;r<t;r++)n.push(e.readFloatLE(r*4));return n}};function wn(u={}){return new bt(u)}te();j();pt();var Ws={minQualityThreshold:.6,maxExperiencesPerDomain:500,similarityThreshold:.7,topK:5,embedding:{modelName:"Xenova/all-MiniLM-L6-v2",quantized:!0},autoPrune:!0,pruneThreshold:.3},Ct=class{config;unifiedMemory=null;db=null;prepared=new Map;initialized=!1;hnswIndex;idToExperienceId=new Map;experienceIdToHnswId=new Map;nextHnswId=0;recentExperiences;reservoirBuffer=null;stats={experiencesStored:0,experiencesApplied:0,totalTokensSaved:0,avgSimilarityOnRetrieval:0,totalRetrievals:0};constructor(e={}){this.config={...Ws,...e},this.recentExperiences=new fe(100),this.hnswIndex=new ei({dimension:384,M:16,efConstruction:200,efSearch:100,metric:"cosine"})}async initialize(){this.initialized||(this.unifiedMemory=z(),await this.unifiedMemory.initialize(),this.db=this.unifiedMemory.getDatabase(),this.ensureSchema(),this.prepareStatements(),await this.loadEmbeddingIndex(),(async()=>{try{if(!this.db)return;let e=this.db.prepare(`
|
|
125
65
|
SELECT id, domain, task FROM captured_experiences
|
|
126
66
|
WHERE embedding IS NULL AND consolidated_into IS NULL
|
|
127
67
|
LIMIT 200
|
|
@@ -133,7 +73,7 @@ import{b as bt,c as Ct}from"./chunk-ZWSRIJ2T.js";import{a as Se}from"./chunk-ROE
|
|
|
133
73
|
SELECT id, domain, task FROM qe_trajectories
|
|
134
74
|
WHERE embedding IS NULL AND ended_at IS NOT NULL
|
|
135
75
|
LIMIT 200
|
|
136
|
-
`).all();if(t.length===0)return;let n=this.db.prepare("UPDATE qe_trajectories SET embedding = ? WHERE id = ?"),r=0;for(let i of t){let s=`${i.domain??""}: ${i.task}`.slice(0,512),a=await be(s);n.run(Buffer.from(new Float32Array(a).buffer),i.id),r++}console.log(`[ExperienceReplay] Backfilled ${r} qe_trajectories embeddings`)}catch(e){console.warn("[ExperienceReplay] Trajectory embedding backfill failed:",e instanceof Error?e.message:e)}})(),ve().useReservoirReplay&&(this.reservoirBuffer=new
|
|
76
|
+
`).all();if(t.length===0)return;let n=this.db.prepare("UPDATE qe_trajectories SET embedding = ? WHERE id = ?"),r=0;for(let i of t){let s=`${i.domain??""}: ${i.task}`.slice(0,512),a=await be(s);n.run(Buffer.from(new Float32Array(a).buffer),i.id),r++}console.log(`[ExperienceReplay] Backfilled ${r} qe_trajectories embeddings`)}catch(e){console.warn("[ExperienceReplay] Trajectory embedding backfill failed:",e instanceof Error?e.message:e)}})(),ve().useReservoirReplay&&(this.reservoirBuffer=new Fr({capacity:1e4}),console.log("[ExperienceReplay] Reservoir replay buffer enabled")),this.initialized=!0,console.log("[ExperienceReplay] Initialized"))}ensureSchema(){if(!this.db)throw new Error("Database not initialized");this.db.exec(`
|
|
137
77
|
CREATE TABLE IF NOT EXISTS captured_experiences (
|
|
138
78
|
id TEXT PRIMARY KEY,
|
|
139
79
|
task TEXT NOT NULL,
|
|
@@ -207,7 +147,7 @@ import{b as bt,c as Ct}from"./chunk-ZWSRIJ2T.js";import{a as Se}from"./chunk-ROE
|
|
|
207
147
|
VALUES (?, ?, ?, ?, ?, ?)
|
|
208
148
|
`)),this.prepared.set("countByDomain",this.db.prepare(`
|
|
209
149
|
SELECT domain, COUNT(*) as count FROM captured_experiences WHERE consolidated_into IS NULL GROUP BY domain
|
|
210
|
-
`))}async loadEmbeddingIndex(){let e=this.prepared.get("getAllEmbeddings");if(!e)return;let t=e.all();this.idToExperienceId.clear(),this.experienceIdToHnswId.clear(),this.hnswIndex.clearIndex("experiences"),this.nextHnswId=0;for(let n of t)if(n.embedding&&n.embedding_dimension){let r=this.bufferToFloatArray(n.embedding,n.embedding_dimension),i=this.nextHnswId++,s={vector:r,dimension:384,namespace:"experiences",text:n.id,timestamp:Date.now(),quantization:"none",metadata:{}};this.hnswIndex.addEmbedding(s,i),this.idToExperienceId.set(i,n.id),this.experienceIdToHnswId.set(n.id,i)}console.log(`[ExperienceReplay] Loaded ${this.idToExperienceId.size} embeddings into HNSW index`)}async storeExperience(e,t,n=[]){if(this.ensureInitialized(),e.metrics.efficiencyScore<this.config.minQualityThreshold)return console.log(`[ExperienceReplay] Trajectory quality too low: ${e.metrics.efficiencyScore}`),null;let r=e.steps.filter(d=>d.result.outcome==="success").map(d=>d.action),i=`${e.task} ${t} ${r.join(" ")}`,s=await be(i,this.config.embedding),a
|
|
150
|
+
`))}async loadEmbeddingIndex(){let e=this.prepared.get("getAllEmbeddings");if(!e)return;let t=e.all();this.idToExperienceId.clear(),this.experienceIdToHnswId.clear(),this.hnswIndex.clearIndex("experiences"),this.nextHnswId=0;for(let n of t)if(n.embedding&&n.embedding_dimension){let r=this.bufferToFloatArray(n.embedding,n.embedding_dimension),i=this.nextHnswId++,s={vector:r,dimension:384,namespace:"experiences",text:n.id,timestamp:Date.now(),quantization:"none",metadata:{}};this.hnswIndex.addEmbedding(s,i),this.idToExperienceId.set(i,n.id),this.experienceIdToHnswId.set(n.id,i)}console.log(`[ExperienceReplay] Loaded ${this.idToExperienceId.size} embeddings into HNSW index`)}async storeExperience(e,t,n=[]){if(this.ensureInitialized(),e.metrics.efficiencyScore<this.config.minQualityThreshold)return console.log(`[ExperienceReplay] Trajectory quality too low: ${e.metrics.efficiencyScore}`),null;let r=e.steps.filter(d=>d.result.outcome==="success").map(d=>d.action),i=`${e.task} ${t} ${r.join(" ")}`,s=await be(i,this.config.embedding),a=$(),o=e.domain||"test-generation",l={id:a,trajectoryId:e.id,task:e.task,domain:o,strategy:t,keyActions:r,qualityScore:e.metrics.efficiencyScore,applicationCount:0,successRate:1,avgTokenSavings:0,embedding:s,createdAt:new Date,originalMetrics:e.metrics,tags:n},c=this.prepared.get("insertExperience");if(c){let d=s?this.floatArrayToBuffer(s):null;c.run(a,e.task,t,o,e.metrics.efficiencyScore,JSON.stringify(r),JSON.stringify(e.metrics),d,s?.length??null,JSON.stringify(n))}if(s){let d=this.nextHnswId++,m={vector:s,dimension:384,namespace:"experiences",text:a,timestamp:Date.now(),quantization:"none",metadata:{}};this.hnswIndex.addEmbedding(m,d),this.idToExperienceId.set(d,a),this.experienceIdToHnswId.set(a,d)}return this.recentExperiences.push(l),this.reservoirBuffer&&this.reservoirBuffer.admit(l.id,l,l.qualityScore),this.stats.experiencesStored++,this.config.autoPrune&&await this.autoConsolidate(o),l}async getGuidance(e,t){this.ensureInitialized();let n=await this.findSimilarExperiences(e,t);if(this.reservoirBuffer&&this.reservoirBuffer.size()>0){let g=this.reservoirBuffer.sample(Math.max(2,Math.floor(this.config.topK/2)),.6);for(let p of g){let h=p.data;n.some(f=>f.experience.id===h.id)||t&&h.domain!==t||n.push({experience:h,similarity:p.coherenceScore*.8})}}if(n.length===0)return null;this.stats.totalRetrievals++;let r=n.reduce((g,p)=>g+p.similarity,0)/n.length;this.stats.avgSimilarityOnRetrieval=(this.stats.avgSimilarityOnRetrieval*(this.stats.totalRetrievals-1)+r)/this.stats.totalRetrievals;let i=n.map(g=>({...g,weight:g.similarity*g.experience.qualityScore}));i.sort((g,p)=>p.weight-g.weight);let a=i[0].experience.strategy,o=new Map;for(let g of i)for(let p of g.experience.keyActions)o.set(p,(o.get(p)||0)+g.weight);let l=Array.from(o.entries()).sort((g,p)=>p[1]-g[1]).slice(0,5).map(([g])=>g),c=[],d=i.reduce((g,p)=>g+p.weight,0)/i.length,m=i.reduce((g,p)=>g+p.experience.avgTokenSavings*p.similarity,0)/i.length;return{recommendedStrategy:a,suggestedActions:l,pitfallsToAvoid:c,confidence:Math.min(d,1),sourceExperiences:i.slice(0,3).map(g=>({id:g.experience.id,similarity:g.similarity,qualityScore:g.experience.qualityScore})),estimatedTokenSavings:m}}async findSimilarExperiences(e,t,n){this.ensureInitialized();let r=n??this.config.topK;if(this.idToExperienceId.size===0)return[];let s={vector:await be(e,this.config.embedding),dimension:384,namespace:"experiences",text:e,timestamp:Date.now(),quantization:"none",metadata:{}},a=t?r*4:r*2,o=this.hnswIndex.search(s,{limit:a,namespace:"experiences"}),l=[],c=this.prepared.get("getExperience");for(let{id:d,distance:m}of o){let g=1-m;if(g<this.config.similarityThreshold)continue;let p=this.idToExperienceId.get(d);if(p&&c){let h=c.get(p);if(h){if(t&&h.domain!==t)continue;let f=this.rowToExperience(h);if(f&&(l.push({experience:f,similarity:g}),l.length>=r))break}}}return l}async recordApplication(e,t,n,r=0,i){this.ensureInitialized();let s=this.prepared.get("updateApplication");s&&s.run(r,e);let a=this.prepared.get("insertApplication");a&&a.run($(),e,t,n?1:0,r,i??null),this.stats.experiencesApplied++,this.stats.totalTokensSaved+=r}async getExperience(e){this.ensureInitialized();let t=this.prepared.get("getExperience");if(!t)return null;let n=t.get(e);return n?this.rowToExperience(n):null}async getExperiencesByDomain(e,t=10){this.ensureInitialized();let n=this.prepared.get("getExperiencesByDomain");return n?n.all(e,t).map(i=>this.rowToExperience(i)).filter(i=>i!==null):[]}async autoConsolidate(e){if(!this.db)return 0;let t=this.prepared.get("countByDomain");if(!t)return 0;let r=t.all().find(i=>i.domain===e)?.count??0;if(r>400)try{let i=new ti;await i.initialize(this.db);let s=await i.consolidateDomain(e,r);return s.merged>0&&await this.loadEmbeddingIndex(),console.log(`[ExperienceReplay] Auto-consolidated ${e}: ${s.merged} merged, ${s.archived} archived`),s.merged+s.archived}catch(i){console.warn("[ExperienceReplay] Auto-consolidation failed, skipping:",i)}return 0}async recordReuse(e,t){if(this.ensureInitialized(),!this.db)return;let n=t?"reuse_success_count":"reuse_failure_count";try{this.db.prepare(`UPDATE captured_experiences SET ${n} = ${n} + 1 WHERE id = ?`).run(e)}catch{}}getStats(){return{...this.stats,embeddingIndexSize:this.idToExperienceId.size,hnswIndexSize:this.hnswIndex.getSize("experiences"),recentBufferSize:this.recentExperiences.length}}getReservoirStats(){if(!this.reservoirBuffer)return null;let e=this.reservoirBuffer.getStats();return{size:e.size,totalAdmitted:e.totalAdmitted,totalRejected:e.totalRejected,tierCounts:e.tierCounts}}async dispose(){this.hnswIndex.clearIndex("experiences"),this.idToExperienceId.clear(),this.experienceIdToHnswId.clear(),this.recentExperiences.clear(),this.prepared.clear(),this.db=null,this.unifiedMemory=null,this.initialized=!1,console.log("[ExperienceReplay] Disposed")}ensureInitialized(){if(!this.initialized)throw new Error("ExperienceReplay not initialized. Call initialize() first.")}rowToExperience(e){return e?{id:e.id,trajectoryId:e.id,task:e.task,domain:e.domain,strategy:e.agent,keyActions:x(e.steps_json||"[]"),qualityScore:e.quality,applicationCount:e.application_count??0,successRate:e.success?1:0,avgTokenSavings:e.avg_token_savings??0,embedding:e.embedding&&e.embedding_dimension?this.bufferToFloatArray(e.embedding,e.embedding_dimension):void 0,createdAt:new Date(e.started_at),lastAppliedAt:e.last_applied_at?new Date(e.last_applied_at):void 0,originalMetrics:x(e.routing_json||"{}"),tags:x(e.tags||"[]")}:null}floatArrayToBuffer(e){let t=Buffer.alloc(e.length*4);for(let n=0;n<e.length;n++)t.writeFloatLE(e[n],n*4);return t}bufferToFloatArray(e,t){let n=[];for(let r=0;r<t;r++)n.push(e.readFloatLE(r*4));return n}};function Rn(u={}){return new Ct(u)}te();j();var Ks={driftThreshold:.3,mergeSimilarityThreshold:.85,minQualityForRetention:.3,obsoleteDaysThreshold:60,maxPatternsPerDomain:200,embedding:{modelName:"Xenova/all-MiniLM-L6-v2",quantized:!0},historyBufferSize:500},Tt=class{config;unifiedMemory=null;db=null;prepared=new Map;initialized=!1;embeddingCache=new Map;recentEvents;stats={versionsTracked:0,driftDetections:0,significantDrifts:0,patternsMerged:0,patternsPruned:0,consolidationRuns:0};constructor(e={}){this.config={...Ks,...e},this.recentEvents=new fe(this.config.historyBufferSize)}async initialize(){this.initialized||(this.unifiedMemory=z(),await this.unifiedMemory.initialize(),this.db=this.unifiedMemory.getDatabase(),this.ensureSchema(),this.prepareStatements(),await this.loadEmbeddingCache(),this.initialized=!0,console.log("[PatternEvolution] Initialized"))}ensureSchema(){if(!this.db)throw new Error("Database not initialized");this.db.exec(`
|
|
211
151
|
CREATE TABLE IF NOT EXISTS pattern_versions (
|
|
212
152
|
id TEXT PRIMARY KEY,
|
|
213
153
|
pattern_id TEXT NOT NULL,
|
|
@@ -279,16 +219,16 @@ import{b as bt,c as Ct}from"./chunk-ZWSRIJ2T.js";import{a as Se}from"./chunk-ROE
|
|
|
279
219
|
FROM qe_patterns
|
|
280
220
|
WHERE qe_domain = ? AND quality_score < ?
|
|
281
221
|
ORDER BY quality_score ASC
|
|
282
|
-
`))}async loadEmbeddingCache(){let e=this.prepared.get("getAllPatternEmbeddings");if(!e)return;let t=e.all();this.embeddingCache.clear();for(let n of t){let r=this.bufferToFloatArray(n.embedding,n.dimension);this.embeddingCache.set(n.pattern_id,r)}console.log(`[PatternEvolution] Loaded ${this.embeddingCache.size} pattern embeddings`)}async trackVersion(e,t,n=[],r="manual"){this.ensureInitialized();let a=(this.prepared.get("getVersionCount")?.get(e)?.count??0)+1,l=this.prepared.get("getPattern")?.get(e),c
|
|
222
|
+
`))}async loadEmbeddingCache(){let e=this.prepared.get("getAllPatternEmbeddings");if(!e)return;let t=e.all();this.embeddingCache.clear();for(let n of t){let r=this.bufferToFloatArray(n.embedding,n.dimension);this.embeddingCache.set(n.pattern_id,r)}console.log(`[PatternEvolution] Loaded ${this.embeddingCache.size} pattern embeddings`)}async trackVersion(e,t,n=[],r="manual"){this.ensureInitialized();let a=(this.prepared.get("getVersionCount")?.get(e)?.count??0)+1,l=this.prepared.get("getPattern")?.get(e),c=$(),d={id:c,patternId:e,version:a,embedding:t,changes:n,qualityScore:l?.quality_score??.5,successRate:l?.success_rate??.5,timestamp:new Date,trigger:r},m=this.prepared.get("insertVersion");if(m){let g=this.floatArrayToBuffer(t);m.run(c,e,a,g,t.length,JSON.stringify(n),d.qualityScore,d.successRate,r)}return this.embeddingCache.set(e,t),await this.recordEvent(e,"updated",{version:a,changes:n,trigger:r}),this.stats.versionsTracked++,d}async detectDrift(e){this.ensureInitialized(),this.stats.driftDetections++;let t=this.prepared.get("getVersionHistory");if(!t)return null;let n=t.all(e,10);if(n.length<2)return null;let r=n[0],i=n[n.length-1],s=this.bufferToFloatArray(r.embedding,r.embedding_dimension),a=this.bufferToFloatArray(i.embedding,i.embedding_dimension),l=1-mt(s,a),c=l>this.config.driftThreshold;c&&this.stats.significantDrifts++;let d,m;return l<.1?(d="keep",m="Pattern is stable with minimal drift"):l<this.config.driftThreshold?(d="keep",m="Drift is within acceptable range"):l<.6?(d="update",m="Moderate drift detected - consider versioning"):l<.8?(d="split",m="Significant drift - pattern may represent multiple concepts"):(d="archive",m="Severe drift - pattern has fundamentally changed"),{patternId:e,currentEmbedding:s,originalEmbedding:a,driftScore:l,hasSignificantDrift:c,recommendation:d,reason:m}}async findMergeCandidates(e){this.ensureInitialized();let t=this.prepared.get("getPatternEmbeddings");if(!t)return[];let n=t.all(e),r=[],i=this.prepared.get("getPattern");for(let s=0;s<n.length;s++)for(let a=s+1;a<n.length;a++){let o=this.bufferToFloatArray(n[s].embedding,n[s].dimension),l=this.bufferToFloatArray(n[a].embedding,n[a].dimension),c=mt(o,l);if(c>=this.config.mergeSimilarityThreshold){let d=i?.get(n[s].pattern_id),m=i?.get(n[a].pattern_id),g=((d?.quality_score??0)+(m?.quality_score??0))/2,p=c*g;r.push({patternId1:n[s].pattern_id,patternId2:n[a].pattern_id,similarity:c,mergeBenefit:p,suggestedName:`${d?.name??"Pattern"} + ${m?.name??"Pattern"}`})}}return r.sort((s,a)=>a.mergeBenefit-s.mergeBenefit)}async findPruneCandidates(e){this.ensureInitialized();let t=[],n=this.prepared.get("getPatternsForPruning");if(n){let i=n.all(e,this.config.minQualityForRetention);for(let s of i){let a=s.last_used_at?new Date(s.last_used_at):new Date(0),o=Math.floor((Date.now()-a.getTime())/(1e3*60*60*24)),l;o>this.config.obsoleteDaysThreshold?l="obsolete":(s.quality_score??0)<.2?l="low-quality":l="unused",t.push({patternId:s.id,name:s.name,reason:l,qualityScore:s.quality_score??0,daysSinceLastUse:o})}}let r=await this.findMergeCandidates(e);for(let i of r){let s=this.prepared.get("getPattern")?.get(i.patternId1),a=this.prepared.get("getPattern")?.get(i.patternId2);if(s&&a&&Math.abs((s.quality_score??0)-(a.quality_score??0))>.3){let l=(s.quality_score??0)<(a.quality_score??0)?s:a,c=(s.quality_score??0)>=(a.quality_score??0)?s:a;t.find(d=>d.patternId===l.id)||t.push({patternId:l.id,name:l.name,reason:"redundant",qualityScore:l.quality_score??0,daysSinceLastUse:0,similarPatterns:[c.id]})}}return t}async mergePatterns(e,t,n){if(this.ensureInitialized(),!this.db)return null;let r=this.prepared.get("getPattern"),i=r?.get(e),s=r?.get(t);if(!i||!s)return null;let[a,o]=(i.quality_score??0)>=(s.quality_score??0)?[i,s]:[s,i];n&&this.db.prepare("UPDATE qe_patterns SET name = ? WHERE id = ?").run(n,a.id);let l=(a.usage_count??0)+(o.usage_count??0),c=(a.successful_uses??0)+(o.successful_uses??0),d=l>0?c/l:0;this.db.prepare(`
|
|
283
223
|
UPDATE qe_patterns SET
|
|
284
224
|
usage_count = ?,
|
|
285
225
|
successful_uses = ?,
|
|
286
226
|
success_rate = ?,
|
|
287
227
|
updated_at = datetime('now')
|
|
288
228
|
WHERE id = ?
|
|
289
|
-
`).run(l,c,d,a.id);let m=this.prepared.get("insertRelationship");return m&&m.run(
|
|
229
|
+
`).run(l,c,d,a.id);let m=this.prepared.get("insertRelationship");return m&&m.run($(),o.id,a.id,"merged",1),this.db.prepare("UPDATE qe_patterns SET tier = 'archived' WHERE id = ?").run(o.id),await this.recordEvent(a.id,"merged",{absorbedFrom:o.id}),await this.recordEvent(o.id,"archived",{mergedInto:a.id}),this.stats.patternsMerged++,a.id}async autoConsolidate(e){this.ensureInitialized(),this.stats.consolidationRuns++;let t=0,n=0,r=await this.findMergeCandidates(e);for(let a of r.slice(0,5))await this.mergePatterns(a.patternId1,a.patternId2)&&t++;let i=await this.findPruneCandidates(e);for(let a of i)(a.reason==="low-quality"||a.reason==="obsolete")&&this.db&&(this.db.prepare("DELETE FROM qe_patterns WHERE id = ?").run(a.patternId),this.embeddingCache.delete(a.patternId),await this.recordEvent(a.patternId,"pruned",{reason:a.reason}),n++,this.stats.patternsPruned++);let s=this.db?.prepare(`
|
|
290
230
|
SELECT COUNT(*) as count FROM qe_patterns WHERE qe_domain = ? AND tier != 'archived'
|
|
291
|
-
`).get(e);return{merged:t,pruned:n,retained:s?.count??0}}async getEvolutionHistory(e,t=20){this.ensureInitialized();let i=(this.prepared.get("getVersionHistory")?.all(e,t)??[]).map(l=>({id:l.id,patternId:l.pattern_id,version:l.version,embedding:this.bufferToFloatArray(l.embedding,l.embedding_dimension),changes:P(l.changes||"[]"),qualityScore:l.quality_score,successRate:l.success_rate,timestamp:new Date(l.created_at),trigger:l.trigger})),o=(this.prepared.get("getEvents")?.all(e,t)??[]).map(l=>({id:l.id,patternId:l.pattern_id,eventType:l.event_type,details:P(l.details||"{}"),timestamp:new Date(l.created_at)}));return{versions:i,events:o}}async recordEvent(e,t,n){let r=this.prepared.get("insertEvent");if(r){let i={id:L(),patternId:e,eventType:t,details:n,timestamp:new Date};r.run(i.id,e,t,JSON.stringify(n)),this.recentEvents.push(i)}}getStats(){return{...this.stats,embeddingCacheSize:this.embeddingCache.size,recentEventsSize:this.recentEvents.length}}async dispose(){this.embeddingCache.clear(),this.recentEvents.clear(),this.prepared.clear(),this.db=null,this.unifiedMemory=null,this.initialized=!1,console.log("[PatternEvolution] Disposed")}ensureInitialized(){if(!this.initialized)throw new Error("PatternEvolution not initialized. Call initialize() first.")}floatArrayToBuffer(e){let t=Buffer.alloc(e.length*4);for(let n=0;n<e.length;n++)t.writeFloatLE(e[n],n*4);return t}bufferToFloatArray(e,t){let n=[];for(let r=0;r<t;r++)n.push(e.readFloatLE(r*4));return n}};function Mn(u={}){return new Rt(u)}k();var ia={base:{},trajectoryTracker:{},experienceReplay:{},patternEvolution:{},enableTrajectories:!0,enableExperienceReplay:!0,enablePatternEvolution:!0,autoStoreExperiences:!0,autoConsolidate:!0,consolidationIntervalMs:3600*1e3},Dn=class{config;reasoningBank=null;trajectoryTracker=null;experienceReplay=null;patternEvolution=null;initialized=!1;consolidationTimer=null;stats={tasksRouted:0,trajectoriesCompleted:0,experiencesApplied:0,tokensSavedEstimate:0,avgTaskSpeedupPercent:0,successRate:0,totalSuccesses:0,totalTasks:0};constructor(e={}){this.config={...ia,...e}}async initialize(){if(this.initialized)return;let e=performance.now();this.reasoningBank=xn(this.config.base),await this.reasoningBank.initialize(),this.config.enableTrajectories&&(this.trajectoryTracker=An(this.config.trajectoryTracker),await this.trajectoryTracker.initialize()),this.config.enableExperienceReplay&&(this.experienceReplay=kn(this.config.experienceReplay),await this.experienceReplay.initialize()),this.config.enablePatternEvolution&&(this.patternEvolution=Mn(this.config.patternEvolution),await this.patternEvolution.initialize()),this.config.autoConsolidate&&this.patternEvolution&&this.startConsolidationTimer(),this.initialized=!0;let t=performance.now()-e;console.log(`[EnhancedReasoningBank] Initialized in ${t.toFixed(0)}ms`)}async routeTaskWithExperience(e){this.ensureInitialized(),this.stats.tasksRouted++;try{let t=await this.reasoningBank.routeTask(e);if(!t.success)return t;let n={...t.value};if(this.experienceReplay){let r=await this.experienceReplay.getGuidance(e.task,e.domain);if(r){n.experienceGuidance=r,n.guidance=[`Strategy: ${r.recommendedStrategy}`,...r.suggestedActions.map(i=>`Action: ${i}`),...n.guidance],this.stats.tokensSavedEstimate+=r.estimatedTokenSavings,this.stats.experiencesApplied++;for(let i of r.sourceExperiences)this.experienceReplay.recordApplication(i.id,e.task,!0,Math.round(r.estimatedTokenSavings)).catch(s=>{console.warn(`[EnhancedAdapter] Failed to record experience application: ${s}`)})}}if(this.trajectoryTracker){let r=await this.trajectoryTracker.findSimilarTrajectories(e.task,3);r.length>0&&(n.similarTrajectories=r.map(i=>({id:i.id,task:i.task,outcome:i.outcome,similarity:.8})))}return I(n)}catch(t){return q(z(t))}}async startTaskTrajectory(e,t={}){if(this.ensureInitialized(),!this.trajectoryTracker)throw new Error("Trajectory tracking not enabled");return this.trajectoryTracker.startTrajectory(e,t)}async recordTaskStep(e,t,n,r){if(this.ensureInitialized(),!this.trajectoryTracker)throw new Error("Trajectory tracking not enabled");await this.trajectoryTracker.recordStep(e,t,n,r)}async endTaskTrajectory(e,t,n){if(this.ensureInitialized(),!this.trajectoryTracker)throw new Error("Trajectory tracking not enabled");let r=await this.trajectoryTracker.endTrajectory(e,t,n);if(this.stats.trajectoriesCompleted++,this.stats.totalTasks++,t&&this.stats.totalSuccesses++,this.stats.successRate=this.stats.totalSuccesses/this.stats.totalTasks,this.config.autoStoreExperiences&&t&&this.experienceReplay){let i=this.deriveStrategy(r);await this.experienceReplay.storeExperience(r,i)}return r}async getTrajectory(e){return this.ensureInitialized(),this.trajectoryTracker?.getTrajectory(e)??null}async getExperienceGuidance(e,t){if(this.ensureInitialized(),!this.experienceReplay)return null;let n=await this.experienceReplay.getGuidance(e,t);if(n){this.stats.experiencesApplied++;for(let r of n.sourceExperiences)this.experienceReplay.recordApplication(r.id,e,!0,Math.round(n.estimatedTokenSavings)).catch(i=>{console.warn(`[EnhancedAdapter] Failed to record experience application: ${i}`)})}return n}async recordExperienceApplication(e,t,n,r=0){this.ensureInitialized(),this.experienceReplay&&(await this.experienceReplay.recordApplication(e,t,n,r),this.stats.tokensSavedEstimate+=r)}async storePattern(e){this.ensureInitialized();let t=await this.reasoningBank.storeQEPattern(e);return t.success&&this.patternEvolution&&t.value.embedding&&await this.patternEvolution.trackVersion(t.value.id,t.value.embedding,["Initial version"],"initial"),t}async searchPatterns(e,t){return this.ensureInitialized(),this.reasoningBank.searchQEPatterns(e,t)}async recordPatternOutcome(e){this.ensureInitialized();let t=await this.reasoningBank.recordOutcome(e);if(this.patternEvolution&&e.success!==void 0){let n=await this.patternEvolution.detectDrift(e.patternId);n?.hasSignificantDrift&&console.log(`[EnhancedReasoningBank] Pattern drift detected: ${e.patternId}, recommendation: ${n.recommendation}`)}return t}async detectPatternDrift(e){return this.ensureInitialized(),this.patternEvolution?.detectDrift(e)??null}async findMergeCandidates(e){return this.ensureInitialized(),this.patternEvolution?.findMergeCandidates(e)??[]}async consolidatePatterns(e){return this.ensureInitialized(),this.patternEvolution?this.patternEvolution.autoConsolidate(e):{merged:0,pruned:0,retained:0}}async getPatternHistory(e){return this.ensureInitialized(),this.patternEvolution?.getEvolutionHistory(e)??null}async getStats(){return this.ensureInitialized(),{adapter:this.stats,reasoningBank:await this.reasoningBank.getQEStats(),trajectoryTracker:this.trajectoryTracker?.getStats(),experienceReplay:this.experienceReplay?.getStats(),patternEvolution:this.patternEvolution?.getStats()}}async dispose(){this.consolidationTimer&&(clearInterval(this.consolidationTimer),this.consolidationTimer=null),await this.patternEvolution?.dispose(),await this.experienceReplay?.dispose(),await this.trajectoryTracker?.dispose(),await this.reasoningBank?.dispose(),this.patternEvolution=null,this.experienceReplay=null,this.trajectoryTracker=null,this.reasoningBank=null,this.initialized=!1,console.log("[EnhancedReasoningBank] Disposed")}ensureInitialized(){if(!this.initialized||!this.reasoningBank)throw new Error("EnhancedReasoningBankAdapter not initialized. Call initialize() first.")}startConsolidationTimer(){this.consolidationTimer=setInterval(async()=>{try{let e=["test-generation","coverage-analysis","test-execution","quality-assessment"];for(let t of e){let n=await this.patternEvolution.autoConsolidate(t);(n.merged>0||n.pruned>0)&&console.log(`[EnhancedReasoningBank] Consolidated ${t}: merged=${n.merged}, pruned=${n.pruned}, retained=${n.retained}`)}}catch(e){console.error("[EnhancedReasoningBank] Consolidation error:",e)}},this.config.consolidationIntervalMs)}deriveStrategy(e){let t=e.steps.filter(n=>n.result.outcome==="success").map(n=>n.action);return t.length===0?`Attempted ${e.steps.length} actions for: ${e.task}`:`Used ${t.join(" -> ")} pattern for: ${e.task.substring(0,50)}`}};function Kl(u={}){return new Dn(u)}import{randomUUID as fa}from"crypto";var O=class extends Error{constructor(t,n,r){super(n);this.type=t;this.details=r;this.name="EmbeddingError"}type;details};var xt=class{cache;maxSize;hits=0;misses=0;constructor(e){this.maxSize=e,this.cache=new Map}get(e){let t=this.cache.get(e);if(t)return this.hits++,this.cache.delete(e),this.cache.set(e,t),t;this.misses++}set(e,t){if(this.cache.size>=this.maxSize){let n=this.cache.keys().next().value;n!==void 0&&this.cache.delete(n)}this.cache.set(e,t)}clear(){this.cache.clear(),this.hits=0,this.misses=0}getStats(){return{hits:this.hits,misses:this.misses,size:this.cache.size}}},we=class{config;cache;totalGenerated=0;generationTimes=[];isInitialized=!1;onnxRuntime=null;constructor(e={}){this.config={model:e.model??"all-MiniLM-L6-v2",normalize:e.normalize??!0,hyperbolic:e.hyperbolic??!1,cacheSize:e.cacheSize??256,curvature:e.curvature??-1},this.cache=new xt(this.config.cacheSize)}async initialize(){if(!this.isInitialized)try{let{computeRealEmbedding:e}=await import("./real-embeddings-PZUZ5RXJ.js");this.onnxRuntime={generateEmbedding:async(t,n)=>{let r=await e(t);if(this.config.normalize){let i=Math.sqrt(r.reduce((s,a)=>s+a*a,0));if(i>0)return r.map(s=>s/i)}return r},isAvailable:()=>!0},this.isInitialized=!0}catch(e){throw new O("RUNTIME_UNAVAILABLE","Failed to initialize ONNX runtime",e)}}async generate(e){if(this.isInitialized||await this.initialize(),!e||e.trim().length===0)throw new O("INVALID_INPUT","Text cannot be empty");let t=this.getCacheKey(e),n=this.cache.get(t);if(n)return n;let r=Date.now();try{if(!this.onnxRuntime)throw new O("RUNTIME_UNAVAILABLE","ONNX runtime not available");let i=await this.onnxRuntime.generateEmbedding(e,this.config.model),s=i,a=!1;this.config.hyperbolic&&(s=this.euclideanToPoincare(i),a=!0);let o={vector:s,dimensions:s.length,model:this.config.model,isHyperbolic:a};return this.cache.set(t,o),this.totalGenerated++,this.generationTimes.push(Date.now()-r),this.generationTimes.length>100&&this.generationTimes.shift(),o}catch(i){throw new O("MODEL_LOAD_FAILED",`Failed to generate embedding: ${i instanceof Error?i.message:"Unknown error"}`,i)}}async generateBatch(e){if(!e.texts||e.texts.length===0)throw new O("INVALID_INPUT","Batch request must contain at least one text");let t=Date.now(),n=0,r=[],i={...this.config};e.config&&(this.config={...this.config,...e.config});try{for(let s of e.texts){let a=this.getCacheKey(s),o=this.cache.get(a);if(o)r.push(o),n++;else{let l=await this.generate(s);r.push(l)}}return{embeddings:r,duration:Date.now()-t,cacheHits:n}}finally{this.config=i}}getStats(){let e=this.cache.getStats(),t=this.generationTimes.length>0?this.generationTimes.reduce((n,r)=>n+r,0)/this.generationTimes.length:0;return{totalGenerated:this.totalGenerated,cacheHits:e.hits,cacheMisses:e.misses,avgGenerationTime:t,currentModel:this.config.model,vectorsStored:e.size}}clearCache(){this.cache.clear()}updateConfig(e){let t=e.model&&e.model!==this.config.model;this.config={...this.config,...e},e.cacheSize!==void 0&&e.cacheSize!==this.cache.getStats().size&&(this.cache=new xt(e.cacheSize)),t&&(this.isInitialized=!1)}getCacheKey(e){return`${this.config.model}:${this.config.hyperbolic}:${e}`}euclideanToPoincare(e){let t=Math.sqrt(e.reduce((s,a)=>s+a*a,0));if(t===0)return e;let n=Math.abs(this.config.curvature),r=Math.sqrt(n),i=Math.tanh(r*t/2)/(r*t);return e.map(s=>s*i)}isReady(){return this.isInitialized&&this.onnxRuntime!==null}};var Re=class{embeddings;searchCount=0;searchTimes=[];constructor(){this.embeddings=new Map}store(e){this.embeddings.set(e.id,e)}storeBatch(e){for(let t of e)this.store(t)}remove(e){return this.embeddings.delete(e)}clear(){this.embeddings.clear()}async search(e,t={}){let n=Date.now(),r={metric:t.metric??"cosine",topK:t.topK??5,threshold:t.threshold??.5,namespace:t.namespace};try{let i=Array.from(this.embeddings.values());r.namespace&&(i=i.filter(c=>c.namespace===r.namespace));let s=[];for(let c of i){if(c.embedding.dimensions!==e.dimensions)continue;let d=this.calculateSimilarity(e.vector,c.embedding.vector,r.metric);(r.metric==="cosine"?d>=r.threshold:d<=r.threshold)&&s.push({stored:c,score:d})}let a=r.metric==="cosine"?-1:1;s.sort((c,d)=>a*(c.score-d.score));let l=s.slice(0,r.topK).map(({stored:c,score:d})=>({text:c.text,embedding:c.embedding,score:d,metadata:c.metadata}));return this.searchCount++,this.searchTimes.push(Date.now()-n),this.searchTimes.length>100&&this.searchTimes.shift(),l}catch(i){throw new O("DIMENSION_MISMATCH",`Search failed: ${i instanceof Error?i.message:"Unknown error"}`,i)}}async findMostSimilar(e,t={}){let n=await this.search(e,{...t,topK:1});return n.length>0?n[0]:null}calculateSimilarity(e,t,n){if(e.length!==t.length)throw new O("DIMENSION_MISMATCH",`Vector dimensions do not match: ${e.length} vs ${t.length}`);switch(n){case"cosine":return this.cosineSimilarity(e,t);case"euclidean":return this.euclideanDistance(e,t);case"poincare":return this.poincareDistance(e,t);default:throw new O("INVALID_INPUT",`Unknown similarity metric: ${n}`)}}getStats(){let e=this.searchTimes.length>0?this.searchTimes.reduce((t,n)=>t+n,0)/this.searchTimes.length:0;return{searchCount:this.searchCount,avgSearchTime:e,storedCount:this.embeddings.size}}getAll(e){let t=Array.from(this.embeddings.values());return e?t.filter(n=>n.namespace===e):t}get(e){return this.embeddings.get(e)}cosineSimilarity(e,t){let n=0,r=0,i=0;for(let a=0;a<e.length;a++)n+=e[a]*t[a],r+=e[a]*e[a],i+=t[a]*t[a];let s=Math.sqrt(r)*Math.sqrt(i);return s===0?0:n/s}euclideanDistance(e,t){let n=0;for(let r=0;r<e.length;r++){let i=e[r]-t[r];n+=i*i}return Math.sqrt(n)}poincareDistance(e,t,n=-1){let r=Math.abs(n),i=Math.sqrt(r),s=e.reduce((p,g)=>p+g*g,0),a=t.reduce((p,g)=>p+g*g,0),o=0;for(let p=0;p<e.length;p++){let g=e[p]-t[p];o+=g*g}let l=2*o,c=(1-s)*(1-a);if(c<=0)return 1/0;let d=l/c;return Math.acosh(1+d)/i}async searchBatch(e,t={}){let n=[];for(let r of e){let i=await this.search(r,t);n.push(i)}return n}async findInRadius(e,t,n="cosine"){return this.search(e,{metric:n,threshold:t,topK:this.embeddings.size})}};var xe=class{config;constructor(e={}){if(this.config={curvature:e.curvature??-1,epsilon:e.epsilon??1e-7},this.config.curvature>=0)throw new O("HYPERBOLIC_ERROR","Curvature must be negative for hyperbolic space")}euclideanToPoincare(e){if(e.isHyperbolic)return e;let t=e.vector,n=this.norm(t);if(n<this.config.epsilon)return{...e,isHyperbolic:!0};let r=Math.abs(this.config.curvature),i=Math.sqrt(r),s=Math.tanh(i*n/2)/(i*n),a=t.map(l=>l*s),o=this.norm(a);if(o>=1-this.config.epsilon)throw new O("HYPERBOLIC_ERROR",`Poincar\xE9 ball constraint violated: norm = ${o}`);return{vector:a,dimensions:e.dimensions,model:e.model,isHyperbolic:!0}}poincareToEuclidean(e){if(!e.isHyperbolic)return e;let t=e.vector,n=this.norm(t);if(n<this.config.epsilon)return{...e,isHyperbolic:!1};let r=Math.abs(this.config.curvature),i=Math.sqrt(r),s=i*n;if(s>=1)throw new O("HYPERBOLIC_ERROR","Point is on or outside Poincar\xE9 ball boundary");let a=2/i*Math.atanh(s)/n;return{vector:t.map(l=>l*a),dimensions:e.dimensions,model:e.model,isHyperbolic:!1}}distance(e,t){if(e.dimensions!==t.dimensions)throw new O("DIMENSION_MISMATCH","Embeddings must have same dimensions");if(!e.isHyperbolic||!t.isHyperbolic)throw new O("HYPERBOLIC_ERROR","Both embeddings must be in hyperbolic space");let n=e.vector,r=t.vector,i=Math.abs(this.config.curvature),s=Math.sqrt(i),a=this.normSquared(n),o=this.normSquared(r),c=2*this.euclideanDistanceSquared(n,r),d=(1-a)*(1-o);if(d<=this.config.epsilon)return 1/0;let m=c/d;return Math.acosh(1+m)/s}midpoint(e,t){if(e.dimensions!==t.dimensions)throw new O("DIMENSION_MISMATCH","Embeddings must have same dimensions");if(!e.isHyperbolic||!t.isHyperbolic)throw new O("HYPERBOLIC_ERROR","Both embeddings must be in hyperbolic space");let n=e.vector,r=t.vector;return{vector:this.mobiusAddition(n,this.mobiusScalarMultiply(this.mobiusAddition(this.mobiusNegate(n),r),.5)),dimensions:e.dimensions,model:e.model,isHyperbolic:!0}}mobiusAddition(e,t){let n=Math.abs(this.config.curvature),r=this.dot(e,t),i=this.normSquared(e),s=this.normSquared(t),a=1+2*n*r+n*s,o=1-n*i,l=1+2*n*r+n*n*i*s;if(Math.abs(l)<this.config.epsilon)throw new O("HYPERBOLIC_ERROR","M\xF6bius addition denominator is zero");return e.map((d,m)=>(a*d+o*t[m])/l)}mobiusScalarMultiply(e,t){let n=Math.abs(this.config.curvature),r=Math.sqrt(n),i=this.norm(e);if(i<this.config.epsilon)return e;let s=r*i;if(Math.abs(s)>=1)throw new O("HYPERBOLIC_ERROR","M\xF6bius scalar multiplication out of bounds");let a=Math.tanh(t*Math.atanh(s))/(r*i);return e.map(o=>o*a)}mobiusNegate(e){return e.map(t=>-t)}projectToBall(e){let t=this.norm(e);if(t>=1-this.config.epsilon){let n=(1-this.config.epsilon)/t;return e.map(r=>r*n)}return e}norm(e){return Math.sqrt(this.normSquared(e))}normSquared(e){return e.reduce((t,n)=>t+n*n,0)}dot(e,t){return e.reduce((n,r,i)=>n+r*t[i],0)}euclideanDistanceSquared(e,t){return e.reduce((n,r,i)=>{let s=r-t[i];return n+s*s},0)}updateConfig(e){if(e.curvature!==void 0&&e.curvature>=0)throw new O("HYPERBOLIC_ERROR","Curvature must be negative");this.config={...this.config,...e}}getConfig(){return{...this.config}}};ee();var Ue=class{generator;search;hyperbolic;isInitialized=!1;constructor(e={}){this.generator=new we(e.embedding),this.search=new Re,this.hyperbolic=new xe(e.hyperbolic),e.autoInitialize!==!1&&this.initialize().catch(t=>{console.error("Failed to auto-initialize ONNX embeddings:",t)})}async initialize(){if(!this.isInitialized)try{await this.generator.initialize(),this.isInitialized=!0}catch(e){throw new O("RUNTIME_UNAVAILABLE","Failed to initialize ONNX embeddings adapter",e)}}async getHealth(){try{let e=this.generator.isReady();return{available:e,modelLoaded:e?this.getStats().currentModel:null,system:{memory:process.memoryUsage().heapUsed,threads:1}}}catch(e){return{available:!1,modelLoaded:null,error:e instanceof Error?e.message:"Unknown error",system:{memory:process.memoryUsage().heapUsed,threads:0}}}}async generateEmbedding(e){return await this.ensureInitialized(),this.generator.generate(e)}async generateBatch(e){return await this.ensureInitialized(),this.generator.generateBatch(e)}async generateAndStore(e,t){let n=await this.generateEmbedding(e),r={id:t?.id??this.generateId(),text:e,embedding:n,namespace:t?.namespace,metadata:t?.customData,createdAt:Date.now()};this.search.store(r);try{let i=$();await i.initialize(),await i.vectorStore(r.id,r.embedding.vector,r.namespace??"onnx",{text:r.text,customData:r.metadata,createdAt:r.createdAt})}catch{}return r}async searchByText(e,t){let n=await this.generateEmbedding(e);return this.search.search(n,t)}async searchByEmbedding(e,t){return this.search.search(e,t)}async findMostSimilar(e,t){let n=await this.generateEmbedding(e);return this.search.findMostSimilar(n,t)}async compareSimilarity(e,t,n="cosine"){let[r,i]=await this.generateBatch({texts:[e,t]}).then(s=>s.embeddings);return this.search.calculateSimilarity(r.vector,i.vector,n)}storeEmbedding(e){this.search.store(e)}storeBatch(e){this.search.storeBatch(e)}removeEmbedding(e){return this.search.remove(e)}getEmbedding(e){return this.search.get(e)}getAllEmbeddings(e){return this.search.getAll(e)}clearEmbeddings(){this.search.clear()}toHyperbolic(e){return this.hyperbolic.euclideanToPoincare(e)}toEuclidean(e){return this.hyperbolic.poincareToEuclidean(e)}hyperbolicDistance(e,t){return this.hyperbolic.distance(e,t)}hyperbolicMidpoint(e,t){return this.hyperbolic.midpoint(e,t)}projectToBall(e){return this.hyperbolic.projectToBall(e)}getStats(){let e=this.generator.getStats(),t=this.search.getStats();return{totalGenerated:e.totalGenerated??0,cacheHits:e.cacheHits??0,cacheMisses:e.cacheMisses??0,totalSearches:t.searchCount,avgGenerationTime:e.avgGenerationTime??0,avgSearchTime:t.avgSearchTime,currentModel:e.currentModel??"all-MiniLM-L6-v2",vectorsStored:t.storedCount}}updateEmbeddingConfig(e){this.generator.updateConfig(e)}updateHyperbolicConfig(e){this.hyperbolic.updateConfig(e)}clearCaches(){this.generator.clearCache()}reset(){this.clearCaches(),this.clearEmbeddings()}async bridgeToMCPGenerate(e,t=!1){let n=await this.generateEmbedding(e);return t?this.toHyperbolic(n):n}async bridgeToMCPSearch(e,t){return this.searchByText(e,t)}async bridgeToMCPCompare(e,t,n="cosine"){return this.compareSimilarity(e,t,n)}async ensureInitialized(){this.isInitialized||await this.initialize()}generateId(){return`emb_${Date.now()}_${fa().slice(0,9)}`}isReady(){return this.isInitialized&&this.generator.isReady()}};function kt(u){return new Ue(u)}var In={enabled:!0,dbPath:".agentic-qe/memory.db",maxOutcomes:1e5,retentionDays:90,autoCleanup:!0,cleanupIntervalMs:3600*1e3};ee();k();U();var wa={enabled:!0,haikuThreshold:.8,sonnetThreshold:.4,includeHealthSnapshot:!1,enableLogging:!0},_n=class{config;minCutService;constructor(e){this.config={...wa,...e},this.minCutService=ri()}route(e){let t=Date.now();if(!this.config.enabled)return this.createFallbackResult(e,t,"MinCut routing disabled");let n=e.agentTopology||this.config.defaultTopology;if(!n||n.length===0)return this.createFallbackResult(e,t,"No agent topology available for mincut analysis");try{let r=this.minCutService.computeRoutingTier(e.task,n),i=this.routingTierToModelTier(r.tier);e.isCritical&&i<2&&(i=2);let s=this.modelTierToLabel(i),a;if(this.config.includeHealthSnapshot){let c=e.taskGraph||this.minCutService.buildTaskGraphFromTopology(n);a=this.minCutService.getStructuralHealth(c)}let o=Date.now()-t,l={modelTier:i,tierLabel:s,lambda:r.lambda,normalizedLambda:r.normalizedLambda,confidence:r.confidence,rationale:r.rationale,usedMinCut:!0,healthSnapshot:a,decisionTimeMs:o};return this.config.enableLogging&&this.logDecision(l),l}catch(r){return this.createFallbackResult(e,t,`MinCut routing error: ${r instanceof Error?r.message:String(r)}`)}}getMinCutService(){return this.minCutService}isEnabled(){return this.config.enabled}routingTierToModelTier(e){switch(e){case 1:return 1;case 2:return 2;case 3:return 4;default:return 2}}modelTierToLabel(e){switch(e){case 0:return"Booster";case 1:return"Haiku";case 2:return"Sonnet";case 3:return"Sonnet-Extended";case 4:return"Opus";default:return"Sonnet"}}createFallbackResult(e,t,n){return{modelTier:(e.isCritical,2),tierLabel:"Sonnet",lambda:0,normalizedLambda:0,confidence:.3,rationale:`Fallback to Sonnet: ${n}`,usedMinCut:!1,decisionTimeMs:Date.now()-t}}logDecision(e){let t=e.usedMinCut?"MinCut":"Fallback";console.error(`[MinCutRouter] [${t}] Tier ${e.modelTier} (${e.tierLabel}) | Lambda: ${e.normalizedLambda.toFixed(3)} | Confidence: ${(e.confidence*100).toFixed(0)}% | Time: ${e.decisionTimeMs}ms`)}};function oi(u){return new _n(u)}import{existsSync as Ra}from"fs";import{join as xa}from"path";var Mt=class{id="memory";name="Pattern Memory";priority=80;maxTokens=2e3;async gather(e){let t=[];try{let n=xa(process.cwd(),".agentic-qe","memory.db");if(!Ra(n))return this.fallbackGather(e);let{openDatabase:r}=await import("./safe-db-PLJRHQIC.js"),i=r(n,{readonly:!0});try{let s=this.extractDomainKeywords(e.taskDescription);if(s.length>0){let a=s.map(()=>"domain LIKE ?").join(" OR "),o=s.map(d=>`%${d}%`),c=i.prepare(`SELECT name, domain, description, confidence
|
|
231
|
+
`).get(e);return{merged:t,pruned:n,retained:s?.count??0}}async getEvolutionHistory(e,t=20){this.ensureInitialized();let i=(this.prepared.get("getVersionHistory")?.all(e,t)??[]).map(l=>({id:l.id,patternId:l.pattern_id,version:l.version,embedding:this.bufferToFloatArray(l.embedding,l.embedding_dimension),changes:x(l.changes||"[]"),qualityScore:l.quality_score,successRate:l.success_rate,timestamp:new Date(l.created_at),trigger:l.trigger})),o=(this.prepared.get("getEvents")?.all(e,t)??[]).map(l=>({id:l.id,patternId:l.pattern_id,eventType:l.event_type,details:x(l.details||"{}"),timestamp:new Date(l.created_at)}));return{versions:i,events:o}}async recordEvent(e,t,n){let r=this.prepared.get("insertEvent");if(r){let i={id:$(),patternId:e,eventType:t,details:n,timestamp:new Date};r.run(i.id,e,t,JSON.stringify(n)),this.recentEvents.push(i)}}getStats(){return{...this.stats,embeddingCacheSize:this.embeddingCache.size,recentEventsSize:this.recentEvents.length}}async dispose(){this.embeddingCache.clear(),this.recentEvents.clear(),this.prepared.clear(),this.db=null,this.unifiedMemory=null,this.initialized=!1,console.log("[PatternEvolution] Disposed")}ensureInitialized(){if(!this.initialized)throw new Error("PatternEvolution not initialized. Call initialize() first.")}floatArrayToBuffer(e){let t=Buffer.alloc(e.length*4);for(let n=0;n<e.length;n++)t.writeFloatLE(e[n],n*4);return t}bufferToFloatArray(e,t){let n=[];for(let r=0;r<t;r++)n.push(e.readFloatLE(r*4));return n}};function Pn(u={}){return new Tt(u)}k();var Xs={base:{},trajectoryTracker:{},experienceReplay:{},patternEvolution:{},enableTrajectories:!0,enableExperienceReplay:!0,enablePatternEvolution:!0,autoStoreExperiences:!0,autoConsolidate:!0,consolidationIntervalMs:3600*1e3},xn=class{config;reasoningBank=null;trajectoryTracker=null;experienceReplay=null;patternEvolution=null;initialized=!1;consolidationTimer=null;stats={tasksRouted:0,trajectoriesCompleted:0,experiencesApplied:0,tokensSavedEstimate:0,avgTaskSpeedupPercent:0,successRate:0,totalSuccesses:0,totalTasks:0};constructor(e={}){this.config={...Xs,...e}}async initialize(){if(this.initialized)return;let e=performance.now();this.reasoningBank=Sn(this.config.base),await this.reasoningBank.initialize(),this.config.enableTrajectories&&(this.trajectoryTracker=wn(this.config.trajectoryTracker),await this.trajectoryTracker.initialize()),this.config.enableExperienceReplay&&(this.experienceReplay=Rn(this.config.experienceReplay),await this.experienceReplay.initialize()),this.config.enablePatternEvolution&&(this.patternEvolution=Pn(this.config.patternEvolution),await this.patternEvolution.initialize()),this.config.autoConsolidate&&this.patternEvolution&&this.startConsolidationTimer(),this.initialized=!0;let t=performance.now()-e;console.log(`[EnhancedReasoningBank] Initialized in ${t.toFixed(0)}ms`)}async routeTaskWithExperience(e){this.ensureInitialized(),this.stats.tasksRouted++;try{let t=await this.reasoningBank.routeTask(e);if(!t.success)return t;let n={...t.value};if(this.experienceReplay){let r=await this.experienceReplay.getGuidance(e.task,e.domain);if(r){n.experienceGuidance=r,n.guidance=[`Strategy: ${r.recommendedStrategy}`,...r.suggestedActions.map(i=>`Action: ${i}`),...n.guidance],this.stats.tokensSavedEstimate+=r.estimatedTokenSavings,this.stats.experiencesApplied++;for(let i of r.sourceExperiences)this.experienceReplay.recordApplication(i.id,e.task,!0,Math.round(r.estimatedTokenSavings)).catch(s=>{console.warn(`[EnhancedAdapter] Failed to record experience application: ${s}`)})}}if(this.trajectoryTracker){let r=await this.trajectoryTracker.findSimilarTrajectories(e.task,3);r.length>0&&(n.similarTrajectories=r.map(i=>({id:i.id,task:i.task,outcome:i.outcome,similarity:.8})))}return I(n)}catch(t){return N(G(t))}}async startTaskTrajectory(e,t={}){if(this.ensureInitialized(),!this.trajectoryTracker)throw new Error("Trajectory tracking not enabled");return this.trajectoryTracker.startTrajectory(e,t)}async recordTaskStep(e,t,n,r){if(this.ensureInitialized(),!this.trajectoryTracker)throw new Error("Trajectory tracking not enabled");await this.trajectoryTracker.recordStep(e,t,n,r)}async endTaskTrajectory(e,t,n){if(this.ensureInitialized(),!this.trajectoryTracker)throw new Error("Trajectory tracking not enabled");let r=await this.trajectoryTracker.endTrajectory(e,t,n);if(this.stats.trajectoriesCompleted++,this.stats.totalTasks++,t&&this.stats.totalSuccesses++,this.stats.successRate=this.stats.totalSuccesses/this.stats.totalTasks,this.config.autoStoreExperiences&&t&&this.experienceReplay){let i=this.deriveStrategy(r);await this.experienceReplay.storeExperience(r,i)}return r}async getTrajectory(e){return this.ensureInitialized(),this.trajectoryTracker?.getTrajectory(e)??null}async getExperienceGuidance(e,t){if(this.ensureInitialized(),!this.experienceReplay)return null;let n=await this.experienceReplay.getGuidance(e,t);if(n){this.stats.experiencesApplied++;for(let r of n.sourceExperiences)this.experienceReplay.recordApplication(r.id,e,!0,Math.round(n.estimatedTokenSavings)).catch(i=>{console.warn(`[EnhancedAdapter] Failed to record experience application: ${i}`)})}return n}async recordExperienceApplication(e,t,n,r=0){this.ensureInitialized(),this.experienceReplay&&(await this.experienceReplay.recordApplication(e,t,n,r),this.stats.tokensSavedEstimate+=r)}async storePattern(e){this.ensureInitialized();let t=await this.reasoningBank.storeQEPattern(e);return t.success&&this.patternEvolution&&t.value.embedding&&await this.patternEvolution.trackVersion(t.value.id,t.value.embedding,["Initial version"],"initial"),t}async searchPatterns(e,t){return this.ensureInitialized(),this.reasoningBank.searchQEPatterns(e,t)}async recordPatternOutcome(e){this.ensureInitialized();let t=await this.reasoningBank.recordOutcome(e);if(this.patternEvolution&&e.success!==void 0){let n=await this.patternEvolution.detectDrift(e.patternId);n?.hasSignificantDrift&&console.log(`[EnhancedReasoningBank] Pattern drift detected: ${e.patternId}, recommendation: ${n.recommendation}`)}return t}async detectPatternDrift(e){return this.ensureInitialized(),this.patternEvolution?.detectDrift(e)??null}async findMergeCandidates(e){return this.ensureInitialized(),this.patternEvolution?.findMergeCandidates(e)??[]}async consolidatePatterns(e){return this.ensureInitialized(),this.patternEvolution?this.patternEvolution.autoConsolidate(e):{merged:0,pruned:0,retained:0}}async getPatternHistory(e){return this.ensureInitialized(),this.patternEvolution?.getEvolutionHistory(e)??null}async getStats(){return this.ensureInitialized(),{adapter:this.stats,reasoningBank:await this.reasoningBank.getQEStats(),trajectoryTracker:this.trajectoryTracker?.getStats(),experienceReplay:this.experienceReplay?.getStats(),patternEvolution:this.patternEvolution?.getStats()}}async dispose(){this.consolidationTimer&&(clearInterval(this.consolidationTimer),this.consolidationTimer=null),await this.patternEvolution?.dispose(),await this.experienceReplay?.dispose(),await this.trajectoryTracker?.dispose(),await this.reasoningBank?.dispose(),this.patternEvolution=null,this.experienceReplay=null,this.trajectoryTracker=null,this.reasoningBank=null,this.initialized=!1,console.log("[EnhancedReasoningBank] Disposed")}ensureInitialized(){if(!this.initialized||!this.reasoningBank)throw new Error("EnhancedReasoningBankAdapter not initialized. Call initialize() first.")}startConsolidationTimer(){this.consolidationTimer=setInterval(async()=>{try{let e=["test-generation","coverage-analysis","test-execution","quality-assessment"];for(let t of e){let n=await this.patternEvolution.autoConsolidate(t);(n.merged>0||n.pruned>0)&&console.log(`[EnhancedReasoningBank] Consolidated ${t}: merged=${n.merged}, pruned=${n.pruned}, retained=${n.retained}`)}}catch(e){console.error("[EnhancedReasoningBank] Consolidation error:",e)}},this.config.consolidationIntervalMs)}deriveStrategy(e){let t=e.steps.filter(n=>n.result.outcome==="success").map(n=>n.action);return t.length===0?`Attempted ${e.steps.length} actions for: ${e.task}`:`Used ${t.join(" -> ")} pattern for: ${e.task.substring(0,50)}`}};function Ll(u={}){return new xn(u)}import{randomUUID as ca}from"crypto";var _=class extends Error{constructor(t,n,r){super(n);this.type=t;this.details=r;this.name="EmbeddingError"}type;details};var St=class{cache;maxSize;hits=0;misses=0;constructor(e){this.maxSize=e,this.cache=new Map}get(e){let t=this.cache.get(e);if(t)return this.hits++,this.cache.delete(e),this.cache.set(e,t),t;this.misses++}set(e,t){if(this.cache.size>=this.maxSize){let n=this.cache.keys().next().value;n!==void 0&&this.cache.delete(n)}this.cache.set(e,t)}clear(){this.cache.clear(),this.hits=0,this.misses=0}getStats(){return{hits:this.hits,misses:this.misses,size:this.cache.size}}},Ee=class{config;cache;totalGenerated=0;generationTimes=[];isInitialized=!1;onnxRuntime=null;constructor(e={}){this.config={model:e.model??"all-MiniLM-L6-v2",normalize:e.normalize??!0,hyperbolic:e.hyperbolic??!1,cacheSize:e.cacheSize??256,curvature:e.curvature??-1},this.cache=new St(this.config.cacheSize)}async initialize(){if(!this.isInitialized)try{let{computeRealEmbedding:e}=await import("./real-embeddings-VD3EVV3U.js");this.onnxRuntime={generateEmbedding:async(t,n)=>{let r=await e(t);if(this.config.normalize){let i=Math.sqrt(r.reduce((s,a)=>s+a*a,0));if(i>0)return r.map(s=>s/i)}return r},isAvailable:()=>!0},this.isInitialized=!0}catch(e){throw new _("RUNTIME_UNAVAILABLE","Failed to initialize ONNX runtime",e)}}async generate(e){if(this.isInitialized||await this.initialize(),!e||e.trim().length===0)throw new _("INVALID_INPUT","Text cannot be empty");let t=this.getCacheKey(e),n=this.cache.get(t);if(n)return n;let r=Date.now();try{if(!this.onnxRuntime)throw new _("RUNTIME_UNAVAILABLE","ONNX runtime not available");let i=await this.onnxRuntime.generateEmbedding(e,this.config.model),s=i,a=!1;this.config.hyperbolic&&(s=this.euclideanToPoincare(i),a=!0);let o={vector:s,dimensions:s.length,model:this.config.model,isHyperbolic:a};return this.cache.set(t,o),this.totalGenerated++,this.generationTimes.push(Date.now()-r),this.generationTimes.length>100&&this.generationTimes.shift(),o}catch(i){throw new _("MODEL_LOAD_FAILED",`Failed to generate embedding: ${i instanceof Error?i.message:"Unknown error"}`,i)}}async generateBatch(e){if(!e.texts||e.texts.length===0)throw new _("INVALID_INPUT","Batch request must contain at least one text");let t=Date.now(),n=0,r=[],i={...this.config};e.config&&(this.config={...this.config,...e.config});try{for(let s of e.texts){let a=this.getCacheKey(s),o=this.cache.get(a);if(o)r.push(o),n++;else{let l=await this.generate(s);r.push(l)}}return{embeddings:r,duration:Date.now()-t,cacheHits:n}}finally{this.config=i}}getStats(){let e=this.cache.getStats(),t=this.generationTimes.length>0?this.generationTimes.reduce((n,r)=>n+r,0)/this.generationTimes.length:0;return{totalGenerated:this.totalGenerated,cacheHits:e.hits,cacheMisses:e.misses,avgGenerationTime:t,currentModel:this.config.model,vectorsStored:e.size}}clearCache(){this.cache.clear()}updateConfig(e){let t=e.model&&e.model!==this.config.model;this.config={...this.config,...e},e.cacheSize!==void 0&&e.cacheSize!==this.cache.getStats().size&&(this.cache=new St(e.cacheSize)),t&&(this.isInitialized=!1)}getCacheKey(e){return`${this.config.model}:${this.config.hyperbolic}:${e}`}euclideanToPoincare(e){let t=Math.sqrt(e.reduce((s,a)=>s+a*a,0));if(t===0)return e;let n=Math.abs(this.config.curvature),r=Math.sqrt(n),i=Math.tanh(r*t/2)/(r*t);return e.map(s=>s*i)}isReady(){return this.isInitialized&&this.onnxRuntime!==null}};var we=class{embeddings;searchCount=0;searchTimes=[];constructor(){this.embeddings=new Map}store(e){this.embeddings.set(e.id,e)}storeBatch(e){for(let t of e)this.store(t)}remove(e){return this.embeddings.delete(e)}clear(){this.embeddings.clear()}async search(e,t={}){let n=Date.now(),r={metric:t.metric??"cosine",topK:t.topK??5,threshold:t.threshold??.5,namespace:t.namespace};try{let i=Array.from(this.embeddings.values());r.namespace&&(i=i.filter(c=>c.namespace===r.namespace));let s=[];for(let c of i){if(c.embedding.dimensions!==e.dimensions)continue;let d=this.calculateSimilarity(e.vector,c.embedding.vector,r.metric);(r.metric==="cosine"?d>=r.threshold:d<=r.threshold)&&s.push({stored:c,score:d})}let a=r.metric==="cosine"?-1:1;s.sort((c,d)=>a*(c.score-d.score));let l=s.slice(0,r.topK).map(({stored:c,score:d})=>({text:c.text,embedding:c.embedding,score:d,metadata:c.metadata}));return this.searchCount++,this.searchTimes.push(Date.now()-n),this.searchTimes.length>100&&this.searchTimes.shift(),l}catch(i){throw new _("DIMENSION_MISMATCH",`Search failed: ${i instanceof Error?i.message:"Unknown error"}`,i)}}async findMostSimilar(e,t={}){let n=await this.search(e,{...t,topK:1});return n.length>0?n[0]:null}calculateSimilarity(e,t,n){if(e.length!==t.length)throw new _("DIMENSION_MISMATCH",`Vector dimensions do not match: ${e.length} vs ${t.length}`);switch(n){case"cosine":return this.cosineSimilarity(e,t);case"euclidean":return this.euclideanDistance(e,t);case"poincare":return this.poincareDistance(e,t);default:throw new _("INVALID_INPUT",`Unknown similarity metric: ${n}`)}}getStats(){let e=this.searchTimes.length>0?this.searchTimes.reduce((t,n)=>t+n,0)/this.searchTimes.length:0;return{searchCount:this.searchCount,avgSearchTime:e,storedCount:this.embeddings.size}}getAll(e){let t=Array.from(this.embeddings.values());return e?t.filter(n=>n.namespace===e):t}get(e){return this.embeddings.get(e)}cosineSimilarity(e,t){let n=0,r=0,i=0;for(let a=0;a<e.length;a++)n+=e[a]*t[a],r+=e[a]*e[a],i+=t[a]*t[a];let s=Math.sqrt(r)*Math.sqrt(i);return s===0?0:n/s}euclideanDistance(e,t){let n=0;for(let r=0;r<e.length;r++){let i=e[r]-t[r];n+=i*i}return Math.sqrt(n)}poincareDistance(e,t,n=-1){let r=Math.abs(n),i=Math.sqrt(r),s=e.reduce((g,p)=>g+p*p,0),a=t.reduce((g,p)=>g+p*p,0),o=0;for(let g=0;g<e.length;g++){let p=e[g]-t[g];o+=p*p}let l=2*o,c=(1-s)*(1-a);if(c<=0)return 1/0;let d=l/c;return Math.acosh(1+d)/i}async searchBatch(e,t={}){let n=[];for(let r of e){let i=await this.search(r,t);n.push(i)}return n}async findInRadius(e,t,n="cosine"){return this.search(e,{metric:n,threshold:t,topK:this.embeddings.size})}};var Re=class{config;constructor(e={}){if(this.config={curvature:e.curvature??-1,epsilon:e.epsilon??1e-7},this.config.curvature>=0)throw new _("HYPERBOLIC_ERROR","Curvature must be negative for hyperbolic space")}euclideanToPoincare(e){if(e.isHyperbolic)return e;let t=e.vector,n=this.norm(t);if(n<this.config.epsilon)return{...e,isHyperbolic:!0};let r=Math.abs(this.config.curvature),i=Math.sqrt(r),s=Math.tanh(i*n/2)/(i*n),a=t.map(l=>l*s),o=this.norm(a);if(o>=1-this.config.epsilon)throw new _("HYPERBOLIC_ERROR",`Poincar\xE9 ball constraint violated: norm = ${o}`);return{vector:a,dimensions:e.dimensions,model:e.model,isHyperbolic:!0}}poincareToEuclidean(e){if(!e.isHyperbolic)return e;let t=e.vector,n=this.norm(t);if(n<this.config.epsilon)return{...e,isHyperbolic:!1};let r=Math.abs(this.config.curvature),i=Math.sqrt(r),s=i*n;if(s>=1)throw new _("HYPERBOLIC_ERROR","Point is on or outside Poincar\xE9 ball boundary");let a=2/i*Math.atanh(s)/n;return{vector:t.map(l=>l*a),dimensions:e.dimensions,model:e.model,isHyperbolic:!1}}distance(e,t){if(e.dimensions!==t.dimensions)throw new _("DIMENSION_MISMATCH","Embeddings must have same dimensions");if(!e.isHyperbolic||!t.isHyperbolic)throw new _("HYPERBOLIC_ERROR","Both embeddings must be in hyperbolic space");let n=e.vector,r=t.vector,i=Math.abs(this.config.curvature),s=Math.sqrt(i),a=this.normSquared(n),o=this.normSquared(r),c=2*this.euclideanDistanceSquared(n,r),d=(1-a)*(1-o);if(d<=this.config.epsilon)return 1/0;let m=c/d;return Math.acosh(1+m)/s}midpoint(e,t){if(e.dimensions!==t.dimensions)throw new _("DIMENSION_MISMATCH","Embeddings must have same dimensions");if(!e.isHyperbolic||!t.isHyperbolic)throw new _("HYPERBOLIC_ERROR","Both embeddings must be in hyperbolic space");let n=e.vector,r=t.vector;return{vector:this.mobiusAddition(n,this.mobiusScalarMultiply(this.mobiusAddition(this.mobiusNegate(n),r),.5)),dimensions:e.dimensions,model:e.model,isHyperbolic:!0}}mobiusAddition(e,t){let n=Math.abs(this.config.curvature),r=this.dot(e,t),i=this.normSquared(e),s=this.normSquared(t),a=1+2*n*r+n*s,o=1-n*i,l=1+2*n*r+n*n*i*s;if(Math.abs(l)<this.config.epsilon)throw new _("HYPERBOLIC_ERROR","M\xF6bius addition denominator is zero");return e.map((d,m)=>(a*d+o*t[m])/l)}mobiusScalarMultiply(e,t){let n=Math.abs(this.config.curvature),r=Math.sqrt(n),i=this.norm(e);if(i<this.config.epsilon)return e;let s=r*i;if(Math.abs(s)>=1)throw new _("HYPERBOLIC_ERROR","M\xF6bius scalar multiplication out of bounds");let a=Math.tanh(t*Math.atanh(s))/(r*i);return e.map(o=>o*a)}mobiusNegate(e){return e.map(t=>-t)}projectToBall(e){let t=this.norm(e);if(t>=1-this.config.epsilon){let n=(1-this.config.epsilon)/t;return e.map(r=>r*n)}return e}norm(e){return Math.sqrt(this.normSquared(e))}normSquared(e){return e.reduce((t,n)=>t+n*n,0)}dot(e,t){return e.reduce((n,r,i)=>n+r*t[i],0)}euclideanDistanceSquared(e,t){return e.reduce((n,r,i)=>{let s=r-t[i];return n+s*s},0)}updateConfig(e){if(e.curvature!==void 0&&e.curvature>=0)throw new _("HYPERBOLIC_ERROR","Curvature must be negative");this.config={...this.config,...e}}getConfig(){return{...this.config}}};te();var Be=class{generator;search;hyperbolic;isInitialized=!1;constructor(e={}){this.generator=new Ee(e.embedding),this.search=new we,this.hyperbolic=new Re(e.hyperbolic),e.autoInitialize!==!1&&this.initialize().catch(t=>{console.error("Failed to auto-initialize ONNX embeddings:",t)})}async initialize(){if(!this.isInitialized)try{await this.generator.initialize(),this.isInitialized=!0}catch(e){throw new _("RUNTIME_UNAVAILABLE","Failed to initialize ONNX embeddings adapter",e)}}async getHealth(){try{let e=this.generator.isReady();return{available:e,modelLoaded:e?this.getStats().currentModel:null,system:{memory:process.memoryUsage().heapUsed,threads:1}}}catch(e){return{available:!1,modelLoaded:null,error:e instanceof Error?e.message:"Unknown error",system:{memory:process.memoryUsage().heapUsed,threads:0}}}}async generateEmbedding(e){return await this.ensureInitialized(),this.generator.generate(e)}async generateBatch(e){return await this.ensureInitialized(),this.generator.generateBatch(e)}async generateAndStore(e,t){let n=await this.generateEmbedding(e),r={id:t?.id??this.generateId(),text:e,embedding:n,namespace:t?.namespace,metadata:t?.customData,createdAt:Date.now()};this.search.store(r);try{let i=z();await i.initialize(),await i.vectorStore(r.id,r.embedding.vector,r.namespace??"onnx",{text:r.text,customData:r.metadata,createdAt:r.createdAt})}catch{}return r}async searchByText(e,t){let n=await this.generateEmbedding(e);return this.search.search(n,t)}async searchByEmbedding(e,t){return this.search.search(e,t)}async findMostSimilar(e,t){let n=await this.generateEmbedding(e);return this.search.findMostSimilar(n,t)}async compareSimilarity(e,t,n="cosine"){let[r,i]=await this.generateBatch({texts:[e,t]}).then(s=>s.embeddings);return this.search.calculateSimilarity(r.vector,i.vector,n)}storeEmbedding(e){this.search.store(e)}storeBatch(e){this.search.storeBatch(e)}removeEmbedding(e){return this.search.remove(e)}getEmbedding(e){return this.search.get(e)}getAllEmbeddings(e){return this.search.getAll(e)}clearEmbeddings(){this.search.clear()}toHyperbolic(e){return this.hyperbolic.euclideanToPoincare(e)}toEuclidean(e){return this.hyperbolic.poincareToEuclidean(e)}hyperbolicDistance(e,t){return this.hyperbolic.distance(e,t)}hyperbolicMidpoint(e,t){return this.hyperbolic.midpoint(e,t)}projectToBall(e){return this.hyperbolic.projectToBall(e)}getStats(){let e=this.generator.getStats(),t=this.search.getStats();return{totalGenerated:e.totalGenerated??0,cacheHits:e.cacheHits??0,cacheMisses:e.cacheMisses??0,totalSearches:t.searchCount,avgGenerationTime:e.avgGenerationTime??0,avgSearchTime:t.avgSearchTime,currentModel:e.currentModel??"all-MiniLM-L6-v2",vectorsStored:t.storedCount}}updateEmbeddingConfig(e){this.generator.updateConfig(e)}updateHyperbolicConfig(e){this.hyperbolic.updateConfig(e)}clearCaches(){this.generator.clearCache()}reset(){this.clearCaches(),this.clearEmbeddings()}async bridgeToMCPGenerate(e,t=!1){let n=await this.generateEmbedding(e);return t?this.toHyperbolic(n):n}async bridgeToMCPSearch(e,t){return this.searchByText(e,t)}async bridgeToMCPCompare(e,t,n="cosine"){return this.compareSimilarity(e,t,n)}async ensureInitialized(){this.isInitialized||await this.initialize()}generateId(){return`emb_${Date.now()}_${ca().slice(0,9)}`}isReady(){return this.isInitialized&&this.generator.isReady()}};function Rt(u){return new Be(u)}var An={enabled:!0,dbPath:".agentic-qe/memory.db",maxOutcomes:1e5,retentionDays:90,autoCleanup:!0,cleanupIntervalMs:3600*1e3};te();k();j();var fa={enabled:!0,haikuThreshold:.8,sonnetThreshold:.4,includeHealthSnapshot:!1,enableLogging:!0},kn=class{config;minCutService;constructor(e){this.config={...fa,...e},this.minCutService=ni()}route(e){let t=Date.now();if(!this.config.enabled)return this.createFallbackResult(e,t,"MinCut routing disabled");let n=e.agentTopology||this.config.defaultTopology;if(!n||n.length===0)return this.createFallbackResult(e,t,"No agent topology available for mincut analysis");try{let r=this.minCutService.computeRoutingTier(e.task,n),i=this.routingTierToModelTier(r.tier);e.isCritical&&i<2&&(i=2);let s=this.modelTierToLabel(i),a;if(this.config.includeHealthSnapshot){let c=e.taskGraph||this.minCutService.buildTaskGraphFromTopology(n);a=this.minCutService.getStructuralHealth(c)}let o=Date.now()-t,l={modelTier:i,tierLabel:s,lambda:r.lambda,normalizedLambda:r.normalizedLambda,confidence:r.confidence,rationale:r.rationale,usedMinCut:!0,healthSnapshot:a,decisionTimeMs:o};return this.config.enableLogging&&this.logDecision(l),l}catch(r){return this.createFallbackResult(e,t,`MinCut routing error: ${r instanceof Error?r.message:String(r)}`)}}getMinCutService(){return this.minCutService}isEnabled(){return this.config.enabled}routingTierToModelTier(e){switch(e){case 1:return 1;case 2:return 2;case 3:return 4;default:return 2}}modelTierToLabel(e){switch(e){case 0:return"Booster";case 1:return"Haiku";case 2:return"Sonnet";case 3:return"Sonnet-Extended";case 4:return"Opus";default:return"Sonnet"}}createFallbackResult(e,t,n){return{modelTier:(e.isCritical,2),tierLabel:"Sonnet",lambda:0,normalizedLambda:0,confidence:.3,rationale:`Fallback to Sonnet: ${n}`,usedMinCut:!1,decisionTimeMs:Date.now()-t}}logDecision(e){let t=e.usedMinCut?"MinCut":"Fallback";console.error(`[MinCutRouter] [${t}] Tier ${e.modelTier} (${e.tierLabel}) | Lambda: ${e.normalizedLambda.toFixed(3)} | Confidence: ${(e.confidence*100).toFixed(0)}% | Time: ${e.decisionTimeMs}ms`)}};function si(u){return new kn(u)}import{existsSync as ya}from"fs";import{join as va}from"path";var Pt=class{id="memory";name="Pattern Memory";priority=80;maxTokens=2e3;async gather(e){let t=[];try{let n=va(process.cwd(),".agentic-qe","memory.db");if(!ya(n))return this.fallbackGather(e);let{openDatabase:r}=await import("./safe-db-YXMCSKFH.js"),i=r(n,{readonly:!0});try{let s=this.extractDomainKeywords(e.taskDescription);if(s.length>0){let a=s.map(()=>"domain LIKE ?").join(" OR "),o=s.map(d=>`%${d}%`),c=i.prepare(`SELECT name, domain, description, confidence
|
|
292
232
|
FROM qe_patterns
|
|
293
233
|
WHERE ${a}
|
|
294
234
|
ORDER BY confidence DESC
|
|
@@ -296,46 +236,46 @@ import{b as bt,c as Ct}from"./chunk-ZWSRIJ2T.js";import{a as Se}from"./chunk-ROE
|
|
|
296
236
|
`);t.push({sourceId:this.id,title:"Relevant Patterns from Learning Database",content:`Found ${c.length} relevant patterns:
|
|
297
237
|
|
|
298
238
|
${d}`,estimatedTokens:Math.ceil(d.length/3.5),relevance:.8})}}}finally{i.close()}}catch{return this.fallbackGather(e)}return t.length===0?this.fallbackGather(e):t}fallbackGather(e){let t=[`Task: ${e.taskDescription}`,`Agent: ${e.agentType}`,`Files: ${e.targetFiles.join(", ")}`].join(`
|
|
299
|
-
`);return[{sourceId:this.id,title:"Task Context",content:t,estimatedTokens:Math.ceil(t.length/3.5),relevance:.5}]}extractDomainKeywords(e){let t=[],n=e.toLowerCase(),r={"test-generation":["test","generate","create test","unit test","spec"],"coverage-analysis":["coverage","gap","branch","uncovered"],"security-compliance":["security","vulnerability","owasp","injection","auth"],"quality-assessment":["quality","review","code review","assessment"],"defect-intelligence":["defect","bug","regression","root cause"]};for(let[i,s]of Object.entries(r))s.some(a=>n.includes(a))&&t.push(i);return t.length>0?t:["test-generation"]}};import{execSync as
|
|
300
|
-
${r}`;t.push({sourceId:this.id,title:`Git history: ${n}`,content:i,estimatedTokens:Math.ceil(i.length/3.5),relevance:.5})}}catch{}return t}};import{existsSync as
|
|
239
|
+
`);return[{sourceId:this.id,title:"Task Context",content:t,estimatedTokens:Math.ceil(t.length/3.5),relevance:.5}]}extractDomainKeywords(e){let t=[],n=e.toLowerCase(),r={"test-generation":["test","generate","create test","unit test","spec"],"coverage-analysis":["coverage","gap","branch","uncovered"],"security-compliance":["security","vulnerability","owasp","injection","auth"],"quality-assessment":["quality","review","code review","assessment"],"defect-intelligence":["defect","bug","regression","root cause"]};for(let[i,s]of Object.entries(r))s.some(a=>n.includes(a))&&t.push(i);return t.length>0?t:["test-generation"]}};import{execSync as ba}from"child_process";var xt=class{id="git";name="Git History";priority=60;maxTokens=1500;async gather(e){let t=[];for(let n of e.targetFiles.slice(0,5))try{let r=ba(`git log --oneline -5 -- "${n}" 2>/dev/null || true`,{encoding:"utf-8",timeout:5e3}).trim();if(r){let i=`Recent commits for ${n}:
|
|
240
|
+
${r}`;t.push({sourceId:this.id,title:`Git history: ${n}`,content:i,estimatedTokens:Math.ceil(i.length/3.5),relevance:.5})}}catch{}return t}};import{existsSync as Ca,readFileSync as Ta}from"fs";import{basename as Mn,dirname as Sa,join as Dn}from"path";var At=class{id="tests";name="Existing Tests";priority=70;maxTokens=2e3;async gather(e){let t=[];for(let n of e.targetFiles.slice(0,3)){let r=this.findTestPaths(n);for(let i of r)if(Ca(i))try{let a=Ta(i,"utf-8").match(/(?:it|test|describe)\s*\(\s*['"`]([^'"`]+)['"`]/g)||[];if(a.length>0){let o=`Tests for ${Mn(n)} (${i}):
|
|
301
241
|
${a.join(`
|
|
302
|
-
`)}`;t.push({sourceId:this.id,title:`Tests: ${
|
|
242
|
+
`)}`;t.push({sourceId:this.id,title:`Tests: ${Mn(n)}`,content:o,estimatedTokens:Math.ceil(o.length/3.5),relevance:.8})}}catch{}}return t}findTestPaths(e){let t=Mn(e).replace(/\.(ts|js|tsx|jsx)$/,""),n=Sa(e),r=[".test.ts",".spec.ts",".test.js",".spec.js"],i=[];for(let s of r)i.push(Dn(n,`${t}${s}`)),i.push(Dn(n,"__tests__",`${t}${s}`)),i.push(Dn(n,"..","tests",`${t}${s}`));return i}};import{existsSync as Ea,readFileSync as wa}from"fs";import{join as In,basename as Ra}from"path";var kt=class{id="coverage";name="Coverage Data";priority=50;maxTokens=1e3;async gather(e){let t=[],n=[In(process.cwd(),"coverage","coverage-summary.json"),In(process.cwd(),"coverage","coverage-final.json"),In(process.cwd(),".coverage","coverage-summary.json")];for(let r of n)if(Ea(r))try{let i=wa(r,"utf-8"),s=JSON.parse(i),a=[];for(let o of e.targetFiles){let l=Ra(o);for(let[c,d]of Object.entries(s))if(c.includes(l)&&d&&typeof d=="object"){let m=d,g=m.lines?.pct??m.statements?.pct,p=m.branches?.pct,h=m.functions?.pct;g!==void 0&&a.push(`${l}: lines=${g}%${p!==void 0?`, branches=${p}%`:""}${h!==void 0?`, functions=${h}%`:""}`)}}if(a.length>0){let o=`Coverage for target files:
|
|
303
243
|
${a.join(`
|
|
304
|
-
`)}`;t.push({sourceId:this.id,title:"File Coverage Data",content:o,estimatedTokens:Math.ceil(o.length/3.5),relevance:.6})}if(s.total&&typeof s.total=="object"){let o=s.total,l=`Project coverage: lines=${o.lines?.pct??"?"}%, branches=${o.branches?.pct??"?"}%, functions=${o.functions?.pct??"?"}%`;t.push({sourceId:this.id,title:"Project Coverage Summary",content:l,estimatedTokens:Math.ceil(l.length/3.5),relevance:.4})}break}catch{continue}return t}};import{existsSync as
|
|
244
|
+
`)}`;t.push({sourceId:this.id,title:"File Coverage Data",content:o,estimatedTokens:Math.ceil(o.length/3.5),relevance:.6})}if(s.total&&typeof s.total=="object"){let o=s.total,l=`Project coverage: lines=${o.lines?.pct??"?"}%, branches=${o.branches?.pct??"?"}%, functions=${o.functions?.pct??"?"}%`;t.push({sourceId:this.id,title:"Project Coverage Summary",content:l,estimatedTokens:Math.ceil(l.length/3.5),relevance:.4})}break}catch{continue}return t}};import{existsSync as Pa}from"fs";import{join as xa}from"path";var Mt=class{id="requirements";name="Requirements Traceability";priority=75;maxTokens=2e3;async gather(e){let t=[];try{let n=xa(process.cwd(),".agentic-qe","memory.db");if(!Pa(n))return this.fallbackGather(e);let{openDatabase:r}=await import("./safe-db-YXMCSKFH.js"),i=r(n,{readonly:!0});try{if(!i.prepare("SELECT name FROM sqlite_master WHERE type='table' AND name='qe_patterns'").get())return this.fallbackGather(e);let a=e.targetFiles.map(l=>`%${l.split("/").pop()}%`);if(a.length>0){let l=a.map(()=>"description LIKE ?").join(" OR "),d=i.prepare(`SELECT name, domain, description, confidence
|
|
305
245
|
FROM qe_patterns
|
|
306
246
|
WHERE domain LIKE '%requirement%'
|
|
307
247
|
AND (${l})
|
|
308
248
|
ORDER BY confidence DESC
|
|
309
|
-
LIMIT 10`).all(...a);if(d.length>0){let m=d.map(
|
|
249
|
+
LIMIT 10`).all(...a);if(d.length>0){let m=d.map(g=>`- **${g.name}** (confidence: ${(g.confidence*100).toFixed(0)}%): ${g.description||"No description"}`).join(`
|
|
310
250
|
`);t.push({sourceId:this.id,title:"Linked Requirements",content:`Found ${d.length} requirements linked to target files:
|
|
311
251
|
|
|
312
|
-
${m}`,estimatedTokens:Math.ceil(m.length/3.5),relevance:.75})}}let o=this.extractRequirementKeywords(e.taskDescription);if(o.length>0){let l=o.map(()=>"name LIKE ? OR description LIKE ?").join(" OR "),c=o.flatMap(
|
|
252
|
+
${m}`,estimatedTokens:Math.ceil(m.length/3.5),relevance:.75})}}let o=this.extractRequirementKeywords(e.taskDescription);if(o.length>0){let l=o.map(()=>"name LIKE ? OR description LIKE ?").join(" OR "),c=o.flatMap(g=>[`%${g}%`,`%${g}%`]),m=i.prepare(`SELECT DISTINCT name, domain, description, confidence
|
|
313
253
|
FROM qe_patterns
|
|
314
254
|
WHERE domain LIKE '%requirement%'
|
|
315
255
|
AND (${l})
|
|
316
256
|
ORDER BY confidence DESC
|
|
317
|
-
LIMIT 5`).all(...c);if(m.length>0){let
|
|
257
|
+
LIMIT 5`).all(...c);if(m.length>0){let g=m.map(p=>`- **${p.name}**: ${p.description||"No description"}`).join(`
|
|
318
258
|
`);t.push({sourceId:this.id,title:"Related Requirements",content:`Requirements related to task:
|
|
319
259
|
|
|
320
|
-
${
|
|
260
|
+
${g}`,estimatedTokens:Math.ceil(g.length/3.5),relevance:.6})}}}finally{i.close()}}catch{return this.fallbackGather(e)}return t.length===0?this.fallbackGather(e):t}fallbackGather(e){let n=`No requirements traceability data found for: ${e.targetFiles.join(", ")}. Consider running requirements validation to establish traceability.`;return[{sourceId:this.id,title:"Requirements Context",content:n,estimatedTokens:Math.ceil(n.length/3.5),relevance:.3}]}extractRequirementKeywords(e){let t=[],n=e.toLowerCase(),r=n.match(/(?:req|us|story|epic|feat)-?\d+/gi)||[];t.push(...r);let i=["authentication","authorization","payment","registration","notification","search","api","login","user","admin","report","dashboard","import","export","integration"];for(let s of i)n.includes(s)&&t.push(s);return t.slice(0,5)}};import{existsSync as Aa}from"fs";import{join as ka}from"path";var Dt=class{id="defects";name="Defect Intelligence";priority=65;maxTokens=1500;async gather(e){let t=[];try{let n=ka(process.cwd(),".agentic-qe","memory.db");if(!Aa(n))return[];let{openDatabase:r}=await import("./safe-db-YXMCSKFH.js"),i=r(n,{readonly:!0});try{if(!i.prepare("SELECT name FROM sqlite_master WHERE type='table' AND name='qe_patterns'").get())return[];let a=e.targetFiles.map(l=>`%${l.split("/").pop()}%`);if(a.length>0){let l=a.map(()=>"description LIKE ?").join(" OR "),d=i.prepare(`SELECT name, domain, description, confidence
|
|
321
261
|
FROM qe_patterns
|
|
322
262
|
WHERE domain LIKE '%defect%'
|
|
323
263
|
AND (${l})
|
|
324
264
|
ORDER BY confidence DESC
|
|
325
|
-
LIMIT 8`).all(...a);if(d.length>0){let m=d.map(
|
|
265
|
+
LIMIT 8`).all(...a);if(d.length>0){let m=d.map(g=>`- **${g.name}** (confidence: ${(g.confidence*100).toFixed(0)}%): ${g.description||"No description"}`).join(`
|
|
326
266
|
`);t.push({sourceId:this.id,title:"Historical Defect Patterns",content:`Found ${d.length} defect patterns for target files:
|
|
327
267
|
|
|
328
|
-
${m}`,estimatedTokens:Math.ceil(m.length/3.5),relevance:.7})}}let o=this.extractDefectKeywords(e.taskDescription);if(o.length>0){let l=o.map(()=>"description LIKE ?").join(" OR "),c=o.map(
|
|
268
|
+
${m}`,estimatedTokens:Math.ceil(m.length/3.5),relevance:.7})}}let o=this.extractDefectKeywords(e.taskDescription);if(o.length>0){let l=o.map(()=>"description LIKE ?").join(" OR "),c=o.map(g=>`%${g}%`),m=i.prepare(`SELECT name, domain, description, confidence
|
|
329
269
|
FROM qe_patterns
|
|
330
270
|
WHERE (domain LIKE '%defect%' OR domain LIKE '%regression%')
|
|
331
271
|
AND (${l})
|
|
332
272
|
ORDER BY confidence DESC
|
|
333
|
-
LIMIT 5`).all(...c);if(m.length>0){let
|
|
273
|
+
LIMIT 5`).all(...c);if(m.length>0){let g=m.map(p=>`- **${p.name}**: ${p.description||"No description"}`).join(`
|
|
334
274
|
`);t.push({sourceId:this.id,title:"Regression Hotspots",content:`Known regression patterns:
|
|
335
275
|
|
|
336
|
-
${
|
|
337
|
-
`)}var
|
|
338
|
-
`)}async quickRoute(e){return this.routeTask({task:e})}async routeBatch(e){return Promise.all(e.map(t=>this.routeTask(t)))}getMetrics(){return this.modelRouter.getMetrics()}getRoutingLog(e=100,t=0){return this.routingLog.slice(t,t+e)}getRoutingStats(){let e=this.routingLog;if(e.length===0)return this.createEmptyStats();let t=new Map,n=0,r=0,i=0,s=0;for(let o of e)t.set(o.selectedTier,(t.get(o.selectedTier)||0)+1),n+=o.complexity,r+=o.decisionTimeMs,o.wasDowngraded&&i++,o.agentBoosterEligible&&s++;let a={};for(let[o,l]of t)a[o]=l/e.length;return{totalRouted:e.length,avgComplexity:n/e.length,avgDecisionTimeMs:r/e.length,downgradeRate:i/e.length,agentBoosterRate:s/e.length,tierDistribution:a,period:{start:e[0].timestamp,end:e[e.length-1].timestamp}}}reset(){this.routingLog.length=0,this.modelRouter.resetMetrics(),this.config.enableLogging&&console.error("[TaskRouter] Reset routing log and metrics")}async dispose(){this.disposed||(this.disposed=!0,await this.modelRouter.dispose(),u.instance=null,this.config.enableLogging&&console.error("[TaskRouter] Disposed"))}isEnabled(){return this.config.enabled&&!this.disposed}mapTierToStrategy(e){switch(e){case 0:return"booster";case 1:return"haiku";case 2:return"sonnet";case 3:return"sonnet-extended";case 4:return"opus";default:return"sonnet"}}addLogEntry(e){this.routingLog.push(e),this.routingLog.length>this.config.maxLogEntries&&this.routingLog.splice(0,this.routingLog.length-this.config.maxLogEntries)}logRoutingDecision(e){let t=Se[e.selectedTier].name,n=e.agentBoosterEligible?"[AgentBooster]":`[Tier${e.selectedTier}]`;console.error(`[TaskRouter] ${n} ${t} | Complexity: ${e.complexity.toFixed(0)} | Confidence: ${(e.confidence*100).toFixed(0)}% | Time: ${e.decisionTimeMs.toFixed(1)}ms`+(e.wasDowngraded?" [DOWNGRADED]":""))}createDisabledResult(e){let n=Se[2],r={timestamp:new Date,taskDescription:e.task.slice(0,200),selectedTier:2,modelId:n.exampleModels[0],complexity:50,confidence:.5,wasDowngraded:!1,agentBoosterEligible:!1,decisionTimeMs:0,rationale:"Routing disabled - using default tier"};return{decision:{tier:2,modelId:n.exampleModels[0],complexityAnalysis:{overall:50,codeComplexity:50,reasoningComplexity:50,scopeComplexity:50,confidence:.5,signals:{hasArchitectureScope:!1,hasSecurityScope:!1,requiresMultiStepReasoning:!1,requiresCrossDomainCoordination:!1,isMechanicalTransform:!1,requiresCreativity:!1,keywordMatches:{simple:[],moderate:[],complex:[],critical:[]}},recommendedTier:2,alternateTiers:[],explanation:"Routing disabled"},budgetDecision:{allowed:!0,reason:"Routing disabled",requestedTier:2,approvedTier:2,wasDowngraded:!1,estimatedCostUsd:0,currentUsage:{tier:2,costSpentTodayUsd:0,requestsThisHour:0,requestsToday:0,budgetUtilization:0,isExceeded:!1,isNearLimit:!1,resetTime:new Date,remainingBudgetUsd:100,remainingRequestsThisHour:100,remainingRequestsToday:1e3},warnings:[]},confidence:.5,rationale:"Routing disabled - using default tier",agentBoosterEligible:!1,alternativeTiers:[],metadata:{timestamp:new Date,decisionTimeMs:0,fromCache:!1},warnings:["Routing is disabled"]},executionStrategy:"sonnet",useAgentBooster:!1,modelId:n.exampleModels[0],tierInfo:{tier:2,name:n.name,typicalLatencyMs:n.typicalLatencyMs,relativeCost:n.relativeCost},logEntry:r}}createEmptyStats(){let e=new Date;return{totalRouted:0,avgComplexity:0,avgDecisionTimeMs:0,downgradeRate:0,agentBoosterRate:0,tierDistribution:{},period:{start:e,end:e}}}};async function
|
|
276
|
+
${g}`,estimatedTokens:Math.ceil(g.length/3.5),relevance:.6})}}}finally{i.close()}}catch{return[]}return t}extractDefectKeywords(e){let t=[],n=e.toLowerCase(),r=["bug","defect","regression","fix","crash","error","null","undefined","timeout","race condition","deadlock","memory leak","overflow","injection","broken"];for(let i of r)n.includes(i)&&t.push(i);return t.slice(0,5)}};var Ma=8e3,Da=300*1e3;function Ia(){return[new Pt,new Mt,new At,new Dt,new xt,new kt]}var It=class{sources;maxTokenBudget;cache=new Map;cacheTtl;constructor(e){this.sources=e?.sources||Ia(),this.maxTokenBudget=e?.maxTokenBudget||Ma,this.cacheTtl=e?.cacheTtlMs||Da}async compile(e){let t=Date.now(),n=this.buildCacheKey(e),r=this.cache.get(n);if(r&&Date.now()-r.timestamp<this.cacheTtl)return r.result;let i=e.maxTokenBudget||this.maxTokenBudget,s=await Promise.allSettled(this.sources.map(async g=>{try{let p=await g.gather(e);return{sourceId:g.id,sourceName:g.name,priority:g.priority,fragments:p}}catch{return{sourceId:g.id,sourceName:g.name,priority:g.priority,fragments:[]}}})),a=[],o=[];for(let g of s)if(g.status==="fulfilled"){let{sourceId:p,priority:h,fragments:f}=g.value;if(f.length>0){o.push(p);for(let v of f)a.push({...v,sourcePriority:h})}}a.sort((g,p)=>g.sourcePriority!==p.sourcePriority?p.sourcePriority-g.sourcePriority:p.relevance-g.relevance);let l=[],c=0;for(let g of a)if(c+g.estimatedTokens<=i){let{sourcePriority:p,...h}=g;l.push(h),c+=g.estimatedTokens}let m={summary:this.generateSummary(e,l,o),fragments:l,totalTokens:c,sources:o,timestamp:new Date().toISOString(),duration:Date.now()-t};return this.cache.set(n,{result:m,timestamp:Date.now()}),m}clearCache(){this.cache.clear()}getCacheStats(){return{size:this.cache.size,ttlMs:this.cacheTtl}}buildCacheKey(e){return`${e.agentType}:${e.targetFiles.sort().join(",")}:${e.taskDescription.slice(0,100)}`}generateSummary(e,t,n){return[`Context compiled for ${e.agentType} agent.`,`Target: ${e.targetFiles.length} file(s).`,`Sources: ${n.join(", ")}.`,`Fragments: ${t.length} (${t.reduce((r,i)=>r+i.estimatedTokens,0)} est. tokens).`].join(" ")}};function ai(u){let e=[];e.push("## Compiled Context"),e.push(""),e.push(u.summary),e.push("");for(let t of u.fragments)e.push(`### ${t.title}`),e.push(t.content),e.push("");return e.push(`_Context compiled: ${u.timestamp} (${u.duration}ms)_`),e.join(`
|
|
277
|
+
`)}var Oa={enabled:!0,enableAgentBooster:!0,enableLogging:!0,maxLogEntries:1e3},On=class u{static instance=null;static initializationPromise=null;config;modelRouter;minCutRouter;routingLog=[];contextCompiler;disposed=!1;constructor(e,t){this.config=e,this.modelRouter=t,this.contextCompiler=new It,this.minCutRouter=si({enableLogging:e.enableLogging})}static async getInstance(e){if(u.instance&&!u.instance.disposed)return u.instance;if(u.initializationPromise)return u.initializationPromise;u.initializationPromise=u.create(e);try{return u.instance=await u.initializationPromise,u.instance}finally{u.initializationPromise=null}}static async create(e){let t={...Oa,...e},n;t.enableAgentBooster?n=await vt(t.modelRouterConfig):n=yt(t.modelRouterConfig);let r=new u(t,n);return t.enableLogging&&console.error(`[TaskRouter] Initialized with Agent Booster: ${t.enableAgentBooster}`),r}async routeTask(e){if(!this.config.enabled)return this.createDisabledResult(e);if(this.disposed)throw new Error("TaskRouterService has been disposed");let t=null;if(this.minCutRouter.isEnabled()&&e.agentTopology)try{t=this.minCutRouter.route({task:e.task,domain:e.domain,agentType:e.agentType,agentTopology:e.agentTopology,isCritical:e.isCritical})}catch(p){this.config.enableLogging&&console.error(`[TaskRouter] MinCut routing failed, falling back to heuristic: ${p instanceof Error?p.message:String(p)}`)}let n={task:e.task,codeContext:e.codeContext,filePaths:e.filePaths,manualTier:e.manualTier,isCritical:e.isCritical,agentType:e.agentType,domain:e.domain,metadata:e.metadata},r=await this.modelRouter.route(n),i=r;if(t&&t.usedMinCut){let p=t.modelTier;p!==r.tier&&(i={...r,tier:p,rationale:`[MinCut] ${t.rationale} (heuristic suggested Tier ${r.tier})`},this.config.enableLogging&&console.error(`[TaskRouter] MinCut override: Tier ${r.tier} -> Tier ${p} (lambda=${t.normalizedLambda.toFixed(3)})`))}let s=Se[i.tier],a=this.mapTierToStrategy(i.tier),o={timestamp:i.metadata.timestamp,taskDescription:e.task.slice(0,200),requestedTier:e.manualTier,selectedTier:i.tier,modelId:i.modelId,complexity:i.complexityAnalysis.overall,confidence:i.confidence,wasDowngraded:i.budgetDecision.wasDowngraded,agentBoosterEligible:i.agentBoosterEligible,decisionTimeMs:i.metadata.decisionTimeMs,rationale:i.rationale};this.addLogEntry(o),this.config.enableLogging&&this.logRoutingDecision(o);let l=e.patternHints,c=l&&l.length>0?this.formatPatternContext(l):void 0,d=e.agentType,m=d?Tn(d)||Tn(d.replace("v3-qe-","qe-")):void 0,g;if(e.filePaths&&e.filePaths.length>0)try{let p=await this.contextCompiler.compile({targetFiles:e.filePaths,agentType:e.agentType||"unknown",taskDescription:e.task});g=ai(p)}catch{}return{decision:i,executionStrategy:a,useAgentBooster:i.agentBoosterEligible,modelId:i.modelId,tierInfo:{tier:i.tier,name:s.name,typicalLatencyMs:s.typicalLatencyMs,relativeCost:s.relativeCost},logEntry:o,patternHints:l,patternContext:c,overlayConfig:m,compiledContext:g}}formatPatternContext(e){if(!e||e.length===0)return"";let t=["--- Relevant Patterns from Learning ---",""];for(let n of e){let r=n.canReuse?" [REUSABLE]":"";t.push(`[${n.name}]${r}`,` ${n.description}`,` Similarity: ${(n.similarity*100).toFixed(0)}% | Confidence: ${(n.confidence*100).toFixed(0)}%`,"")}return t.push("Use these patterns as guidance when applicable."),t.join(`
|
|
278
|
+
`)}async quickRoute(e){return this.routeTask({task:e})}async routeBatch(e){return Promise.all(e.map(t=>this.routeTask(t)))}getMetrics(){return this.modelRouter.getMetrics()}getRoutingLog(e=100,t=0){return this.routingLog.slice(t,t+e)}getRoutingStats(){let e=this.routingLog;if(e.length===0)return this.createEmptyStats();let t=new Map,n=0,r=0,i=0,s=0;for(let o of e)t.set(o.selectedTier,(t.get(o.selectedTier)||0)+1),n+=o.complexity,r+=o.decisionTimeMs,o.wasDowngraded&&i++,o.agentBoosterEligible&&s++;let a={};for(let[o,l]of t)a[o]=l/e.length;return{totalRouted:e.length,avgComplexity:n/e.length,avgDecisionTimeMs:r/e.length,downgradeRate:i/e.length,agentBoosterRate:s/e.length,tierDistribution:a,period:{start:e[0].timestamp,end:e[e.length-1].timestamp}}}reset(){this.routingLog.length=0,this.modelRouter.resetMetrics(),this.config.enableLogging&&console.error("[TaskRouter] Reset routing log and metrics")}async dispose(){this.disposed||(this.disposed=!0,await this.modelRouter.dispose(),u.instance=null,this.config.enableLogging&&console.error("[TaskRouter] Disposed"))}isEnabled(){return this.config.enabled&&!this.disposed}mapTierToStrategy(e){switch(e){case 0:return"booster";case 1:return"haiku";case 2:return"sonnet";case 3:return"sonnet-extended";case 4:return"opus";default:return"sonnet"}}addLogEntry(e){this.routingLog.push(e),this.routingLog.length>this.config.maxLogEntries&&this.routingLog.splice(0,this.routingLog.length-this.config.maxLogEntries)}logRoutingDecision(e){let t=Se[e.selectedTier].name,n=e.agentBoosterEligible?"[AgentBooster]":`[Tier${e.selectedTier}]`;console.error(`[TaskRouter] ${n} ${t} | Complexity: ${e.complexity.toFixed(0)} | Confidence: ${(e.confidence*100).toFixed(0)}% | Time: ${e.decisionTimeMs.toFixed(1)}ms`+(e.wasDowngraded?" [DOWNGRADED]":""))}createDisabledResult(e){let n=Se[2],r={timestamp:new Date,taskDescription:e.task.slice(0,200),selectedTier:2,modelId:n.exampleModels[0],complexity:50,confidence:.5,wasDowngraded:!1,agentBoosterEligible:!1,decisionTimeMs:0,rationale:"Routing disabled - using default tier"};return{decision:{tier:2,modelId:n.exampleModels[0],complexityAnalysis:{overall:50,codeComplexity:50,reasoningComplexity:50,scopeComplexity:50,confidence:.5,signals:{hasArchitectureScope:!1,hasSecurityScope:!1,requiresMultiStepReasoning:!1,requiresCrossDomainCoordination:!1,isMechanicalTransform:!1,requiresCreativity:!1,keywordMatches:{simple:[],moderate:[],complex:[],critical:[]}},recommendedTier:2,alternateTiers:[],explanation:"Routing disabled"},budgetDecision:{allowed:!0,reason:"Routing disabled",requestedTier:2,approvedTier:2,wasDowngraded:!1,estimatedCostUsd:0,currentUsage:{tier:2,costSpentTodayUsd:0,requestsThisHour:0,requestsToday:0,budgetUtilization:0,isExceeded:!1,isNearLimit:!1,resetTime:new Date,remainingBudgetUsd:100,remainingRequestsThisHour:100,remainingRequestsToday:1e3},warnings:[]},confidence:.5,rationale:"Routing disabled - using default tier",agentBoosterEligible:!1,alternativeTiers:[],metadata:{timestamp:new Date,decisionTimeMs:0,fromCache:!1},warnings:["Routing is disabled"]},executionStrategy:"sonnet",useAgentBooster:!1,modelId:n.exampleModels[0],tierInfo:{tier:2,name:n.name,typicalLatencyMs:n.typicalLatencyMs,relativeCost:n.relativeCost},logEntry:r}}createEmptyStats(){let e=new Date;return{totalRouted:0,avgComplexity:0,avgDecisionTimeMs:0,downgradeRate:0,agentBoosterRate:0,tierDistribution:{},period:{start:e,end:e}}}};async function Ot(u){return On.getInstance(u)}k();j();import*as O from"fs/promises";import*as M from"path";import{createHash as _a}from"crypto";var Fa={typescript:{jest:".test.ts",vitest:".test.ts",mocha:".spec.ts",default:".test.ts"},javascript:{jest:".test.js",vitest:".test.js",mocha:".spec.js",default:".test.js"},python:{pytest:"test_",unittest:"_test",default:"test_"},java:{junit:"Test.java",testng:"Test.java",default:"Test.java"},go:{testing:"_test.go",default:"_test.go"},rust:{cargo:"_test.rs",default:"_test.rs"},ruby:{rspec:"_spec.rb",minitest:"_test.rb",default:"_spec.rb"},php:{phpunit:"Test.php",pest:".test.php",default:"Test.php"},csharp:{xunit:"Tests.cs",nunit:"Tests.cs",mstest:"Tests.cs",default:"Tests.cs"},kotlin:{junit:"Test.kt",kotest:"Spec.kt",default:"Test.kt"},swift:{xctest:"Tests.swift",default:"Tests.swift"}},_n=class{baseDir;resultsDir;constructor(e=".agentic-qe"){this.baseDir=e,this.resultsDir=M.join(e,"results")}async save(e,t,n,r={}){let i=new Date,s=[];await this.ensureDirectories(t);let a=this.formatTimestamp(i),o=r.filenamePrefix||a;switch(t){case"generate-tests":s.push(...await this.saveTestGeneration(n,o,r));break;case"analyze-coverage":s.push(...await this.saveCoverage(n,o,r));break;case"scan-security":s.push(...await this.saveSecurityScan(n,o,r));break;case"assess-quality":s.push(...await this.saveQualityAssessment(n,o,r));break;case"index-code":s.push(...await this.saveCodeIndex(n,o,r));break;case"predict-defects":s.push(...await this.saveDefectPrediction(n,o,r));break;case"validate-contracts":s.push(...await this.saveContractValidation(n,o,r));break;case"test-accessibility":s.push(...await this.saveAccessibilityTest(n,o,r));break;case"run-chaos":s.push(...await this.saveChaosTest(n,o,r));break;default:s.push(...await this.saveGeneric(t,n,o))}let l=this.extractSummary(t,n);return await this.updateIndex(e,t,i,s,l),{taskId:e,taskType:t,timestamp:i,files:s,summary:l}}async saveTestGeneration(e,t,n){let r=[],i=e,s=M.join(this.resultsDir,"tests","generated");await O.mkdir(s,{recursive:!0});let a=M.join(this.resultsDir,"tests",`${t}_manifest.json`),o=JSON.stringify({generated:new Date().toISOString(),testsGenerated:i.testsGenerated,coverageEstimate:i.coverageEstimate,patternsUsed:i.patternsUsed,language:n.language||"typescript",framework:n.framework||"vitest",tests:i.tests},null,2);if(await O.writeFile(a,o),r.push(await this.createFileEntry(a,"json")),i.tests){for(let d of i.tests)if(d.code){let m=this.getTestExtension(n.language||"typescript",n.framework||"vitest"),g=this.sanitizeFilename(d.name)+m,p=M.join(s,g);await O.writeFile(p,d.code),r.push(await this.createFileEntry(p,"source"))}}let l=M.join(this.resultsDir,"tests",`${t}_report.md`),c=this.generateTestReport(i,n);return await O.writeFile(l,c),r.push(await this.createFileEntry(l,"markdown")),r}async saveCoverage(e,t,n){let r=[],i=e,s=M.join(this.resultsDir,"coverage"),a=M.join(s,`${t}_coverage.json`);if(await O.writeFile(a,JSON.stringify(i,null,2)),r.push(await this.createFileEntry(a,"json")),n.includeSecondary!==!1){let c=M.join(s,`${t}_coverage.lcov`),d=this.generateLcov(i);await O.writeFile(c,d),r.push(await this.createFileEntry(c,"lcov"))}let o=M.join(s,`${t}_report.md`),l=this.generateCoverageReport(i);return await O.writeFile(o,l),r.push(await this.createFileEntry(o,"markdown")),r}async saveSecurityScan(e,t,n){let r=[],i=e,s=M.join(this.resultsDir,"security"),a=M.join(s,`${t}_scan.json`);if(await O.writeFile(a,JSON.stringify(i,null,2)),r.push(await this.createFileEntry(a,"json")),n.includeSecondary!==!1){let c=M.join(s,`${t}_scan.sarif`),d=this.generateSarif(i);await O.writeFile(c,d),r.push(await this.createFileEntry(c,"sarif"))}let o=M.join(s,`${t}_report.md`),l=this.generateSecurityReport(i);return await O.writeFile(o,l),r.push(await this.createFileEntry(o,"markdown")),r}async saveQualityAssessment(e,t,n){let r=[],i=e,s=M.join(this.resultsDir,"quality"),a=M.join(s,`${t}_assessment.json`);await O.writeFile(a,JSON.stringify(i,null,2)),r.push(await this.createFileEntry(a,"json"));let o=M.join(s,`${t}_report.md`),l=this.generateQualityReport(i);return await O.writeFile(o,l),r.push(await this.createFileEntry(o,"markdown")),r}async saveCodeIndex(e,t,n){let r=[],i=e,s=M.join(this.resultsDir,"code-index");await O.mkdir(s,{recursive:!0});let a=M.join(s,`${t}_index.json`);return await O.writeFile(a,JSON.stringify(i,null,2)),r.push(await this.createFileEntry(a,"json")),r}async saveDefectPrediction(e,t,n){let r=[],i=M.join(this.resultsDir,"defects");await O.mkdir(i,{recursive:!0});let s=M.join(i,`${t}_prediction.json`);return await O.writeFile(s,JSON.stringify(e,null,2)),r.push(await this.createFileEntry(s,"json")),r}async saveContractValidation(e,t,n){let r=[],i=M.join(this.resultsDir,"contracts");await O.mkdir(i,{recursive:!0});let s=M.join(i,`${t}_validation.json`);return await O.writeFile(s,JSON.stringify(e,null,2)),r.push(await this.createFileEntry(s,"json")),r}async saveAccessibilityTest(e,t,n){let r=[],i=M.join(this.resultsDir,"accessibility");await O.mkdir(i,{recursive:!0});let s=M.join(i,`${t}_test.json`);return await O.writeFile(s,JSON.stringify(e,null,2)),r.push(await this.createFileEntry(s,"json")),r}async saveChaosTest(e,t,n){let r=[],i=M.join(this.resultsDir,"chaos");await O.mkdir(i,{recursive:!0});let s=M.join(i,`${t}_chaos.json`);return await O.writeFile(s,JSON.stringify(e,null,2)),r.push(await this.createFileEntry(s,"json")),r}async saveGeneric(e,t,n){let r=[],i=M.join(this.resultsDir,"other");await O.mkdir(i,{recursive:!0});let s=M.join(i,`${n}_${e}.json`);return await O.writeFile(s,JSON.stringify(t,null,2)),r.push(await this.createFileEntry(s,"json")),r}generateLcov(e){return`TN:agentic-qe-coverage
|
|
339
279
|
SF:summary
|
|
340
280
|
DA:1,${Math.round(e.lineCoverage)}
|
|
341
281
|
LF:100
|
|
@@ -437,16 +377,16 @@ ${Object.entries(e.metrics).map(([t,n])=>`| ${t} | ${n.toFixed(1)} |`).join(`
|
|
|
437
377
|
|
|
438
378
|
${e.recommendations.length===0?"No recommendations - all quality gates passed.":e.recommendations.map((t,n)=>`${n+1}. ${t}`).join(`
|
|
439
379
|
`)}
|
|
440
|
-
`}async ensureDirectories(e){let t=[this.resultsDir,M.join(this.resultsDir,"security"),M.join(this.resultsDir,"coverage"),M.join(this.resultsDir,"quality"),M.join(this.resultsDir,"tests"),M.join(this.resultsDir,"tests","generated")];for(let n of t)await
|
|
441
|
-
`,a=r(t),o=
|
|
442
|
-
`),n=null,r=0,i=0,s=0,a=0,o=0,l=0,c=[],d=[];for(let y of t)if(y.startsWith("SF:"))n=y.slice(3);else if(y.startsWith("LF:"))r=parseInt(y.slice(3),10);else if(y.startsWith("LH:"))i=parseInt(y.slice(3),10);else if(y.startsWith("BRF:"))s=parseInt(y.slice(4),10);else if(y.startsWith("BRH:"))a=parseInt(y.slice(4),10);else if(y.startsWith("FNF:"))o=parseInt(y.slice(4),10);else if(y.startsWith("FNH:"))l=parseInt(y.slice(4),10);else if(y.startsWith("DA:")){let[C,b]=y.slice(3).split(",").map(E=>parseInt(E,10));b===0&&c.push(C)}else if(y.startsWith("BRDA:")){let C=y.slice(5).split(","),b=parseInt(C[0],10),E=C[3];(E==="0"||E==="-")&&d.push(b)}else y==="end_of_record"&&n&&(e.push({path:n,lines:{covered:i,total:r},branches:{covered:a,total:s},functions:{covered:l,total:o},statements:{covered:i,total:r},uncoveredLines:Array.from(new Set(c)),uncoveredBranches:Array.from(new Set(d))}),n=null,r=i=0,s=a=0,o=l=0,c.length=0,d.length=0);let m=0,
|
|
443
|
-
`).length,y=Math.max((h.match(/\b(function|=>)\b/g)||[]).length,1),C=Math.max((h.match(/\b(if|switch|case|\?\?|\|\|)\b/g)||[]).length,1),E=[
|
|
444
|
-
`),E=y.startsWith(r)?y.slice(r.length).replace(/^\//,""):y,S=[{regex:/\w*(?:secret|password|passwd|api_key|apikey|private_key|jwt_secret)\w*\s*[=:]\s*['"][^'"]{4,}['"]/gi,title:"Hardcoded secret",severity:"critical"},{regex:/\w*(?:token|auth_token|access_key|secret_key)\w*\s*[=:]\s*['"][^'"]{8,}['"]/gi,title:"Hardcoded credential",severity:"critical"},{regex:/(?:AWS_SECRET|GITHUB_TOKEN|SLACK_TOKEN|OPENAI_API_KEY)\s*[=:]\s*['"][^'"]+['"]/gi,title:"Hardcoded cloud credential",severity:"critical"}];for(let D of S)for(let
|
|
445
|
-
`).findIndex(T=>S.pattern.test(T))+1},description:S.description,category:"dependencies"})}}catch{}}let c=s.map(y=>
|
|
446
|
-
`).length,note:"Structural validation passed. For semantic contract testing, use consumer-driven contract tests."})}catch(n){return I({contractPath:t.contractPath,valid:!1,breakingChanges:[],warnings:[],error:`Could not read or parse contract file: ${w(n)}`})}}catch(n){return
|
|
447
|
-
`),p=m.length,g=0,h=[];p>500?(g+=.25,h.push(`Large file (${p} lines)`)):p>300&&(g+=.15,h.push(`Medium-large file (${p} lines)`));let f=d.match(/\b(if|else|switch|case|for|while|catch|&&|\|\|)\b/g)||[],v=f.length/Math.max(p,1);v>.15?(g+=.25,h.push(`High branch density (${f.length} branches in ${p} lines)`)):v>.08&&(g+=.1,h.push("Moderate branch complexity")),Math.max(...m.map(E=>{let S=E.match(/^(\s*)/);return S?S[1].length:0}))>20&&(g+=.15,h.push("Deep nesting detected"));let C=(d.match(/\b(TODO|FIXME|HACK|XXX|WORKAROUND)\b/gi)||[]).length;C>3&&(g+=.15,h.push(`${C} technical debt markers`));let b=(d.match(/\b(function|def|func|async)\b/g)||[]).length;if(b>0&&p/b>80&&(g+=.1,h.push("Potentially long functions")),g=Math.min(g,.95),g>=r){let E=c.startsWith(n)?c.slice(n.length).replace(/^\//,""):c;s.push({file:E,probability:Math.round(g*100)/100,reason:h.join("; ")})}}catch{}s.sort((c,d)=>d.probability-c.probability);let a=s.length>0?s.reduce((c,d)=>c+d.probability,0)/s.length:0,o=Math.round(a*100),l=[];if(s.length>0){l.push(`${s.length} files flagged for potential defects out of ${i.length} analyzed`);let c=s[0];l.push(`Highest risk: ${c.file} (${Math.round(c.probability*100)}%) \u2014 ${c.reason}`)}return s.some(c=>c.reason.includes("Large file"))&&l.push("Consider splitting large files to reduce complexity"),s.some(c=>c.reason.includes("technical debt"))&&l.push("Address TODO/FIXME comments to reduce technical debt"),s.length===0&&l.push("No files exceeded the defect probability threshold \u2014 code looks healthy"),I({predictedDefects:s.slice(0,20),riskScore:o,recommendations:l,filesAnalyzed:i.length})}catch(n){return q(z(n))}})}function Kn(u){u.registerHandler("test-accessibility",async e=>{let t=e.payload;return I({url:t.url||"",standard:t.standard||"wcag21-aa",passed:!1,violations:[],warnings:[],score:0,note:"Accessibility testing requires a browser environment (Puppeteer/Playwright). Use tools like axe-core, pa11y, or Lighthouse CLI for WCAG compliance testing. Example: npx pa11y "+(t.url||"<url>")})}),u.registerHandler("run-chaos",async e=>{let t=e.payload;return I({faultType:t.faultType||"unknown",target:t.target||"unknown",dryRun:t.dryRun??!0,duration:t.duration||0,systemBehavior:"not-executed",resilience:null,note:"Chaos engineering requires infrastructure-level fault injection. Use tools like Chaos Monkey, Litmus, or toxiproxy for real resilience testing. For Node.js apps, consider: nock (HTTP faults), testcontainers (dependency failures)."})}),u.registerHandler("optimize-learning",async e=>{try{let t=await import("./unified-memory-hnsw-6N7YZCLR.js");return I({patternsLearned:0,modelsUpdated:0,memoryConsolidated:!1,note:'Learning optimization runs during the dream cycle (SessionEnd hook). Use "npx agentic-qe hooks session-end --save-state" to trigger pattern consolidation.'})}catch{return I({patternsLearned:0,modelsUpdated:0,memoryConsolidated:!1,note:'Learning system not initialized. Run "aqe init --auto" first.'})}})}var re=ye("TaskExecutor");function no(u){return Te.resolve(Ce.CoverageAnalyzerService)(u)}function ro(u){return Te.resolve(Ce.SecurityScannerService)(u)}function io(u){return Te.resolve(Ce.createTestGeneratorService)(u)}function so(u){return Te.resolve(Ce.KnowledgeGraphService)(u)}function ao(u){return Te.resolve(Ce.QualityAnalyzerService)(u)}function Ri(u){switch(u){case 0:return"agent-booster";case 1:return"claude-haiku-4-5-20251001";case 2:return"claude-sonnet-4-6";case 3:return"claude-sonnet-4-6";case 4:return"claude-opus-4-7";default:return"claude-sonnet-4-6"}}function oo(u){if(["generate-tests","analyze-coverage","scan-security","execute-tests","assess-quality","validate-contracts","test-accessibility","chaos-test","predict-defects","validate-requirements","index-code"].includes(u.type))return null;let t=u.payload?.codeContext||"",n=u.payload?.sourceCode||"",r=t||n;return r?r.includes("var ")&&!r.includes("const ")&&!r.includes("let ")?"var-to-const":r.includes("console.log")||r.includes("console.warn")||r.includes("console.error")?"remove-console":r.includes(".then(")&&r.includes(".catch(")?"promise-to-async":r.includes("require(")&&!r.includes("import ")?"cjs-to-esm":r.includes("function ")&&!r.includes("=>")?"func-to-arrow":null:null}var Yn=class{constructor(e,t,n){this.kernel=e;this.eventBus=t;this._config={timeout:n?.timeout??3e5,maxRetries:n?.maxRetries??3,enableCaching:n?.enableCaching??!0,saveResults:n?.saveResults??!0,resultsDir:n?.resultsDir??".agentic-qe",defaultLanguage:n?.defaultLanguage??"typescript",defaultFramework:n?.defaultFramework??"vitest"},this.resultSaver=li(this._config.resultsDir),this.registerHandlers()}kernel;eventBus;_config;resultSaver;coverageAnalyzer=null;securityScanner=null;testGenerator=null;knowledgeGraph=null;qualityAnalyzer=null;agentBooster=null;taskRouter=null;qualityFeedbackLoop=null;coherenceActionGate=null;taskHandlers=new Map;get config(){return this._config}registerHandler(e,t){this.taskHandlers.set(e,t)}setQualityFeedbackLoop(e){this.qualityFeedbackLoop=e}getCoverageAnalyzer(){return this.coverageAnalyzer||(this.coverageAnalyzer=no(this.kernel.memory)),this.coverageAnalyzer}getSecurityScanner(){return this.securityScanner||(this.securityScanner=ro(this.kernel.memory)),this.securityScanner}getTestGenerator(){return this.testGenerator||(this.testGenerator=io(this.kernel.memory)),this.testGenerator}getKnowledgeGraph(){return this.knowledgeGraph||(this.knowledgeGraph=so(this.kernel.memory)),this.knowledgeGraph}getQualityAnalyzer(){return this.qualityAnalyzer||(this.qualityAnalyzer=ao(this.kernel.memory)),this.qualityAnalyzer}registerHandlers(){$n(this),Un(this),Hn(this),Vn(this),Qn(this),Wn(this),Kn(this)}async getAgentBooster(){return this.agentBooster||(this.agentBooster=await vt({enabled:!0,fallbackToLLM:!0,confidenceThreshold:.7})),this.agentBooster}async getTaskRouterInstance(){if(!this.taskRouter)try{this.taskRouter=await Lt()}catch{return null}return this.taskRouter}async executeWithAgentBooster(e,t,n){let r=oo(e);if(!r)return console.debug(`[TaskExecutor] No applicable Agent Booster transform for task ${e.id}`),null;try{let i=await this.getAgentBooster(),s=e.payload?.codeContext||e.payload?.sourceCode||"",a=await i.transform(s,r);return a.success&&a.confidence>=.7?(console.debug(`[TaskExecutor] Agent Booster transform succeeded: ${r}, confidence=${a.confidence}`),{taskId:e.id,success:!0,data:{transformed:!0,transformType:r,originalCode:a.originalCode,transformedCode:a.transformedCode,confidence:a.confidence,implementationUsed:a.implementationUsed,durationMs:a.durationMs,changeCount:a.changeCount,tier:0,model:"agent-booster"},duration:Date.now()-t,domain:n}):(console.debug(`[TaskExecutor] Agent Booster low confidence (${a.confidence}), falling back to Tier 1`),null)}catch(i){return console.warn(`[TaskExecutor] Agent Booster error, falling back: ${i}`),null}}async recordOutcome(e,t,n,r){try{if(!await this.getTaskRouterInstance())return;if(console.debug(`[TaskExecutor] Outcome recorded: task=${e.id}, tier=${t}, model=${Ri(t)}, success=${n}, duration=${r}ms`),this.qualityFeedbackLoop){let s=e.targetDomains||[],a=n?1:0,o=r<100?1:r<500?.8:r<2e3?.6:r<5e3?.4:r<1e4?.2:.1,l=.25*a+.325+.1*o;await this.qualityFeedbackLoop.recordRoutingOutcome({taskId:e.id,taskDescription:e.type,recommendedAgent:String(t),usedAgent:String(t),followedRecommendation:!0,success:n,qualityScore:l,durationMs:r,timestamp:new Date,error:n?void 0:"Task execution failed"})}}catch(i){console.warn("[TaskExecutor] Failed to record outcome:",i)}}async execute(e){let t=Date.now(),n=this.getTaskDomain(e.type),r=e.payload,i=r?.routingTier??2,s=r?.useAgentBooster??!1,a=r?.compiledContext??void 0,o=Ri(i);a&&e.payload&&(e.payload.__compiledContext=a),console.debug(`[TaskExecutor] Executing task ${e.id}: type=${e.type}, tier=${i}, model=${o}, useAgentBooster=${s}${a?", hasContext=true":""}`);let l=this.evaluateCoherenceGate(e,n);l&&console.debug(`[TaskExecutor] Coherence gate: task=${e.id}, decision=${l.decision}, combined=${l.combinedScore.toFixed(3)}, advisory=${l.advisory}`),this.validateWithReasoningQEC(e,n);try{if(i===0||s){let p=await this.executeWithAgentBooster(e,t,n);if(p)return this.recordOutcome(e,0,!0,Date.now()-t).catch(g=>{re.warn("recordOutcome failed",{error:g instanceof Error?g.message:String(g),taskId:e.id})}),await this.publishTaskCompleted(e.id,p.data,n),p;console.debug(`[TaskExecutor] Agent Booster fallback to Tier 1 for task ${e.id}`)}let c=this.taskHandlers.get(e.type);if(!c){let p={taskId:e.id,success:!1,error:`No handler registered for task type: ${e.type}`,duration:Date.now()-t,domain:n};return this.recordOutcome(e,i,!1,Date.now()-t).catch(g=>{re.warn("recordOutcome failed",{error:g instanceof Error?g.message:String(g),taskId:e.id})}),p}let d=await Promise.race([c(e),this.timeout(e.timeout||this._config.timeout)]);if(!d.success){let p="error"in d?d.error.message:"Unknown error";return await this.publishTaskFailed(e.id,p,n),this.recordOutcome(e,i,!1,Date.now()-t).catch(g=>{re.warn("recordOutcome failed",{error:g instanceof Error?g.message:String(g),taskId:e.id})}),{taskId:e.id,success:!1,error:p,duration:Date.now()-t,domain:n}}await this.publishTaskCompleted(e.id,d.value,n),this.recordOutcome(e,i,!0,Date.now()-t).catch(p=>{re.warn("recordOutcome failed",{error:p instanceof Error?p.message:String(p),taskId:e.id})});let m;if(this._config.saveResults)try{let p={language:r?.language||this._config.defaultLanguage,framework:r?.framework||this._config.defaultFramework,includeSecondary:!0};m=(await this.resultSaver.save(e.id,e.type,d.value,p)).files.map(h=>h.path)}catch(p){console.error(`[TaskExecutor] Failed to save results: ${p}`)}return{taskId:e.id,success:!0,data:{...d.value,_routing:{tier:i,model:o,usedAgentBooster:!1}},duration:Date.now()-t,domain:n,savedFiles:m}}catch(c){let d=w(c);return await this.publishTaskFailed(e.id,d,n),this.recordOutcome(e,i,!1,Date.now()-t).catch(m=>{re.warn("recordOutcome failed",{error:m instanceof Error?m.message:String(m),taskId:e.id})}),{taskId:e.id,success:!1,error:d,duration:Date.now()-t,domain:n}}}async resetServiceCaches(){if(this.coverageAnalyzer=null,this.securityScanner=null,this.testGenerator=null,this.knowledgeGraph=null,this.qualityAnalyzer=null,this.coherenceActionGate=null,this.agentBooster){try{await this.agentBooster.dispose()}catch(e){console.debug("[TaskExecutor] Agent Booster disposal error:",e instanceof Error?e.message:e)}this.agentBooster=null}this.taskRouter=null}resetServiceCachesSync(){this.coverageAnalyzer=null,this.securityScanner=null,this.testGenerator=null,this.knowledgeGraph=null,this.qualityAnalyzer=null,this.agentBooster=null,this.taskRouter=null,this.coherenceActionGate=null}evaluateCoherenceGate(e,t){try{this.coherenceActionGate||(this.coherenceActionGate=di({advisory:!0}));let n=e.payload,r=typeof n?.confidence=="number"?n.confidence:.7,i=n?.riskLevel??"medium";return mi(e.type,t,r,i,n??{},this.coherenceActionGate)}catch(n){return re.warn("Coherence gate evaluation error (continuing)",{error:n instanceof Error?n.message:String(n),taskId:e.id}),null}}_reasoningQEC=null;_reasoningQECLoaded=!1;validateWithReasoningQEC(e,t){try{if(!this._reasoningQECLoaded){this._reasoningQECLoaded=!0;try{let{isReasoningQECEnabled:s}=(ht(),mt(As));if(s()){let{createReasoningQEC:a}=(wi(),mt(Ei));this._reasoningQEC=a()}}catch(s){re.debug("ReasoningQEC module unavailable",{error:s instanceof Error?s.message:String(s)})}}if(!this._reasoningQEC)return;let n=e.payload,r=n?.reasoningSteps;if(!r||r.length<2)return;let i=this._reasoningQEC.validate({type:t,context:n,steps:r});i.valid||re.warn("ReasoningQEC validation found issues (advisory)",{taskId:e.id,domain:t,confidence:i.confidence,issues:i.issues.length})}catch(n){re.debug("ReasoningQEC evaluation error",{error:n instanceof Error?n.message:String(n),taskId:e.id})}}getTaskDomain(e){return{"generate-tests":"test-generation","execute-tests":"test-execution","analyze-coverage":"coverage-analysis","assess-quality":"quality-assessment","predict-defects":"defect-intelligence","validate-requirements":"requirements-validation","index-code":"code-intelligence","scan-security":"security-compliance","validate-contracts":"contract-testing","test-accessibility":"visual-accessibility","run-chaos":"chaos-resilience","optimize-learning":"learning-optimization","cross-domain-workflow":"learning-optimization","protocol-execution":"learning-optimization","ideation-assessment":"requirements-validation"}[e]||"learning-optimization"}async timeout(e){return new Promise((t,n)=>{setTimeout(()=>n(new Error(`Task execution timed out after ${e}ms`)),e)})}async publishTaskCompleted(e,t,n){await this.eventBus.publish({id:L(),type:"TaskCompleted",timestamp:new Date,source:n,payload:{taskId:e,result:t}})}async publishTaskFailed(e,t,n){await this.eventBus.publish({id:L(),type:"TaskFailed",timestamp:new Date,source:n,payload:{taskId:e,error:t}})}};function xi(u,e){return new Yn(u,u.eventBus,e)}import{randomUUID as ke}from"crypto";k();var Jn={effectiveness:.25,coverage:.2,mutationKill:.15,stability:.15,maintainability:.15,performance:.1},Zn={"short-term":{minSuccessCount:0,minSuccessRate:0,minQualityScore:0,minAgeDays:0},working:{minSuccessCount:3,minSuccessRate:.6,minQualityScore:.5,minAgeDays:1},"long-term":{minSuccessCount:10,minSuccessRate:.75,minQualityScore:.7,minAgeDays:7},permanent:{minSuccessCount:50,minSuccessRate:.9,minQualityScore:.85,minAgeDays:30}},ce={qualityWeights:Jn,promotionCriteria:Zn,autoPromote:!0,autoDemote:!0,minCoverageImprovementToLearn:5,maxOutcomesInMemory:1e4,persistOutcomes:!0,batchSize:100};ee();k();U();var er=class{outcomes=[];maxOutcomes;constructor(e){this.maxOutcomes=e}add(e){this.outcomes.push(e),this.outcomes.length>this.maxOutcomes&&(this.outcomes=this.outcomes.slice(-this.maxOutcomes))}getAll(){return[...this.outcomes]}getByPattern(e){return this.outcomes.filter(t=>t.patternId===e)}getByAgent(e){return this.outcomes.filter(t=>t.generatedBy===e)}getByDomain(e){return this.outcomes.filter(t=>t.domain===e)}getRecent(e){return this.outcomes.slice(-e)}clear(){this.outcomes=[]}get size(){return this.outcomes.length}},tr=class u{store;reasoningBank=null;config;db=null;persistCount=0;static RETENTION_CLEANUP_INTERVAL=100;patternMetrics=new Map;constructor(e={}){this.config={...ce,...e},this.store=new er(this.config.maxOutcomesInMemory)}connectReasoningBank(e){this.reasoningBank=e}async initialize(){try{this.db=$(),this.db.isInitialized()||await this.db.initialize(),await this.loadFromDb()}catch(e){console.warn("[TestOutcomeTracker] DB initialization failed, using memory-only:",w(e)),this.db=null}}async loadFromDb(){if(!this.db)return;let t=this.db.getDatabase().prepare(`
|
|
380
|
+
`}async ensureDirectories(e){let t=[this.resultsDir,M.join(this.resultsDir,"security"),M.join(this.resultsDir,"coverage"),M.join(this.resultsDir,"quality"),M.join(this.resultsDir,"tests"),M.join(this.resultsDir,"tests","generated")];for(let n of t)await O.mkdir(n,{recursive:!0})}formatTimestamp(e){return e.toISOString().replace(/[:.]/g,"-").slice(0,19)}sanitizeFilename(e){return e.replace(/[^a-zA-Z0-9_-]/g,"_").toLowerCase()}getTestExtension(e,t){let n=Fa[e.toLowerCase()];return n&&(n[t.toLowerCase()]||n.default)||".test.ts"}async createFileEntry(e,t){let n=await O.readFile(e),r=await O.stat(e),i=_a("sha256").update(n).digest("hex").slice(0,16);return{path:e,format:t,size:r.size,checksum:i}}extractSummary(e,t){let n=t;switch(e){case"scan-security":return{vulnerabilities:n.vulnerabilities,critical:n.critical,high:n.high};case"analyze-coverage":return{lineCoverage:n.lineCoverage,branchCoverage:n.branchCoverage};case"assess-quality":return{qualityScore:n.qualityScore,passed:n.passed};case"generate-tests":return{testsGenerated:n.testsGenerated,coverageEstimate:n.coverageEstimate};default:return{}}}async updateIndex(e,t,n,r,i){let s=M.join(this.resultsDir,"index.json"),a;try{let o=await O.readFile(s,"utf-8");a=x(o)}catch{a={version:"1.0",created:new Date().toISOString(),updated:new Date().toISOString(),results:[],trends:{}}}a.results.push({id:e,type:t,timestamp:n.toISOString(),files:r.map(o=>M.relative(this.resultsDir,o.path)),summary:i}),a.updated=new Date().toISOString(),a.results.length>100&&(a.results=a.results.slice(-100)),await O.writeFile(s,JSON.stringify(a,null,2))}};function oi(u){return new _n(u)}fn();fn();pt();var Fn=ye("CoherenceActionGate"),La={structuralPermit:.4,structuralDeny:.2,shiftPermit:.5,shiftDeny:.25,evidencePermit:.5,evidenceDeny:.2,combinedPermit:.5,combinedDeny:.25},Ln={structural:.3,shift:.35,evidence:.35},Na={low:1,medium:.9,high:.75,critical:.6},ci=1e3,_t=class{thresholds;advisoryMode;nativeAvailable=null;evaluationHistory=[];permitCount=0;deferCount=0;denyCount=0;totalCombinedScore=0;totalStructuralScore=0;totalShiftScore=0;totalEvidenceScore=0;cusumHigh=0;cusumLow=0;cusumMean=.7;cusumK=.05;cusumH=4;cusumSampleCount=0;cusumAlertActive=!1;constructor(e){this.advisoryMode=e?.advisory??!0,this.thresholds={...La,...e?.thresholds}}evaluate(e){let t=this.computeStructuralScore(e),n=this.computeShiftScore(e),r=this.computeEvidenceScore(e),i=t*Ln.structural+n*Ln.shift+r*Ln.evidence,s=Na[e.riskLevel]??1,a=i*s,o=this.computeDecision(t,n,r,a),l=this.buildReasoning(e,o,t,n,r,a),c={decision:o,structuralScore:t,shiftScore:n,evidenceScore:r,combinedScore:a,reasoning:l,advisory:this.advisoryMode};return this.recordEvaluation(c),Fn.debug("Action gate evaluation",{action:e.type,domain:e.domain,decision:o,combinedScore:a,advisory:this.advisoryMode}),c}getStatistics(){let e=this.evaluationHistory.length;return{totalEvaluations:e,permitCount:this.permitCount,deferCount:this.deferCount,denyCount:this.denyCount,averageCombinedScore:e>0?this.totalCombinedScore/e:0,averageStructuralScore:e>0?this.totalStructuralScore/e:0,averageShiftScore:e>0?this.totalShiftScore/e:0,averageEvidenceScore:e>0?this.totalEvidenceScore/e:0,advisoryMode:this.advisoryMode}}configureThresholds(e){this.thresholds={...this.thresholds,...e},Fn.info("Action gate thresholds updated",{thresholds:this.thresholds})}getThresholds(){return{...this.thresholds}}isAdvisory(){return this.advisoryMode}getEvaluationHistory(){return[...this.evaluationHistory]}resetStatistics(){this.evaluationHistory=[],this.permitCount=0,this.deferCount=0,this.denyCount=0,this.totalCombinedScore=0,this.totalStructuralScore=0,this.totalShiftScore=0,this.totalEvidenceScore=0,this.resetCusum()}resetCusum(){this.cusumHigh=0,this.cusumLow=0,this.cusumAlertActive=!1,this.cusumSampleCount=0}computeStructuralScore(e){let t=.5;["generate-test","modify-code","analyze-coverage","scan-security","assess-quality","validate-contracts","test-accessibility","execute-tests","index-code","predict-defects","validate-requirements","deploy","run-chaos","optimize-learning"].includes(e.type)&&(t+=.2),JSON.stringify(e.context).toLowerCase().includes(e.domain.toLowerCase())&&(t+=.15);let i=Object.keys(e.context);return i.length>=3?t+=.15:i.length>=1&&(t+=.05),Math.min(Math.max(t,0),1)}computeShiftScore(e){let t=e.confidence,r={low:.25,medium:.5,high:.75,critical:1}[e.riskLevel]??.5,i=Math.max(0,r-e.confidence);t-=i*.3;let s=e.context;(s.stale===!0||s.outdated===!0)&&(t-=.3),(s.distributionShift===!0||s.contextChanged===!0)&&(t-=.4),this.cusumSampleCount++;let a=e.confidence;return this.cusumHigh=Math.max(0,this.cusumHigh+(a-this.cusumMean)-this.cusumK),this.cusumLow=Math.max(0,this.cusumLow-(a-this.cusumMean)-this.cusumK),this.cusumHigh>this.cusumH||this.cusumLow>this.cusumH?(t-=.2,this.cusumAlertActive||(this.cusumAlertActive=!0,Fn.warn("CUSUM shift detected",{cusumHigh:this.cusumHigh,cusumLow:this.cusumLow}))):this.cusumAlertActive=!1,Math.min(Math.max(t,0),1)}computeEvidenceScore(e){let t=.5,n=e.context,r=["testResults","coverageData","securityScan","qualityReport","peerReview","analysisResult","validationPassed","precedent","historicalSuccess"];for(let s of r)n[s]!==void 0&&n[s]!==null&&(t*=1+.15);let i=["errors","failures","warnings","regressions","conflictingResults","noTestCoverage"];for(let s of i)n[s]!==void 0&&n[s]!==null&&(t*=1-.18);if((e.riskLevel==="critical"||e.riskLevel==="high")&&!n.testResults&&!n.peerReview&&(t-=.15),typeof n.evidenceCount=="number"){let s=n.evidenceCount;t+=Math.min(s*.05,.2)}return Math.min(Math.max(t,0),1)}computeDecision(e,t,n,r){return e<this.thresholds.structuralDeny||t<this.thresholds.shiftDeny||n<this.thresholds.evidenceDeny||r<this.thresholds.combinedDeny?"DENY":e>=this.thresholds.structuralPermit&&t>=this.thresholds.shiftPermit&&n>=this.thresholds.evidencePermit&&r>=this.thresholds.combinedPermit?"PERMIT":"DEFER"}buildReasoning(e,t,n,r,i,s){let a=[];if(a.push(`Decision: ${t} for ${e.type} (${e.domain}).`),a.push(`Scores: structural=${n.toFixed(2)}, shift=${r.toFixed(2)}, evidence=${i.toFixed(2)}, combined=${s.toFixed(2)}.`),t==="DENY")n<this.thresholds.structuralDeny&&a.push("Structural filter failed: action does not fit codebase graph."),r<this.thresholds.shiftDeny&&a.push("Shift filter failed: significant context distribution shift detected."),i<this.thresholds.evidenceDeny&&a.push("Evidence filter failed: insufficient evidence to justify action."),s<this.thresholds.combinedDeny&&a.push("Combined score below minimum threshold.");else if(t==="DEFER"){let o=[];n<this.thresholds.structuralPermit&&o.push("structural"),r<this.thresholds.shiftPermit&&o.push("shift"),i<this.thresholds.evidencePermit&&o.push("evidence"),o.length>0&&a.push(`Marginal filters: ${o.join(", ")}. Human review recommended.`)}return this.advisoryMode&&a.push("(Advisory mode: decision logged only, not enforced.)"),a.join(" ")}recordEvaluation(e){switch(this.evaluationHistory.push(e),this.evaluationHistory.length>ci&&(this.evaluationHistory=this.evaluationHistory.slice(-ci)),this.totalCombinedScore+=e.combinedScore,this.totalStructuralScore+=e.structuralScore,this.totalShiftScore+=e.shiftScore,this.totalEvidenceScore+=e.evidenceScore,e.decision){case"PERMIT":this.permitCount++;break;case"DEFER":this.deferCount++;break;case"DENY":this.denyCount++;break}}};function li(u){return new _t(u)}function ui(u,e,t,n,r,i){if(!ve().useCoherenceActionGate)return null;let a=i??new _t,o={type:u,domain:e,confidence:t,context:r,riskLevel:n};return a.evaluate(o)}import*as Ft from"fs/promises";k();function qa(u){return u.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ga(u,e,t,n){if(!t)return{testCode:u,sourceFile:e};let r=m=>m.replace(/\.[a-z]+$/i,""),i=n?n.match(/\.(ts|tsx|js|jsx|mjs|cjs)$/i)?r(n):n:"./module-under-test",s=n?"":`// TODO: replace './module-under-test' with the actual import path of the module under test
|
|
381
|
+
`,a=r(t),o=qa(a),l=new RegExp(o+"(?:\\.[a-zA-Z]+){0,2}","g");return{testCode:u&&s+u.replace(l,i),sourceFile:e===t&&n||e}}function Nn(u){u.registerHandler("generate-tests",async e=>{let t=e.payload;try{let n=u.getTestGenerator(),r=[],i;if(t.sourceFiles&&t.sourceFiles.length>0)r=t.sourceFiles;else if(t.filePath)r=[t.filePath];else if(t.sourceCode){let m={python:".py",typescript:".ts",javascript:".js",go:".go",rust:".rs",java:".java",ruby:".rb",kotlin:".kt",csharp:".cs",php:".php",swift:".swift",cpp:".cpp",c:".c",scala:".scala"}[t.language?.toLowerCase()||"typescript"]||".ts";i=`/tmp/aqe-temp-${$()}${m}`,await Ft.writeFile(i,t.sourceCode,"utf-8"),r=[i]}if(r.length===0)return I({testsGenerated:0,coverageEstimate:0,tests:[],patternsUsed:[],warning:"No source files or code provided for test generation. Provide sourceCode, filePath, or sourceFiles in the payload."});let s=t.framework||"vitest",a=i?{[i]:t.filePath?t.filePath.replace(/\.(ts|tsx|js|jsx|mjs|cjs)$/i,""):"./module-under-test"}:void 0,o=await n.generateTests({sourceFiles:r,testType:t.testType||"unit",framework:s,coverageTarget:t.coverageGoal||80,patterns:[],importPathOverrides:a});if(i)try{await Ft.unlink(i)}catch{}if(!o.success)return o;let l=o.value,c=l.tests.map(d=>{let m=Ga(d.testCode,d.sourceFile,i,t.filePath);return{name:d.name,file:d.testFile,type:d.type,sourceFile:m.sourceFile,assertions:d.assertions,testCode:m.testCode}});return I({testsGenerated:c.length,coverageEstimate:l.coverageEstimate,tests:c,patternsUsed:l.patternsUsed})}catch(n){return N(G(n))}}),u.registerHandler("execute-tests",async e=>{let t=e.payload;try{let n=t.testFiles||[];if(n.length===0)return I({total:0,passed:0,failed:0,skipped:0,duration:0,coverage:0,failedTests:[],warning:"No test files specified. Provide testFiles array with paths to test files."});let r=process.cwd(),i,s=/^[a-zA-Z0-9_.\/\-@]+$/,a=n.filter(o=>s.test(o));if(a.length!==n.length)return I({total:0,passed:0,failed:0,skipped:0,duration:0,coverage:0,failedTests:[],warning:"Some test file paths contain invalid characters and were rejected."});try{let{spawnSync:o}=await import("child_process"),l=o("npx",["vitest","run",...a,"--reporter=json"],{cwd:r,timeout:12e4,encoding:"utf-8",stdio:["pipe","pipe","pipe"]});i=l.stdout||"",!i.includes("{")&&l.status!==0&&(i=o("npx",["jest",...a,"--json"],{cwd:r,timeout:12e4,encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).stdout||"")}catch(o){i=o.stdout||""}try{let o=i.indexOf("{");if(o>=0){let l=JSON.parse(i.slice(o));if(l.testResults){let c=l.numTotalTests||0,d=l.numPassedTests||0,m=l.numFailedTests||0;return I({total:c,passed:d,failed:m,skipped:c-d-m,duration:0,coverage:0,failedTests:[]})}}}catch{}return I({total:n.length,passed:0,failed:0,skipped:0,duration:0,coverage:0,failedTests:[],warning:"Could not parse test runner output. Check that vitest or jest is installed.",rawOutput:i.slice(0,500)})}catch(n){return N(G(n))}})}import*as mi from"fs/promises";import*as ne from"fs";import*as xe from"path";k();j();j();import*as Pe from"fs/promises";import*as Y from"path";async function qn(u){let e=[Y.join(u,"coverage","coverage-final.json"),Y.join(u,"coverage","lcov.info"),Y.join(u,".nyc_output","coverage-final.json"),Y.join(u,"coverage-final.json"),Y.join(u,"coverage.xml"),Y.join(u,"htmlcov","status.json"),Y.join(u,"cobertura-coverage.xml")];for(let t of e)try{let n=await Pe.readFile(t,"utf-8");if(t.endsWith(".json"))return $a(n);if(t.endsWith(".info"))return za(n);if(t.endsWith(".xml"))return Ba(n)}catch{}return null}function $a(u){let e=x(u),t=[],n=0,r=0,i=0,s=0,a=0,o=0,l=0,c=0;for(let[d,m]of Object.entries(e)){let g=m,p=g.statementMap||{},h=g.s||{},f=g.branchMap||{},v=g.b||{},y=g.f||{},C=Object.keys(h).length,b=Object.values(h).filter(L=>L>0).length,E=Object.values(v).flat().length,S=Object.values(v).flat().filter(L=>L>0).length,T=Object.keys(y).length,R=Object.values(y).filter(L=>L>0).length,D=Object.keys(p).length,q=Object.values(h).filter(L=>L>0).length,U=[];for(let[L,H]of Object.entries(h))if(H===0){let ue=p[L];ue?.start?.line&&U.push(ue.start.line)}let W=[];for(let[L,H]of Object.entries(v)){let ue=f[L];H.forEach((lt,K)=>{lt===0&&ue?.locations?.[K]?.start?.line&&W.push(ue.locations[K].start.line)})}t.push({path:d,lines:{covered:b,total:C},branches:{covered:S,total:E},functions:{covered:R,total:T},statements:{covered:q,total:D},uncoveredLines:Array.from(new Set(U)).sort((L,H)=>L-H),uncoveredBranches:Array.from(new Set(W)).sort((L,H)=>L-H)}),n+=C,r+=b,i+=E,s+=S,a+=T,o+=R,l+=D,c+=q}return{files:t,summary:{line:n>0?r/n*100:0,branch:i>0?s/i*100:0,function:a>0?o/a*100:0,statement:l>0?c/l*100:0,files:t.length}}}function za(u){let e=[],t=u.split(`
|
|
382
|
+
`),n=null,r=0,i=0,s=0,a=0,o=0,l=0,c=[],d=[];for(let y of t)if(y.startsWith("SF:"))n=y.slice(3);else if(y.startsWith("LF:"))r=parseInt(y.slice(3),10);else if(y.startsWith("LH:"))i=parseInt(y.slice(3),10);else if(y.startsWith("BRF:"))s=parseInt(y.slice(4),10);else if(y.startsWith("BRH:"))a=parseInt(y.slice(4),10);else if(y.startsWith("FNF:"))o=parseInt(y.slice(4),10);else if(y.startsWith("FNH:"))l=parseInt(y.slice(4),10);else if(y.startsWith("DA:")){let[C,b]=y.slice(3).split(",").map(E=>parseInt(E,10));b===0&&c.push(C)}else if(y.startsWith("BRDA:")){let C=y.slice(5).split(","),b=parseInt(C[0],10),E=C[3];(E==="0"||E==="-")&&d.push(b)}else y==="end_of_record"&&n&&(e.push({path:n,lines:{covered:i,total:r},branches:{covered:a,total:s},functions:{covered:l,total:o},statements:{covered:i,total:r},uncoveredLines:Array.from(new Set(c)),uncoveredBranches:Array.from(new Set(d))}),n=null,r=i=0,s=a=0,o=l=0,c.length=0,d.length=0);let m=0,g=0,p=0,h=0,f=0,v=0;for(let y of e)m+=y.lines.total,g+=y.lines.covered,p+=y.branches.total,h+=y.branches.covered,f+=y.functions.total,v+=y.functions.covered;return{files:e,summary:{line:m>0?g/m*100:0,branch:p>0?h/p*100:0,function:f>0?v/f*100:0,statement:m>0?g/m*100:0,files:e.length}}}function Ba(u){let e=[];function t(p,h){let f=p.match(new RegExp(`${h}=["']([^"']*)["']`));return f?f[1]:null}let n=/<class\s[^>]*?>/g,r;for(;(r=n.exec(u))!==null;){let p=r[0],h=t(p,"filename");if(!h)continue;let f=parseFloat(t(p,"line-rate")||"NaN"),v=parseFloat(t(p,"branch-rate")||"NaN"),y=r.index,C=u.indexOf("</class>",y),b=C>y?u.slice(y,C):"",E=0,S=0,T=0,R=0,D=0,q=0,U=[],W=[],L=/<line\s([^>]*?)\/>/g,H;for(;(H=L.exec(b))!==null;){let K=H[1],Ne=parseInt(t(K,"number")||"0",10),ut=parseInt(t(K,"hits")||"0",10),gn=t(K,"branch")==="true",qe=t(K,"condition-coverage");E++,ut>0?S++:U.push(Ne),gn&&(T++,(qe?parseInt(qe,10):ut>0?100:0)===100?R++:W.push(Ne))}let ue=/<method\s([^>]*?)>/g,lt;for(;(lt=ue.exec(b))!==null;){D++;let K=lt.index,Ne=b.indexOf("</method>",K);if(Ne>K){let ut=b.slice(K,Ne),gn=/<line\s([^>]*?)\/>/g,qe=!1,hn;for(;(hn=gn.exec(ut))!==null;)if(parseInt(t(hn[1],"hits")||"0",10)>0){qe=!0;break}qe&&q++}}E===0&&!isNaN(f)&&(E=1,S=f>=.5?1:0),e.push({path:h,lines:{covered:S,total:E},branches:{covered:R,total:T},functions:{covered:q,total:D},statements:{covered:S,total:E},uncoveredLines:U,uncoveredBranches:W})}let i=0,s=0,a=0,o=0,l=0,c=0;for(let p of e)i+=p.lines.total,s+=p.lines.covered,a+=p.branches.total,o+=p.branches.covered,l+=p.functions.total,c+=p.functions.covered;let d=u.match(/<coverage\s[^>]*?>/),m=d?parseFloat(t(d[0],"line-rate")||"NaN")*100:NaN,g=d?parseFloat(t(d[0],"branch-rate")||"NaN")*100:NaN;return{files:e,summary:{line:isNaN(m)?i>0?s/i*100:0:m,branch:isNaN(g)?a>0?o/a*100:0:g,function:l>0?c/l*100:0,statement:i>0?s/i*100:0,files:e.length}}}async function ee(u,e={}){let t=[],{includeTests:n=!0,languages:r,maxFiles:i=5e3}=e,s=[".ts",".tsx",".js",".jsx",".mjs",".cjs",".py",".pyw",".go",".rs",".java",".kt",".kts",".rb",".cs",".php",".swift",".c",".h",".cpp",".hpp",".cc",".scala"];if(r&&r.length>0){s=[];for(let o of r)o==="typescript"&&s.push(".ts",".tsx"),o==="javascript"&&s.push(".js",".jsx",".mjs",".cjs"),o==="python"&&s.push(".py",".pyw"),o==="go"&&s.push(".go"),o==="rust"&&s.push(".rs"),o==="java"&&s.push(".java"),o==="kotlin"&&s.push(".kt",".kts"),o==="ruby"&&s.push(".rb"),(o==="csharp"||o==="c#")&&s.push(".cs"),o==="php"&&s.push(".php"),o==="swift"&&s.push(".swift"),(o==="c"||o==="cpp"||o==="c++")&&s.push(".c",".h",".cpp",".hpp",".cc"),o==="scala"&&s.push(".scala")}async function a(o){try{let l=await Pe.readdir(o,{withFileTypes:!0});for(let c of l){let d=Y.join(o,c.name);if(c.isDirectory()){if(["node_modules",".git","dist","build","coverage",".nyc_output","__pycache__",".venv","venv",".tox",".mypy_cache","target",".gradle","vendor",".bundle",".agentic-qe",".claude",".cache",".npm",".yarn",".next",".nuxt",".svelte-kit","out",".turbo","tmp","temp",".tmp"].includes(c.name))continue;if(t.length>=i)return;await a(d)}else if(c.isFile()){let m=Y.extname(c.name);if(!s.includes(m)||!n&&(c.name.includes(".test.")||c.name.includes(".spec.")||c.name.endsWith("_test.ts")||c.name.endsWith("_test.js")||d.includes("/__tests__/")||d.includes("/test/")||d.includes("/tests/")))continue;if(t.length>=i)return;t.push(d)}}}catch{}}try{if((await Pe.stat(u)).isFile())return[u];await a(u)}catch{}return t}function di(u){let e=new Set,t={injection:"Use parameterized queries and input validation to prevent injection attacks",xss:"Sanitize user input and use Content-Security-Policy headers","sensitive-data":"Never hardcode secrets; use environment variables or secret managers","access-control":"Implement proper authentication and authorization checks","security-misconfiguration":"Review and harden security configurations","insecure-deserialization":"Avoid deserializing untrusted data; use safe alternatives","broken-auth":"Use strong authentication mechanisms and secure session management",dependencies:"Keep dependencies updated and regularly audit for vulnerabilities"};for(let i of u){let s=t[i.category];s&&e.add(s)}let n=u.some(i=>i.severity==="critical"),r=u.some(i=>i.severity==="high");return n&&e.add("CRITICAL: Address critical vulnerabilities immediately before deployment"),r&&e.add("Prioritize fixing high-severity issues in the next sprint"),e.size===0&&u.length===0&&e.add("No vulnerabilities found - maintain current security practices"),Array.from(e)}function ja(u){let e=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs",".py",".go",".rs",".java",".rb"]),t=new Set(["node_modules","dist","build","coverage",".git",".claude",".agentic-qe","__pycache__",".venv"]),n=[".test.",".spec.","_test.","_spec."];if(!ne.existsSync(u)||!ne.statSync(u).isDirectory())return null;let r=[];function i(p,h){if(h>6)return;let f;try{f=ne.readdirSync(p,{withFileTypes:!0})}catch{return}for(let v of f)if(v.isDirectory()){if(t.has(v.name))continue;i(xe.join(p,v.name),h+1)}else if(v.isFile()){let y=xe.extname(v.name);if(!e.has(y)||n.some(C=>v.name.includes(C)))continue;r.push(xe.join(p,v.name))}}if(i(u,0),r.length===0)return null;let s=r.map(p=>{let h="";try{h=ne.readFileSync(p,"utf-8")}catch{}let v=h.split(`
|
|
383
|
+
`).length,y=Math.max((h.match(/\b(function|=>)\b/g)||[]).length,1),C=Math.max((h.match(/\b(if|switch|case|\?\?|\|\|)\b/g)||[]).length,1),E=[p.replace(".ts",".test.ts").replace("/src/","/tests/"),p.replace(".ts",".spec.ts").replace("/src/","/tests/"),p.replace(".ts",".test.ts"),p.replace(".js",".test.js"),p.replace(".js",".test.js").replace("/src/","/tests/")].some(L=>ne.existsSync(L)),S=Math.min(C*.005,.15),T=Math.min(v*1e-4,.1),R=Math.max(.05,Math.min(.95,E?.85-S-T:.2)),D=Math.floor(v*R),q=Math.min(Math.floor(D*.7),C),U=Math.min(Math.floor(y*R*.9),y),W=Array.from({length:v-D},(L,H)=>H+D+1);return{path:p,lines:{covered:D,total:v},branches:{covered:q,total:C},functions:{covered:U,total:y},statements:{covered:D,total:v},uncoveredLines:W,uncoveredBranches:W.slice(0,Math.floor(W.length/2))}}),a=s.reduce((p,h)=>p+h.lines.total,0),o=s.reduce((p,h)=>p+h.lines.covered,0),l=s.reduce((p,h)=>p+h.branches.total,0),c=s.reduce((p,h)=>p+h.branches.covered,0),d=s.reduce((p,h)=>p+h.functions.total,0),m=s.reduce((p,h)=>p+h.functions.covered,0),g=(p,h)=>h>0?Math.round(p/h*100):0;return{files:s,summary:{line:g(o,a),branch:g(c,l),function:g(m,d),statement:g(o,a),files:s.length}}}function Gn(u){u.registerHandler("analyze-coverage",async e=>{let t=e.payload;try{let n=u.getCoverageAnalyzer(),r=t.target||process.cwd(),i=t.threshold||80,s=await qn(r);if(!s){let c=!1;try{let{execSync:d}=await import("child_process"),m="npx vitest run --coverage --reporter=json 2>/dev/null";try{let g=await mi.readFile(xe.join(r,"package.json"),"utf-8"),p=x(g),h={...p.devDependencies||{},...p.dependencies||{}};h.jest||h["@jest/core"]?m="npx jest --coverage --json 2>/dev/null":(h.mocha||h.nyc)&&(m="npx nyc mocha 2>/dev/null")}catch{}d(m,{cwd:r,timeout:12e4,encoding:"utf-8",stdio:["pipe","pipe","pipe"]}),c=!0}catch{}if(s=await qn(r),s||(s=ja(r)),!s)return I({lineCoverage:0,branchCoverage:0,functionCoverage:0,statementCoverage:0,totalFiles:0,coverageByFile:[],gaps:[],algorithm:"sublinear-O(log n)",warning:c?"Tests ran but no coverage output was generated. Ensure a coverage provider is configured (e.g., @vitest/coverage-v8, istanbul).":"No coverage data found and could not run tests automatically. Run: npm test -- --coverage"})}let a=await n.analyze({coverageData:s,threshold:i,includeFileDetails:t.detectGaps});if(!a.success)return a;let o=a.value,l=[];if(t.detectGaps){let c=await n.findGaps(s,i);c.success&&(l=c.value.gaps.map(d=>({file:d.file,lines:d.lines,risk:d.severity})))}return I({lineCoverage:Math.round(o.summary.line*10)/10,branchCoverage:Math.round(o.summary.branch*10)/10,functionCoverage:Math.round(o.summary.function*10)/10,statementCoverage:Math.round(o.summary.statement*10)/10,totalFiles:o.summary.files,coverageByFile:s.files.map(c=>({file:c.path,lineCoverage:c.lines.total>0?Math.round(c.lines.covered/c.lines.total*1e3)/10:0,branchCoverage:c.branches.total>0?Math.round(c.branches.covered/c.branches.total*1e3)/10:0,functionCoverage:c.functions.total>0?Math.round(c.functions.covered/c.functions.total*1e3)/10:0})),gaps:l,meetsThreshold:o.meetsThreshold,delta:o.delta,recommendations:o.recommendations,algorithm:"sublinear-O(log n)"})}catch(n){return N(G(n))}})}import*as $n from"fs/promises";import*as pi from"path";k();function zn(u){u.registerHandler("scan-security",async e=>{let t=e.payload;try{let n=u.getSecurityScanner(),r=t.target||process.cwd(),i=await ee(r);if(i.length===0)return I({vulnerabilities:0,critical:0,high:0,medium:0,low:0,informational:0,topVulnerabilities:[],recommendations:["No source files found to scan"],scanTypes:{sast:t.sast!==!1,dast:t.dast||!1},warning:`No source files found in ${r}`});let s=i.filter(y=>/\.(ts|tsx|js|jsx|mjs|cjs)$/.test(y)),a=i.filter(y=>!/\.(ts|tsx|js|jsx|mjs|cjs)$/.test(y)),o=[];for(let y of i)try{let C=await $n.readFile(y,"utf-8"),b=C.split(`
|
|
384
|
+
`),E=y.startsWith(r)?y.slice(r.length).replace(/^\//,""):y,S=[{regex:/\w*(?:secret|password|passwd|api_key|apikey|private_key|jwt_secret)\w*\s*[=:]\s*['"][^'"]{4,}['"]/gi,title:"Hardcoded secret",severity:"critical"},{regex:/\w*(?:token|auth_token|access_key|secret_key)\w*\s*[=:]\s*['"][^'"]{8,}['"]/gi,title:"Hardcoded credential",severity:"critical"},{regex:/(?:AWS_SECRET|GITHUB_TOKEN|SLACK_TOKEN|OPENAI_API_KEY)\s*[=:]\s*['"][^'"]+['"]/gi,title:"Hardcoded cloud credential",severity:"critical"}];for(let D of S)for(let q=0;q<b.length;q++){let U=[...b[q].matchAll(D.regex)];for(let W of U)o.push({title:D.title,severity:D.severity,location:{file:E,line:q+1},description:`Potential hardcoded secret found at line ${q+1}`,category:"sensitive-data"})}let T=/(?:execute|query|cursor\.execute)\s*\(\s*(?:f['"]|['"].*%s|['"].*\+\s*\w)/gi;for(let D=0;D<b.length;D++)T.test(b[D])&&o.push({title:"Potential SQL injection",severity:"high",location:{file:E,line:D+1},description:"String interpolation in SQL query \u2014 use parameterized queries",category:"injection"}),T.lastIndex=0;let R=[/allow_origins\s*=\s*\[?\s*['"]?\*['"]?\s*\]?/i,/cors\(\s*\{[^}]*origin:\s*['"]?\*['"]?/i,/Access-Control-Allow-Origin['":\s]+\*/i,/@CrossOrigin\(\s*origins?\s*=\s*["']\*["']/i,/\.Header\(\)\.Set\(["']Access-Control-Allow-Origin["'],\s*["']\*["']/i];for(let D of R)if(D.test(C)){o.push({title:"CORS wildcard origin",severity:"high",location:{file:E,line:b.findIndex(q=>D.test(q))+1},description:"CORS configured with wildcard (*) origin \u2014 restrict to specific domains",category:"security-misconfiguration"});break}/(?:DEBUG|debug)\s*[=:]\s*(?:True|true|1)/i.test(C)&&o.push({title:"Debug mode enabled",severity:"medium",location:{file:E,line:b.findIndex(D=>/DEBUG\s*[=:]\s*(?:True|true|1)/i.test(D))+1},description:"Debug mode should be disabled in production",category:"security-misconfiguration"}),/\b(?:eval|exec)\s*\(/i.test(C)&&o.push({title:"Dangerous eval/exec usage",severity:"high",location:{file:E,line:b.findIndex(D=>/\b(?:eval|exec)\s*\(/.test(D))+1},description:"eval/exec can lead to code injection \u2014 avoid using with user input",category:"injection"})}catch{}let l=["requirements.txt","pyproject.toml","Gemfile","go.mod","Cargo.toml"];for(let y of l){let C=pi.join(r,y);try{let b=await $n.readFile(C,"utf-8");if(o.push({title:"Dependency audit recommended",severity:"informational",location:{file:y,line:1},description:`Found ${y} \u2014 run language-specific dependency audit (e.g., pip-audit, npm audit, cargo audit)`,category:"dependencies"}),y==="requirements.txt"||y==="pyproject.toml"){let E=[{pkg:"python-jose",pattern:/python-jose/i,cve:"CVE-2024-33663",severity:"high",title:"python-jose ECDSA key confusion (CVE-2024-33663)",description:"python-jose allows ECDSA key confusion \u2014 upgrade to >=3.3.0 or switch to PyJWT"},{pkg:"python-jose",pattern:/python-jose/i,cve:"CVE-2024-33664",severity:"high",title:"python-jose JWT algorithm confusion (CVE-2024-33664)",description:"python-jose JWT algorithm confusion vulnerability \u2014 upgrade or switch to PyJWT"},{pkg:"python-multipart",pattern:/python-multipart/i,cve:"CVE-2026-24486",severity:"critical",title:"python-multipart DoS (CVE-2026-24486)",description:"python-multipart denial of service via crafted multipart data \u2014 upgrade to >=0.0.18"}];for(let S of E)S.pattern.test(b)&&o.push({title:S.title,severity:S.severity,location:{file:y,line:b.split(`
|
|
385
|
+
`).findIndex(T=>S.pattern.test(T))+1},description:S.description,category:"dependencies"})}}catch{}}let c=s.map(y=>Lr.create(y)),d=null;if(t.sast!==!1&&c.length>0){let y=await n.scanFiles(c);y.success&&(d=y.value)}let m=null;if(t.dast&&t.targetUrl){let y=await n.scanUrl(t.targetUrl,{activeScanning:!0,maxDepth:3,timeout:3e4});y.success&&(m=y.value)}let g={critical:o.filter(y=>y.severity==="critical").length,high:o.filter(y=>y.severity==="high").length,medium:o.filter(y=>y.severity==="medium").length,low:o.filter(y=>y.severity==="low").length,informational:o.filter(y=>y.severity==="informational").length},p={critical:(d?.summary?.critical||0)+(m?.summary?.critical||0)+g.critical,high:(d?.summary?.high||0)+(m?.summary?.high||0)+g.high,medium:(d?.summary?.medium||0)+(m?.summary?.medium||0)+g.medium,low:(d?.summary?.low||0)+(m?.summary?.low||0)+g.low,informational:(d?.summary?.informational||0)+(m?.summary?.informational||0)+g.informational},h=[...d?.vulnerabilities||[],...m?.vulnerabilities||[],...o],f=h.sort((y,C)=>{let b={critical:0,high:1,medium:2,low:3,informational:4};return b[y.severity]-b[C.severity]}).slice(0,10).map(y=>({type:y.title,severity:y.severity,file:y.location.file,line:y.location.line,description:y.description})),v=di(h);return I({vulnerabilities:h.length,critical:p.critical,high:p.high,medium:p.medium,low:p.low,informational:p.informational,topVulnerabilities:f,recommendations:v,scanTypes:{sast:t.sast!==!1,dast:t.dast||!1},filesScanned:i.length,jstsFilesScanned:s.length,otherFilesScanned:a.length,coverage:d?.coverage,...a.length>0&&s.length===0?{note:"Non-JS/TS files were scanned with cross-language pattern matching. For deeper analysis, use language-specific security tools."}:{}})}catch(n){return N(G(n))}})}k();function Bn(u){u.registerHandler("assess-quality",async e=>{let t=e.payload;try{let n=u.getQualityAnalyzer(),r=t.threshold||80,i=[];if(t.sourceFiles&&t.sourceFiles.length>0)i=t.sourceFiles;else if(t.target)i=await ee(t.target,{includeTests:!1});else{let c=await import("path"),d=await import("fs"),m=c.join(process.cwd(),"src"),g=d.existsSync(m)?m:process.cwd();i=await ee(g,{includeTests:!1})}if(i.length===0)return I({qualityScore:0,passed:!1,threshold:r,metrics:{coverage:0,complexity:0,maintainability:0,testability:0},recommendations:["No source files found for quality assessment"],warning:"No source files found"});let s=await n.analyzeQuality({sourceFiles:i,includeMetrics:t.metrics||["coverage","complexity","maintainability","testability"]});if(!s.success)return s;let a=s.value,o=a.score.overall>=r,l={};for(let c of a.metrics)l[c.name]=c.value;return I({qualityScore:a.score.overall,passed:o,threshold:r,metrics:{coverage:a.score.coverage,complexity:a.score.complexity,maintainability:a.score.maintainability,security:a.score.security,...l},recommendations:a.recommendations.map(c=>`[${c.type}] ${c.title}: ${c.description}`),trends:a.trends.map(c=>({metric:c.metric,direction:c.direction,dataPoints:c.dataPoints.length})),filesAnalyzed:i.length})}catch(n){return N(G(n))}})}import*as gi from"fs/promises";k();function jn(u){u.registerHandler("validate-requirements",async e=>{let t=e.payload;try{let n=t.requirementsPath||process.cwd(),r=await ee(n,{includeTests:!1,languages:[]}),i=[".md",".feature",".gherkin",".txt",".rst"],s=[];for(let a of r)i.some(o=>a.endsWith(o))&&s.push(a);return I({requirementsAnalyzed:s.length,testable:0,ambiguous:0,untestable:0,coverage:0,bddScenarios:[],warning:s.length===0?"No requirement files (.md, .feature, .gherkin) found. Provide requirementsPath or add requirement docs.":"Requirements validation requires LLM analysis. File inventory returned \u2014 use task_orchestrate for deep analysis.",files:s.map(a=>a.startsWith(n)?a.slice(n.length+1):a).slice(0,20)})}catch(n){return N(G(n))}}),u.registerHandler("validate-contracts",async e=>{let t=e.payload;try{if(!t.contractPath)return I({contractPath:"",valid:!1,breakingChanges:[],warnings:[],coverage:0,error:"contractPath is required. Provide a path to an OpenAPI spec, JSON Schema, or Protocol Buffer file."});try{let n=await gi.readFile(t.contractPath,"utf-8"),r=t.contractPath.endsWith(".json"),i=t.contractPath.endsWith(".yaml")||t.contractPath.endsWith(".yml");return r&&JSON.parse(n),I({contractPath:t.contractPath,valid:!0,format:r?"json":i?"yaml":"unknown",breakingChanges:[],warnings:[],linesAnalyzed:n.split(`
|
|
386
|
+
`).length,note:"Structural validation passed. For semantic contract testing, use consumer-driven contract tests."})}catch(n){return I({contractPath:t.contractPath,valid:!1,breakingChanges:[],warnings:[],error:`Could not read or parse contract file: ${w(n)}`})}}catch(n){return N(G(n))}})}import*as hi from"fs/promises";import*as fi from"path";k();function Un(u){u.registerHandler("index-code",async e=>{let t=e.payload;try{let n=u.getKnowledgeGraph(),r=t.target||process.cwd(),i=Date.now(),s=await ee(r,{includeTests:t.includeTests!==!1,languages:t.languages});if(s.length===0)return I({filesIndexed:0,nodesCreated:0,edgesCreated:0,target:r,incremental:t.incremental||!1,languages:t.languages||[],duration:Date.now()-i,warning:`No source files found in ${r}. Searched for: TypeScript, JavaScript, Python, Go, Rust, Java, Ruby, C/C++, and more.`});let a=await n.index({paths:s,incremental:t.incremental||!1,includeTests:t.includeTests!==!1,languages:t.languages});if(!a.success)return a;let o=a.value,l=new Set,c={ts:"typescript",tsx:"typescript",js:"javascript",jsx:"javascript",mjs:"javascript",cjs:"javascript",py:"python",pyw:"python",go:"go",rs:"rust",java:"java",kt:"kotlin",kts:"kotlin",rb:"ruby",cs:"csharp",php:"php",swift:"swift",c:"c",h:"c",cpp:"cpp",hpp:"cpp",cc:"cpp",scala:"scala"};for(let d of s){let m=fi.extname(d).slice(1),g=c[m];g&&l.add(g)}return I({filesIndexed:o.filesIndexed,nodesCreated:o.nodesCreated,edgesCreated:o.edgesCreated,target:r,incremental:t.incremental||!1,languages:Array.from(l),duration:o.duration,errors:o.errors})}catch(n){return N(G(n))}}),u.registerHandler("predict-defects",async e=>{let t=e.payload;try{let n=t.target||process.cwd(),r=t.minConfidence||.5,i=await ee(n,{includeTests:!1});if(i.length===0)return I({predictedDefects:[],riskScore:0,recommendations:[`No source files found in ${n}. Ensure the path contains source code files.`],warning:`No source files found in ${n}`,filesAnalyzed:0});let s=[];for(let c of i)try{let d=await hi.readFile(c,"utf-8"),m=d.split(`
|
|
387
|
+
`),g=m.length,p=0,h=[];g>500?(p+=.25,h.push(`Large file (${g} lines)`)):g>300&&(p+=.15,h.push(`Medium-large file (${g} lines)`));let f=d.match(/\b(if|else|switch|case|for|while|catch|&&|\|\|)\b/g)||[],v=f.length/Math.max(g,1);v>.15?(p+=.25,h.push(`High branch density (${f.length} branches in ${g} lines)`)):v>.08&&(p+=.1,h.push("Moderate branch complexity")),Math.max(...m.map(E=>{let S=E.match(/^(\s*)/);return S?S[1].length:0}))>20&&(p+=.15,h.push("Deep nesting detected"));let C=(d.match(/\b(TODO|FIXME|HACK|XXX|WORKAROUND)\b/gi)||[]).length;C>3&&(p+=.15,h.push(`${C} technical debt markers`));let b=(d.match(/\b(function|def|func|async)\b/g)||[]).length;if(b>0&&g/b>80&&(p+=.1,h.push("Potentially long functions")),p=Math.min(p,.95),p>=r){let E=c.startsWith(n)?c.slice(n.length).replace(/^\//,""):c;s.push({file:E,probability:Math.round(p*100)/100,reason:h.join("; ")})}}catch{}s.sort((c,d)=>d.probability-c.probability);let a=s.length>0?s.reduce((c,d)=>c+d.probability,0)/s.length:0,o=Math.round(a*100),l=[];if(s.length>0){l.push(`${s.length} files flagged for potential defects out of ${i.length} analyzed`);let c=s[0];l.push(`Highest risk: ${c.file} (${Math.round(c.probability*100)}%) \u2014 ${c.reason}`)}return s.some(c=>c.reason.includes("Large file"))&&l.push("Consider splitting large files to reduce complexity"),s.some(c=>c.reason.includes("technical debt"))&&l.push("Address TODO/FIXME comments to reduce technical debt"),s.length===0&&l.push("No files exceeded the defect probability threshold \u2014 code looks healthy"),I({predictedDefects:s.slice(0,20),riskScore:o,recommendations:l,filesAnalyzed:i.length})}catch(n){return N(G(n))}})}function Hn(u){u.registerHandler("test-accessibility",async e=>{let t=e.payload;return I({url:t.url||"",standard:t.standard||"wcag21-aa",passed:!1,violations:[],warnings:[],score:0,note:"Accessibility testing requires a browser environment (Puppeteer/Playwright). Use tools like axe-core, pa11y, or Lighthouse CLI for WCAG compliance testing. Example: npx pa11y "+(t.url||"<url>")})}),u.registerHandler("run-chaos",async e=>{let t=e.payload;return I({faultType:t.faultType||"unknown",target:t.target||"unknown",dryRun:t.dryRun??!0,duration:t.duration||0,systemBehavior:"not-executed",resilience:null,note:"Chaos engineering requires infrastructure-level fault injection. Use tools like Chaos Monkey, Litmus, or toxiproxy for real resilience testing. For Node.js apps, consider: nock (HTTP faults), testcontainers (dependency failures)."})}),u.registerHandler("optimize-learning",async e=>{try{let t=await import("./unified-memory-hnsw-6FOIGINN.js");return I({patternsLearned:0,modelsUpdated:0,memoryConsolidated:!1,note:'Learning optimization runs during the dream cycle (SessionEnd hook). Use "npx agentic-qe hooks session-end --save-state" to trigger pattern consolidation.'})}catch{return I({patternsLearned:0,modelsUpdated:0,memoryConsolidated:!1,note:'Learning system not initialized. Run "aqe init --auto" first.'})}})}var re=ye("TaskExecutor");function Wa(u){return Te.resolve(Ce.CoverageAnalyzerService)(u)}function Ka(u){return Te.resolve(Ce.SecurityScannerService)(u)}function Xa(u){return Te.resolve(Ce.createTestGeneratorService)(u)}function Ya(u){return Te.resolve(Ce.KnowledgeGraphService)(u)}function Ja(u){return Te.resolve(Ce.QualityAnalyzerService)(u)}function Ei(u){switch(u){case 0:return"agent-booster";case 1:return"claude-haiku-4-5-20251001";case 2:return"claude-sonnet-4-6";case 3:return"claude-sonnet-4-6";case 4:return"claude-opus-4-7";default:return"claude-sonnet-4-6"}}function Za(u){if(["generate-tests","analyze-coverage","scan-security","execute-tests","assess-quality","validate-contracts","test-accessibility","chaos-test","predict-defects","validate-requirements","index-code"].includes(u.type))return null;let t=u.payload?.codeContext||"",n=u.payload?.sourceCode||"",r=t||n;return r?r.includes("var ")&&!r.includes("const ")&&!r.includes("let ")?"var-to-const":r.includes("console.log")||r.includes("console.warn")||r.includes("console.error")?"remove-console":r.includes(".then(")&&r.includes(".catch(")?"promise-to-async":r.includes("require(")&&!r.includes("import ")?"cjs-to-esm":r.includes("function ")&&!r.includes("=>")?"func-to-arrow":null:null}var Qn=class{constructor(e,t,n){this.kernel=e;this.eventBus=t;this._config={timeout:n?.timeout??3e5,maxRetries:n?.maxRetries??3,enableCaching:n?.enableCaching??!0,saveResults:n?.saveResults??!0,resultsDir:n?.resultsDir??".agentic-qe",defaultLanguage:n?.defaultLanguage??"typescript",defaultFramework:n?.defaultFramework??"vitest"},this.resultSaver=oi(this._config.resultsDir),this.registerHandlers()}kernel;eventBus;_config;resultSaver;coverageAnalyzer=null;securityScanner=null;testGenerator=null;knowledgeGraph=null;qualityAnalyzer=null;agentBooster=null;taskRouter=null;qualityFeedbackLoop=null;coherenceActionGate=null;taskHandlers=new Map;get config(){return this._config}registerHandler(e,t){this.taskHandlers.set(e,t)}setQualityFeedbackLoop(e){this.qualityFeedbackLoop=e}getCoverageAnalyzer(){return this.coverageAnalyzer||(this.coverageAnalyzer=Wa(this.kernel.memory)),this.coverageAnalyzer}getSecurityScanner(){return this.securityScanner||(this.securityScanner=Ka(this.kernel.memory)),this.securityScanner}getTestGenerator(){return this.testGenerator||(this.testGenerator=Xa(this.kernel.memory)),this.testGenerator}getKnowledgeGraph(){return this.knowledgeGraph||(this.knowledgeGraph=Ya(this.kernel.memory)),this.knowledgeGraph}getQualityAnalyzer(){return this.qualityAnalyzer||(this.qualityAnalyzer=Ja(this.kernel.memory)),this.qualityAnalyzer}registerHandlers(){Nn(this),Gn(this),zn(this),Bn(this),jn(this),Un(this),Hn(this)}async getAgentBooster(){return this.agentBooster||(this.agentBooster=await ft({enabled:!0,fallbackToLLM:!0,confidenceThreshold:.7})),this.agentBooster}async getTaskRouterInstance(){if(!this.taskRouter)try{this.taskRouter=await Ot()}catch{return null}return this.taskRouter}async executeWithAgentBooster(e,t,n){let r=Za(e);if(!r)return console.debug(`[TaskExecutor] No applicable Agent Booster transform for task ${e.id}`),null;try{let i=await this.getAgentBooster(),s=e.payload?.codeContext||e.payload?.sourceCode||"",a=await i.transform(s,r);return a.success&&a.confidence>=.7?(console.debug(`[TaskExecutor] Agent Booster transform succeeded: ${r}, confidence=${a.confidence}`),{taskId:e.id,success:!0,data:{transformed:!0,transformType:r,originalCode:a.originalCode,transformedCode:a.transformedCode,confidence:a.confidence,implementationUsed:a.implementationUsed,durationMs:a.durationMs,changeCount:a.changeCount,tier:0,model:"agent-booster"},duration:Date.now()-t,domain:n}):(console.debug(`[TaskExecutor] Agent Booster low confidence (${a.confidence}), falling back to Tier 1`),null)}catch(i){return console.warn(`[TaskExecutor] Agent Booster error, falling back: ${i}`),null}}async recordOutcome(e,t,n,r){try{if(!await this.getTaskRouterInstance())return;if(console.debug(`[TaskExecutor] Outcome recorded: task=${e.id}, tier=${t}, model=${Ei(t)}, success=${n}, duration=${r}ms`),this.qualityFeedbackLoop){let s=e.targetDomains||[],a=n?1:0,o=r<100?1:r<500?.8:r<2e3?.6:r<5e3?.4:r<1e4?.2:.1,l=.25*a+.325+.1*o;await this.qualityFeedbackLoop.recordRoutingOutcome({taskId:e.id,taskDescription:e.type,recommendedAgent:String(t),usedAgent:String(t),followedRecommendation:!0,success:n,qualityScore:l,durationMs:r,timestamp:new Date,error:n?void 0:"Task execution failed"})}}catch(i){console.warn("[TaskExecutor] Failed to record outcome:",i)}}async execute(e){let t=Date.now(),n=this.getTaskDomain(e.type),r=e.payload,i=r?.routingTier??2,s=r?.useAgentBooster??!1,a=r?.compiledContext??void 0,o=Ei(i);a&&e.payload&&(e.payload.__compiledContext=a),console.debug(`[TaskExecutor] Executing task ${e.id}: type=${e.type}, tier=${i}, model=${o}, useAgentBooster=${s}${a?", hasContext=true":""}`);let l=this.evaluateCoherenceGate(e,n);l&&console.debug(`[TaskExecutor] Coherence gate: task=${e.id}, decision=${l.decision}, combined=${l.combinedScore.toFixed(3)}, advisory=${l.advisory}`),this.validateWithReasoningQEC(e,n);try{if(i===0||s){let g=await this.executeWithAgentBooster(e,t,n);if(g)return this.recordOutcome(e,0,!0,Date.now()-t).catch(p=>{re.warn("recordOutcome failed",{error:p instanceof Error?p.message:String(p),taskId:e.id})}),await this.publishTaskCompleted(e.id,g.data,n),g;console.debug(`[TaskExecutor] Agent Booster fallback to Tier 1 for task ${e.id}`)}let c=this.taskHandlers.get(e.type);if(!c){let g={taskId:e.id,success:!1,error:`No handler registered for task type: ${e.type}`,duration:Date.now()-t,domain:n};return this.recordOutcome(e,i,!1,Date.now()-t).catch(p=>{re.warn("recordOutcome failed",{error:p instanceof Error?p.message:String(p),taskId:e.id})}),g}let d=await Promise.race([c(e),this.timeout(e.timeout||this._config.timeout)]);if(!d.success){let g="error"in d?d.error.message:"Unknown error";return await this.publishTaskFailed(e.id,g,n),this.recordOutcome(e,i,!1,Date.now()-t).catch(p=>{re.warn("recordOutcome failed",{error:p instanceof Error?p.message:String(p),taskId:e.id})}),{taskId:e.id,success:!1,error:g,duration:Date.now()-t,domain:n}}await this.publishTaskCompleted(e.id,d.value,n),this.recordOutcome(e,i,!0,Date.now()-t).catch(g=>{re.warn("recordOutcome failed",{error:g instanceof Error?g.message:String(g),taskId:e.id})});let m;if(this._config.saveResults)try{let g={language:r?.language||this._config.defaultLanguage,framework:r?.framework||this._config.defaultFramework,includeSecondary:!0};m=(await this.resultSaver.save(e.id,e.type,d.value,g)).files.map(h=>h.path)}catch(g){console.error(`[TaskExecutor] Failed to save results: ${g}`)}return{taskId:e.id,success:!0,data:{...d.value,_routing:{tier:i,model:o,usedAgentBooster:!1}},duration:Date.now()-t,domain:n,savedFiles:m}}catch(c){let d=w(c);return await this.publishTaskFailed(e.id,d,n),this.recordOutcome(e,i,!1,Date.now()-t).catch(m=>{re.warn("recordOutcome failed",{error:m instanceof Error?m.message:String(m),taskId:e.id})}),{taskId:e.id,success:!1,error:d,duration:Date.now()-t,domain:n}}}async resetServiceCaches(){if(this.coverageAnalyzer=null,this.securityScanner=null,this.testGenerator=null,this.knowledgeGraph=null,this.qualityAnalyzer=null,this.coherenceActionGate=null,this.agentBooster){try{await this.agentBooster.dispose()}catch(e){console.debug("[TaskExecutor] Agent Booster disposal error:",e instanceof Error?e.message:e)}this.agentBooster=null}this.taskRouter=null}resetServiceCachesSync(){this.coverageAnalyzer=null,this.securityScanner=null,this.testGenerator=null,this.knowledgeGraph=null,this.qualityAnalyzer=null,this.agentBooster=null,this.taskRouter=null,this.coherenceActionGate=null}evaluateCoherenceGate(e,t){try{this.coherenceActionGate||(this.coherenceActionGate=li({advisory:!0}));let n=e.payload,r=typeof n?.confidence=="number"?n.confidence:.7,i=n?.riskLevel??"medium";return ui(e.type,t,r,i,n??{},this.coherenceActionGate)}catch(n){return re.warn("Coherence gate evaluation error (continuing)",{error:n instanceof Error?n.message:String(n),taskId:e.id}),null}}_reasoningQEC=null;_reasoningQECLoaded=!1;validateWithReasoningQEC(e,t){try{if(!this._reasoningQECLoaded){this._reasoningQECLoaded=!0;try{let{isReasoningQECEnabled:s}=(pt(),Sr(Ps));if(s()){let{createReasoningQEC:a}=(Si(),Sr(Ti));this._reasoningQEC=a()}}catch(s){re.debug("ReasoningQEC module unavailable",{error:s instanceof Error?s.message:String(s)})}}if(!this._reasoningQEC)return;let n=e.payload,r=n?.reasoningSteps;if(!r||r.length<2)return;let i=this._reasoningQEC.validate({type:t,context:n,steps:r});i.valid||re.warn("ReasoningQEC validation found issues (advisory)",{taskId:e.id,domain:t,confidence:i.confidence,issues:i.issues.length})}catch(n){re.debug("ReasoningQEC evaluation error",{error:n instanceof Error?n.message:String(n),taskId:e.id})}}getTaskDomain(e){return{"generate-tests":"test-generation","execute-tests":"test-execution","analyze-coverage":"coverage-analysis","assess-quality":"quality-assessment","predict-defects":"defect-intelligence","validate-requirements":"requirements-validation","index-code":"code-intelligence","scan-security":"security-compliance","validate-contracts":"contract-testing","test-accessibility":"visual-accessibility","run-chaos":"chaos-resilience","optimize-learning":"learning-optimization","cross-domain-workflow":"learning-optimization","protocol-execution":"learning-optimization","ideation-assessment":"requirements-validation"}[e]||"learning-optimization"}async timeout(e){return new Promise((t,n)=>{setTimeout(()=>n(new Error(`Task execution timed out after ${e}ms`)),e)})}async publishTaskCompleted(e,t,n){await this.eventBus.publish({id:$(),type:"TaskCompleted",timestamp:new Date,source:n,payload:{taskId:e,result:t}})}async publishTaskFailed(e,t,n){await this.eventBus.publish({id:$(),type:"TaskFailed",timestamp:new Date,source:n,payload:{taskId:e,error:t}})}};function wi(u,e){return new Qn(u,u.eventBus,e)}import{randomUUID as Ae}from"crypto";k();var Wn={effectiveness:.25,coverage:.2,mutationKill:.15,stability:.15,maintainability:.15,performance:.1},Kn={"short-term":{minSuccessCount:0,minSuccessRate:0,minQualityScore:0,minAgeDays:0},working:{minSuccessCount:3,minSuccessRate:.6,minQualityScore:.5,minAgeDays:1},"long-term":{minSuccessCount:10,minSuccessRate:.75,minQualityScore:.7,minAgeDays:7},permanent:{minSuccessCount:50,minSuccessRate:.9,minQualityScore:.85,minAgeDays:30}},ce={qualityWeights:Wn,promotionCriteria:Kn,autoPromote:!0,autoDemote:!0,minCoverageImprovementToLearn:5,maxOutcomesInMemory:1e4,persistOutcomes:!0,batchSize:100};te();k();j();var Xn=class{outcomes=[];maxOutcomes;constructor(e){this.maxOutcomes=e}add(e){this.outcomes.push(e),this.outcomes.length>this.maxOutcomes&&(this.outcomes=this.outcomes.slice(-this.maxOutcomes))}getAll(){return[...this.outcomes]}getByPattern(e){return this.outcomes.filter(t=>t.patternId===e)}getByAgent(e){return this.outcomes.filter(t=>t.generatedBy===e)}getByDomain(e){return this.outcomes.filter(t=>t.domain===e)}getRecent(e){return this.outcomes.slice(-e)}clear(){this.outcomes=[]}get size(){return this.outcomes.length}},Yn=class u{store;reasoningBank=null;config;db=null;persistCount=0;static RETENTION_CLEANUP_INTERVAL=100;patternMetrics=new Map;constructor(e={}){this.config={...ce,...e},this.store=new Xn(this.config.maxOutcomesInMemory)}connectReasoningBank(e){this.reasoningBank=e}async initialize(){try{this.db=z(),this.db.isInitialized()||await this.db.initialize(),await this.loadFromDb()}catch(e){console.warn("[TestOutcomeTracker] DB initialization failed, using memory-only:",w(e)),this.db=null}}async loadFromDb(){if(!this.db)return;let t=this.db.getDatabase().prepare(`
|
|
448
388
|
SELECT * FROM test_outcomes ORDER BY created_at DESC LIMIT ?
|
|
449
|
-
`).all(this.config.maxOutcomesInMemory);for(let n of t.reverse()){let r={id:n.id,testId:n.test_id,testName:n.test_name,generatedBy:n.generated_by,patternId:n.pattern_id||void 0,framework:n.framework,language:n.language,domain:n.domain,passed:!!n.passed,errorMessage:n.error_message||void 0,coverage:{lines:n.coverage_lines,branches:n.coverage_branches,functions:n.coverage_functions},mutationScore:n.mutation_score??void 0,executionTimeMs:n.execution_time_ms,flaky:!!n.flaky,flakinessScore:n.flakiness_score??void 0,maintainabilityScore:n.maintainability_score,complexity:n.complexity??void 0,linesOfCode:n.lines_of_code??void 0,assertionCount:n.assertion_count??void 0,filePath:n.file_path||void 0,sourceFilePath:n.source_file_path||void 0,timestamp:new Date(n.created_at),metadata:n.metadata_json?
|
|
389
|
+
`).all(this.config.maxOutcomesInMemory);for(let n of t.reverse()){let r={id:n.id,testId:n.test_id,testName:n.test_name,generatedBy:n.generated_by,patternId:n.pattern_id||void 0,framework:n.framework,language:n.language,domain:n.domain,passed:!!n.passed,errorMessage:n.error_message||void 0,coverage:{lines:n.coverage_lines,branches:n.coverage_branches,functions:n.coverage_functions},mutationScore:n.mutation_score??void 0,executionTimeMs:n.execution_time_ms,flaky:!!n.flaky,flakinessScore:n.flakiness_score??void 0,maintainabilityScore:n.maintainability_score,complexity:n.complexity??void 0,linesOfCode:n.lines_of_code??void 0,assertionCount:n.assertion_count??void 0,filePath:n.file_path||void 0,sourceFilePath:n.source_file_path||void 0,timestamp:new Date(n.created_at),metadata:n.metadata_json?x(n.metadata_json):void 0};this.store.add(r),r.patternId&&this.updatePatternMetrics(r)}t.length>0&&console.log(`[TestOutcomeTracker] Loaded ${t.length} outcomes from DB`)}persistOutcome(e){if(this.db)try{let t=this.db.getDatabase();t.prepare(`
|
|
450
390
|
INSERT OR REPLACE INTO test_outcomes (
|
|
451
391
|
id, test_id, test_name, generated_by, pattern_id,
|
|
452
392
|
framework, language, domain, passed, error_message,
|
|
@@ -459,9 +399,9 @@ ${e.recommendations.length===0?"No recommendations - all quality gates passed.":
|
|
|
459
399
|
DELETE FROM test_outcomes WHERE id NOT IN (
|
|
460
400
|
SELECT id FROM test_outcomes ORDER BY created_at DESC LIMIT ?
|
|
461
401
|
)
|
|
462
|
-
`).run(t)}catch(t){console.warn("[TestOutcomeTracker] Retention cleanup failed:",w(t))}}async track(e){this.store.add(e),this.persistOutcome(e),e.patternId&&(this.updatePatternMetrics(e),this.reasoningBank&&await this.updateReasoningBankPattern(e),(this.config.autoPromote||this.config.autoDemote)&&await this.checkPatternTierChange(e.patternId))}async trackBatch(e){for(let t of e)await this.track(t)}updatePatternMetrics(e){let t=e.patternId,n=this.patternMetrics.get(t)||{successCount:0,failureCount:0,totalQuality:0,outcomes:0};e.passed&&!e.flaky?n.successCount++:n.failureCount++,n.totalQuality+=e.maintainabilityScore,n.outcomes++,this.patternMetrics.set(t,n)}async updateReasoningBankPattern(e){if(!this.reasoningBank||!e.patternId)return;let t=this.calculateOutcomeQuality(e),n=e.passed&&!e.flaky;await this.reasoningBank.recordPatternOutcome(e.patternId,n,t)}calculateOutcomeQuality(e){let t=this.config.qualityWeights,n=e.passed&&!e.flaky?1:0,r=(e.coverage.lines+e.coverage.branches+e.coverage.functions)/3/100,i=e.mutationScore??.5,s=e.flaky?.2:1-(e.flakinessScore??0),a=e.maintainabilityScore,l=Math.max(0,1-e.executionTimeMs/1e4);return t.effectiveness*n+t.coverage*r+t.mutationKill*i+t.stability*s+t.maintainability*a+t.performance*l}async checkPatternTierChange(e){if(!this.reasoningBank)return;let t=this.patternMetrics.get(e);if(!t)return;let n=t.successCount/(t.successCount+t.failureCount),r=t.totalQuality/t.outcomes;if(this.config.autoPromote&&await this.reasoningBank.checkPatternPromotion(e,t.successCount,n,r)&&await this.reasoningBank.promotePattern(e),this.config.autoDemote){let i=this.store.getByPattern(e).slice(-10);i.length>=5&&i.filter(a=>a.passed&&!a.flaky).length/i.length<.3&&await this.reasoningBank.demotePattern(e)}}getStats(){let e=this.store.getAll();if(e.length===0)return this.emptyStats();let t=e.filter(
|
|
402
|
+
`).run(t)}catch(t){console.warn("[TestOutcomeTracker] Retention cleanup failed:",w(t))}}async track(e){this.store.add(e),this.persistOutcome(e),e.patternId&&(this.updatePatternMetrics(e),this.reasoningBank&&await this.updateReasoningBankPattern(e),(this.config.autoPromote||this.config.autoDemote)&&await this.checkPatternTierChange(e.patternId))}async trackBatch(e){for(let t of e)await this.track(t)}updatePatternMetrics(e){let t=e.patternId,n=this.patternMetrics.get(t)||{successCount:0,failureCount:0,totalQuality:0,outcomes:0};e.passed&&!e.flaky?n.successCount++:n.failureCount++,n.totalQuality+=e.maintainabilityScore,n.outcomes++,this.patternMetrics.set(t,n)}async updateReasoningBankPattern(e){if(!this.reasoningBank||!e.patternId)return;let t=this.calculateOutcomeQuality(e),n=e.passed&&!e.flaky;await this.reasoningBank.recordPatternOutcome(e.patternId,n,t)}calculateOutcomeQuality(e){let t=this.config.qualityWeights,n=e.passed&&!e.flaky?1:0,r=(e.coverage.lines+e.coverage.branches+e.coverage.functions)/3/100,i=e.mutationScore??.5,s=e.flaky?.2:1-(e.flakinessScore??0),a=e.maintainabilityScore,l=Math.max(0,1-e.executionTimeMs/1e4);return t.effectiveness*n+t.coverage*r+t.mutationKill*i+t.stability*s+t.maintainability*a+t.performance*l}async checkPatternTierChange(e){if(!this.reasoningBank)return;let t=this.patternMetrics.get(e);if(!t)return;let n=t.successCount/(t.successCount+t.failureCount),r=t.totalQuality/t.outcomes;if(this.config.autoPromote&&await this.reasoningBank.checkPatternPromotion(e,t.successCount,n,r)&&await this.reasoningBank.promotePattern(e),this.config.autoDemote){let i=this.store.getByPattern(e).slice(-10);i.length>=5&&i.filter(a=>a.passed&&!a.flaky).length/i.length<.3&&await this.reasoningBank.demotePattern(e)}}getStats(){let e=this.store.getAll();if(e.length===0)return this.emptyStats();let t=e.filter(g=>g.passed).length,n={lines:e.reduce((g,p)=>g+p.coverage.lines,0)/e.length,branches:e.reduce((g,p)=>g+p.coverage.branches,0)/e.length,functions:e.reduce((g,p)=>g+p.coverage.functions,0)/e.length},r=e.filter(g=>g.mutationScore!==void 0),i=r.length>0?r.reduce((g,p)=>g+p.mutationScore,0)/r.length:0,s=e.reduce((g,p)=>g+p.executionTimeMs,0)/e.length,a=e.filter(g=>g.flaky).length,o=e.reduce((g,p)=>g+p.maintainabilityScore,0)/e.length,l=new Map,c=this.groupBy(e,g=>g.generatedBy);for(let[g,p]of c)l.set(g,{total:p.length,passed:p.filter(h=>h.passed).length,avgCoverage:p.reduce((h,f)=>h+f.coverage.lines,0)/p.length,avgMaintainability:p.reduce((h,f)=>h+f.maintainabilityScore,0)/p.length});let d=new Map,m=this.groupBy(e,g=>g.domain);for(let[g,p]of m)d.set(g,{total:p.length,passed:p.filter(h=>h.passed).length,avgCoverage:p.reduce((h,f)=>h+f.coverage.lines,0)/p.length});return{totalTests:e.length,passedTests:t,passRate:t/e.length,avgCoverage:n,avgMutationScore:i,avgExecutionTimeMs:s,flakyTests:a,avgMaintainability:o,byAgent:l,byDomain:d}}getPatternMetrics(e){let t=this.patternMetrics.get(e);if(!t)return null;let n=t.successCount+t.failureCount;return{successCount:t.successCount,failureCount:t.failureCount,successRate:n>0?t.successCount/n:0,avgQuality:t.outcomes>0?t.totalQuality/t.outcomes:0}}getAllPatternMetrics(){let e=new Map;for(let[t,n]of this.patternMetrics)e.set(t,this.getPatternMetrics(t));return e}getAgentOutcomes(e){return this.store.getByAgent(e)}getRecentOutcomes(e){return this.store.getRecent(e)}exportOutcomes(){return this.store.getAll()}importOutcomes(e){for(let t of e)this.store.add(t),t.patternId&&this.updatePatternMetrics(t)}clear(){this.store.clear(),this.patternMetrics.clear()}getTrackerStats(){return{totalOutcomes:this.store.size,patternsTracked:this.patternMetrics.size,hasReasoningBank:this.reasoningBank!==null}}emptyStats(){return{totalTests:0,passedTests:0,passRate:0,avgCoverage:{lines:0,branches:0,functions:0},avgMutationScore:0,avgExecutionTimeMs:0,flakyTests:0,avgMaintainability:0,byAgent:new Map,byDomain:new Map}}groupBy(e,t){let n=new Map;for(let r of e){let i=t(r),s=n.get(i)||[];s.push(r),n.set(i,s)}return n}};function Ri(u){return new Yn(u)}import{randomUUID as eo}from"crypto";te();k();j();var Jn=class{sessions=[];maxSessions;constructor(e){this.maxSessions=e}add(e){this.sessions.push(e),this.sessions.length>this.maxSessions&&(this.sessions=this.sessions.slice(-this.maxSessions))}getAll(){return[...this.sessions]}getByTechnique(e){return this.sessions.filter(t=>t.technique===e)}getByAgent(e){return this.sessions.filter(t=>t.agentId===e)}getSuccessful(e){return this.sessions.filter(t=>this.calculateImprovement(t)>=e)}calculateImprovement(e){return(e.afterCoverage.lines-e.beforeCoverage.lines+(e.afterCoverage.branches-e.beforeCoverage.branches)+(e.afterCoverage.functions-e.beforeCoverage.functions))/3}clear(){this.sessions=[]}get size(){return this.sessions.length}},Zn=class u{sessionStore;strategies=new Map;reasoningBank=null;config;db=null;persistCount=0;static RETENTION_CLEANUP_INTERVAL=50;constructor(e={}){this.config={...ce,...e},this.sessionStore=new Jn(this.config.maxOutcomesInMemory)}connectReasoningBank(e){this.reasoningBank=e}async initialize(){try{this.db=z(),this.db.isInitialized()||await this.db.initialize(),await this.loadFromDb()}catch(e){console.warn("[CoverageLearner] DB init failed, using memory-only:",w(e)),this.db=null}}async loadFromDb(){if(!this.db)return;let t=this.db.getDatabase().prepare(`
|
|
463
403
|
SELECT * FROM coverage_sessions ORDER BY created_at DESC LIMIT ?
|
|
464
|
-
`).all(this.config.maxOutcomesInMemory);for(let n of t.reverse()){let r={id:n.id,targetPath:n.target_path,agentId:n.agent_id,technique:n.technique,beforeCoverage:{lines:n.before_lines,branches:n.before_branches,functions:n.before_functions},afterCoverage:{lines:n.after_lines,branches:n.after_branches,functions:n.after_functions},testsGenerated:n.tests_generated,testsPassed:n.tests_passed,gapsTargeted:n.gaps_json?
|
|
404
|
+
`).all(this.config.maxOutcomesInMemory);for(let n of t.reverse()){let r={id:n.id,targetPath:n.target_path,agentId:n.agent_id,technique:n.technique,beforeCoverage:{lines:n.before_lines,branches:n.before_branches,functions:n.before_functions},afterCoverage:{lines:n.after_lines,branches:n.after_branches,functions:n.after_functions},testsGenerated:n.tests_generated,testsPassed:n.tests_passed,gapsTargeted:n.gaps_json?x(n.gaps_json):[],durationMs:n.duration_ms,startedAt:new Date(n.started_at),completedAt:new Date(n.completed_at),context:n.context_json?x(n.context_json):void 0};this.sessionStore.add(r);let i=(r.afterCoverage.lines-r.beforeCoverage.lines)*.4+(r.afterCoverage.branches-r.beforeCoverage.branches)*.35+(r.afterCoverage.functions-r.beforeCoverage.functions)*.25;if(i>=this.config.minCoverageImprovementToLearn){let s=this.extractFilePattern(r.targetPath),a=`${r.technique}:${s}`,o=this.strategies.get(a);o?this.strategies.set(a,{...o,avgImprovement:(o.avgImprovement*o.successCount+i)/(o.successCount+1),successCount:o.successCount+1,confidence:Math.min(1,o.confidence+.05),lastUsedAt:new Date(n.completed_at)}):this.strategies.set(a,{id:`strategy-${n.id}`,description:`Coverage strategy: ${r.technique} for ${s} files`,technique:r.technique,filePatterns:[s],avgImprovement:i,successCount:1,confidence:.5,createdAt:new Date(n.started_at),lastUsedAt:new Date(n.completed_at)})}}t.length>0&&console.log(`[CoverageLearner] Loaded ${t.length} sessions from DB`)}persistSession(e){if(this.db)try{let t=this.db.getDatabase();t.prepare(`
|
|
465
405
|
INSERT OR REPLACE INTO coverage_sessions (
|
|
466
406
|
id, target_path, agent_id, technique,
|
|
467
407
|
before_lines, before_branches, before_functions,
|
|
@@ -473,17 +413,17 @@ ${e.recommendations.length===0?"No recommendations - all quality gates passed.":
|
|
|
473
413
|
DELETE FROM coverage_sessions WHERE id NOT IN (
|
|
474
414
|
SELECT id FROM coverage_sessions ORDER BY created_at DESC LIMIT ?
|
|
475
415
|
)
|
|
476
|
-
`).run(t)}catch(t){console.warn("[CoverageLearner] Retention cleanup failed:",w(t))}}async learnFromSession(e){this.sessionStore.add(e),this.persistSession(e);let t=this.calculateOverallImprovement(e);if(t<this.config.minCoverageImprovementToLearn)return null;let n=await this.extractStrategy(e,t);return this.reasoningBank&&n&&await this.storeStrategyAsPattern(n),n}calculateOverallImprovement(e){let t=e.beforeCoverage,n=e.afterCoverage,r=n.lines-t.lines,i=n.branches-t.branches,s=n.functions-t.functions;return r*.4+i*.35+s*.25}async extractStrategy(e,t){let n=this.extractFilePattern(e.targetPath),r=`${e.technique}:${n}`,i=this.strategies.get(r);return i?i={...i,avgImprovement:(i.avgImprovement*i.successCount+t)/(i.successCount+1),successCount:i.successCount+1,confidence:Math.min(1,i.confidence+.05),lastUsedAt:new Date}:i={id:`strategy-${Date.now()}-${co().slice(0,8)}`,description:this.generateStrategyDescription(e,t),technique:e.technique,filePatterns:[n],avgImprovement:t,successCount:1,confidence:.5,createdAt:new Date,lastUsedAt:new Date},this.strategies.set(r,i),i}extractFilePattern(e){let t=e.split("/"),r=t[t.length-1].split(".").pop()||"";return t.length>=2?`${t[t.length-2]}/*.${r}`:`*.${r}`}generateStrategyDescription(e,t){let r={"gap-analysis":"Identify and target uncovered code paths","branch-coverage":"Focus on branch conditions and decision points","edge-case-generation":"Generate tests for edge cases and boundary conditions","mutation-guided":"Use mutation testing to identify weak test areas","risk-based":"Prioritize high-risk code paths","semantic-analysis":"Use code semantics to generate meaningful tests","boundary-testing":"Test boundary conditions and limits","state-machine":"Model state transitions and test state changes","data-flow":"Follow data flow paths through the code"}[e.technique]||e.technique,i=e.gapsTargeted.filter(a=>a.addressed).length,s=e.gapsTargeted.length;return`${r} for ${this.extractFilePattern(e.targetPath)} files. Achieved ${t.toFixed(1)}% improvement. Addressed ${i}/${s} gaps with ${e.testsGenerated} tests.`}async storeStrategyAsPattern(e){this.reasoningBank&&await this.reasoningBank.storeQEPattern({patternType:"coverage-strategy",name:`Coverage Strategy: ${e.technique}`,description:e.description,template:{type:"workflow",content:JSON.stringify({technique:e.technique,filePatterns:e.filePatterns,avgImprovement:e.avgImprovement}),variables:[{name:"targetFile",type:"string",required:!0,description:"Target file to analyze"},{name:"currentCoverage",type:"number",required:!0,description:"Current coverage percentage"}]},context:{tags:["coverage",e.technique,...e.filePatterns]}})}getRecommendedStrategy(e){let t=this.extractFilePattern(e),n=null,r=0;for(let i of this.strategies.values())if(i.filePatterns.some(a=>t.includes(a.split("/").pop()||"")||a.includes(t.split("/").pop()||""))||i.filePatterns.length===0){let a=(Date.now()-i.lastUsedAt.getTime())/864e5,o=Math.max(.5,1-a/30),l=i.avgImprovement*i.confidence*o;l>r&&(r=l,n=i)}return n}getAllStrategies(){return Array.from(this.strategies.values())}getStrategiesByTechnique(e){return this.getAllStrategies().filter(t=>t.technique===e)}getSessionStats(){let e=this.sessionStore.getAll();if(e.length===0)return{totalSessions:0,successfulSessions:0,avgImprovement:0,byTechnique:new Map,strategiesLearned:0};let t=e.map(a=>this.calculateOverallImprovement(a)),n=t.filter(a=>a>=this.config.minCoverageImprovementToLearn).length,r=t.reduce((a,o)=>a+o,0)/t.length,i=new Map,s=new Map;for(let a of e){let o=s.get(a.technique)||[];o.push(a),s.set(a.technique,o)}for(let[a,o]of s){let l=o.map(c=>this.calculateOverallImprovement(c));i.set(a,{count:o.length,avgImprovement:l.reduce((c,d)=>c+d,0)/l.length})}return{totalSessions:e.length,successfulSessions:n,avgImprovement:r,byTechnique:i,strategiesLearned:this.strategies.size}}analyzeGapResolution(){let t=this.sessionStore.getAll().flatMap(i=>i.gapsTargeted);if(t.length===0)return{totalGapsTargeted:0,gapsAddressed:0,resolutionRate:0,byGapType:new Map};let n=t.filter(i=>i.addressed).length,r=new Map;for(let i of t){let s=r.get(i.type)||{targeted:0,addressed:0};s.targeted++,i.addressed&&s.addressed++,r.set(i.type,s)}return{totalGapsTargeted:t.length,gapsAddressed:n,resolutionRate:n/t.length,byGapType:r}}exportSessions(){return this.sessionStore.getAll()}importSessions(e){for(let t of e)this.sessionStore.add(t)}exportStrategies(){return this.getAllStrategies()}importStrategies(e){for(let t of e){let n=`${t.technique}:${t.filePatterns[0]||"*"}`;this.strategies.set(n,t)}}clear(){this.sessionStore.clear(),this.strategies.clear()}getLearnerStats(){return{totalSessions:this.sessionStore.size,totalStrategies:this.strategies.size,hasReasoningBank:this.reasoningBank!==null,minImprovementThreshold:this.config.minCoverageImprovementToLearn}}};function Ai(u){return new rr(u)}var ir=class{weights;historicalScores=[];maxHistory;constructor(e={},t=100){this.weights={...Jn,...e},this.maxHistory=t}calculateFromOutcome(e){let t=this.calculateDimensions(e),n=this.calculateOverall(t);return this.trackScore(n),{overall:n,dimensions:t,weights:this.weights,trend:this.calculateTrend(),calculatedAt:new Date}}calculateDimensions(e){return{effectiveness:this.calculateEffectiveness(e),coverage:this.calculateCoverageScore(e.coverage),mutationKill:e.mutationScore??.5,stability:this.calculateStability(e),maintainability:e.maintainabilityScore,performance:this.calculatePerformanceScore(e.executionTimeMs)}}calculateEffectiveness(e){return e.passed?e.flaky?.3:1:0}calculateCoverageScore(e){return(e.lines*.4+e.branches*.35+e.functions*.25)/100}calculateStability(e){return e.flaky?.2:e.flakinessScore!==void 0?1-e.flakinessScore:1}calculatePerformanceScore(e){return e<100?1:e<500?.8:e<2e3?.6:e<5e3?.4:e<1e4?.2:.1}calculateOverall(e){return this.weights.effectiveness*e.effectiveness+this.weights.coverage*e.coverage+this.weights.mutationKill*e.mutationKill+this.weights.stability*e.stability+this.weights.maintainability*e.maintainability+this.weights.performance*e.performance}trackScore(e){this.historicalScores.push(e),this.historicalScores.length>this.maxHistory&&(this.historicalScores=this.historicalScores.slice(-this.maxHistory))}calculateTrend(){if(this.historicalScores.length<10)return"stable";let e=this.historicalScores.slice(-10),t=this.historicalScores.slice(-20,-10);if(t.length===0)return"stable";let n=e.reduce((s,a)=>s+a,0)/e.length,r=t.reduce((s,a)=>s+a,0)/t.length,i=n-r;return i>.05?"improving":i<-.05?"declining":"stable"}calculateAggregate(e){if(e.length===0)return{overall:0,dimensions:{effectiveness:0,coverage:0,mutationKill:0,stability:0,maintainability:0,performance:0},weights:this.weights,trend:"stable",calculatedAt:new Date};let t={effectiveness:0,coverage:0,mutationKill:0,stability:0,maintainability:0,performance:0};for(let s of e){let a=this.calculateDimensions(s);t.effectiveness+=a.effectiveness,t.coverage+=a.coverage,t.mutationKill+=a.mutationKill,t.stability+=a.stability,t.maintainability+=a.maintainability,t.performance+=a.performance}let n=e.length,r={effectiveness:t.effectiveness/n,coverage:t.coverage/n,mutationKill:t.mutationKill/n,stability:t.stability/n,maintainability:t.maintainability/n,performance:t.performance/n};return{overall:this.calculateOverall(r),dimensions:r,weights:this.weights,trend:this.calculateTrend(),calculatedAt:new Date}}calculateDelta(e,t){let n={effectiveness:t.dimensions.effectiveness-e.dimensions.effectiveness,coverage:t.dimensions.coverage-e.dimensions.coverage,mutationKill:t.dimensions.mutationKill-e.dimensions.mutationKill,stability:t.dimensions.stability-e.dimensions.stability,maintainability:t.dimensions.maintainability-e.dimensions.maintainability,performance:t.dimensions.performance-e.dimensions.performance},r=t.overall-e.overall;return{overallDelta:r,dimensionDeltas:n,improved:r>0}}getRecommendations(e){let t=[],n=e.dimensions;return n.effectiveness<.8&&t.push("Improve test pass rate - investigate failing tests"),n.coverage<.7&&t.push("Increase code coverage - target uncovered paths"),n.mutationKill<.6&&t.push("Strengthen assertions - tests may be too weak"),n.stability<.9&&t.push("Address test flakiness - stabilize intermittent tests"),n.maintainability<.7&&t.push("Improve test maintainability - reduce complexity"),n.performance<.6&&t.push("Optimize test performance - reduce execution time"),t.length===0&&t.push("Quality is excellent - maintain current practices"),t}updateWeights(e){this.weights={...this.weights,...e}}getWeights(){return{...this.weights}}getStats(){let e=this.historicalScores.slice(-10),t=e.length>0?e.reduce((n,r)=>n+r,0)/e.length:0;return{scoresTracked:this.historicalScores.length,currentTrend:this.calculateTrend(),avgRecentScore:t}}clearHistory(){this.historicalScores=[]}};function ki(u,e){return new ir(u,e)}var sr=class{criteria;promotionHistory=[];demotionHistory=[];reasoningBank=null;config;constructor(e={}){this.config={...ce,...e},this.criteria={...Zn}}connectReasoningBank(e){this.reasoningBank=e}evaluatePromotion(e,t){let n=e.tier,r=this.getNextTier(n);if(!r)return null;let i=this.criteria[r];if(this.meetsPromotionCriteria(t,i)){let s={patternId:e.id,fromTier:n,toTier:r,reason:this.generatePromotionReason(t,i),metrics:{successCount:t.successCount,successRate:t.successRate,qualityScore:t.qualityScore,ageDays:t.ageDays},timestamp:new Date};return this.promotionHistory.push(s),s}return null}evaluateDemotion(e,t){if(!this.config.autoDemote)return null;let n=e.tier;if(n==="short-term")return null;if(t.recentSuccessRate<.4||t.recentFailureCount>=5||t.qualityScore<.3){let i=this.getPreviousTier(n);if(!i)return null;let s={patternId:e.id,fromTier:n,toTier:i,reason:this.generateDemotionReason(t),metrics:{recentSuccessRate:t.recentSuccessRate,recentQualityScore:t.qualityScore,failureCount:t.recentFailureCount},timestamp:new Date};return this.demotionHistory.push(s),s}return null}async processPatternChange(e,t){let n=this.evaluateDemotion(e,t);if(n)return this.reasoningBank&&await this.reasoningBank.demotePattern(e.id),{action:"demoted",event:n};let r=this.evaluatePromotion(e,t);return r?(this.reasoningBank&&await this.reasoningBank.promotePattern(e.id),{action:"promoted",event:r}):{action:"unchanged"}}meetsPromotionCriteria(e,t){return e.successCount>=t.minSuccessCount&&e.successRate>=t.minSuccessRate&&e.qualityScore>=t.minQualityScore&&e.ageDays>=t.minAgeDays}getNextTier(e){let t=["short-term","working","long-term","permanent"],n=t.indexOf(e);return n<t.length-1?t[n+1]:null}getPreviousTier(e){let t=["short-term","working","long-term","permanent"],n=t.indexOf(e);return n>0?t[n-1]:null}generatePromotionReason(e,t){let n=[];return e.successCount>=t.minSuccessCount&&n.push(`${e.successCount} successful uses (>=${t.minSuccessCount})`),e.successRate>=t.minSuccessRate&&n.push(`${(e.successRate*100).toFixed(0)}% success rate (>=${t.minSuccessRate*100}%)`),e.qualityScore>=t.minQualityScore&&n.push(`${(e.qualityScore*100).toFixed(0)}% quality score (>=${t.minQualityScore*100}%)`),`Pattern promoted: ${n.join(", ")}`}generateDemotionReason(e){let t=[];return e.recentSuccessRate<.4&&t.push(`low recent success rate (${(e.recentSuccessRate*100).toFixed(0)}%)`),e.recentFailureCount>=5&&t.push(`${e.recentFailureCount} recent failures`),e.qualityScore<.3&&t.push(`low quality score (${(e.qualityScore*100).toFixed(0)}%)`),`Pattern demoted: ${t.join(", ")}`}updateCriteria(e,t){this.criteria[e]={...this.criteria[e],...t}}getCriteria(e){return{...this.criteria[e]}}getAllCriteria(){return{...this.criteria}}getPromotionHistory(e=100){return this.promotionHistory.slice(-e)}getDemotionHistory(e=100){return this.demotionHistory.slice(-e)}getStats(){let e={"short-term":0,working:0,"long-term":0,permanent:0};for(let s of this.promotionHistory)e[s.toTier]++;let t={"short-term":0,working:0,"long-term":0,permanent:0};for(let s of this.demotionHistory)t[s.toTier]++;let n=Date.now()-10080*60*1e3,r=this.promotionHistory.filter(s=>s.timestamp.getTime()>n).length,i=this.demotionHistory.filter(s=>s.timestamp.getTime()>n).length;return{totalPromotions:this.promotionHistory.length,totalDemotions:this.demotionHistory.length,promotionsByTier:e,demotionsByTier:t,recentPromotions:r,recentDemotions:i}}exportHistory(){return{promotions:[...this.promotionHistory],demotions:[...this.demotionHistory]}}importHistory(e){e.promotions&&this.promotionHistory.push(...e.promotions),e.demotions&&this.demotionHistory.push(...e.demotions)}clearHistory(){this.promotionHistory=[],this.demotionHistory=[]}};function Mi(u){return new sr(u)}var ar=class{outcomeTracker;coverageLearner;qualityCalculator;promotionManager;routingFeedback;reasoningBank=null;config;constructor(e={}){this.config={...ce,...e},this.outcomeTracker=Pi(this.config),this.coverageLearner=Ai(this.config),this.qualityCalculator=ki(this.config.qualityWeights),this.promotionManager=Mi(this.config),this.routingFeedback=Yr(this.config.maxOutcomesInMemory)}async initialize(){await Promise.all([this.outcomeTracker.initialize(),this.coverageLearner.initialize(),this.routingFeedback.initialize()])}connectReasoningBank(e){this.reasoningBank=e,this.outcomeTracker.connectReasoningBank(e),this.coverageLearner.connectReasoningBank(e),this.promotionManager.connectReasoningBank(e)}async recordTestOutcome(e){await this.outcomeTracker.track(e);let t=this.qualityCalculator.calculateFromOutcome(e),n;if(e.patternId&&this.reasoningBank){let r=await this.reasoningBank.searchQEPatterns(e.patternId,{limit:1});if(r.success&&r.value.length>0){let i=r.value[0].pattern,s=this.outcomeTracker.getPatternMetrics(e.patternId);if(s){let a=await this.promotionManager.processPatternChange(i,{patternId:e.patternId,successCount:s.successCount,failureCount:s.failureCount,successRate:s.successRate,qualityScore:s.avgQuality,ageDays:this.calculateAgeDays(i.createdAt),recentSuccessRate:this.calculateRecentSuccessRate(e.patternId),recentFailureCount:this.calculateRecentFailures(e.patternId)});n={action:a.action,tier:a.event&&"toTier"in a.event?a.event.toTier:void 0}}}}return{qualityScore:t,patternUpdate:n}}async recordCoverageSession(e){let t=await this.coverageLearner.learnFromSession(e);return{improvement:(e.afterCoverage.lines-e.beforeCoverage.lines+e.afterCoverage.branches-e.beforeCoverage.branches+e.afterCoverage.functions-e.beforeCoverage.functions)/3,strategyLearned:t!==null,strategyId:t?.id}}getRecommendedCoverageStrategy(e){return this.coverageLearner.getRecommendedStrategy(e)}getQualityRecommendations(){let e=this.outcomeTracker.getRecentOutcomes(50);if(e.length===0)return["No test outcomes recorded yet. Start tracking test results to get recommendations."];let t=this.qualityCalculator.calculateAggregate(e);return this.qualityCalculator.getRecommendations(t)}async recordRoutingOutcome(e){let t={id:e.taskId,description:e.taskDescription,complexity:"medium",domains:["test-generation"],context:{}},n={recommended:e.recommendedAgent,confidence:.8,reasoning:"Recorded from feedback",alternatives:[],scores:{similarity:.8,performance:.8,capabilities:.8,combined:.8},latencyMs:0,timestamp:e.timestamp};this.routingFeedback.recordOutcome(t,n,e.usedAgent,{success:e.success,qualityScore:e.qualityScore,durationMs:e.durationMs,error:e.error})}getRoutingAnalysis(){let e=this.routingFeedback.analyzeRoutingAccuracy(),t=this.routingFeedback.getImprovementRecommendations();return{totalOutcomes:e.totalOutcomes,recommendationFollowRate:1-e.overrideRate,successRateWhenFollowed:e.recommendationSuccessRate,successRateWhenOverridden:e.overrideSuccessRate,confidenceCorrelation:e.confidenceCorrelation,recommendations:t}}calculateAgeDays(e){return(Date.now()-e.getTime())/(1e3*60*60*24)}calculateRecentSuccessRate(e){let t=this.outcomeTracker.exportOutcomes().filter(r=>r.patternId===e).slice(-10);return t.length===0?0:t.filter(r=>r.passed&&!r.flaky).length/t.length}calculateRecentFailures(e){return this.outcomeTracker.exportOutcomes().filter(n=>n.patternId===e).slice(-10).filter(n=>!n.passed||n.flaky).length}getStats(){let e=this.outcomeTracker.getStats(),t=this.coverageLearner.getSessionStats(),n=this.promotionManager.getStats(),r=this.qualityCalculator.getStats(),i=this.outcomeTracker.getTrackerStats(),s=this.routingFeedback.analyzeRoutingAccuracy();return{testOutcomes:{total:e.totalTests,passRate:e.passRate,avgQuality:e.avgMaintainability,flakyCount:e.flakyTests},coverage:{totalSessions:t.totalSessions,successfulSessions:t.successfulSessions,avgImprovement:t.avgImprovement,strategiesLearned:t.strategiesLearned},patterns:{promoted:n.totalPromotions,demoted:n.totalDemotions,tracked:i.patternsTracked},quality:{currentTrend:r.currentTrend,avgRecentScore:r.avgRecentScore},routing:{totalOutcomes:s.totalOutcomes,recommendationFollowRate:1-s.overrideRate,successRateWhenFollowed:s.recommendationSuccessRate,successRateWhenOverridden:s.overrideSuccessRate},integrationStatus:{reasoningBankConnected:this.reasoningBank!==null}}}exportData(){return{outcomes:this.outcomeTracker.exportOutcomes(),sessions:this.coverageLearner.exportSessions(),strategies:this.coverageLearner.exportStrategies(),promotionHistory:this.promotionManager.exportHistory(),routingOutcomes:this.routingFeedback.exportOutcomes()}}importData(e){e.outcomes&&this.outcomeTracker.importOutcomes(e.outcomes),e.sessions&&this.coverageLearner.importSessions(e.sessions),e.strategies&&this.coverageLearner.importStrategies(e.strategies),e.promotionHistory&&this.promotionManager.importHistory(e.promotionHistory),e.routingOutcomes&&this.routingFeedback.importOutcomes(e.routingOutcomes)}clear(){this.outcomeTracker.clear(),this.coverageLearner.clear(),this.qualityCalculator.clearHistory(),this.promotionManager.clearHistory(),this.routingFeedback.clear()}};async function Di(u){let e=new ar(u);return await e.initialize(),Ii=e,e}var Ii=null;function _i(){return Ii}function Me(){return`test-${ke()}`}function Fi(u){return`${u}-${ke()}`}function Bt(u){return{enabled:!0,agentId:Fi(u),message:"Experience captured asynchronously via learning pipeline"}}async function lo(u,e,t,n,r){let i=Fi(u);try{let{kernel:s}=je();if(!s)return{enabled:!1,agentId:i,message:"Learning engine not available - kernel not initialized"};let a=await mo();if(!a)return{enabled:!1,agentId:i,message:"Learning engine not available"};let o=a.getExperienceCaptureService();if(!o)return{enabled:!1,agentId:i,message:"Experience capture service not available"};let l=uo(e),c=o.startCapture(`${e}: ${JSON.stringify(t).slice(0,200)}`,{agent:u,domain:l||void 0,metadata:{tool:e,durationMs:r}});o.recordStep(c,{action:`execute-${e}`,result:typeof n=="object"?JSON.stringify(n).slice(0,500):String(n).slice(0,500),quality:.7});let d=await o.completeCapture(c,{success:!0,quality:.7});if(d.success){let m=d.value;return{enabled:!0,agentId:i,message:`Experience captured: ${m.id} (domain: ${l||"general"}, quality: ${m.quality})`,experienceId:m.id,domain:l||"general"}}return{enabled:!0,agentId:i,message:"Experience capture completed (no pattern extracted)"}}catch(s){return{enabled:!1,agentId:i,message:`Learning capture failed: ${w(s)}`}}}function uo(u){return{test_generate_enhanced:"test-generation",test_execute_parallel:"test-execution",coverage_analyze_sublinear:"coverage-analysis",quality_assess:"quality-assessment",security_scan_comprehensive:"security-compliance",contract_validate:"contract-testing",accessibility_test:"visual-accessibility",chaos_test:"chaos-resilience",defect_predict:"defect-intelligence",requirements_validate:"requirements-validation",code_index:"code-intelligence"}[u]||null}async function mo(){return zi()}async function po(u,e,t,n){let r=_i();if(!r&&or&&(r=await or),!!r){if(u==="test-generation"&&e){let i=e.tests||e.generatedTests||[];for(let s of i.slice(0,20)){let a={id:String(s.id||ke()),testId:String(s.id||s.name||ke()),testName:String(s.name||s.testName||"generated-test"),generatedBy:"qe-test-generation",patternId:s.patternId,framework:s.framework||n.framework||"vitest",language:s.language||n.language||"typescript",domain:"test-generation",passed:s.passed!==!1,coverage:{lines:Number(s.coverageLines||0),branches:Number(s.coverageBranches||0),functions:Number(s.coverageFunctions||0)},executionTimeMs:Number(s.executionTimeMs||t/Math.max(i.length,1)),flaky:!!s.flaky,maintainabilityScore:Number(s.qualityScore||s.maintainability||.7),timestamp:new Date};await r.recordTestOutcome(a)}}if(u==="coverage-analysis"&&e){let i={id:ke(),targetPath:String(n.target||n.targetPath||"src/"),agentId:"qe-coverage-analysis",technique:n.technique||"gap-analysis",beforeCoverage:{lines:Number(e.beforeCoverage?.lines||0),branches:Number(e.beforeCoverage?.branches||0),functions:Number(e.beforeCoverage?.functions||0)},afterCoverage:{lines:Number(e.lineCoverage||e.lines||0),branches:Number(e.branchCoverage||e.branches||0),functions:Number(e.functionCoverage||e.functions||0)},testsGenerated:Number(e.testsGenerated||0),testsPassed:Number(e.testsPassed||0),gapsTargeted:(e.gaps||[]).map((s,a)=>({id:String(s.id||`gap-${ke().slice(0,8)}-${a}`),type:["uncovered-line","uncovered-branch","uncovered-function","partial-branch"].includes(String(s.type))?String(s.type):"uncovered-line",filePath:String(s.file||s.filePath||""),startLine:Number(s.line||s.startLine||0),endLine:s.endLine?Number(s.endLine):void 0,riskScore:Number(s.riskScore||.5),addressed:!!s.addressed})),durationMs:t,startedAt:new Date(Date.now()-t),completedAt:new Date};await r.recordCoverageSession(i)}}}function Ni(u){let e=u.split(`
|
|
477
|
-
`).length,t=(u.match(/if|switch|for|while|catch/g)||[]).length;return{score:e+t*2,level:t>5?"high":t>2?"medium":"low"}}function
|
|
478
|
-
`);return u.includes("eval(")&&t.push({type:"dangerous-eval",line:n.findIndex(r=>r.includes("eval("))+1,severity:"critical",suggestion:"Replace eval() with safer alternatives"}),u.includes("var ")&&(e==="javascript"||e==="typescript")&&t.push({type:"var-usage",line:n.findIndex(r=>r.includes("var "))+1,severity:"low",suggestion:"Use const or let instead of var"}),u.includes("any")&&e==="typescript"&&t.push({type:"any-type",line:n.findIndex(r=>r.includes("any"))+1,severity:"medium",suggestion:"Replace any with specific types"}),t}var $t=null,or=null,de=null;function go(){if(!$t){let{kernel:u}=je();if(!u)throw new Error("Kernel not initialized");$t=xi(u);let e=$t;or=Di().then(t=>(e.setQualityFeedbackLoop(t),t)).catch(t=>(console.warn("[HandlerFactory] Failed to initialize QualityFeedbackLoop:",t),null))}return $t}async function zi(){if(de)return de;try{let{kernel:u}=je();if(!u)return null;let{createAQELearningEngine:e}=await import("./aqe-learning-engine-KNQKALLI.js"),t=u.memory;return de=e(t,{projectRoot:process.cwd(),enableClaudeFlow:!1}),await de.initialize(),de}catch(u){return console.debug("[HandlerFactory] Learning engine init failed:",w(u)),null}}async function ho(u,e){try{let t=await zi();if(!t)return[];let n=e,r=await t.searchPatterns(u,{limit:5,minConfidence:.4,domain:n,useVectorSearch:!0});return!r.success||r.value.length===0?[]:r.value.filter(i=>i.similarity>=.4).map(i=>({name:i.pattern.name,description:i.pattern.description,similarity:i.similarity,confidence:i.pattern.confidence,canReuse:i.canReuse,patternId:i.pattern.id}))}catch(t){return console.debug("[HandlerFactory] Pattern search failed:",w(t)),[]}}async function fo(u,e,t){try{let n=await ho(u,e);return n.length>0&&console.debug(`[HandlerFactory] Found ${n.length} relevant patterns for ${e}`),await(await Lt()).routeTask({task:u,domain:e,codeContext:t,agentType:`qe-${e}`,enablePatternSearch:!0,patternHints:n.length>0?n:void 0})}catch(n){return console.error(`[HandlerFactory] Routing failed for ${e}: ${n}`),null}}async function Oi(u,e,t,n){if(!(!u||u.length===0)&&de)try{for(let r of u)r.patternId&&await de.recordOutcome({patternId:r.patternId,success:e,metrics:{executionTimeMs:n},feedback:`Domain handler ${t} execution ${e?"succeeded":"failed"}`})}catch{}}function V(u){let{domain:e,taskType:t,priority:n="p1",defaultTimeout:r=18e4,buildTaskDescription:i,mapToPayload:s,mapToResult:a,calculateTimeout:o,includeCodeContext:l}=u;return async c=>{if(!$i())return{success:!1,error:"Fleet not initialized. Call fleet_init first."};let{queen:d}=je(),m=null;try{let p=i(c),g=l?.(c);m=await fo(p,e,g);let h=s(c,m),f=o?.(c)??r,v=await d.submitTask({type:t,priority:n,targetDomains:[e],payload:h,timeout:f});if(!v.success)return{success:!1,error:v.error.message};let y=go(),C=d.getTaskStatus(v.value);if(!C)return{success:!1,error:"Task not found after submission"};let b=await y.execute(C.task);if(!b.success)return{success:!1,error:b.error||"Task execution failed"};let E=b.data,S=a(v.value,E,b.duration,b.savedFiles,c);Oi(m?.patternHints,!0,e,b.duration),lo(`qe-${e}`,t,c,E,b.duration).catch(()=>{});try{await po(e,E,b.duration,c)}catch{}return{success:!0,data:S}}catch(p){let g=w(p);return Oi(m?.patternHints,!1,e,0),{success:!1,error:`Failed to ${t.replace(/-/g," ")}: ${g}`}}}}var Ut=class{taskMetrics=[];agentMetrics=new Map;resourceSnapshots=[];workerLoads=new Map;activeTasks=new Map;lastCpuUsage=null;snapshotInterval=null;initialized=!1;initialize(){this.initialized||(this.initialized=!0,this.lastCpuUsage=process.cpuUsage(),this.snapshotInterval=setInterval(()=>{this.takeResourceSnapshot()},1e3),this.snapshotInterval.unref&&this.snapshotInterval.unref())}shutdown(){this.snapshotInterval&&(clearInterval(this.snapshotInterval),this.snapshotInterval=null),this.initialized=!1}startTask(e,t){this.ensureInitialized();let n={taskId:e,agentId:t,startTime:process.hrtime(),success:!1,retries:0};this.activeTasks.set(e,n),this.updateWorkerLoad(t,1,0)}recordRetry(e){let t=this.activeTasks.get(e);t&&t.retries++}completeTask(e,t){let n=this.activeTasks.get(e);if(!n)return 0;n.endTime=process.hrtime(),n.success=t;let r=process.hrtime(n.startTime);return n.durationMs=r[0]*1e3+r[1]/1e6,this.updateAgentMetrics(n),this.updateWorkerLoad(n.agentId,-1,1),this.taskMetrics.push(n),this.taskMetrics.length>100&&this.taskMetrics.shift(),this.activeTasks.delete(e),n.durationMs}getCpuUsagePercent(){if(this.ensureInitialized(),!this.lastCpuUsage)return this.lastCpuUsage=process.cpuUsage(),0;let e=process.cpuUsage(this.lastCpuUsage);this.lastCpuUsage=process.cpuUsage();let t=e.user+e.system,r=1e3*1e3,i=t/r*100;return Math.min(100,Math.max(0,i))}getMemoryUsagePercent(){let e=process.memoryUsage(),t=e.heapUsed/e.heapTotal*100;return Math.min(100,Math.max(0,t))}getResourceStats(e){return{cpu:this.getCpuUsagePercent(),memory:this.getMemoryUsagePercent()}}getAgentTaskStats(e){let t=this.agentMetrics.get(e);if(!t||t.taskCount===0)return{tasksCompleted:0,averageTime:0,successRate:1};let n=t.tasksCompleted+t.tasksFailed,r=n>0?t.tasksCompleted/n:1,i=t.taskCount>0?t.totalDurationMs/t.taskCount:0;return{tasksCompleted:t.tasksCompleted,averageTime:Math.round(i),successRate:Math.min(1,Math.max(0,r))}}getWorkerEfficiency(){if(this.taskMetrics.length===0)return .85;let t=this.taskMetrics.filter(a=>a.success).length/this.taskMetrics.length,r=this.taskMetrics.reduce((a,o)=>a+o.retries,0)/this.taskMetrics.length,i=Math.min(.2,r*.1),s=t*(1-i);return Math.min(1,Math.max(0,s))}getLoadBalanceScore(){if(this.workerLoads.size===0)return .9;let e=Array.from(this.workerLoads.values()).map(a=>a.completedTaskCount);if(e.length<=1)return 1;let t=e.reduce((a,o)=>a+o,0)/e.length;if(t===0)return 1;let n=e.reduce((a,o)=>a+Math.pow(o-t,2),0)/e.length,s=1/(1+Math.sqrt(n)/t);return Math.min(1,Math.max(0,s))}getRetryStats(){let e=0,t=0,n=0;for(let r of this.agentMetrics.values())e+=r.totalRetries,t+=r.successfulRetries,n+=r.maxRetriesReached;return{totalRetries:e,successfulRetries:t,maxRetriesReached:n}}getAverageExecutionTime(){if(this.taskMetrics.length===0)return 0;let e=this.taskMetrics.reduce((t,n)=>t+(n.durationMs||0),0);return Math.round(e/this.taskMetrics.length)}getWorkersUsed(){return this.workerLoads.size}getTestDurations(e){let t=[];if(this.taskMetrics.length===0){for(let r=0;r<e;r++)t.push(100+r*10);return t}let n=this.taskMetrics.map(r=>r.durationMs||200).sort((r,i)=>r-i);for(let r=0;r<e;r++){let i=r%n.length;t.push(Math.round(n[i]))}return t}recordSuccessfulRetry(e){let t=this.agentMetrics.get(e);t&&t.successfulRetries++}recordMaxRetriesReached(e){let t=this.agentMetrics.get(e);t&&t.maxRetriesReached++}reset(){this.taskMetrics=[],this.agentMetrics.clear(),this.resourceSnapshots=[],this.workerLoads.clear(),this.activeTasks.clear(),this.lastCpuUsage=null}ensureInitialized(){this.initialized||this.initialize()}updateAgentMetrics(e){let t=this.agentMetrics.get(e.agentId);t||(t={agentId:e.agentId,tasksCompleted:0,tasksFailed:0,totalRetries:0,successfulRetries:0,maxRetriesReached:0,totalDurationMs:0,taskCount:0},this.agentMetrics.set(e.agentId,t)),e.success?(t.tasksCompleted++,e.retries>0&&t.successfulRetries++):t.tasksFailed++,t.totalRetries+=e.retries,t.totalDurationMs+=e.durationMs||0,t.taskCount++}updateWorkerLoad(e,t,n){let r=this.workerLoads.get(e);r||(r={workerId:e,activeTaskCount:0,completedTaskCount:0,lastActivityTime:Date.now()},this.workerLoads.set(e,r)),r.activeTaskCount=Math.max(0,r.activeTaskCount+t),r.completedTaskCount+=n,r.lastActivityTime=Date.now()}takeResourceSnapshot(){let e=process.memoryUsage(),t=process.cpuUsage(),n={timestamp:Date.now(),cpuUser:t.user,cpuSystem:t.system,memoryHeapUsed:e.heapUsed,memoryHeapTotal:e.heapTotal,memoryExternal:e.external,memoryRss:e.rss};this.resourceSnapshots.push(n),this.resourceSnapshots.length>60&&this.resourceSnapshots.shift()}},me=new Ut;Ds();var Bi=Object.keys(yt);function yo(u){if(!u)return"typescript";let e=u.toLowerCase().trim(),t={ts:"typescript",js:"javascript",py:"python","c#":"csharp","c-sharp":"csharp",cs:"csharp",golang:"go",rs:"rust",kt:"kotlin"};return t[e]?t[e]:Bi.includes(e)?e:null}var Ui={domain:"test-generation",taskType:"generate-tests",priority:"p1",defaultTimeout:12e4,buildTaskDescription:u=>`Generate ${u.testType||"unit"} tests for ${u.language||"typescript"} code`,includeCodeContext:u=>u.sourceCode,mapToPayload:(u,e)=>{let t=yo(u.language);if(t===null)throw new Error(`Unsupported language '${u.language}'. Supported languages: ${Bi.join(", ")}. Open a feature request for additional language support.`);let n;if(u.framework){n=u.framework;let r=Dr[n];if(r&&r!==t){let i=s=>s==="javascript"||s==="typescript";if(!(i(r)&&i(t)))throw new Error(`Framework '${n}' targets ${r}, but language was '${t}'. Either pick a matching framework or omit \`framework\` to use the default (${yt[t]}).`)}}else n=yt[t];return{sourceCode:u.sourceCode,filePath:u.filePath,language:t,framework:n,testType:u.testType||"unit",coverageGoal:u.coverageGoal||80,aiEnhancement:u.aiEnhancement!==!1,detectAntiPatterns:u.detectAntiPatterns||!1,routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}},mapToResult:(u,e,t,n,r)=>{let i=r?.sourceCode||"",s=r?.language||"typescript",a=r?.testType||"unit",o=e.testsGenerated||6,l=Ni(i),c=r?.aiEnhancement!==!1?Li(l,a):{recommendations:[],estimatedTime:"0 minutes",confidence:0},d=r?.detectAntiPatterns?Gi(i,s):[],m=Bt("test-generator"),p=e.tests,h=Array.isArray(p)&&p.length>0&&p[0].testCode?p.map((f,v)=>({id:Me(),name:f.name||`test_${v}`,type:f.type||a,parameters:[],assertions:f.testCode?vo(f.testCode):[`test assertion ${v}`],expectedResult:null,estimatedDuration:f.type==="integration"?2e3:1e3,aiGenerated:!0,testCode:f.testCode,sourceFile:f.sourceFile,testFile:f.testFile||f.file})):qi(i,a,s,o);return{tests:h,antiPatterns:d,suggestions:d.map(f=>`Fix: ${f.type} - ${f.suggestion}`),aiInsights:c,coverage:{predicted:e.coverageEstimate||r?.coverageGoal||80,confidence:.9,achievable:!0},properties:h.filter(f=>f.type==="property").map(f=>({name:f.name,invariant:"output_matches_expectation"})),language:s,complexity:l,learning:m,taskId:u,status:"completed",testsGenerated:h.length,coverageEstimate:e.coverageEstimate||r?.coverageGoal||80,patternsUsed:e.patternsUsed||["assertion-patterns","mock-generation","edge-case-detection"],duration:t,savedFiles:n}}},ji={domain:"test-execution",taskType:"execute-tests",priority:"p1",defaultTimeout:3e5,buildTaskDescription:u=>`Execute ${u.testFiles?.length||0} test files with ${u.parallel!==!1?"parallel":"sequential"} execution`,mapToPayload:(u,e)=>({testFiles:u.testFiles||[],testSuites:u.testSuites||[],parallel:u.parallel!==!1,parallelism:u.parallelism||4,retryCount:u.retryCount||3,timeout:u.timeout||6e4,collectCoverage:u.collectCoverage||!1,reportFormat:u.reportFormat||"json",routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),calculateTimeout:u=>u.timeout||3e5,mapToResult:(u,e,t,n,r)=>{let i=e.total||0,s=e.passed||0,a=e.failed||0,o=e.coverage,l=r?.parallelism||4,c=me.getRetryStats(),d=me.getWorkersUsed(),m={workersUsed:d>0?d:Math.min(l,i||1),efficiency:me.getWorkerEfficiency(),loadBalance:me.getLoadBalanceScore(),avgExecutionTime:t/Math.max(i,1)},p={totalRetries:c.totalRetries,successfulRetries:c.successfulRetries,maxRetriesReached:c.maxRetriesReached},g=Bt("test-executor");return{workerStats:m,retryStats:p,results:(()=>{let h=me.getTestDurations(i);return Array.from({length:i},(f,v)=>({id:Me(),name:`test_case_${v}`,status:v<s?"passed":"failed",duration:h[v]||200,retries:0}))})(),summary:{totalTests:i,passRate:i>0?s/i*100:0,avgDuration:t/Math.max(i,1),parallelEfficiency:m.efficiency},learning:g,taskId:u,status:"completed",total:i,passed:s,failed:a,duration:t,coverage:o,savedFiles:n}}},Hi={domain:"coverage-analysis",taskType:"analyze-coverage",priority:"p1",defaultTimeout:18e4,buildTaskDescription:u=>`Analyze coverage for ${u.target||"project"} with gap detection`,mapToPayload:(u,e)=>({target:u.target||".",includeRisk:u.includeRisk||!1,detectGaps:u.detectGaps!==!1,mlPowered:u.mlPowered||!1,prioritization:u.prioritization||"complexity",routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>{let r=e.summary,i=r?.line??e.lineCoverage??0,s=r?.branch??e.branchCoverage??0,a=r?.function??e.functionCoverage??0,o=r?.statement??e.statementCoverage??i,l=r?.files??e.totalFiles??0,c=e.gaps||[],d=Bt("coverage-analyzer"),m=c.map((h,f)=>{let v=h;return v?.file?{id:`gap-${Date.now()}-${f}`,file:v.file,line:v.lines?.[0]||0,uncoveredLines:v.lines||[],type:v.type||"uncovered-line",severity:v.severity||"medium",reason:v.reason||"Missing test case",priority:v.priority||"medium",suggestion:v.suggestedTest||"Add test coverage",suggestedTest:v.suggestedTest||"Add test coverage",riskScore:v.riskScore||.5,confidence:v.confidence||.7}:null}).filter(h=>h!==null),p=e.coverageByFile;return{coverageByFile:p?p.map(h=>({file:h.file,lineCoverage:h.lineCoverage||0,branchCoverage:h.branchCoverage||0,functionCoverage:h.functionCoverage||0})):[],gapAnalysis:{totalGaps:m.length,highPriority:m.filter(h=>h.priority==="high").length,gaps:m},trends:{lineCoverageTrend:l>0?"stable":"no-data",branchCoverageTrend:l>0?"stable":"no-data",weeklyChange:0},aiInsights:l>0?{recommendations:e.recommendations||["Run tests with coverage enabled to get accurate metrics"],riskAssessment:i<70?"high":i<85?"medium":"low",confidence:.88}:{recommendations:["No coverage data found. Run tests with coverage first (e.g., npm test -- --coverage, or pytest --cov)"],riskAssessment:"unknown",confidence:0},learning:d,taskId:u,status:"completed",lineCoverage:i,branchCoverage:s,functionCoverage:a,statementCoverage:o,totalFiles:l,gaps:m,duration:t,savedFiles:n}}},Vi={domain:"quality-assessment",taskType:"assess-quality",priority:"p0",defaultTimeout:18e4,buildTaskDescription:u=>`Assess quality with ${u.runGate?"quality gate":"metrics analysis"}`,mapToPayload:(u,e)=>({runGate:u.runGate||!1,threshold:u.threshold||80,metrics:u.metrics||["coverage","complexity","maintainability"],routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",qualityScore:e.qualityScore||0,passed:e.passed||!1,metrics:e.metrics||{},recommendations:e.recommendations||[],duration:t,savedFiles:n})},Qi={domain:"security-compliance",taskType:"scan-security",priority:"p0",defaultTimeout:6e5,buildTaskDescription:u=>{let e=[];return u.sast!==!1&&e.push("SAST"),u.dast&&e.push("DAST"),`Security scan (${e.join(", ")}) for ${u.target||"project"}`},mapToPayload:(u,e)=>({sast:u.sast!==!1,dast:u.dast||!1,compliance:u.compliance||[],target:u.target||".",routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",vulnerabilities:e.vulnerabilities||0,critical:e.critical||0,high:e.high||0,medium:e.medium||0,low:e.low||0,topVulnerabilities:e.topVulnerabilities||[],recommendations:e.recommendations||[],duration:t,savedFiles:n})},Wi={domain:"contract-testing",taskType:"validate-contracts",priority:"p1",defaultTimeout:18e4,buildTaskDescription:u=>`Validate API contract at ${u.contractPath}`,mapToPayload:(u,e)=>({contractPath:u.contractPath,providerUrl:u.providerUrl,consumerName:u.consumerName,checkBreakingChanges:u.checkBreakingChanges!==!1,routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",valid:e.valid||!1,breakingChanges:e.breakingChanges||[],warnings:e.warnings||[],duration:t,savedFiles:n})},Ki={domain:"visual-accessibility",taskType:"test-accessibility",priority:"p1",defaultTimeout:18e4,buildTaskDescription:u=>`Test accessibility for ${u.url} against ${u.standard||"WCAG 2.1 AA"} standard`,mapToPayload:(u,e)=>({url:u.url,standard:u.standard||"wcag21-aa",includeScreenReader:u.includeScreenReader||!1,routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",passed:e.passed||!1,score:e.score||0,violations:e.violations||[],warnings:e.warnings||[],duration:t,savedFiles:n})},Xi={domain:"chaos-resilience",taskType:"run-chaos",priority:"p2",defaultTimeout:9e4,buildTaskDescription:u=>`Run chaos test with ${u.faultType||"latency"} fault injection on ${u.target}`,mapToPayload:(u,e)=>({faultType:u.faultType||"latency",target:u.target,duration:u.duration||3e4,intensity:u.intensity||50,dryRun:u.dryRun!==!1,routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),calculateTimeout:u=>(u.duration||3e4)+6e4,mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",faultType:e.faultType||"latency",resilience:e.resilience||{recovered:!1,recoveryTime:0,dataLoss:!1},duration:t,savedFiles:n})},Yi={domain:"defect-intelligence",taskType:"predict-defects",priority:"p1",defaultTimeout:18e4,buildTaskDescription:u=>`Predict defects in ${u.target||"codebase"} with ${u.lookback||30} day lookback`,mapToPayload:(u,e)=>({target:u.target||".",lookback:u.lookback||30,minConfidence:u.minConfidence||.7,routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",predictedDefects:e.predictedDefects||[],riskScore:e.riskScore||0,recommendations:e.recommendations||[],duration:t,savedFiles:n})},Ji={domain:"requirements-validation",taskType:"validate-requirements",priority:"p1",defaultTimeout:18e4,buildTaskDescription:u=>`Validate requirements${u.generateBDD?" and generate BDD scenarios":""}`,mapToPayload:(u,e)=>({requirementsPath:u.requirementsPath,testPath:u.testPath,generateBDD:u.generateBDD||!1,routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",requirementsAnalyzed:e.requirementsAnalyzed||0,testable:e.testable||0,coverage:e.coverage||0,bddScenarios:e.bddScenarios||[],duration:t,savedFiles:n})},Zi={domain:"code-intelligence",taskType:"index-code",priority:"p2",defaultTimeout:3e5,buildTaskDescription:u=>`Index code in ${u.target||"codebase"}${u.incremental?" incrementally":""}`,mapToPayload:(u,e)=>({target:u.target||".",incremental:u.incremental||!1,gitSince:u.gitSince,routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",filesIndexed:e.filesIndexed||0,symbolsExtracted:e.symbolsExtracted||0,relationsFound:e.relationsFound||0,duration:t,savedFiles:n})};function vo(u){let e=[],t=u.split(`
|
|
479
|
-
`);for(let n of t){let r=n.trim(),i=r.match(/expect\((.+?)\)\.(to\w+)\((.+?)\)/);if(i){e.push(`expect(${i[1]}).${i[2]}(${i[3]})`);continue}let s=r.match(/assert\w*\((.+)\)/);if(s){e.push(s[0]);continue}let a=r.match(/(?:it|test)\s*\(\s*['"`](.+?)['"`]/);a&&e.push(a[1])}return e.length>0?e:["test generated from source analysis"]}var
|
|
480
|
-
`),s=/(?<![\w.])(\d{2,}|[2-9]\d*)(?![\w.])/g,a=new Set(["10","100","1000","60","24","365","404","500","200","201"]);i.forEach((
|
|
481
|
-
`).length;e.push({name:"no-assertions",location:`${n}:${S}`,severity:"high",suggestion:`Test "${h}" has no assertions. Add expect() or assert() calls to verify behavior`})}}}let c=[{pattern:/let\s+\w+\s*=\s*(?!undefined|null)/g,name:"mutable-let-declaration"},{pattern:/(?:^|\s)var\s+\w+\s*=/g,name:"mutable-var-declaration"}],d=r.match(/describe\s*\([^)]+,\s*(?:function\s*\(\)|(?:\(\s*\))?\s*=>)\s*\{/g);if(d)for(let
|
|
482
|
-
`).length;e.push({name:"test-interdependence",location:`${n}:${b}`,severity:"high",suggestion:`Shared mutable variable '${y}' is modified in multiple tests, causing test interdependence. Use beforeEach to reset state or isolate test data`})}}}}if(/\.test\.|\.spec\./.test(n)){let
|
|
483
|
-
`).length;e.push({name:"long-test-description",location:`${n}:${
|
|
484
|
-
`).length;e.push({name:"real-timers-in-tests",location:`${n}:${f}`,severity:"medium",suggestion:"Using real timers in tests can cause flakiness. Consider using fake timers (jest.useFakeTimers() or vi.useFakeTimers())"})}}}catch{continue}return e}function
|
|
485
|
-
`),r=null,i=new Map,s=[],a=[],o=0,l=0,c=0,d=0,m=0,
|
|
486
|
-
`);for(let i of r){let s=i.trim();if(!s||s.startsWith("mode:"))continue;let a=s.match(/^(.+):(\d+)\.\d+,(\d+)\.\d+\s+(\d+)\s+(\d+)$/);if(!a)continue;let o=a[1],l=parseInt(a[2],10),c=parseInt(a[3],10),d=parseInt(a[4],10),m=parseInt(a[5],10);n.has(o)||n.set(o,{lineDetails:new Map,stmtTotal:0,stmtCovered:0});let p=n.get(o);for(let g=l;g<=c;g++){let h=p.lineDetails.get(g)||0;p.lineDetails.set(g,h+m)}p.stmtTotal+=d,m>0&&(p.stmtCovered+=d)}for(let[i,s]of n.entries()){let a=s.lineDetails.size,o=Array.from(s.lineDetails.values()).filter(c=>c>0).length,l=Array.from(s.lineDetails.entries()).filter(([,c])=>c===0).map(([c])=>c).sort((c,d)=>c-d);t.set(i,{path:i,relativePath:A.relative(e,i),lines:{total:a,covered:o,percentage:a>0?o/a*100:0,details:s.lineDetails,uncoveredLines:l},branches:{total:0,covered:0,percentage:0,uncoveredBranches:[]},functions:{total:0,covered:0,percentage:0,details:[],uncoveredFunctions:[]},statements:{total:s.stmtTotal,covered:s.stmtCovered,percentage:s.stmtTotal>0?s.stmtCovered/s.stmtTotal*100:0},coveragePercentage:s.stmtTotal>0?s.stmtCovered/s.stmtTotal*100:0})}return{timestamp:new Date,format:"gocover",language:"go",files:t,summary:pe(t)}}async function is(u,e){let t=await Q.readFile(u,"utf-8"),n=Vt(t,e||A.dirname(u));return n.format="kover",n.language="kotlin",n}async function ss(u,e){let t=await Q.readFile(u,"utf-8");return us(t,e||A.dirname(u))}function us(u,e){let t=new Map,r=P(u)?.targets||[];for(let i of r)for(let s of i.files||[]){let a=s.path||"",o=s.executableLines||0,l=s.coveredLines||0,c=s.lineCoverage||0,d=[],m=0,p=0;for(let g of s.functions||[]){let h=g.coveredLines>0?1:0;d.push({name:g.name||"unknown",line:g.lineNumber||0,hits:h}),m++,h>0&&p++}t.set(a,{path:a,relativePath:A.relative(e,a),lines:{total:o,covered:l,percentage:c*100,details:new Map,uncoveredLines:[]},branches:{total:0,covered:0,percentage:0,uncoveredBranches:[]},functions:{total:m,covered:p,percentage:m>0?p/m*100:0,details:d,uncoveredFunctions:d.filter(g=>g.hits===0).map(g=>g.name)},statements:{total:o,covered:l,percentage:c*100},coveragePercentage:c*100})}return{timestamp:new Date,format:"xcresult",language:"swift",files:t,summary:pe(t)}}var xo={java:["jacoco","cobertura","lcov"],kotlin:["kover","jacoco"],csharp:["dotcover","cobertura"],rust:["tarpaulin","lcov"],go:["gocover"],swift:["xcresult"],dart:["lcov"],typescript:["lcov","json"],javascript:["lcov","json"],python:["lcov","cobertura","json"]};async function He(u,e,t,n){if(t)switch(t){case"lcov":return cr(u,e);case"json":return lr(u,e);case"jacoco":return es(u,e);case"dotcover":return ts(u,e);case"tarpaulin":return ns(u,e);case"gocover":return rs(u,e);case"kover":return is(u,e);case"xcresult":return ss(u,e);default:break}let r=A.extname(u).toLowerCase(),i=A.basename(u).toLowerCase();if(r===".json"||i.includes("coverage-final"))return lr(u,e);if(i==="lcov.info"||r===".info"||i.includes("lcov"))return cr(u,e);if(i.includes("jacoco")&&r===".xml")return es(u,e);if(i.includes("dotcover")&&r===".xml")return ts(u,e);if(i.includes("tarpaulin"))return ns(u,e);if(i.includes("kover")&&r===".xml")return is(u,e);if(i.includes("coverage")&&r===".out")return rs(u,e);if(i.includes("xcresult")||i.includes("xccov"))return ss(u,e);let s=await Q.readFile(u,"utf-8"),a=s.trim();if(a.startsWith("{"))return a.includes('"files"')&&a.includes('"traces"')?cs(s,e||A.dirname(u)):a.includes('"targets"')&&a.includes('"lineCoverage"')?us(s,e||A.dirname(u)):lr(u,e);if(s.includes("SF:")&&s.includes("end_of_record"))return cr(u,e);if(a.startsWith("mode:"))return ls(s,e||A.dirname(u));if(a.startsWith("<?xml")||a.startsWith("<")){if(s.includes('<counter type="')||s.includes("<report ")){if(n==="kotlin"){let o=Vt(s,e||A.dirname(u));return o.format="kover",o.language="kotlin",o}return Vt(s,e||A.dirname(u))}if(s.includes("CoveredStatements=")||s.includes("<Root"))return os(s,e||A.dirname(u))}if(n){let o=n.toLowerCase(),l=xo[o];if(l&&l.length>0)try{return await He(u,e,l[0])}catch{}}throw new Error(`Unknown coverage format: ${u}`)}async function ur(u,e){let t=e||u,n=[A.join(u,"coverage","lcov.info"),A.join(u,"coverage","coverage-final.json"),A.join(u,"lcov.info"),A.join(u,".nyc_output","coverage.json"),A.join(u,"target","site","jacoco","jacoco.xml"),A.join(u,"build","reports","jacoco","test","jacocoTestReport.xml"),A.join(u,"dotcover-report.xml"),A.join(u,"tarpaulin-report.json"),A.join(u,"cobertura.xml"),A.join(u,"coverage.out"),A.join(u,"cover.out"),A.join(u,"build","reports","kover","report.xml"),A.join(u,"coverage.json")];for(let r of n)try{return await Q.access(r),He(r,t)}catch{}return null}function dr(u,e,t,n){let r=e>0?u/e*100:0,i=n>0?t/n*100:0;return n===0?r:r*.7+i*.3}function pe(u){let e=0,t=0,n=0,r=0,i=0,s=0,a=0,o=0;for(let l of u.values())e+=l.lines.total,t+=l.lines.covered,n+=l.branches.total,r+=l.branches.covered,i+=l.functions.total,s+=l.functions.covered,a+=l.statements.total,o+=l.statements.covered;return{totalFiles:u.size,lines:{total:e,covered:t,percentage:e>0?t/e*100:0},branches:{total:n,covered:r,percentage:n>0?r/n*100:0},functions:{total:i,covered:s,percentage:i>0?s/i*100:0},statements:{total:a,covered:o,percentage:a>0?o/a*100:0}}}k();function ds(u){let e=0,t=0,n=0,r=0,i=0,s=0,a=0,o=0;for(let l of u)e+=l.lines.total,t+=l.lines.covered,n+=l.branches.total,r+=l.branches.covered,i+=l.functions.total,s+=l.functions.covered,a+=l.statements.total,o+=l.statements.covered;return{line:e>0?t/e*100:0,branch:n>0?r/n*100:0,function:i>0?s/i*100:0,statement:a>0?o/a*100:0,files:u.length}}function ms(u){let e=[];for(let[t,n]of u.files.entries())e.push({path:n.relativePath||t,lines:{covered:n.lines.covered,total:n.lines.total},branches:{covered:n.branches.covered,total:n.branches.total},functions:{covered:n.functions.covered,total:n.functions.total},statements:{covered:n.statements.covered,total:n.statements.total},uncoveredLines:n.lines.uncoveredLines,uncoveredBranches:n.branches.uncoveredBranches.map(r=>r.line)});return e}var Qt=class extends x{config={name:"qe/coverage/analyze",description:"Analyze code coverage using real LCOV/JSON parsing and compare against thresholds. Includes risk scoring and trend analysis.",domain:"coverage-analysis",schema:Po,streaming:!0,timeout:18e4};analyzerService=null;async getService(e){if(!this.analyzerService){let t=e.memory;this.analyzerService=new _r(t||await F())}return this.analyzerService}async execute(e,t){let{target:n=".",coverageFile:r,thresholds:i={lines:80,branches:70,functions:80,statements:80},includeRisk:s=!1,includeRiskScoring:a=!1,dryRun:o=!1,coverageFormat:l,language:c}=e,d=s||a;try{if(this.emitStream(t,{status:"analyzing",message:`Analyzing coverage for ${n}`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};if(this.isDemoMode(t)||o)return this.markAsDemoData(t,"Demo mode explicitly requested"),this.getDemoResult(n,i,d,t);let m=null;if(r)try{m=await He(r,n,l,c)}catch(R){return{success:!1,error:`Failed to parse coverage file '${r}': ${w(R)}`}}else m=await ur(n);if(!m||m.files.size===0)return{success:!1,error:`No coverage data found in '${n}'. Run your test suite with coverage enabled (e.g., 'npm test -- --coverage') and ensure coverage reports are generated (lcov.info, coverage-final.json, etc.)`};this.markAsRealData();let p=ms(m),h=await(await this.getService(t)).analyze({coverageData:{files:p,summary:ds(p)},threshold:i.lines||80,includeFileDetails:!0});if(!h.success)return{success:!1,error:`Analysis failed: ${h.error?.message||"Unknown error"}`};let f=h.value,v={lines:{covered:m.summary.lines.covered,total:m.summary.lines.total,percentage:Math.round(m.summary.lines.percentage*100)/100},branches:{covered:m.summary.branches.covered,total:m.summary.branches.total,percentage:Math.round(m.summary.branches.percentage*100)/100},functions:{covered:m.summary.functions.covered,total:m.summary.functions.total,percentage:Math.round(m.summary.functions.percentage*100)/100},statements:{covered:m.summary.statements.covered,total:m.summary.statements.total,percentage:Math.round(m.summary.statements.percentage*100)/100}},y=p.map(R=>({file:R.path,lines:Math.round(R.lines.covered/(R.lines.total||1)*100),branches:Math.round(R.branches.covered/(R.branches.total||1)*100),functions:Math.round(R.functions.covered/(R.functions.total||1)*100),uncoveredLines:R.uncoveredLines.slice(0,20)})),C=v.lines.percentage>=(i.lines||0)&&v.branches.percentage>=(i.branches||0)&&v.functions.percentage>=(i.functions||0)&&v.statements.percentage>=(i.statements||0),b;if(d){let R=p.reduce((G,j)=>G+j.uncoveredLines.length,0),D=(v.lines.percentage+v.branches.percentage+v.functions.percentage)/3;b=Math.round((1-D/100+Math.min(R/1e3,.5))*100)/100}let E;f.delta&&(E={direction:f.delta.trend,delta:Math.round((f.delta.line+f.delta.branch+f.delta.function)/3*100)/100,history:[{date:new Date(Date.now()-10080*60*1e3).toISOString().split("T")[0],coverage:v.lines.percentage-(f.delta.line||0)},{date:new Date().toISOString().split("T")[0],coverage:v.lines.percentage}]}),this.emitStream(t,{status:"complete",message:`Coverage analysis complete: ${v.lines.percentage}% lines covered`,progress:100});let S=e.language||m.language,T=m.format;return{success:!0,data:{summary:v,byFile:y,thresholdsPassed:C,riskScore:b,trends:E,language:S,format:T}}}catch(m){return{success:!1,error:`Coverage analysis failed: ${w(m)}`}}}getDemoResult(e,t,n,r){let i={lines:{covered:850,total:1e3,percentage:85},branches:{covered:120,total:150,percentage:80},functions:{covered:90,total:100,percentage:90},statements:{covered:900,total:1050,percentage:85.71}},s=[{file:`${e}/service.ts`,lines:92,branches:85,functions:95,uncoveredLines:[45,67,89]},{file:`${e}/utils.ts`,lines:78,branches:70,functions:85,uncoveredLines:[12,34,56,78,90]},{file:`${e}/handler.ts`,lines:88,branches:82,functions:90,uncoveredLines:[23,45]}],a=i.lines.percentage>=(t.lines||0)&&i.branches.percentage>=(t.branches||0)&&i.functions.percentage>=(t.functions||0)&&i.statements.percentage>=(t.statements||0);return this.emitStream(r,{status:"complete",message:`Coverage analysis complete (sample data): ${i.lines.percentage}% lines covered`,progress:100}),{success:!0,data:{summary:i,byFile:s,thresholdsPassed:a,riskScore:n?.25:void 0,trends:{direction:"improving",delta:2.5,history:[{date:new Date(Date.now()-10080*60*1e3).toISOString().split("T")[0],coverage:82.5},{date:new Date().toISOString().split("T")[0],coverage:85}]}}}}resetInstanceCache(){this.analyzerService=null}},Wt=class extends x{config={name:"qe/coverage/gaps",description:"Find coverage gaps using O(log n) HNSW vector search. Prioritizes by risk, complexity, or ML confidence using real coverage data.",domain:"coverage-analysis",schema:Ao,streaming:!0,timeout:12e4};gapService=null;async getService(e){if(!this.gapService){let t=e.memory;this.gapService=new Or(t||await F())}return this.gapService}async execute(e,t){let{target:n=".",coverageFile:r,minRisk:i=.3,limit:s=20,prioritization:a="complexity",coverageFormat:o,language:l}=e;try{if(this.emitStream(t,{status:"detecting",message:`Detecting coverage gaps in ${n} (O(log n) search)`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let c=null;if(r)try{c=await He(r,n,o,l)}catch(C){return{success:!1,error:`Failed to parse coverage file: ${w(C)}`}}else c=await ur(n);if(this.isDemoMode(t))return this.markAsDemoData(t,"Demo mode explicitly requested"),this.getDemoGapsResult(n,i,s,t);if(!c||c.files.size===0)return r?{success:!1,error:`Coverage file '${r}' contains no usable coverage data (parsed 0 files). Verify the file is a non-empty Istanbul/LCOV/JaCoCo/etc. report.`}:{success:!1,error:`No coverage data found by autodiscovery under target '${n}'. Run your test suite with coverage enabled, or pass coverageFile pointing to an existing report.`};this.markAsRealData();let d=ms(c),m=await this.getService(t),p=a==="change-frequency"?"recent-changes":"risk",g=await m.detectGaps({coverageData:{files:d,summary:ds(d)},minCoverage:80,prioritize:p});if(!g.success)return{success:!1,error:`Gap detection failed: ${g.error?.message||"Unknown error"}`};let h=g.value,f=h.gaps.filter(C=>C.riskScore>=i).slice(0,s).map(C=>({file:C.file,lines:C.lines,type:C.branches.length>0?"uncovered-branch":"uncovered-line",severity:C.severity,riskScore:Math.round(C.riskScore*100)/100,reason:C.recommendation})),v=f.slice(0,5).map((C,b)=>({file:C.file.replace(/\.ts$/,".test.ts"),description:`Add tests for ${C.lines.length} uncovered lines in ${C.file}`,estimatedCoverageGain:Math.round(C.lines.length/(h.totalUncoveredLines||1)*100*100)/100,priority:b+1})),y;if(e.includeGhost)try{let b=t.kernel;if(b){let E=await b.getDomainAPIAsync("coverage-analysis");if(E?.analyzeGhostCoverage){let S=await E.analyzeGhostCoverage(d.map(T=>T.path),n);S?.success&&S.value&&(y=(S.value.gaps||[]).map(T=>({category:T.category,severity:T.severity,description:T.description,confidence:T.confidence})))}}}catch{}return this.emitStream(t,{status:"complete",message:`Found ${f.length} coverage gaps (${h.totalUncoveredLines} uncovered lines)`,progress:100}),{success:!0,data:{gaps:f,totalGaps:h.gaps.length,criticalGaps:f.filter(C=>C.severity==="critical").length,suggestedTests:v,...y?{ghostGaps:y}:{}}}}catch(c){return{success:!1,error:`Gap detection failed: ${w(c)}`}}}getDemoGapsResult(e,t,n,r){let s=[{file:`${e}/service.ts`,lines:[45,67,89,102,115],type:"uncovered-line",severity:"high",riskScore:.85,reason:"Core business logic with no test coverage"},{file:`${e}/utils.ts`,lines:[12,34,56],type:"uncovered-branch",severity:"medium",riskScore:.65,reason:"Utility functions missing edge case tests"},{file:`${e}/handler.ts`,lines:[23,45,67,89],type:"uncovered-function",severity:"critical",riskScore:.92,reason:"Error handling paths untested"},{file:`${e}/validator.ts`,lines:[10,20,30],type:"uncovered-line",severity:"low",riskScore:.35,reason:"Simple validation logic"}].filter(o=>o.riskScore>=t).slice(0,n),a=s.slice(0,5).map((o,l)=>({file:o.file.replace(/\.ts$/,".test.ts"),description:`Add tests for ${o.lines.length} uncovered lines in ${o.file}`,estimatedCoverageGain:Math.round(o.lines.length/50*100*100)/100,priority:l+1}));return this.emitStream(r,{status:"complete",message:`Found ${s.length} coverage gaps (sample data)`,progress:100}),{success:!0,data:{gaps:s,totalGaps:s.length,criticalGaps:s.filter(o=>o.severity==="critical").length,suggestedTests:a}}}resetInstanceCache(){this.gapService=null}},Po={type:"object",properties:{target:{type:"string",description:"Target directory to analyze (searches for coverage files)",default:"."},coverageFile:{type:"string",description:"Path to coverage report file (lcov.info, coverage-final.json, etc.)"},thresholds:{type:"object",description:"Coverage thresholds",properties:{lines:{type:"number",description:"Line coverage threshold"},branches:{type:"number",description:"Branch coverage threshold"},functions:{type:"number",description:"Function coverage threshold"},statements:{type:"number",description:"Statement coverage threshold"}}},includeRisk:{type:"boolean",description:"Include risk score analysis",default:!1},mlPowered:{type:"boolean",description:"Use ML-powered analysis (vector similarity)",default:!1},language:{type:"string",description:"Source language hint (java, csharp, go, rust, kotlin, swift, dart, typescript, python)"},coverageFormat:{type:"string",description:"Coverage format hint",enum:["lcov","json","jacoco","dotcover","tarpaulin","gocover","kover","xcresult"]}}},Ao={type:"object",properties:{target:{type:"string",description:"Target directory to analyze",default:"."},coverageFile:{type:"string",description:"Path to coverage report file"},minRisk:{type:"number",description:"Minimum risk score to include (0-1)",minimum:0,maximum:1,default:.3},limit:{type:"number",description:"Maximum number of gaps to return",minimum:1,maximum:100,default:20},prioritization:{type:"string",description:"Gap prioritization strategy",enum:["complexity","criticality","change-frequency","ml-confidence"],default:"complexity"},includeGhost:{type:"boolean",description:"Include ADR-059 ghost intent coverage analysis (detect untested behavioral intents)",default:!1},language:{type:"string",description:"Source language filter (java, csharp, go, rust, kotlin, swift, dart)"},coverageFormat:{type:"string",description:"Coverage format hint",enum:["lcov","json","jacoco","dotcover","tarpaulin","gocover","kover","xcresult"]}}};k();var Kt=class extends x{config={name:"qe/quality/evaluate",description:"Evaluate quality gates and provide deployment recommendations. Analyzes coverage, bugs, complexity, and security.",domain:"quality-assessment",schema:ko,streaming:!0,timeout:12e4};async execute(e,t){let{metrics:n=Mo(),gateName:r="default",thresholds:i=Do(),includeAdvice:s=!0,riskTolerance:a="medium"}=e;try{if(this.emitStream(t,{status:"evaluating",message:`Evaluating quality gate: ${r}`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let o=[];i.coverage&&n.coverage!==void 0&&o.push({name:"Coverage",passed:n.coverage>=i.coverage.min,value:n.coverage,threshold:i.coverage.min,severity:"high",message:n.coverage>=i.coverage.min?`Coverage ${n.coverage}% meets threshold`:`Coverage ${n.coverage}% below ${i.coverage.min}% threshold`}),i.testsPassing&&n.testsPassing!==void 0&&o.push({name:"Tests Passing",passed:n.testsPassing>=i.testsPassing.min,value:n.testsPassing,threshold:i.testsPassing.min,severity:"critical",message:n.testsPassing>=i.testsPassing.min?`${n.testsPassing}% tests passing`:`Only ${n.testsPassing}% tests passing`}),i.criticalBugs&&n.criticalBugs!==void 0&&o.push({name:"Critical Bugs",passed:n.criticalBugs<=i.criticalBugs.max,value:n.criticalBugs,threshold:i.criticalBugs.max,severity:"critical",message:n.criticalBugs<=i.criticalBugs.max?`${n.criticalBugs} critical bugs within threshold`:`${n.criticalBugs} critical bugs exceed threshold of ${i.criticalBugs.max}`}),i.securityVulnerabilities&&n.securityVulnerabilities!==void 0&&o.push({name:"Security Vulnerabilities",passed:n.securityVulnerabilities<=i.securityVulnerabilities.max,value:n.securityVulnerabilities,threshold:i.securityVulnerabilities.max,severity:"critical",message:n.securityVulnerabilities<=i.securityVulnerabilities.max?`${n.securityVulnerabilities} vulnerabilities within threshold`:`${n.securityVulnerabilities} vulnerabilities found`}),i.codeSmells&&n.codeSmells!==void 0&&o.push({name:"Code Smells",passed:n.codeSmells<=i.codeSmells.max,value:n.codeSmells,threshold:i.codeSmells.max,severity:"medium",message:n.codeSmells<=i.codeSmells.max?`${n.codeSmells} code smells within threshold`:`${n.codeSmells} code smells detected`});let l=o.filter(f=>f.passed).length,c=o.length,d=c>0?Math.round(l/c*100):100,m=Io(d,o),p=o.every(f=>f.passed||f.severity!=="critical"),g=s?_o(p,d,o,a):void 0,h=Oo(o,n);return this.emitStream(t,{status:"complete",message:`Quality evaluation complete: ${m} (${d}%)`,progress:100}),{success:!0,data:{passed:p,score:d,grade:m,checks:o,deploymentAdvice:g,recommendations:h}}}catch(o){return{success:!1,error:`Quality evaluation failed: ${w(o)}`}}}},ko={type:"object",properties:{metrics:{type:"object",description:"Quality metrics to evaluate",properties:{coverage:{type:"number",description:"Code coverage percentage"},testsPassing:{type:"number",description:"Percentage of passing tests"},criticalBugs:{type:"number",description:"Number of critical bugs"},codeSmells:{type:"number",description:"Number of code smells"},securityVulnerabilities:{type:"number",description:"Number of security vulnerabilities"},technicalDebt:{type:"number",description:"Technical debt in hours"},duplications:{type:"number",description:"Code duplication percentage"},complexity:{type:"number",description:"Cyclomatic complexity"}}},gateName:{type:"string",description:"Name of the quality gate",default:"default"},thresholds:{type:"object",description:"Quality gate thresholds"},includeAdvice:{type:"boolean",description:"Include deployment advice",default:!0},riskTolerance:{type:"string",description:"Risk tolerance level",enum:["low","medium","high"],default:"medium"}}};function Mo(){return{coverage:80,testsPassing:95,criticalBugs:0,codeSmells:15,securityVulnerabilities:0,technicalDebt:4,duplications:3,complexity:8}}function Do(){return{coverage:{min:80},testsPassing:{min:95},criticalBugs:{max:0},securityVulnerabilities:{max:0},codeSmells:{max:50},technicalDebt:{max:8}}}function Io(u,e){return e.some(n=>!n.passed&&n.severity==="critical")?"F":u>=90?"A":u>=80?"B":u>=70?"C":u>=60?"D":"F"}function _o(u,e,t,n){let r=t.filter(d=>!d.passed&&d.severity==="critical"),i=t.filter(d=>!d.passed&&d.severity==="high"),s=r.length*.4+i.length*.2+(100-e)/100,a=Math.min(s,1),o,c={low:{block:.2,warn:.1},medium:{block:.4,warn:.2},high:{block:.6,warn:.4}}[n];return a>=c.block||r.length>0?o="blocked":a>=c.warn?o="warning":o="approved",{decision:o,confidence:Math.round((1-a)*100)/100,riskScore:Math.round(a*100)/100,reasons:[...r.map(d=>`Critical: ${d.name} - ${d.message}`),...i.map(d=>`High: ${d.name} - ${d.message}`)],conditions:o==="warning"?["Monitor closely after deployment","Prepare rollback plan"]:void 0,rollbackPlan:o!=="approved"?"Revert to previous version if issues detected":void 0}}function Oo(u,e){let t=[],n=u.filter(r=>!r.passed);for(let r of n)t.push({type:r.severity==="critical"?"critical":r.severity==="high"?"warning":"improvement",title:`Fix ${r.name}`,description:r.message,impact:r.severity==="critical"||r.severity==="high"?"high":"medium",effort:"medium"});return(e.coverage||0)<90&&t.push({type:"improvement",title:"Increase test coverage",description:`Current coverage is ${e.coverage}%. Consider adding tests for critical paths.`,impact:"medium",effort:"medium"}),t}k();var Xt={codeComplexity:"High cyclomatic complexity increases defect probability",changeFrequency:"Frequently modified files are more prone to defects",bugHistory:"Previous defects in this area indicate higher risk",testCoverage:"Low test coverage increases undetected defect risk",developerExperience:"Code written by less experienced developers may have more issues",codeAge:"New code is more likely to have defects than mature, stable code",complexity:"High cyclomatic complexity increases defect probability",churn:"Frequently modified files are more prone to defects",history:"Previous defects in this area indicate higher risk",coverage:"Low test coverage increases undetected defect risk",coupling:"High coupling makes changes risky",age:"New code may have more defects than stable code"},Yt=class extends x{config={name:"qe/defects/predict",description:"Predict defect probability for files using ML models. Analyzes code complexity, change frequency, git history, and test coverage.",domain:"defect-intelligence",schema:Fo,streaming:!0,timeout:18e4};predictorService=null;async getService(e){if(!this.predictorService){let t=e.memory;t?this.predictorService=new wn(t):this.predictorService=new wn(await F())}return this.predictorService}async execute(e,t){let{files:n=[],threshold:r=.5,minConfidence:i=.7,features:s=[{name:"codeComplexity",weight:.25},{name:"changeFrequency",weight:.2},{name:"developerExperience",weight:.15},{name:"testCoverage",weight:.2},{name:"codeAge",weight:.1},{name:"bugHistory",weight:.1}]}=e;try{if(this.emitStream(t,{status:"analyzing",message:`Analyzing ${n.length||"provided"} files using ML-based prediction`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};if(this.isDemoMode(t))return this.markAsDemoData(t,"Demo mode explicitly requested"),this.getDemoResult(n);let a=await this.getService(t),o=await a.predictDefects({files:n,features:s.map(g=>({name:g.name,weight:g.weight??.25})),threshold:r});if(!o.success)return{success:!1,error:`Defect prediction failed: ${o.error?.message||"Service unavailable"}. Ensure the defect-intelligence domain is properly initialized.`};this.markAsRealData();let d=o.value.predictions.filter(g=>g.probability>=1-i).map(g=>({file:g.file,probability:Math.round(g.probability*100)/100,riskLevel:No(g.riskLevel),factors:g.factors.map(h=>({name:h.name,contribution:h.contribution,description:Xt[h.name]||`${h.name} contributes to defect risk`})),recommendations:g.recommendations}));d.sort((g,h)=>h.probability-g.probability);let m=Lo(d),p=await a.getModelMetrics();return this.emitStream(t,{status:"complete",message:`Analyzed ${n.length} files, ${d.length} with elevated risk`,progress:100}),{success:!0,data:{predictions:d,modelConfidence:o.value.modelConfidence,topRiskFactors:m,recommendations:Go(d),modelMetrics:{accuracy:p.accuracy,precision:p.precision,recall:p.recall,f1Score:p.f1Score}}}}catch(a){return{success:!1,error:`Defect prediction failed: ${w(a)}`}}}getDemoResult(e){let n=(e.length>0?e:["src/service.ts","src/handler.ts","src/utils.ts"]).map((r,i)=>({file:r,probability:Math.max(.9-i*.15,.35),riskLevel:i===0?"high":i===1?"medium":"low",factors:[{name:"codeComplexity",contribution:.35,description:Xt.codeComplexity},{name:"changeFrequency",contribution:.25,description:Xt.changeFrequency},{name:"testCoverage",contribution:.2,description:Xt.testCoverage}],recommendations:[`Increase test coverage for ${r}`,"Consider refactoring complex functions","Review recent changes for potential issues"]}));return{success:!0,data:{predictions:n,modelConfidence:.85,topRiskFactors:[{name:"High Complexity",impact:.35,affectedFiles:n.length},{name:"Frequent Changes",impact:.25,affectedFiles:Math.ceil(n.length*.7)},{name:"Low Coverage",impact:.2,affectedFiles:Math.ceil(n.length*.5)}],recommendations:["Focus testing on files with highest defect probability","Increase test coverage in high-risk areas","Review recent changes to frequently-modified files","Consider refactoring complex modules"],modelMetrics:{accuracy:.82,precision:.78,recall:.85,f1Score:.81}}}}resetInstanceCache(){this.predictorService=null}},Fo={type:"object",properties:{files:{type:"array",description:"Specific files to analyze",items:{type:"string",description:"File path"}},target:{type:"string",description:"Target directory to analyze",default:"."},lookback:{type:"number",description:"Days of history to consider",minimum:7,maximum:365,default:30},threshold:{type:"number",description:"Risk threshold for classification (0-1)",minimum:0,maximum:1,default:.5},minConfidence:{type:"number",description:"Minimum prediction confidence (0-1)",minimum:0,maximum:1,default:.7},features:{type:"array",description:"Features to use for prediction",items:{type:"object",description:"Prediction feature",properties:{name:{type:"string",description:"Feature name"},weight:{type:"number",description:"Feature weight"}}}}}};function No(u){switch(u){case"critical":return"critical";case"high":return"high";case"medium":return"medium";default:return"low"}}function Lo(u){let e=new Map;for(let n of u)for(let r of n.factors){let i=e.get(r.name)||{impact:0,count:0};i.impact+=r.contribution,i.count+=1,e.set(r.name,i)}let t=[];for(let[n,r]of e)t.push({name:qo(n),impact:Math.round(r.impact/r.count*100)/100,affectedFiles:r.count});return t.sort((n,r)=>r.impact-n.impact),t.slice(0,5)}function qo(u){return{codeComplexity:"High Complexity",changeFrequency:"Frequent Changes",bugHistory:"Bug History",testCoverage:"Low Coverage",developerExperience:"Developer Experience",codeAge:"Code Age"}[u]||u.replace(/([A-Z])/g," $1").trim()}function Go(u){let e=[],t=u.filter(i=>i.riskLevel==="critical").length,n=u.filter(i=>i.riskLevel==="high").length,r=u.length>0?u.reduce((i,s)=>i+s.probability,0)/u.length:0;return t>0&&(e.push(`CRITICAL: ${t} files require immediate attention`),e.push("Consider code review and comprehensive testing before deployment")),n>0&&(e.push(`High risk detected in ${n} files`),e.push("Increase test coverage in high-risk areas")),r>.5?(e.push("Overall defect risk is elevated - consider delaying release"),e.push("Run full regression test suite before deployment")):e.push("Focus testing on files with highest defect probability"),e.push("Review recent changes to frequently-modified files"),e.push("Consider refactoring complex modules"),[...new Set(e)]}k();var Jt=class extends x{config={name:"qe/requirements/validate",description:"Validate requirements for testability. Scores each requirement, detects ambiguity, and optionally generates BDD scenarios.",domain:"requirements-validation",schema:zo,streaming:!0,timeout:12e4};async execute(e,t){let{requirements:n,generateBDD:r=!1,checkAmbiguity:i=!0,minTestability:s=60}=e;try{if(this.emitStream(t,{status:"validating",message:`Validating ${n.length} requirements`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let a=[],o=[];for(let c of n){this.emitStream(t,{status:"processing",message:`Analyzing: ${c.title}`});let d=$o(c),m=Bo(c,s,d),p=i?Uo(c):void 0;a.push({requirementId:c.id,isValid:m.filter(g=>g.severity==="error").length===0,testabilityScore:d,errors:m,ambiguityReport:p}),r&&d.value>=s&&o.push(...Ho(c))}let l={total:n.length,valid:a.filter(c=>c.isValid).length,invalid:a.filter(c=>!c.isValid).length,avgTestability:a.reduce((c,d)=>c+d.testabilityScore.value,0)/n.length,blockers:a.filter(c=>c.errors.some(d=>d.severity==="error")).length};return this.emitStream(t,{status:"complete",message:`Validation complete: ${l.valid}/${l.total} valid`,progress:100}),{success:!0,data:{validationResults:a,summary:l,bddScenarios:o.length>0?o:void 0,recommendations:Vo(a)}}}catch(a){return{success:!1,error:`Validation failed: ${w(a)}`}}}},zo={type:"object",properties:{requirements:{type:"array",description:"Requirements to validate",items:{type:"object",description:"Requirement input",properties:{id:{type:"string",description:"Requirement ID"},title:{type:"string",description:"Requirement title"},description:{type:"string",description:"Requirement description"},acceptanceCriteria:{type:"array",description:"Acceptance criteria",items:{type:"string",description:"Criterion"}},type:{type:"string",description:"Requirement type",enum:["user-story","functional","non-functional","technical"]}},required:["id","title","description"]}},generateBDD:{type:"boolean",description:"Generate BDD scenarios from requirements",default:!1},checkAmbiguity:{type:"boolean",description:"Check for ambiguous language",default:!0},minTestability:{type:"number",description:"Minimum testability score (0-100)",minimum:0,maximum:100,default:60}},required:["requirements"]};function $o(u){let e=[],t=u.acceptanceCriteria&&u.acceptanceCriteria.length>0?90:40;e.push({name:"Acceptance Criteria",score:t,issues:t<70?["Missing or incomplete acceptance criteria"]:[]});let n=u.description.length,r=n>100?85:n>50?70:50;e.push({name:"Description Clarity",score:r,issues:r<70?["Description may be too brief"]:[]});let a=["should","must","when","then","verify","validate"].some(l=>u.description.toLowerCase().includes(l))?80:50;e.push({name:"Measurability",score:a,issues:a<70?["Requirement lacks measurable criteria"]:[]});let o=Math.round(e.reduce((l,c)=>l+c.score,0)/e.length);return{value:o,category:o>=80?"excellent":o>=70?"good":o>=50?"fair":"poor",factors:e}}function Bo(u,e,t){let n=[];return t.value<e&&n.push({code:"LOW_TESTABILITY",message:`Testability score ${t.value} is below minimum ${e}`,severity:"error",suggestion:"Add clear acceptance criteria and measurable outcomes"}),(!u.acceptanceCriteria||u.acceptanceCriteria.length===0)&&n.push({code:"MISSING_AC",message:"No acceptance criteria defined",severity:"warning",suggestion:"Define specific, testable acceptance criteria"}),u.description.length<30&&n.push({code:"BRIEF_DESC",message:"Description is too brief",severity:"warning",suggestion:"Expand description with more context and details"}),n}function Uo(u){let e=[],t=["some","few","many","fast","slow","good","better","appropriate"];for(let n of t)u.description.toLowerCase().includes(n)&&e.push({term:n,context:`Found in: "${u.description.substring(0,50)}..."`,alternatives:jo(n)});return{ambiguousTerms:e,overallScore:Math.max(0,100-e.length*15),suggestions:e.length>0?["Replace vague terms with specific, measurable criteria"]:["Requirement language is clear"]}}function jo(u){return{some:["exactly N","at least N","between N and M"],few:["1-3","less than 5"],many:["more than 10","at least N"],fast:["within X milliseconds","response time < Xs"],slow:["longer than X seconds"],good:["score >= 80%","passes all criteria"],better:["improves by X%","exceeds baseline by N"],appropriate:["meets requirement X","validates against schema"]}[u]||["Be more specific"]}function Ho(u){let e=[];return e.push({id:`scenario-${u.id}-1`,feature:u.title,scenario:`Verify ${u.title}`,given:["the system is initialized","the user is authenticated"],when:["the user performs the action"],then:["the expected outcome is observed","the system state is updated"],tags:["@generated",`@${u.type||"functional"}`]}),u.acceptanceCriteria&&u.acceptanceCriteria.length>0&&u.acceptanceCriteria.forEach((t,n)=>{e.push({id:`scenario-${u.id}-ac${n+1}`,feature:u.title,scenario:`Acceptance Criteria: ${t.substring(0,50)}`,given:["the preconditions are met"],when:["the specified action is taken"],then:[t],tags:["@generated","@acceptance"]})}),e}function Vo(u){let e=[],t=u.filter(r=>r.testabilityScore.value<60).length,n=u.filter(r=>r.errors.some(i=>i.code==="MISSING_AC")).length;return t>0&&e.push(`${t} requirements have low testability scores. Consider adding acceptance criteria.`),n>0&&e.push(`${n} requirements lack acceptance criteria. Define testable criteria for each.`),u.every(r=>r.isValid)&&e.push("All requirements are valid and testable."),e}import{existsSync as mr,readFileSync as ps}from"fs";import{join as pr,dirname as Qo}from"path";import{fileURLToPath as Wo}from"url";var De=["Capability","Reliability","Usability","Charisma","Security","Scalability","Compatibility","Performance","Installability","Development"],Ie=["Capability","Reliability","Security","Performance","Development"];var Ko=Wo(import.meta.url),Xo=Qo(Ko),Ve=class{config;templateCache=null;constructor(e={}){this.config={enableSemanticAnalysis:e.enableSemanticAnalysis??!0,defaultOutputFormat:e.defaultOutputFormat??"html",templatePath:e.templatePath??this.findTemplatePath(),minimumCategories:e.minimumCategories??8}}findTemplatePath(){let e=[pr(process.cwd(),".claude/helpers/v3/quality-criteria/quality-criteria-reference-template.html"),pr(process.cwd(),"node_modules/agentic-qe/assets/agents/v3/helpers/quality-criteria/quality-criteria-reference-template.html"),pr(Xo,"../../../../../assets/agents/v3/helpers/quality-criteria/quality-criteria-reference-template.html")];for(let t of e)if(mr(t))return t;return e[0]}analyze(e){let t=e.epicContent||"";if(e.epicPath&&mr(e.epicPath)&&(t=ps(e.epicPath,"utf-8")),!t&&!e.epicPath)throw new Error("Either epicPath or epicContent is required for analysis");return{agentInvocation:{required:!0,agentType:"qe-quality-criteria-recommender",prompt:this.buildAgentPrompt({assessmentName:e.assessmentName,epicContent:t,epicPath:e.epicPath,sourcePaths:e.sourcePaths,outputFormat:e.outputFormat,outputPath:e.outputPath}),timeout:3e5,expectedOutput:"QualityCriteriaAnalysis",instructions:`Claude Code MUST spawn the qe-quality-criteria-recommender agent with this prompt. The agent will perform real semantic HTSM analysis using Claude's reasoning capabilities. Use: Task("HTSM Quality Criteria Analysis", { prompt: <this prompt> }, "qe-quality-criteria-recommender")`},message:"AGENT INVOCATION REQUIRED: This service cannot perform semantic HTSM analysis alone. Claude Code must spawn the qe-quality-criteria-recommender agent with the provided prompt."}}buildAgentPrompt(e){let{assessmentName:t,epicContent:n,epicPath:r,sourcePaths:i,outputFormat:s,outputPath:a}=e,o=i&&i.length>0?`
|
|
416
|
+
`).run(t)}catch(t){console.warn("[CoverageLearner] Retention cleanup failed:",w(t))}}async learnFromSession(e){this.sessionStore.add(e),this.persistSession(e);let t=this.calculateOverallImprovement(e);if(t<this.config.minCoverageImprovementToLearn)return null;let n=await this.extractStrategy(e,t);return this.reasoningBank&&n&&await this.storeStrategyAsPattern(n),n}calculateOverallImprovement(e){let t=e.beforeCoverage,n=e.afterCoverage,r=n.lines-t.lines,i=n.branches-t.branches,s=n.functions-t.functions;return r*.4+i*.35+s*.25}async extractStrategy(e,t){let n=this.extractFilePattern(e.targetPath),r=`${e.technique}:${n}`,i=this.strategies.get(r);return i?i={...i,avgImprovement:(i.avgImprovement*i.successCount+t)/(i.successCount+1),successCount:i.successCount+1,confidence:Math.min(1,i.confidence+.05),lastUsedAt:new Date}:i={id:`strategy-${Date.now()}-${eo().slice(0,8)}`,description:this.generateStrategyDescription(e,t),technique:e.technique,filePatterns:[n],avgImprovement:t,successCount:1,confidence:.5,createdAt:new Date,lastUsedAt:new Date},this.strategies.set(r,i),i}extractFilePattern(e){let t=e.split("/"),r=t[t.length-1].split(".").pop()||"";return t.length>=2?`${t[t.length-2]}/*.${r}`:`*.${r}`}generateStrategyDescription(e,t){let r={"gap-analysis":"Identify and target uncovered code paths","branch-coverage":"Focus on branch conditions and decision points","edge-case-generation":"Generate tests for edge cases and boundary conditions","mutation-guided":"Use mutation testing to identify weak test areas","risk-based":"Prioritize high-risk code paths","semantic-analysis":"Use code semantics to generate meaningful tests","boundary-testing":"Test boundary conditions and limits","state-machine":"Model state transitions and test state changes","data-flow":"Follow data flow paths through the code"}[e.technique]||e.technique,i=e.gapsTargeted.filter(a=>a.addressed).length,s=e.gapsTargeted.length;return`${r} for ${this.extractFilePattern(e.targetPath)} files. Achieved ${t.toFixed(1)}% improvement. Addressed ${i}/${s} gaps with ${e.testsGenerated} tests.`}async storeStrategyAsPattern(e){this.reasoningBank&&await this.reasoningBank.storeQEPattern({patternType:"coverage-strategy",name:`Coverage Strategy: ${e.technique}`,description:e.description,template:{type:"workflow",content:JSON.stringify({technique:e.technique,filePatterns:e.filePatterns,avgImprovement:e.avgImprovement}),variables:[{name:"targetFile",type:"string",required:!0,description:"Target file to analyze"},{name:"currentCoverage",type:"number",required:!0,description:"Current coverage percentage"}]},context:{tags:["coverage",e.technique,...e.filePatterns]}})}getRecommendedStrategy(e){let t=this.extractFilePattern(e),n=null,r=0;for(let i of this.strategies.values())if(i.filePatterns.some(a=>t.includes(a.split("/").pop()||"")||a.includes(t.split("/").pop()||""))||i.filePatterns.length===0){let a=(Date.now()-i.lastUsedAt.getTime())/864e5,o=Math.max(.5,1-a/30),l=i.avgImprovement*i.confidence*o;l>r&&(r=l,n=i)}return n}getAllStrategies(){return Array.from(this.strategies.values())}getStrategiesByTechnique(e){return this.getAllStrategies().filter(t=>t.technique===e)}getSessionStats(){let e=this.sessionStore.getAll();if(e.length===0)return{totalSessions:0,successfulSessions:0,avgImprovement:0,byTechnique:new Map,strategiesLearned:0};let t=e.map(a=>this.calculateOverallImprovement(a)),n=t.filter(a=>a>=this.config.minCoverageImprovementToLearn).length,r=t.reduce((a,o)=>a+o,0)/t.length,i=new Map,s=new Map;for(let a of e){let o=s.get(a.technique)||[];o.push(a),s.set(a.technique,o)}for(let[a,o]of s){let l=o.map(c=>this.calculateOverallImprovement(c));i.set(a,{count:o.length,avgImprovement:l.reduce((c,d)=>c+d,0)/l.length})}return{totalSessions:e.length,successfulSessions:n,avgImprovement:r,byTechnique:i,strategiesLearned:this.strategies.size}}analyzeGapResolution(){let t=this.sessionStore.getAll().flatMap(i=>i.gapsTargeted);if(t.length===0)return{totalGapsTargeted:0,gapsAddressed:0,resolutionRate:0,byGapType:new Map};let n=t.filter(i=>i.addressed).length,r=new Map;for(let i of t){let s=r.get(i.type)||{targeted:0,addressed:0};s.targeted++,i.addressed&&s.addressed++,r.set(i.type,s)}return{totalGapsTargeted:t.length,gapsAddressed:n,resolutionRate:n/t.length,byGapType:r}}exportSessions(){return this.sessionStore.getAll()}importSessions(e){for(let t of e)this.sessionStore.add(t)}exportStrategies(){return this.getAllStrategies()}importStrategies(e){for(let t of e){let n=`${t.technique}:${t.filePatterns[0]||"*"}`;this.strategies.set(n,t)}}clear(){this.sessionStore.clear(),this.strategies.clear()}getLearnerStats(){return{totalSessions:this.sessionStore.size,totalStrategies:this.strategies.size,hasReasoningBank:this.reasoningBank!==null,minImprovementThreshold:this.config.minCoverageImprovementToLearn}}};function Pi(u){return new Zn(u)}var er=class{weights;historicalScores=[];maxHistory;constructor(e={},t=100){this.weights={...Wn,...e},this.maxHistory=t}calculateFromOutcome(e){let t=this.calculateDimensions(e),n=this.calculateOverall(t);return this.trackScore(n),{overall:n,dimensions:t,weights:this.weights,trend:this.calculateTrend(),calculatedAt:new Date}}calculateDimensions(e){return{effectiveness:this.calculateEffectiveness(e),coverage:this.calculateCoverageScore(e.coverage),mutationKill:e.mutationScore??.5,stability:this.calculateStability(e),maintainability:e.maintainabilityScore,performance:this.calculatePerformanceScore(e.executionTimeMs)}}calculateEffectiveness(e){return e.passed?e.flaky?.3:1:0}calculateCoverageScore(e){return(e.lines*.4+e.branches*.35+e.functions*.25)/100}calculateStability(e){return e.flaky?.2:e.flakinessScore!==void 0?1-e.flakinessScore:1}calculatePerformanceScore(e){return e<100?1:e<500?.8:e<2e3?.6:e<5e3?.4:e<1e4?.2:.1}calculateOverall(e){return this.weights.effectiveness*e.effectiveness+this.weights.coverage*e.coverage+this.weights.mutationKill*e.mutationKill+this.weights.stability*e.stability+this.weights.maintainability*e.maintainability+this.weights.performance*e.performance}trackScore(e){this.historicalScores.push(e),this.historicalScores.length>this.maxHistory&&(this.historicalScores=this.historicalScores.slice(-this.maxHistory))}calculateTrend(){if(this.historicalScores.length<10)return"stable";let e=this.historicalScores.slice(-10),t=this.historicalScores.slice(-20,-10);if(t.length===0)return"stable";let n=e.reduce((s,a)=>s+a,0)/e.length,r=t.reduce((s,a)=>s+a,0)/t.length,i=n-r;return i>.05?"improving":i<-.05?"declining":"stable"}calculateAggregate(e){if(e.length===0)return{overall:0,dimensions:{effectiveness:0,coverage:0,mutationKill:0,stability:0,maintainability:0,performance:0},weights:this.weights,trend:"stable",calculatedAt:new Date};let t={effectiveness:0,coverage:0,mutationKill:0,stability:0,maintainability:0,performance:0};for(let s of e){let a=this.calculateDimensions(s);t.effectiveness+=a.effectiveness,t.coverage+=a.coverage,t.mutationKill+=a.mutationKill,t.stability+=a.stability,t.maintainability+=a.maintainability,t.performance+=a.performance}let n=e.length,r={effectiveness:t.effectiveness/n,coverage:t.coverage/n,mutationKill:t.mutationKill/n,stability:t.stability/n,maintainability:t.maintainability/n,performance:t.performance/n};return{overall:this.calculateOverall(r),dimensions:r,weights:this.weights,trend:this.calculateTrend(),calculatedAt:new Date}}calculateDelta(e,t){let n={effectiveness:t.dimensions.effectiveness-e.dimensions.effectiveness,coverage:t.dimensions.coverage-e.dimensions.coverage,mutationKill:t.dimensions.mutationKill-e.dimensions.mutationKill,stability:t.dimensions.stability-e.dimensions.stability,maintainability:t.dimensions.maintainability-e.dimensions.maintainability,performance:t.dimensions.performance-e.dimensions.performance},r=t.overall-e.overall;return{overallDelta:r,dimensionDeltas:n,improved:r>0}}getRecommendations(e){let t=[],n=e.dimensions;return n.effectiveness<.8&&t.push("Improve test pass rate - investigate failing tests"),n.coverage<.7&&t.push("Increase code coverage - target uncovered paths"),n.mutationKill<.6&&t.push("Strengthen assertions - tests may be too weak"),n.stability<.9&&t.push("Address test flakiness - stabilize intermittent tests"),n.maintainability<.7&&t.push("Improve test maintainability - reduce complexity"),n.performance<.6&&t.push("Optimize test performance - reduce execution time"),t.length===0&&t.push("Quality is excellent - maintain current practices"),t}updateWeights(e){this.weights={...this.weights,...e}}getWeights(){return{...this.weights}}getStats(){let e=this.historicalScores.slice(-10),t=e.length>0?e.reduce((n,r)=>n+r,0)/e.length:0;return{scoresTracked:this.historicalScores.length,currentTrend:this.calculateTrend(),avgRecentScore:t}}clearHistory(){this.historicalScores=[]}};function xi(u,e){return new er(u,e)}var tr=class{criteria;promotionHistory=[];demotionHistory=[];reasoningBank=null;config;constructor(e={}){this.config={...ce,...e},this.criteria={...Kn}}connectReasoningBank(e){this.reasoningBank=e}evaluatePromotion(e,t){let n=e.tier,r=this.getNextTier(n);if(!r)return null;let i=this.criteria[r];if(this.meetsPromotionCriteria(t,i)){let s={patternId:e.id,fromTier:n,toTier:r,reason:this.generatePromotionReason(t,i),metrics:{successCount:t.successCount,successRate:t.successRate,qualityScore:t.qualityScore,ageDays:t.ageDays},timestamp:new Date};return this.promotionHistory.push(s),s}return null}evaluateDemotion(e,t){if(!this.config.autoDemote)return null;let n=e.tier;if(n==="short-term")return null;if(t.recentSuccessRate<.4||t.recentFailureCount>=5||t.qualityScore<.3){let i=this.getPreviousTier(n);if(!i)return null;let s={patternId:e.id,fromTier:n,toTier:i,reason:this.generateDemotionReason(t),metrics:{recentSuccessRate:t.recentSuccessRate,recentQualityScore:t.qualityScore,failureCount:t.recentFailureCount},timestamp:new Date};return this.demotionHistory.push(s),s}return null}async processPatternChange(e,t){let n=this.evaluateDemotion(e,t);if(n)return this.reasoningBank&&await this.reasoningBank.demotePattern(e.id),{action:"demoted",event:n};let r=this.evaluatePromotion(e,t);return r?(this.reasoningBank&&await this.reasoningBank.promotePattern(e.id),{action:"promoted",event:r}):{action:"unchanged"}}meetsPromotionCriteria(e,t){return e.successCount>=t.minSuccessCount&&e.successRate>=t.minSuccessRate&&e.qualityScore>=t.minQualityScore&&e.ageDays>=t.minAgeDays}getNextTier(e){let t=["short-term","working","long-term","permanent"],n=t.indexOf(e);return n<t.length-1?t[n+1]:null}getPreviousTier(e){let t=["short-term","working","long-term","permanent"],n=t.indexOf(e);return n>0?t[n-1]:null}generatePromotionReason(e,t){let n=[];return e.successCount>=t.minSuccessCount&&n.push(`${e.successCount} successful uses (>=${t.minSuccessCount})`),e.successRate>=t.minSuccessRate&&n.push(`${(e.successRate*100).toFixed(0)}% success rate (>=${t.minSuccessRate*100}%)`),e.qualityScore>=t.minQualityScore&&n.push(`${(e.qualityScore*100).toFixed(0)}% quality score (>=${t.minQualityScore*100}%)`),`Pattern promoted: ${n.join(", ")}`}generateDemotionReason(e){let t=[];return e.recentSuccessRate<.4&&t.push(`low recent success rate (${(e.recentSuccessRate*100).toFixed(0)}%)`),e.recentFailureCount>=5&&t.push(`${e.recentFailureCount} recent failures`),e.qualityScore<.3&&t.push(`low quality score (${(e.qualityScore*100).toFixed(0)}%)`),`Pattern demoted: ${t.join(", ")}`}updateCriteria(e,t){this.criteria[e]={...this.criteria[e],...t}}getCriteria(e){return{...this.criteria[e]}}getAllCriteria(){return{...this.criteria}}getPromotionHistory(e=100){return this.promotionHistory.slice(-e)}getDemotionHistory(e=100){return this.demotionHistory.slice(-e)}getStats(){let e={"short-term":0,working:0,"long-term":0,permanent:0};for(let s of this.promotionHistory)e[s.toTier]++;let t={"short-term":0,working:0,"long-term":0,permanent:0};for(let s of this.demotionHistory)t[s.toTier]++;let n=Date.now()-10080*60*1e3,r=this.promotionHistory.filter(s=>s.timestamp.getTime()>n).length,i=this.demotionHistory.filter(s=>s.timestamp.getTime()>n).length;return{totalPromotions:this.promotionHistory.length,totalDemotions:this.demotionHistory.length,promotionsByTier:e,demotionsByTier:t,recentPromotions:r,recentDemotions:i}}exportHistory(){return{promotions:[...this.promotionHistory],demotions:[...this.demotionHistory]}}importHistory(e){e.promotions&&this.promotionHistory.push(...e.promotions),e.demotions&&this.demotionHistory.push(...e.demotions)}clearHistory(){this.promotionHistory=[],this.demotionHistory=[]}};function Ai(u){return new tr(u)}var nr=class{outcomeTracker;coverageLearner;qualityCalculator;promotionManager;routingFeedback;reasoningBank=null;config;constructor(e={}){this.config={...ce,...e},this.outcomeTracker=Ri(this.config),this.coverageLearner=Pi(this.config),this.qualityCalculator=xi(this.config.qualityWeights),this.promotionManager=Ai(this.config),this.routingFeedback=Wr(this.config.maxOutcomesInMemory)}async initialize(){await Promise.all([this.outcomeTracker.initialize(),this.coverageLearner.initialize(),this.routingFeedback.initialize()])}connectReasoningBank(e){this.reasoningBank=e,this.outcomeTracker.connectReasoningBank(e),this.coverageLearner.connectReasoningBank(e),this.promotionManager.connectReasoningBank(e)}async recordTestOutcome(e){await this.outcomeTracker.track(e);let t=this.qualityCalculator.calculateFromOutcome(e),n;if(e.patternId&&this.reasoningBank){let r=await this.reasoningBank.searchQEPatterns(e.patternId,{limit:1});if(r.success&&r.value.length>0){let i=r.value[0].pattern,s=this.outcomeTracker.getPatternMetrics(e.patternId);if(s){let a=await this.promotionManager.processPatternChange(i,{patternId:e.patternId,successCount:s.successCount,failureCount:s.failureCount,successRate:s.successRate,qualityScore:s.avgQuality,ageDays:this.calculateAgeDays(i.createdAt),recentSuccessRate:this.calculateRecentSuccessRate(e.patternId),recentFailureCount:this.calculateRecentFailures(e.patternId)});n={action:a.action,tier:a.event&&"toTier"in a.event?a.event.toTier:void 0}}}}return{qualityScore:t,patternUpdate:n}}async recordCoverageSession(e){let t=await this.coverageLearner.learnFromSession(e);return{improvement:(e.afterCoverage.lines-e.beforeCoverage.lines+e.afterCoverage.branches-e.beforeCoverage.branches+e.afterCoverage.functions-e.beforeCoverage.functions)/3,strategyLearned:t!==null,strategyId:t?.id}}getRecommendedCoverageStrategy(e){return this.coverageLearner.getRecommendedStrategy(e)}getQualityRecommendations(){let e=this.outcomeTracker.getRecentOutcomes(50);if(e.length===0)return["No test outcomes recorded yet. Start tracking test results to get recommendations."];let t=this.qualityCalculator.calculateAggregate(e);return this.qualityCalculator.getRecommendations(t)}async recordRoutingOutcome(e){let t={id:e.taskId,description:e.taskDescription,complexity:"medium",domains:["test-generation"],context:{}},n={recommended:e.recommendedAgent,confidence:.8,reasoning:"Recorded from feedback",alternatives:[],scores:{similarity:.8,performance:.8,capabilities:.8,combined:.8},latencyMs:0,timestamp:e.timestamp};this.routingFeedback.recordOutcome(t,n,e.usedAgent,{success:e.success,qualityScore:e.qualityScore,durationMs:e.durationMs,error:e.error})}getRoutingAnalysis(){let e=this.routingFeedback.analyzeRoutingAccuracy(),t=this.routingFeedback.getImprovementRecommendations();return{totalOutcomes:e.totalOutcomes,recommendationFollowRate:1-e.overrideRate,successRateWhenFollowed:e.recommendationSuccessRate,successRateWhenOverridden:e.overrideSuccessRate,confidenceCorrelation:e.confidenceCorrelation,recommendations:t}}calculateAgeDays(e){return(Date.now()-e.getTime())/(1e3*60*60*24)}calculateRecentSuccessRate(e){let t=this.outcomeTracker.exportOutcomes().filter(r=>r.patternId===e).slice(-10);return t.length===0?0:t.filter(r=>r.passed&&!r.flaky).length/t.length}calculateRecentFailures(e){return this.outcomeTracker.exportOutcomes().filter(n=>n.patternId===e).slice(-10).filter(n=>!n.passed||n.flaky).length}getStats(){let e=this.outcomeTracker.getStats(),t=this.coverageLearner.getSessionStats(),n=this.promotionManager.getStats(),r=this.qualityCalculator.getStats(),i=this.outcomeTracker.getTrackerStats(),s=this.routingFeedback.analyzeRoutingAccuracy();return{testOutcomes:{total:e.totalTests,passRate:e.passRate,avgQuality:e.avgMaintainability,flakyCount:e.flakyTests},coverage:{totalSessions:t.totalSessions,successfulSessions:t.successfulSessions,avgImprovement:t.avgImprovement,strategiesLearned:t.strategiesLearned},patterns:{promoted:n.totalPromotions,demoted:n.totalDemotions,tracked:i.patternsTracked},quality:{currentTrend:r.currentTrend,avgRecentScore:r.avgRecentScore},routing:{totalOutcomes:s.totalOutcomes,recommendationFollowRate:1-s.overrideRate,successRateWhenFollowed:s.recommendationSuccessRate,successRateWhenOverridden:s.overrideSuccessRate},integrationStatus:{reasoningBankConnected:this.reasoningBank!==null}}}exportData(){return{outcomes:this.outcomeTracker.exportOutcomes(),sessions:this.coverageLearner.exportSessions(),strategies:this.coverageLearner.exportStrategies(),promotionHistory:this.promotionManager.exportHistory(),routingOutcomes:this.routingFeedback.exportOutcomes()}}importData(e){e.outcomes&&this.outcomeTracker.importOutcomes(e.outcomes),e.sessions&&this.coverageLearner.importSessions(e.sessions),e.strategies&&this.coverageLearner.importStrategies(e.strategies),e.promotionHistory&&this.promotionManager.importHistory(e.promotionHistory),e.routingOutcomes&&this.routingFeedback.importOutcomes(e.routingOutcomes)}clear(){this.outcomeTracker.clear(),this.coverageLearner.clear(),this.qualityCalculator.clearHistory(),this.promotionManager.clearHistory(),this.routingFeedback.clear()}};async function ki(u){let e=new nr(u);return await e.initialize(),Mi=e,e}var Mi=null;function Di(){return Mi}function ke(){return`test-${Ae()}`}function Oi(u){return`${u}-${Ae()}`}function qt(u){return{enabled:!0,agentId:Oi(u),message:"Experience captured asynchronously via learning pipeline"}}async function to(u,e,t,n,r){let i=Oi(u);try{let{kernel:s}=je();if(!s)return{enabled:!1,agentId:i,message:"Learning engine not available - kernel not initialized"};let a=await ro();if(!a)return{enabled:!1,agentId:i,message:"Learning engine not available"};let o=a.getExperienceCaptureService();if(!o)return{enabled:!1,agentId:i,message:"Experience capture service not available"};let l=no(e),c=o.startCapture(`${e}: ${JSON.stringify(t).slice(0,200)}`,{agent:u,domain:l||void 0,metadata:{tool:e,durationMs:r}});o.recordStep(c,{action:`execute-${e}`,result:typeof n=="object"?JSON.stringify(n).slice(0,500):String(n).slice(0,500),quality:.7});let d=await o.completeCapture(c,{success:!0,quality:.7});if(d.success){let m=d.value;return{enabled:!0,agentId:i,message:`Experience captured: ${m.id} (domain: ${l||"general"}, quality: ${m.quality})`,experienceId:m.id,domain:l||"general"}}return{enabled:!0,agentId:i,message:"Experience capture completed (no pattern extracted)"}}catch(s){return{enabled:!1,agentId:i,message:`Learning capture failed: ${w(s)}`}}}function no(u){return{test_generate_enhanced:"test-generation",test_execute_parallel:"test-execution",coverage_analyze_sublinear:"coverage-analysis",quality_assess:"quality-assessment",security_scan_comprehensive:"security-compliance",contract_validate:"contract-testing",accessibility_test:"visual-accessibility",chaos_test:"chaos-resilience",defect_predict:"defect-intelligence",requirements_validate:"requirements-validation",code_index:"code-intelligence"}[u]||null}async function ro(){return qi()}async function io(u,e,t,n){let r=Di();if(!r&&rr&&(r=await rr),!!r){if(u==="test-generation"&&e){let i=e.tests||e.generatedTests||[];for(let s of i.slice(0,20)){let a={id:String(s.id||Ae()),testId:String(s.id||s.name||Ae()),testName:String(s.name||s.testName||"generated-test"),generatedBy:"qe-test-generation",patternId:s.patternId,framework:s.framework||n.framework||"vitest",language:s.language||n.language||"typescript",domain:"test-generation",passed:s.passed!==!1,coverage:{lines:Number(s.coverageLines||0),branches:Number(s.coverageBranches||0),functions:Number(s.coverageFunctions||0)},executionTimeMs:Number(s.executionTimeMs||t/Math.max(i.length,1)),flaky:!!s.flaky,maintainabilityScore:Number(s.qualityScore||s.maintainability||.7),timestamp:new Date};await r.recordTestOutcome(a)}}if(u==="coverage-analysis"&&e){let i={id:Ae(),targetPath:String(n.target||n.targetPath||"src/"),agentId:"qe-coverage-analysis",technique:n.technique||"gap-analysis",beforeCoverage:{lines:Number(e.beforeCoverage?.lines||0),branches:Number(e.beforeCoverage?.branches||0),functions:Number(e.beforeCoverage?.functions||0)},afterCoverage:{lines:Number(e.lineCoverage||e.lines||0),branches:Number(e.branchCoverage||e.branches||0),functions:Number(e.functionCoverage||e.functions||0)},testsGenerated:Number(e.testsGenerated||0),testsPassed:Number(e.testsPassed||0),gapsTargeted:(e.gaps||[]).map((s,a)=>({id:String(s.id||`gap-${Ae().slice(0,8)}-${a}`),type:["uncovered-line","uncovered-branch","uncovered-function","partial-branch"].includes(String(s.type))?String(s.type):"uncovered-line",filePath:String(s.file||s.filePath||""),startLine:Number(s.line||s.startLine||0),endLine:s.endLine?Number(s.endLine):void 0,riskScore:Number(s.riskScore||.5),addressed:!!s.addressed})),durationMs:t,startedAt:new Date(Date.now()-t),completedAt:new Date};await r.recordCoverageSession(i)}}}function _i(u){let e=u.split(`
|
|
417
|
+
`).length,t=(u.match(/if|switch|for|while|catch/g)||[]).length;return{score:e+t*2,level:t>5?"high":t>2?"medium":"low"}}function Fi(u,e){let t=[];return u.level==="high"&&(t.push("Consider refactoring complex functions"),t.push("Add unit tests for each branch")),t.push("Consider adding edge case tests"),t.push("Add error handling tests"),e==="integration"&&(t.push("Add mock external dependencies"),t.push("Test API contract boundaries")),{recommendations:t,estimatedTime:`${Math.round(u.score*.5)} minutes`,confidence:.85}}function Li(u,e,t,n){let r=[],i=/(?:function\s+(\w+)|const\s+(\w+)\s*=|def\s+(\w+)|func\s+(\w+))/g,s=[],a;for(;(a=i.exec(u))!==null;){let l=a[1]||a[2]||a[3]||a[4];l&&s.push(l)}for(let l=0;l<Math.min(s.length,n);l++){let c=s[l]||"exampleFunction";r.push({id:ke(),name:`test_${c}_${l}`,type:e,parameters:[],assertions:[`${c}() === null`],expectedResult:null,estimatedDuration:e==="integration"?2e3:1e3,aiGenerated:!0})}(e==="integration"||n>s.length)&&r.push({id:ke(),name:`integration_ComponentA_${r.length}`,type:"integration",parameters:[],assertions:["ComponentA integration test passes"],expectedResult:null,estimatedDuration:2e3,aiGenerated:!0});let o=["high-complexity","deep-nesting","null-handling","empty-input"];for(let l=r.length;l<n&&l-r.length<o.length;l++)r.push({id:ke(),name:`edge_case_${o[l-r.length]}_${l}`,type:"unit",parameters:[],assertions:[`${o[l-r.length]} edge case handled`],expectedResult:null,estimatedDuration:1500,aiGenerated:!0});return r}function Ni(u,e){let t=[],n=u.split(`
|
|
418
|
+
`);return u.includes("eval(")&&t.push({type:"dangerous-eval",line:n.findIndex(r=>r.includes("eval("))+1,severity:"critical",suggestion:"Replace eval() with safer alternatives"}),u.includes("var ")&&(e==="javascript"||e==="typescript")&&t.push({type:"var-usage",line:n.findIndex(r=>r.includes("var "))+1,severity:"low",suggestion:"Use const or let instead of var"}),u.includes("any")&&e==="typescript"&&t.push({type:"any-type",line:n.findIndex(r=>r.includes("any"))+1,severity:"medium",suggestion:"Replace any with specific types"}),t}var Nt=null,rr=null,de=null;function so(){if(!Nt){let{kernel:u}=je();if(!u)throw new Error("Kernel not initialized");Nt=wi(u);let e=Nt;rr=ki().then(t=>(e.setQualityFeedbackLoop(t),t)).catch(t=>(console.warn("[HandlerFactory] Failed to initialize QualityFeedbackLoop:",t),null))}return Nt}async function qi(){if(de)return de;try{let{kernel:u}=je();if(!u)return null;let{createAQELearningEngine:e}=await import("./aqe-learning-engine-RZK22CJB.js"),t=u.memory;return de=e(t,{projectRoot:process.cwd(),enableClaudeFlow:!1}),await de.initialize(),de}catch(u){return console.debug("[HandlerFactory] Learning engine init failed:",w(u)),null}}async function ao(u,e){try{let t=await qi();if(!t)return[];let n=e,r=await t.searchPatterns(u,{limit:5,minConfidence:.4,domain:n,useVectorSearch:!0});return!r.success||r.value.length===0?[]:r.value.filter(i=>i.similarity>=.4).map(i=>({name:i.pattern.name,description:i.pattern.description,similarity:i.similarity,confidence:i.pattern.confidence,canReuse:i.canReuse,patternId:i.pattern.id}))}catch(t){return console.debug("[HandlerFactory] Pattern search failed:",w(t)),[]}}async function oo(u,e,t){try{let n=await ao(u,e);return n.length>0&&console.debug(`[HandlerFactory] Found ${n.length} relevant patterns for ${e}`),await(await Ot()).routeTask({task:u,domain:e,codeContext:t,agentType:`qe-${e}`,enablePatternSearch:!0,patternHints:n.length>0?n:void 0})}catch(n){return console.error(`[HandlerFactory] Routing failed for ${e}: ${n}`),null}}async function Ii(u,e,t,n){if(!(!u||u.length===0)&&de)try{for(let r of u)r.patternId&&await de.recordOutcome({patternId:r.patternId,success:e,metrics:{executionTimeMs:n},feedback:`Domain handler ${t} execution ${e?"succeeded":"failed"}`})}catch{}}function V(u){let{domain:e,taskType:t,priority:n="p1",defaultTimeout:r=18e4,buildTaskDescription:i,mapToPayload:s,mapToResult:a,calculateTimeout:o,includeCodeContext:l}=u;return async c=>{if(!Gi())return{success:!1,error:"Fleet not initialized. Call fleet_init first."};let{queen:d}=je(),m=null;try{let g=i(c),p=l?.(c);m=await oo(g,e,p);let h=s(c,m),f=o?.(c)??r,v=await d.submitTask({type:t,priority:n,targetDomains:[e],payload:h,timeout:f});if(!v.success)return{success:!1,error:v.error.message};let y=so(),C=d.getTaskStatus(v.value);if(!C)return{success:!1,error:"Task not found after submission"};let b=await y.execute(C.task);if(!b.success)return{success:!1,error:b.error||"Task execution failed"};let E=b.data,S=a(v.value,E,b.duration,b.savedFiles,c);Ii(m?.patternHints,!0,e,b.duration),to(`qe-${e}`,t,c,E,b.duration).catch(()=>{});try{await io(e,E,b.duration,c)}catch{}return{success:!0,data:S}}catch(g){let p=w(g);return Ii(m?.patternHints,!1,e,0),{success:!1,error:`Failed to ${t.replace(/-/g," ")}: ${p}`}}}}var Gt=class{taskMetrics=[];agentMetrics=new Map;resourceSnapshots=[];workerLoads=new Map;activeTasks=new Map;lastCpuUsage=null;snapshotInterval=null;initialized=!1;initialize(){this.initialized||(this.initialized=!0,this.lastCpuUsage=process.cpuUsage(),this.snapshotInterval=setInterval(()=>{this.takeResourceSnapshot()},1e3),this.snapshotInterval.unref&&this.snapshotInterval.unref())}shutdown(){this.snapshotInterval&&(clearInterval(this.snapshotInterval),this.snapshotInterval=null),this.initialized=!1}startTask(e,t){this.ensureInitialized();let n={taskId:e,agentId:t,startTime:process.hrtime(),success:!1,retries:0};this.activeTasks.set(e,n),this.updateWorkerLoad(t,1,0)}recordRetry(e){let t=this.activeTasks.get(e);t&&t.retries++}completeTask(e,t){let n=this.activeTasks.get(e);if(!n)return 0;n.endTime=process.hrtime(),n.success=t;let r=process.hrtime(n.startTime);return n.durationMs=r[0]*1e3+r[1]/1e6,this.updateAgentMetrics(n),this.updateWorkerLoad(n.agentId,-1,1),this.taskMetrics.push(n),this.taskMetrics.length>100&&this.taskMetrics.shift(),this.activeTasks.delete(e),n.durationMs}getCpuUsagePercent(){if(this.ensureInitialized(),!this.lastCpuUsage)return this.lastCpuUsage=process.cpuUsage(),0;let e=process.cpuUsage(this.lastCpuUsage);this.lastCpuUsage=process.cpuUsage();let t=e.user+e.system,r=1e3*1e3,i=t/r*100;return Math.min(100,Math.max(0,i))}getMemoryUsagePercent(){let e=process.memoryUsage(),t=e.heapUsed/e.heapTotal*100;return Math.min(100,Math.max(0,t))}getResourceStats(e){return{cpu:this.getCpuUsagePercent(),memory:this.getMemoryUsagePercent()}}getAgentTaskStats(e){let t=this.agentMetrics.get(e);if(!t||t.taskCount===0)return{tasksCompleted:0,averageTime:0,successRate:1};let n=t.tasksCompleted+t.tasksFailed,r=n>0?t.tasksCompleted/n:1,i=t.taskCount>0?t.totalDurationMs/t.taskCount:0;return{tasksCompleted:t.tasksCompleted,averageTime:Math.round(i),successRate:Math.min(1,Math.max(0,r))}}getWorkerEfficiency(){if(this.taskMetrics.length===0)return .85;let t=this.taskMetrics.filter(a=>a.success).length/this.taskMetrics.length,r=this.taskMetrics.reduce((a,o)=>a+o.retries,0)/this.taskMetrics.length,i=Math.min(.2,r*.1),s=t*(1-i);return Math.min(1,Math.max(0,s))}getLoadBalanceScore(){if(this.workerLoads.size===0)return .9;let e=Array.from(this.workerLoads.values()).map(a=>a.completedTaskCount);if(e.length<=1)return 1;let t=e.reduce((a,o)=>a+o,0)/e.length;if(t===0)return 1;let n=e.reduce((a,o)=>a+Math.pow(o-t,2),0)/e.length,s=1/(1+Math.sqrt(n)/t);return Math.min(1,Math.max(0,s))}getRetryStats(){let e=0,t=0,n=0;for(let r of this.agentMetrics.values())e+=r.totalRetries,t+=r.successfulRetries,n+=r.maxRetriesReached;return{totalRetries:e,successfulRetries:t,maxRetriesReached:n}}getAverageExecutionTime(){if(this.taskMetrics.length===0)return 0;let e=this.taskMetrics.reduce((t,n)=>t+(n.durationMs||0),0);return Math.round(e/this.taskMetrics.length)}getWorkersUsed(){return this.workerLoads.size}getTestDurations(e){let t=[];if(this.taskMetrics.length===0){for(let r=0;r<e;r++)t.push(100+r*10);return t}let n=this.taskMetrics.map(r=>r.durationMs||200).sort((r,i)=>r-i);for(let r=0;r<e;r++){let i=r%n.length;t.push(Math.round(n[i]))}return t}recordSuccessfulRetry(e){let t=this.agentMetrics.get(e);t&&t.successfulRetries++}recordMaxRetriesReached(e){let t=this.agentMetrics.get(e);t&&t.maxRetriesReached++}reset(){this.taskMetrics=[],this.agentMetrics.clear(),this.resourceSnapshots=[],this.workerLoads.clear(),this.activeTasks.clear(),this.lastCpuUsage=null}ensureInitialized(){this.initialized||this.initialize()}updateAgentMetrics(e){let t=this.agentMetrics.get(e.agentId);t||(t={agentId:e.agentId,tasksCompleted:0,tasksFailed:0,totalRetries:0,successfulRetries:0,maxRetriesReached:0,totalDurationMs:0,taskCount:0},this.agentMetrics.set(e.agentId,t)),e.success?(t.tasksCompleted++,e.retries>0&&t.successfulRetries++):t.tasksFailed++,t.totalRetries+=e.retries,t.totalDurationMs+=e.durationMs||0,t.taskCount++}updateWorkerLoad(e,t,n){let r=this.workerLoads.get(e);r||(r={workerId:e,activeTaskCount:0,completedTaskCount:0,lastActivityTime:Date.now()},this.workerLoads.set(e,r)),r.activeTaskCount=Math.max(0,r.activeTaskCount+t),r.completedTaskCount+=n,r.lastActivityTime=Date.now()}takeResourceSnapshot(){let e=process.memoryUsage(),t=process.cpuUsage(),n={timestamp:Date.now(),cpuUser:t.user,cpuSystem:t.system,memoryHeapUsed:e.heapUsed,memoryHeapTotal:e.heapTotal,memoryExternal:e.external,memoryRss:e.rss};this.resourceSnapshots.push(n),this.resourceSnapshots.length>60&&this.resourceSnapshots.shift()}},me=new Gt;xs();var $i=Object.keys(ht);function co(u){if(!u)return"typescript";let e=u.toLowerCase().trim(),t={ts:"typescript",js:"javascript",py:"python","c#":"csharp","c-sharp":"csharp",cs:"csharp",golang:"go",rs:"rust",kt:"kotlin"};return t[e]?t[e]:$i.includes(e)?e:null}var zi={domain:"test-generation",taskType:"generate-tests",priority:"p1",defaultTimeout:12e4,buildTaskDescription:u=>`Generate ${u.testType||"unit"} tests for ${u.language||"typescript"} code`,includeCodeContext:u=>u.sourceCode,mapToPayload:(u,e)=>{let t=co(u.language);if(t===null)throw new Error(`Unsupported language '${u.language}'. Supported languages: ${$i.join(", ")}. Open a feature request for additional language support.`);let n;if(u.framework){n=u.framework;let r=Ar[n];if(r&&r!==t){let i=s=>s==="javascript"||s==="typescript";if(!(i(r)&&i(t)))throw new Error(`Framework '${n}' targets ${r}, but language was '${t}'. Either pick a matching framework or omit \`framework\` to use the default (${ht[t]}).`)}}else n=ht[t];return{sourceCode:u.sourceCode,filePath:u.filePath,language:t,framework:n,testType:u.testType||"unit",coverageGoal:u.coverageGoal||80,aiEnhancement:u.aiEnhancement!==!1,detectAntiPatterns:u.detectAntiPatterns||!1,routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}},mapToResult:(u,e,t,n,r)=>{let i=r?.sourceCode||"",s=r?.language||"typescript",a=r?.testType||"unit",o=e.testsGenerated||6,l=_i(i),c=r?.aiEnhancement!==!1?Fi(l,a):{recommendations:[],estimatedTime:"0 minutes",confidence:0},d=r?.detectAntiPatterns?Ni(i,s):[],m=qt("test-generator"),g=e.tests,h=Array.isArray(g)&&g.length>0&&g[0].testCode?g.map((f,v)=>({id:ke(),name:f.name||`test_${v}`,type:f.type||a,parameters:[],assertions:f.testCode?lo(f.testCode):[`test assertion ${v}`],expectedResult:null,estimatedDuration:f.type==="integration"?2e3:1e3,aiGenerated:!0,testCode:f.testCode,sourceFile:f.sourceFile,testFile:f.testFile||f.file})):Li(i,a,s,o);return{tests:h,antiPatterns:d,suggestions:d.map(f=>`Fix: ${f.type} - ${f.suggestion}`),aiInsights:c,coverage:{predicted:e.coverageEstimate||r?.coverageGoal||80,confidence:.9,achievable:!0},properties:h.filter(f=>f.type==="property").map(f=>({name:f.name,invariant:"output_matches_expectation"})),language:s,complexity:l,learning:m,taskId:u,status:"completed",testsGenerated:h.length,coverageEstimate:e.coverageEstimate||r?.coverageGoal||80,patternsUsed:e.patternsUsed||["assertion-patterns","mock-generation","edge-case-detection"],duration:t,savedFiles:n}}},Bi={domain:"test-execution",taskType:"execute-tests",priority:"p1",defaultTimeout:3e5,buildTaskDescription:u=>`Execute ${u.testFiles?.length||0} test files with ${u.parallel!==!1?"parallel":"sequential"} execution`,mapToPayload:(u,e)=>({testFiles:u.testFiles||[],testSuites:u.testSuites||[],parallel:u.parallel!==!1,parallelism:u.parallelism||4,retryCount:u.retryCount||3,timeout:u.timeout||6e4,collectCoverage:u.collectCoverage||!1,reportFormat:u.reportFormat||"json",routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),calculateTimeout:u=>u.timeout||3e5,mapToResult:(u,e,t,n,r)=>{let i=e.total||0,s=e.passed||0,a=e.failed||0,o=e.coverage,l=r?.parallelism||4,c=me.getRetryStats(),d=me.getWorkersUsed(),m={workersUsed:d>0?d:Math.min(l,i||1),efficiency:me.getWorkerEfficiency(),loadBalance:me.getLoadBalanceScore(),avgExecutionTime:t/Math.max(i,1)},g={totalRetries:c.totalRetries,successfulRetries:c.successfulRetries,maxRetriesReached:c.maxRetriesReached},p=qt("test-executor");return{workerStats:m,retryStats:g,results:(()=>{let h=me.getTestDurations(i);return Array.from({length:i},(f,v)=>({id:ke(),name:`test_case_${v}`,status:v<s?"passed":"failed",duration:h[v]||200,retries:0}))})(),summary:{totalTests:i,passRate:i>0?s/i*100:0,avgDuration:t/Math.max(i,1),parallelEfficiency:m.efficiency},learning:p,taskId:u,status:"completed",total:i,passed:s,failed:a,duration:t,coverage:o,savedFiles:n}}},ji={domain:"coverage-analysis",taskType:"analyze-coverage",priority:"p1",defaultTimeout:18e4,buildTaskDescription:u=>`Analyze coverage for ${u.target||"project"} with gap detection`,mapToPayload:(u,e)=>({target:u.target||".",includeRisk:u.includeRisk||!1,detectGaps:u.detectGaps!==!1,mlPowered:u.mlPowered||!1,prioritization:u.prioritization||"complexity",routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>{let r=e.summary,i=r?.line??e.lineCoverage??0,s=r?.branch??e.branchCoverage??0,a=r?.function??e.functionCoverage??0,o=r?.statement??e.statementCoverage??i,l=r?.files??e.totalFiles??0,c=e.gaps||[],d=qt("coverage-analyzer"),m=c.map((h,f)=>{let v=h;return v?.file?{id:`gap-${Date.now()}-${f}`,file:v.file,line:v.lines?.[0]||0,uncoveredLines:v.lines||[],type:v.type||"uncovered-line",severity:v.severity||"medium",reason:v.reason||"Missing test case",priority:v.priority||"medium",suggestion:v.suggestedTest||"Add test coverage",suggestedTest:v.suggestedTest||"Add test coverage",riskScore:v.riskScore||.5,confidence:v.confidence||.7}:null}).filter(h=>h!==null),g=e.coverageByFile;return{coverageByFile:g?g.map(h=>({file:h.file,lineCoverage:h.lineCoverage||0,branchCoverage:h.branchCoverage||0,functionCoverage:h.functionCoverage||0})):[],gapAnalysis:{totalGaps:m.length,highPriority:m.filter(h=>h.priority==="high").length,gaps:m},trends:{lineCoverageTrend:l>0?"stable":"no-data",branchCoverageTrend:l>0?"stable":"no-data",weeklyChange:0},aiInsights:l>0?{recommendations:e.recommendations||["Run tests with coverage enabled to get accurate metrics"],riskAssessment:i<70?"high":i<85?"medium":"low",confidence:.88}:{recommendations:["No coverage data found. Run tests with coverage first (e.g., npm test -- --coverage, or pytest --cov)"],riskAssessment:"unknown",confidence:0},learning:d,taskId:u,status:"completed",lineCoverage:i,branchCoverage:s,functionCoverage:a,statementCoverage:o,totalFiles:l,gaps:m,duration:t,savedFiles:n}}},Ui={domain:"quality-assessment",taskType:"assess-quality",priority:"p0",defaultTimeout:18e4,buildTaskDescription:u=>`Assess quality with ${u.runGate?"quality gate":"metrics analysis"}`,mapToPayload:(u,e)=>({runGate:u.runGate||!1,threshold:u.threshold||80,metrics:u.metrics||["coverage","complexity","maintainability"],routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",qualityScore:e.qualityScore||0,passed:e.passed||!1,metrics:e.metrics||{},recommendations:e.recommendations||[],duration:t,savedFiles:n})},Hi={domain:"security-compliance",taskType:"scan-security",priority:"p0",defaultTimeout:6e5,buildTaskDescription:u=>{let e=[];return u.sast!==!1&&e.push("SAST"),u.dast&&e.push("DAST"),`Security scan (${e.join(", ")}) for ${u.target||"project"}`},mapToPayload:(u,e)=>({sast:u.sast!==!1,dast:u.dast||!1,compliance:u.compliance||[],target:u.target||".",routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",vulnerabilities:e.vulnerabilities||0,critical:e.critical||0,high:e.high||0,medium:e.medium||0,low:e.low||0,topVulnerabilities:e.topVulnerabilities||[],recommendations:e.recommendations||[],duration:t,savedFiles:n})},Vi={domain:"contract-testing",taskType:"validate-contracts",priority:"p1",defaultTimeout:18e4,buildTaskDescription:u=>`Validate API contract at ${u.contractPath}`,mapToPayload:(u,e)=>({contractPath:u.contractPath,providerUrl:u.providerUrl,consumerName:u.consumerName,checkBreakingChanges:u.checkBreakingChanges!==!1,routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",valid:e.valid||!1,breakingChanges:e.breakingChanges||[],warnings:e.warnings||[],duration:t,savedFiles:n})},Qi={domain:"visual-accessibility",taskType:"test-accessibility",priority:"p1",defaultTimeout:18e4,buildTaskDescription:u=>`Test accessibility for ${u.url} against ${u.standard||"WCAG 2.1 AA"} standard`,mapToPayload:(u,e)=>({url:u.url,standard:u.standard||"wcag21-aa",includeScreenReader:u.includeScreenReader||!1,routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",passed:e.passed||!1,score:e.score||0,violations:e.violations||[],warnings:e.warnings||[],duration:t,savedFiles:n})},Wi={domain:"chaos-resilience",taskType:"run-chaos",priority:"p2",defaultTimeout:9e4,buildTaskDescription:u=>`Run chaos test with ${u.faultType||"latency"} fault injection on ${u.target}`,mapToPayload:(u,e)=>({faultType:u.faultType||"latency",target:u.target,duration:u.duration||3e4,intensity:u.intensity||50,dryRun:u.dryRun!==!1,routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),calculateTimeout:u=>(u.duration||3e4)+6e4,mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",faultType:e.faultType||"latency",resilience:e.resilience||{recovered:!1,recoveryTime:0,dataLoss:!1},duration:t,savedFiles:n})},Ki={domain:"defect-intelligence",taskType:"predict-defects",priority:"p1",defaultTimeout:18e4,buildTaskDescription:u=>`Predict defects in ${u.target||"codebase"} with ${u.lookback||30} day lookback`,mapToPayload:(u,e)=>({target:u.target||".",lookback:u.lookback||30,minConfidence:u.minConfidence||.7,routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",predictedDefects:e.predictedDefects||[],riskScore:e.riskScore||0,recommendations:e.recommendations||[],duration:t,savedFiles:n})},Xi={domain:"requirements-validation",taskType:"validate-requirements",priority:"p1",defaultTimeout:18e4,buildTaskDescription:u=>`Validate requirements${u.generateBDD?" and generate BDD scenarios":""}`,mapToPayload:(u,e)=>({requirementsPath:u.requirementsPath,testPath:u.testPath,generateBDD:u.generateBDD||!1,routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",requirementsAnalyzed:e.requirementsAnalyzed||0,testable:e.testable||0,coverage:e.coverage||0,bddScenarios:e.bddScenarios||[],duration:t,savedFiles:n})},Yi={domain:"code-intelligence",taskType:"index-code",priority:"p2",defaultTimeout:3e5,buildTaskDescription:u=>`Index code in ${u.target||"codebase"}${u.incremental?" incrementally":""}`,mapToPayload:(u,e)=>({target:u.target||".",incremental:u.incremental||!1,gitSince:u.gitSince,routingTier:e?.decision.tier,useAgentBooster:e?.useAgentBooster,compiledContext:e?.compiledContext}),mapToResult:(u,e,t,n)=>({taskId:u,status:"completed",filesIndexed:e.filesIndexed||0,symbolsExtracted:e.symbolsExtracted||0,relationsFound:e.relationsFound||0,duration:t,savedFiles:n})};function lo(u){let e=[],t=u.split(`
|
|
419
|
+
`);for(let n of t){let r=n.trim(),i=r.match(/expect\((.+?)\)\.(to\w+)\((.+?)\)/);if(i){e.push(`expect(${i[1]}).${i[2]}(${i[3]})`);continue}let s=r.match(/assert\w*\((.+)\)/);if(s){e.push(s[0]);continue}let a=r.match(/(?:it|test)\s*\(\s*['"`](.+?)['"`]/);a&&e.push(a[1])}return e.length>0?e:["test generated from source analysis"]}var Hp=V(zi),Vp=V(Bi),Qp=V(ji),Wp=V(Ui),Kp=V(Hi),Xp=V(Vi),Yp=V(Qi),Jp=V(Wi),Zp=V(Ki),eg=V(Xi),tg=V(Yi);k();var $t=class extends P{config={name:"qe/tests/generate",description:"Generate tests for source code files. Supports unit, integration, and e2e tests with AI-powered pattern recognition.",domain:"test-generation",schema:uo,streaming:!0,timeout:12e4};testGeneratorService=null;async getService(){if(!this.testGeneratorService){let e=await F();this.testGeneratorService=kr(e,{defaultFramework:"vitest",maxTestsPerFile:50,coverageTargetDefault:80,enableAIGeneration:!0})}return this.testGeneratorService}async execute(e,t){let{sourceFiles:n,testType:r="unit",framework:i="vitest",language:s="typescript",coverageTarget:a=80,patterns:o=[],aiEnhancement:l=!0,detectAntiPatterns:c=!1}=e;try{if(this.emitStream(t,{status:"analyzing",message:`Analyzing ${n.length} source files`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};if(En.isEnabled()){let v=`Generate ${r} tests for ${n.length} files using ${i}`,y=await En.checkTaskEarlyExit(v,"test-generation");y.canExit&&y.reusedPattern&&(this.emitStream(t,{status:"pattern-reuse",message:`Reusing pattern: ${y.reusedPattern.name}`,tokensSaved:y.estimatedTokensSaved}),console.log(`[TestGenerateTool] Early exit: reusing pattern ${y.reusedPattern.name}, saving ~${y.estimatedTokensSaved} tokens`))}let d=await this.getService(),m={sourceFiles:n,testType:r,framework:i,coverageTarget:a,patterns:o},g=await d.generateTests(m);if(!g.success)return{success:!1,error:g.error?.message||"Test generation failed"};let p=g.value,h=p.tests.map(v=>({id:v.id,name:v.name,sourceFile:v.sourceFile,testFile:v.testFile,testCode:v.testCode,type:v.type,assertions:v.assertions}));this.emitStream(t,{status:"generating",message:`Generated ${h.length} test files`,progress:50});let f=c?mo(n):[];return this.emitStream(t,{status:"complete",message:"Test generation complete",progress:100}),{success:!0,data:{tests:h,coverageEstimate:p.coverageEstimate,patternsUsed:p.patternsUsed,suggestions:ho(h,l),antiPatterns:f.length>0?f:void 0}}}catch(d){return{success:!1,error:`Test generation failed: ${w(d)}`}}}resetInstanceCache(){this.testGeneratorService=null}},uo={type:"object",properties:{sourceFiles:{type:"array",description:"Array of source file paths to generate tests for",items:{type:"string",description:"File path"}},testType:{type:"string",description:"Type of tests to generate",enum:["unit","integration","e2e"],default:"unit"},framework:{type:"string",description:"Test framework to use",enum:["jest","vitest","mocha","pytest"],default:"vitest"},language:{type:"string",description:"Programming language of source files",enum:["typescript","javascript","python","java","go"],default:"typescript"},coverageTarget:{type:"number",description:"Target code coverage percentage (0-100)",minimum:0,maximum:100,default:80},patterns:{type:"array",description:"Test patterns to apply",items:{type:"string",description:"Pattern name"}},aiEnhancement:{type:"boolean",description:"Enable AI-powered test enhancement",default:!0},detectAntiPatterns:{type:"boolean",description:"Detect and report anti-patterns in source code",default:!1}},required:["sourceFiles"]};function mo(u){let e=[],t=Ss("fs");for(let n of u)try{let r;try{r=t.readFileSync(n,"utf-8")}catch{continue}let i=r.split(`
|
|
420
|
+
`),s=/(?<![\w.])(\d{2,}|[2-9]\d*)(?![\w.])/g,a=new Set(["10","100","1000","60","24","365","404","500","200","201"]);i.forEach((p,h)=>{if(p.trim().startsWith("//")||p.trim().startsWith("*")||p.includes("import")||p.includes("require"))return;let f=p.match(s);if(f)for(let v of f){if(a.has(v))continue;let y=p.substring(0,p.indexOf(v)),C=(y.match(/'/g)||[]).length,b=(y.match(/"/g)||[]).length,E=(y.match(/`/g)||[]).length;if(!(C%2===1||b%2===1||E%2===1)){e.push({name:"magic-number",location:`${n}:${h+1}`,severity:"medium",suggestion:`Consider extracting ${v} into a named constant to improve readability and maintainability`});break}}});let o=/(?:it|test)\s*\(\s*['"`]([^'"`]+)['"`]\s*,/g,l;for(;(l=o.exec(r))!==null;){let p=l.index,h=l[1],f=r.substring(p),v=po(f);if(v){let y=/expect\s*\(/.test(v),C=/assert[\.\(]/.test(v),b=/\.should[\.\(]/.test(v),E=/\.toBe|\.toEqual|\.toMatch|\.toThrow|\.toContain/.test(v);if(!y&&!C&&!b&&!E){let S=r.substring(0,p).split(`
|
|
421
|
+
`).length;e.push({name:"no-assertions",location:`${n}:${S}`,severity:"high",suggestion:`Test "${h}" has no assertions. Add expect() or assert() calls to verify behavior`})}}}let c=[{pattern:/let\s+\w+\s*=\s*(?!undefined|null)/g,name:"mutable-let-declaration"},{pattern:/(?:^|\s)var\s+\w+\s*=/g,name:"mutable-var-declaration"}],d=r.match(/describe\s*\([^)]+,\s*(?:function\s*\(\)|(?:\(\s*\))?\s*=>)\s*\{/g);if(d)for(let p of d){let h=r.indexOf(p),f=go(r.substring(h));if(f){let v=f.match(/^\s*let\s+(\w+)\s*(?::\s*\w+)?\s*(?:=|;)/m);if(v){let y=v[1];if((f.match(new RegExp(`(?:it|test)\\s*\\([^)]+,[^]*?${y}\\s*=`,"g"))||[]).length>=2){let b=r.substring(0,h+f.indexOf(v[0])).split(`
|
|
422
|
+
`).length;e.push({name:"test-interdependence",location:`${n}:${b}`,severity:"high",suggestion:`Shared mutable variable '${y}' is modified in multiple tests, causing test interdependence. Use beforeEach to reset state or isolate test data`})}}}}if(/\.test\.|\.spec\./.test(n)){let p=r.match(/import\s+.*from\s+['"].*(?:\.test|\.spec)['"]/g);p&&p.length>0&&e.push({name:"test-importing-tests",location:n,severity:"medium",suggestion:"Test file imports from another test file. Extract shared test utilities to a separate module"})}let m=/(?:it|test|describe)\s*\(\s*['"`]([^'"`]{100,})['"`]/g,g;for(;(g=m.exec(r))!==null;){let p=r.substring(0,g.index).split(`
|
|
423
|
+
`).length;e.push({name:"long-test-description",location:`${n}:${p}`,severity:"low",suggestion:"Test description is too long. Consider breaking into smaller, focused tests or using a more concise description"})}if(/setTimeout|setInterval/.test(r)&&!/useFakeTimers|fakeTimers|clock/.test(r)){let h=r.match(/setTimeout|setInterval/);if(h){let f=r.substring(0,r.indexOf(h[0])).split(`
|
|
424
|
+
`).length;e.push({name:"real-timers-in-tests",location:`${n}:${f}`,severity:"medium",suggestion:"Using real timers in tests can cause flakiness. Consider using fake timers (jest.useFakeTimers() or vi.useFakeTimers())"})}}}catch{continue}return e}function po(u){let e=0,t=-1,n=-1;for(let r=0;r<u.length;r++)if(u[r]==="{")t===-1&&(t=r),e++;else if(u[r]==="}"&&(e--,e===0&&t!==-1)){n=r;break}return t!==-1&&n!==-1?u.substring(t+1,n):null}function go(u){let e=0,t=-1,n=-1;for(let r=0;r<u.length;r++)if(u[r]==="{")t===-1&&(t=r),e++;else if(u[r]==="}"&&(e--,e===0&&t!==-1)){n=r;break}return t!==-1&&n!==-1?u.substring(t+1,n):null}function ho(u,e){let t=[];return u.length===0&&t.push("No tests generated. Ensure source files are valid."),e&&(t.push("Consider adding property-based tests for edge case coverage"),t.push("Parameterized tests can reduce duplication")),t}k();Ge();var zt=class extends P{config={name:"qe/tests/execute",description:"Execute test suites with parallel execution, retry logic, and coverage collection. Detects flaky tests.",domain:"test-execution",schema:fo,streaming:!0,timeout:3e5};async execute(e,t){let{testFiles:n=[],testSuites:r=[],pattern:i,parallel:s=!0,parallelism:a=4,retryCount:o=3,timeout:l=6e4,collectCoverage:c=!1,reportFormat:d="json",failFast:m=!1}=e,g=Date.now();try{let p=n.length>0?n:r.length>0?r:i?[i]:["**/*.test.ts"];if(this.emitStream(t,{status:"starting",message:`Executing ${p.length} test files`,parallel:s,parallelism:a}),this.isAborted(t))return{success:!1,error:"Test execution aborted"};let h=[],f=[];for(let b=0;b<p.length;b++){let E=p[b];this.emitStream(t,{status:"running",message:`Executing ${E}`,progress:Math.round(b/p.length*100)});let S=J()>.1,T={id:`test-${b}`,name:`Test suite for ${E.split("/").pop()}`,file:E,status:S?"passed":"failed",duration:J()*5e3,error:S?void 0:"Assertion failed",retries:S?0:Math.min(o,2)};if(h.push(T),!S&&J()>.7&&f.push({name:T.name,file:T.file,flakinessScore:Z(.5,1),failurePattern:"intermittent-timeout"}),m&&!S)break}let v={total:h.length,passed:h.filter(b=>b.status==="passed").length,failed:h.filter(b=>b.status==="failed").length,skipped:h.filter(b=>b.status==="skipped").length,pending:h.filter(b=>b.status==="pending").length,passRate:0};v.passRate=v.total>0?Math.round(v.passed/v.total*100):0;let y=c?{lines:Z(70,100),branches:Z(60,80),functions:Z(65,90),statements:Z(70,95)}:void 0,C=Date.now()-g;return this.emitStream(t,{status:"complete",message:`Test execution complete: ${v.passed}/${v.total} passed`,progress:100}),{success:v.failed===0,data:{summary:v,testResults:h,coverage:y,flakyTests:f.length>0?f:void 0,duration:C}}}catch(p){return{success:!1,error:`Test execution failed: ${w(p)}`}}}},fo={type:"object",properties:{testFiles:{type:"array",description:"Specific test files to execute",items:{type:"string",description:"Test file path"}},testSuites:{type:"array",description:"Test suite names to execute",items:{type:"string",description:"Suite name"}},pattern:{type:"string",description:"Glob pattern to match test files"},parallel:{type:"boolean",description:"Enable parallel test execution",default:!0},parallelism:{type:"number",description:"Number of parallel workers",minimum:1,maximum:16,default:4},retryCount:{type:"number",description:"Number of retries for failed tests",minimum:0,maximum:5,default:3},timeout:{type:"number",description:"Test timeout in milliseconds",minimum:1e3,default:6e4},collectCoverage:{type:"boolean",description:"Collect code coverage",default:!1},reportFormat:{type:"string",description:"Report output format",enum:["json","junit","html","markdown"],default:"json"},failFast:{type:"boolean",description:"Stop on first failure",default:!1},watch:{type:"boolean",description:"Watch mode for continuous testing",default:!1}}};j();import*as Q from"fs/promises";import*as A from"path";async function ir(u,e){let t=await Q.readFile(u,"utf-8");return is(t,e||A.dirname(u))}function is(u,e){let t=new Map,n=u.split(`
|
|
425
|
+
`),r=null,i=new Map,s=[],a=[],o=0,l=0,c=0,d=0,m=0,g=0;for(let p of n){let h=p.trim();if(h.startsWith("SF:")){let f=h.slice(3);r={path:f,relativePath:A.relative(e,f)},i=new Map,s=[],a=[],o=0,l=0,c=0,d=0,m=0,g=0}else if(h.startsWith("DA:")){let[f,v]=h.slice(3).split(",").map(Number);!isNaN(f)&&!isNaN(v)&&(i.set(f,v),o++,v>0&&l++)}else if(h.startsWith("LF:")){let f=parseInt(h.slice(3),10);isNaN(f)||(o=f)}else if(h.startsWith("LH:")){let f=parseInt(h.slice(3),10);isNaN(f)||(l=f)}else if(h.startsWith("BRDA:")){let f=h.slice(5).split(",");if(f.length>=4){let v=parseInt(f[0],10),y=parseInt(f[1],10),C=parseInt(f[2],10),b=f[3]==="-"?0:parseInt(f[3],10);s.push({line:v,block:y,branch:C,taken:b>0,hits:b}),c++,b>0&&d++}}else if(h.startsWith("BRF:")){let f=parseInt(h.slice(4),10);isNaN(f)||(c=f)}else if(h.startsWith("BRH:")){let f=parseInt(h.slice(4),10);isNaN(f)||(d=f)}else if(h.startsWith("FN:")){let f=h.indexOf(",",3);if(f>0){let v=parseInt(h.slice(3,f),10),y=h.slice(f+1);a.find(b=>b.name===y)||a.push({name:y,line:v,hits:0})}}else if(h.startsWith("FNDA:")){let f=h.indexOf(",",5);if(f>0){let v=parseInt(h.slice(5,f),10),y=h.slice(f+1),C=a.find(b=>b.name===y);C?C.hits=v:a.push({name:y,line:0,hits:v}),m++,v>0&&g++}}else if(h.startsWith("FNF:")){let f=parseInt(h.slice(4),10);isNaN(f)||(m=f)}else if(h.startsWith("FNH:")){let f=parseInt(h.slice(4),10);isNaN(f)||(g=f)}else if(h==="end_of_record"&&r?.path){let f=Array.from(i.entries()).filter(([,b])=>b===0).map(([b])=>b).sort((b,E)=>b-E),v=s.filter(b=>!b.taken),y=a.filter(b=>b.hits===0).map(b=>b.name),C={path:r.path,relativePath:r.relativePath||r.path,lines:{total:o,covered:l,percentage:o>0?l/o*100:0,details:i,uncoveredLines:f},branches:{total:c,covered:d,percentage:c>0?d/c*100:0,uncoveredBranches:v},functions:{total:m,covered:g,percentage:m>0?g/m*100:0,details:a,uncoveredFunctions:y},statements:{total:o,covered:l,percentage:o>0?l/o*100:0},coveragePercentage:or(l,o,d,c)};t.set(r.path,C),r=null}}return{timestamp:new Date,format:"lcov",files:t,summary:pe(t)}}async function sr(u,e){let t=await Q.readFile(u,"utf-8"),n=x(t),r=e||A.dirname(u),i=new Map;for(let[s,a]of Object.entries(n)){if(typeof a!="object"||!a.statementMap)continue;let o=new Map,l=[],c=0,d=0;for(let[b,E]of Object.entries(a.s||{})){let S=a.statementMap[b];if(S?.start?.line){let T=S.start.line,R=o.get(T)||0;o.set(T,R+E)}c++,E>0&&d++}for(let[b,E]of o.entries())E===0&&l.push(b);let m=[],g=0,p=0;for(let[b,E]of Object.entries(a.branchMap||{})){let S=a.b?.[b]||[];for(let T=0;T<S.length;T++)m.push({line:E.loc?.start?.line||0,block:parseInt(b,10),branch:T,taken:S[T]>0,hits:S[T]}),g++,S[T]>0&&p++}let h=[],f=0,v=0;for(let[b,E]of Object.entries(a.fnMap||{})){let S=a.f?.[b]||0;h.push({name:E.name||`anonymous_${b}`,line:E.loc?.start?.line||E.decl?.start?.line||0,hits:S}),f++,S>0&&v++}let y=o.size,C=Array.from(o.values()).filter(b=>b>0).length;i.set(s,{path:s,relativePath:A.relative(r,s),lines:{total:y,covered:C,percentage:y>0?C/y*100:0,details:o,uncoveredLines:l.sort((b,E)=>b-E)},branches:{total:g,covered:p,percentage:g>0?p/g*100:0,uncoveredBranches:m.filter(b=>!b.taken)},functions:{total:f,covered:v,percentage:f>0?v/f*100:0,details:h,uncoveredFunctions:h.filter(b=>b.hits===0).map(b=>b.name)},statements:{total:c,covered:d,percentage:c>0?d/c*100:0},coveragePercentage:or(C,y,p,g)})}return{timestamp:new Date,format:"json",files:i,summary:pe(i)}}async function Ji(u,e){let t=await Q.readFile(u,"utf-8");return Bt(t,e||A.dirname(u))}function Bt(u,e){let t=new Map,n=/<package\s+name="([^"]*)">([\s\S]*?)<\/package>/g,r;for(;(r=n.exec(u))!==null;){let i=r[1].replace(/\//g,A.sep),s=r[2],a=/<sourcefile\s+name="([^"]*)">([\s\S]*?)<\/sourcefile>/g,o;for(;(o=a.exec(s))!==null;){let l=o[1],c=o[2],d=A.join(e,i,l),m=yo(c),g=new Map,p=/<line\s+nr="(\d+)"\s+mi="(\d+)"\s+ci="(\d+)"/g,h;for(;(h=p.exec(c))!==null;){let v=parseInt(h[1],10),y=parseInt(h[3],10);g.set(v,y)}let f=Array.from(g.entries()).filter(([,v])=>v===0).map(([v])=>v).sort((v,y)=>v-y);t.set(d,{path:d,relativePath:A.join(i,l),lines:{total:m.LINE.total,covered:m.LINE.covered,percentage:m.LINE.total>0?m.LINE.covered/m.LINE.total*100:0,details:g,uncoveredLines:f},branches:{total:m.BRANCH.total,covered:m.BRANCH.covered,percentage:m.BRANCH.total>0?m.BRANCH.covered/m.BRANCH.total*100:0,uncoveredBranches:[]},functions:{total:m.METHOD.total,covered:m.METHOD.covered,percentage:m.METHOD.total>0?m.METHOD.covered/m.METHOD.total*100:0,details:[],uncoveredFunctions:[]},statements:{total:m.INSTRUCTION.total,covered:m.INSTRUCTION.covered,percentage:m.INSTRUCTION.total>0?m.INSTRUCTION.covered/m.INSTRUCTION.total*100:0},coveragePercentage:or(m.LINE.covered,m.LINE.total,m.BRANCH.covered,m.BRANCH.total)})}}return{timestamp:new Date,format:"jacoco",language:"java",files:t,summary:pe(t)}}function yo(u){let e={LINE:{covered:0,total:0},BRANCH:{covered:0,total:0},METHOD:{covered:0,total:0},INSTRUCTION:{covered:0,total:0}},t=/<counter\s+type="(\w+)"\s+missed="(\d+)"\s+covered="(\d+)"\s*\/>/g,n;for(;(n=t.exec(u))!==null;){let r=n[1],i=parseInt(n[2],10),s=parseInt(n[3],10);e[r]&&(e[r].covered+=s,e[r].total+=i+s)}return e}async function Zi(u,e){let t=await Q.readFile(u,"utf-8");return ss(t,e||A.dirname(u))}function ss(u,e){let t=new Map,n=new Map,r=/<File\s+Index="(\d+)"\s+Name="([^"]*)"\s*\/>/g,i;for(;(i=r.exec(u))!==null;)n.set(i[1],i[2]);let s=/<Statement\s+FileIndex="(\d+)"\s+Line="(\d+)"\s+Column="\d+"\s+EndLine="\d+"\s+EndColumn="\d+"\s+Covered="(\w+)"\s*\/>/g,a=new Map,o;for(;(o=s.exec(u))!==null;){let l=o[1],c=parseInt(o[2],10),d=o[3]==="True",m=n.get(l)||`file-${l}`;a.has(m)||a.set(m,{lineDetails:new Map,total:0,covered:0});let g=a.get(m);g.lineDetails.set(c,d?1:0),g.total++,d&&g.covered++}if(a.size===0){let c=/CoveredStatements="(\d+)"\s+TotalStatements="(\d+)"/.exec(u);if(c){let d=parseInt(c[1],10),m=parseInt(c[2],10),g=A.join(e,"aggregate");t.set(g,{path:g,relativePath:"aggregate",lines:{total:m,covered:d,percentage:m>0?d/m*100:0,details:new Map,uncoveredLines:[]},branches:{total:0,covered:0,percentage:0,uncoveredBranches:[]},functions:{total:0,covered:0,percentage:0,details:[],uncoveredFunctions:[]},statements:{total:m,covered:d,percentage:m>0?d/m*100:0},coveragePercentage:m>0?d/m*100:0})}}for(let[l,c]of a.entries()){let d=Array.from(c.lineDetails.entries()).filter(([,m])=>m===0).map(([m])=>m).sort((m,g)=>m-g);t.set(l,{path:l,relativePath:A.relative(e,l),lines:{total:c.lineDetails.size,covered:Array.from(c.lineDetails.values()).filter(m=>m>0).length,percentage:c.lineDetails.size>0?Array.from(c.lineDetails.values()).filter(m=>m>0).length/c.lineDetails.size*100:0,details:c.lineDetails,uncoveredLines:d},branches:{total:0,covered:0,percentage:0,uncoveredBranches:[]},functions:{total:0,covered:0,percentage:0,details:[],uncoveredFunctions:[]},statements:{total:c.total,covered:c.covered,percentage:c.total>0?c.covered/c.total*100:0},coveragePercentage:c.total>0?c.covered/c.total*100:0})}return{timestamp:new Date,format:"dotcover",language:"csharp",files:t,summary:pe(t)}}async function es(u,e){let t=await Q.readFile(u,"utf-8"),n=e||A.dirname(u);if(t.includes("SF:")&&t.includes("end_of_record")){let r=is(t,n);return r.format="tarpaulin",r.language="rust",r}return as(t,n)}function as(u,e){let t=new Map,n=x(u);for(let r of n?.files||[]){let i=r.path||"",s=new Map,a=0,o=0;for(let c of r.traces||[]){let d=c.line,m=c.stats?.Line??c.stats?.line??0;typeof d=="number"&&(s.set(d,m),a++,m>0&&o++)}let l=Array.from(s.entries()).filter(([,c])=>c===0).map(([c])=>c).sort((c,d)=>c-d);t.set(i,{path:i,relativePath:A.relative(e,i),lines:{total:a,covered:o,percentage:a>0?o/a*100:0,details:s,uncoveredLines:l},branches:{total:0,covered:0,percentage:0,uncoveredBranches:[]},functions:{total:0,covered:0,percentage:0,details:[],uncoveredFunctions:[]},statements:{total:a,covered:o,percentage:a>0?o/a*100:0},coveragePercentage:a>0?o/a*100:0})}return{timestamp:new Date,format:"tarpaulin",language:"rust",files:t,summary:pe(t)}}async function ts(u,e){let t=await Q.readFile(u,"utf-8");return os(t,e||A.dirname(u))}function os(u,e){let t=new Map,n=new Map,r=u.split(`
|
|
426
|
+
`);for(let i of r){let s=i.trim();if(!s||s.startsWith("mode:"))continue;let a=s.match(/^(.+):(\d+)\.\d+,(\d+)\.\d+\s+(\d+)\s+(\d+)$/);if(!a)continue;let o=a[1],l=parseInt(a[2],10),c=parseInt(a[3],10),d=parseInt(a[4],10),m=parseInt(a[5],10);n.has(o)||n.set(o,{lineDetails:new Map,stmtTotal:0,stmtCovered:0});let g=n.get(o);for(let p=l;p<=c;p++){let h=g.lineDetails.get(p)||0;g.lineDetails.set(p,h+m)}g.stmtTotal+=d,m>0&&(g.stmtCovered+=d)}for(let[i,s]of n.entries()){let a=s.lineDetails.size,o=Array.from(s.lineDetails.values()).filter(c=>c>0).length,l=Array.from(s.lineDetails.entries()).filter(([,c])=>c===0).map(([c])=>c).sort((c,d)=>c-d);t.set(i,{path:i,relativePath:A.relative(e,i),lines:{total:a,covered:o,percentage:a>0?o/a*100:0,details:s.lineDetails,uncoveredLines:l},branches:{total:0,covered:0,percentage:0,uncoveredBranches:[]},functions:{total:0,covered:0,percentage:0,details:[],uncoveredFunctions:[]},statements:{total:s.stmtTotal,covered:s.stmtCovered,percentage:s.stmtTotal>0?s.stmtCovered/s.stmtTotal*100:0},coveragePercentage:s.stmtTotal>0?s.stmtCovered/s.stmtTotal*100:0})}return{timestamp:new Date,format:"gocover",language:"go",files:t,summary:pe(t)}}async function ns(u,e){let t=await Q.readFile(u,"utf-8"),n=Bt(t,e||A.dirname(u));return n.format="kover",n.language="kotlin",n}async function rs(u,e){let t=await Q.readFile(u,"utf-8");return cs(t,e||A.dirname(u))}function cs(u,e){let t=new Map,r=x(u)?.targets||[];for(let i of r)for(let s of i.files||[]){let a=s.path||"",o=s.executableLines||0,l=s.coveredLines||0,c=s.lineCoverage||0,d=[],m=0,g=0;for(let p of s.functions||[]){let h=p.coveredLines>0?1:0;d.push({name:p.name||"unknown",line:p.lineNumber||0,hits:h}),m++,h>0&&g++}t.set(a,{path:a,relativePath:A.relative(e,a),lines:{total:o,covered:l,percentage:c*100,details:new Map,uncoveredLines:[]},branches:{total:0,covered:0,percentage:0,uncoveredBranches:[]},functions:{total:m,covered:g,percentage:m>0?g/m*100:0,details:d,uncoveredFunctions:d.filter(p=>p.hits===0).map(p=>p.name)},statements:{total:o,covered:l,percentage:c*100},coveragePercentage:c*100})}return{timestamp:new Date,format:"xcresult",language:"swift",files:t,summary:pe(t)}}var vo={java:["jacoco","cobertura","lcov"],kotlin:["kover","jacoco"],csharp:["dotcover","cobertura"],rust:["tarpaulin","lcov"],go:["gocover"],swift:["xcresult"],dart:["lcov"],typescript:["lcov","json"],javascript:["lcov","json"],python:["lcov","cobertura","json"]};async function Ue(u,e,t,n){if(t)switch(t){case"lcov":return ir(u,e);case"json":return sr(u,e);case"jacoco":return Ji(u,e);case"dotcover":return Zi(u,e);case"tarpaulin":return es(u,e);case"gocover":return ts(u,e);case"kover":return ns(u,e);case"xcresult":return rs(u,e);default:break}let r=A.extname(u).toLowerCase(),i=A.basename(u).toLowerCase();if(r===".json"||i.includes("coverage-final"))return sr(u,e);if(i==="lcov.info"||r===".info"||i.includes("lcov"))return ir(u,e);if(i.includes("jacoco")&&r===".xml")return Ji(u,e);if(i.includes("dotcover")&&r===".xml")return Zi(u,e);if(i.includes("tarpaulin"))return es(u,e);if(i.includes("kover")&&r===".xml")return ns(u,e);if(i.includes("coverage")&&r===".out")return ts(u,e);if(i.includes("xcresult")||i.includes("xccov"))return rs(u,e);let s=await Q.readFile(u,"utf-8"),a=s.trim();if(a.startsWith("{"))return a.includes('"files"')&&a.includes('"traces"')?as(s,e||A.dirname(u)):a.includes('"targets"')&&a.includes('"lineCoverage"')?cs(s,e||A.dirname(u)):sr(u,e);if(s.includes("SF:")&&s.includes("end_of_record"))return ir(u,e);if(a.startsWith("mode:"))return os(s,e||A.dirname(u));if(a.startsWith("<?xml")||a.startsWith("<")){if(s.includes('<counter type="')||s.includes("<report ")){if(n==="kotlin"){let o=Bt(s,e||A.dirname(u));return o.format="kover",o.language="kotlin",o}return Bt(s,e||A.dirname(u))}if(s.includes("CoveredStatements=")||s.includes("<Root"))return ss(s,e||A.dirname(u))}if(n){let o=n.toLowerCase(),l=vo[o];if(l&&l.length>0)try{return await Ue(u,e,l[0])}catch{}}throw new Error(`Unknown coverage format: ${u}`)}async function ar(u,e){let t=e||u,n=[A.join(u,"coverage","lcov.info"),A.join(u,"coverage","coverage-final.json"),A.join(u,"lcov.info"),A.join(u,".nyc_output","coverage.json"),A.join(u,"target","site","jacoco","jacoco.xml"),A.join(u,"build","reports","jacoco","test","jacocoTestReport.xml"),A.join(u,"dotcover-report.xml"),A.join(u,"tarpaulin-report.json"),A.join(u,"cobertura.xml"),A.join(u,"coverage.out"),A.join(u,"cover.out"),A.join(u,"build","reports","kover","report.xml"),A.join(u,"coverage.json")];for(let r of n)try{return await Q.access(r),Ue(r,t)}catch{}return null}function or(u,e,t,n){let r=e>0?u/e*100:0,i=n>0?t/n*100:0;return n===0?r:r*.7+i*.3}function pe(u){let e=0,t=0,n=0,r=0,i=0,s=0,a=0,o=0;for(let l of u.values())e+=l.lines.total,t+=l.lines.covered,n+=l.branches.total,r+=l.branches.covered,i+=l.functions.total,s+=l.functions.covered,a+=l.statements.total,o+=l.statements.covered;return{totalFiles:u.size,lines:{total:e,covered:t,percentage:e>0?t/e*100:0},branches:{total:n,covered:r,percentage:n>0?r/n*100:0},functions:{total:i,covered:s,percentage:i>0?s/i*100:0},statements:{total:a,covered:o,percentage:a>0?o/a*100:0}}}k();function ls(u){let e=0,t=0,n=0,r=0,i=0,s=0,a=0,o=0;for(let l of u)e+=l.lines.total,t+=l.lines.covered,n+=l.branches.total,r+=l.branches.covered,i+=l.functions.total,s+=l.functions.covered,a+=l.statements.total,o+=l.statements.covered;return{line:e>0?t/e*100:0,branch:n>0?r/n*100:0,function:i>0?s/i*100:0,statement:a>0?o/a*100:0,files:u.length}}function us(u){let e=[];for(let[t,n]of u.files.entries())e.push({path:n.relativePath||t,lines:{covered:n.lines.covered,total:n.lines.total},branches:{covered:n.branches.covered,total:n.branches.total},functions:{covered:n.functions.covered,total:n.functions.total},statements:{covered:n.statements.covered,total:n.statements.total},uncoveredLines:n.lines.uncoveredLines,uncoveredBranches:n.branches.uncoveredBranches.map(r=>r.line)});return e}var jt=class extends P{config={name:"qe/coverage/analyze",description:"Analyze code coverage using real LCOV/JSON parsing and compare against thresholds. Includes risk scoring and trend analysis.",domain:"coverage-analysis",schema:bo,streaming:!0,timeout:18e4};analyzerService=null;async getService(e){if(!this.analyzerService){let t=e.memory;this.analyzerService=new Mr(t||await F())}return this.analyzerService}async execute(e,t){let{target:n=".",coverageFile:r,thresholds:i={lines:80,branches:70,functions:80,statements:80},includeRisk:s=!1,includeRiskScoring:a=!1,dryRun:o=!1,coverageFormat:l,language:c}=e,d=s||a;try{if(this.emitStream(t,{status:"analyzing",message:`Analyzing coverage for ${n}`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};if(this.isDemoMode(t)||o)return this.markAsDemoData(t,"Demo mode explicitly requested"),this.getDemoResult(n,i,d,t);let m=null;if(r)try{m=await Ue(r,n,l,c)}catch(R){return{success:!1,error:`Failed to parse coverage file '${r}': ${w(R)}`}}else m=await ar(n);if(!m||m.files.size===0)return{success:!1,error:`No coverage data found in '${n}'. Run your test suite with coverage enabled (e.g., 'npm test -- --coverage') and ensure coverage reports are generated (lcov.info, coverage-final.json, etc.)`};this.markAsRealData();let g=us(m),h=await(await this.getService(t)).analyze({coverageData:{files:g,summary:ls(g)},threshold:i.lines||80,includeFileDetails:!0});if(!h.success)return{success:!1,error:`Analysis failed: ${h.error?.message||"Unknown error"}`};let f=h.value,v={lines:{covered:m.summary.lines.covered,total:m.summary.lines.total,percentage:Math.round(m.summary.lines.percentage*100)/100},branches:{covered:m.summary.branches.covered,total:m.summary.branches.total,percentage:Math.round(m.summary.branches.percentage*100)/100},functions:{covered:m.summary.functions.covered,total:m.summary.functions.total,percentage:Math.round(m.summary.functions.percentage*100)/100},statements:{covered:m.summary.statements.covered,total:m.summary.statements.total,percentage:Math.round(m.summary.statements.percentage*100)/100}},y=g.map(R=>({file:R.path,lines:Math.round(R.lines.covered/(R.lines.total||1)*100),branches:Math.round(R.branches.covered/(R.branches.total||1)*100),functions:Math.round(R.functions.covered/(R.functions.total||1)*100),uncoveredLines:R.uncoveredLines.slice(0,20)})),C=v.lines.percentage>=(i.lines||0)&&v.branches.percentage>=(i.branches||0)&&v.functions.percentage>=(i.functions||0)&&v.statements.percentage>=(i.statements||0),b;if(d){let R=g.reduce((q,U)=>q+U.uncoveredLines.length,0),D=(v.lines.percentage+v.branches.percentage+v.functions.percentage)/3;b=Math.round((1-D/100+Math.min(R/1e3,.5))*100)/100}let E;f.delta&&(E={direction:f.delta.trend,delta:Math.round((f.delta.line+f.delta.branch+f.delta.function)/3*100)/100,history:[{date:new Date(Date.now()-10080*60*1e3).toISOString().split("T")[0],coverage:v.lines.percentage-(f.delta.line||0)},{date:new Date().toISOString().split("T")[0],coverage:v.lines.percentage}]}),this.emitStream(t,{status:"complete",message:`Coverage analysis complete: ${v.lines.percentage}% lines covered`,progress:100});let S=e.language||m.language,T=m.format;return{success:!0,data:{summary:v,byFile:y,thresholdsPassed:C,riskScore:b,trends:E,language:S,format:T}}}catch(m){return{success:!1,error:`Coverage analysis failed: ${w(m)}`}}}getDemoResult(e,t,n,r){let i={lines:{covered:850,total:1e3,percentage:85},branches:{covered:120,total:150,percentage:80},functions:{covered:90,total:100,percentage:90},statements:{covered:900,total:1050,percentage:85.71}},s=[{file:`${e}/service.ts`,lines:92,branches:85,functions:95,uncoveredLines:[45,67,89]},{file:`${e}/utils.ts`,lines:78,branches:70,functions:85,uncoveredLines:[12,34,56,78,90]},{file:`${e}/handler.ts`,lines:88,branches:82,functions:90,uncoveredLines:[23,45]}],a=i.lines.percentage>=(t.lines||0)&&i.branches.percentage>=(t.branches||0)&&i.functions.percentage>=(t.functions||0)&&i.statements.percentage>=(t.statements||0);return this.emitStream(r,{status:"complete",message:`Coverage analysis complete (sample data): ${i.lines.percentage}% lines covered`,progress:100}),{success:!0,data:{summary:i,byFile:s,thresholdsPassed:a,riskScore:n?.25:void 0,trends:{direction:"improving",delta:2.5,history:[{date:new Date(Date.now()-10080*60*1e3).toISOString().split("T")[0],coverage:82.5},{date:new Date().toISOString().split("T")[0],coverage:85}]}}}}resetInstanceCache(){this.analyzerService=null}},Ut=class extends P{config={name:"qe/coverage/gaps",description:"Find coverage gaps using O(log n) HNSW vector search. Prioritizes by risk, complexity, or ML confidence using real coverage data.",domain:"coverage-analysis",schema:Co,streaming:!0,timeout:12e4};gapService=null;async getService(e){if(!this.gapService){let t=e.memory;this.gapService=new Dr(t||await F())}return this.gapService}async execute(e,t){let{target:n=".",coverageFile:r,minRisk:i=.3,limit:s=20,prioritization:a="complexity",coverageFormat:o,language:l}=e;try{if(this.emitStream(t,{status:"detecting",message:`Detecting coverage gaps in ${n} (O(log n) search)`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let c=null;if(r)try{c=await Ue(r,n,o,l)}catch(C){return{success:!1,error:`Failed to parse coverage file: ${w(C)}`}}else c=await ar(n);if(this.isDemoMode(t))return this.markAsDemoData(t,"Demo mode explicitly requested"),this.getDemoGapsResult(n,i,s,t);if(!c||c.files.size===0)return r?{success:!1,error:`Coverage file '${r}' contains no usable coverage data (parsed 0 files). Verify the file is a non-empty Istanbul/LCOV/JaCoCo/etc. report.`}:{success:!1,error:`No coverage data found by autodiscovery under target '${n}'. Run your test suite with coverage enabled, or pass coverageFile pointing to an existing report.`};this.markAsRealData();let d=us(c),m=await this.getService(t),g=a==="change-frequency"?"recent-changes":"risk",p=await m.detectGaps({coverageData:{files:d,summary:ls(d)},minCoverage:80,prioritize:g});if(!p.success)return{success:!1,error:`Gap detection failed: ${p.error?.message||"Unknown error"}`};let h=p.value,f=h.gaps.filter(C=>C.riskScore>=i).slice(0,s).map(C=>({file:C.file,lines:C.lines,type:C.branches.length>0?"uncovered-branch":"uncovered-line",severity:C.severity,riskScore:Math.round(C.riskScore*100)/100,reason:C.recommendation})),v=f.slice(0,5).map((C,b)=>({file:C.file.replace(/\.ts$/,".test.ts"),description:`Add tests for ${C.lines.length} uncovered lines in ${C.file}`,estimatedCoverageGain:Math.round(C.lines.length/(h.totalUncoveredLines||1)*100*100)/100,priority:b+1})),y;if(e.includeGhost)try{let b=t.kernel;if(b){let E=await b.getDomainAPIAsync("coverage-analysis");if(E?.analyzeGhostCoverage){let S=await E.analyzeGhostCoverage(d.map(T=>T.path),n);S?.success&&S.value&&(y=(S.value.gaps||[]).map(T=>({category:T.category,severity:T.severity,description:T.description,confidence:T.confidence})))}}}catch{}return this.emitStream(t,{status:"complete",message:`Found ${f.length} coverage gaps (${h.totalUncoveredLines} uncovered lines)`,progress:100}),{success:!0,data:{gaps:f,totalGaps:h.gaps.length,criticalGaps:f.filter(C=>C.severity==="critical").length,suggestedTests:v,...y?{ghostGaps:y}:{}}}}catch(c){return{success:!1,error:`Gap detection failed: ${w(c)}`}}}getDemoGapsResult(e,t,n,r){let s=[{file:`${e}/service.ts`,lines:[45,67,89,102,115],type:"uncovered-line",severity:"high",riskScore:.85,reason:"Core business logic with no test coverage"},{file:`${e}/utils.ts`,lines:[12,34,56],type:"uncovered-branch",severity:"medium",riskScore:.65,reason:"Utility functions missing edge case tests"},{file:`${e}/handler.ts`,lines:[23,45,67,89],type:"uncovered-function",severity:"critical",riskScore:.92,reason:"Error handling paths untested"},{file:`${e}/validator.ts`,lines:[10,20,30],type:"uncovered-line",severity:"low",riskScore:.35,reason:"Simple validation logic"}].filter(o=>o.riskScore>=t).slice(0,n),a=s.slice(0,5).map((o,l)=>({file:o.file.replace(/\.ts$/,".test.ts"),description:`Add tests for ${o.lines.length} uncovered lines in ${o.file}`,estimatedCoverageGain:Math.round(o.lines.length/50*100*100)/100,priority:l+1}));return this.emitStream(r,{status:"complete",message:`Found ${s.length} coverage gaps (sample data)`,progress:100}),{success:!0,data:{gaps:s,totalGaps:s.length,criticalGaps:s.filter(o=>o.severity==="critical").length,suggestedTests:a}}}resetInstanceCache(){this.gapService=null}},bo={type:"object",properties:{target:{type:"string",description:"Target directory to analyze (searches for coverage files)",default:"."},coverageFile:{type:"string",description:"Path to coverage report file (lcov.info, coverage-final.json, etc.)"},thresholds:{type:"object",description:"Coverage thresholds",properties:{lines:{type:"number",description:"Line coverage threshold"},branches:{type:"number",description:"Branch coverage threshold"},functions:{type:"number",description:"Function coverage threshold"},statements:{type:"number",description:"Statement coverage threshold"}}},includeRisk:{type:"boolean",description:"Include risk score analysis",default:!1},mlPowered:{type:"boolean",description:"Use ML-powered analysis (vector similarity)",default:!1},language:{type:"string",description:"Source language hint (java, csharp, go, rust, kotlin, swift, dart, typescript, python)"},coverageFormat:{type:"string",description:"Coverage format hint",enum:["lcov","json","jacoco","dotcover","tarpaulin","gocover","kover","xcresult"]}}},Co={type:"object",properties:{target:{type:"string",description:"Target directory to analyze",default:"."},coverageFile:{type:"string",description:"Path to coverage report file"},minRisk:{type:"number",description:"Minimum risk score to include (0-1)",minimum:0,maximum:1,default:.3},limit:{type:"number",description:"Maximum number of gaps to return",minimum:1,maximum:100,default:20},prioritization:{type:"string",description:"Gap prioritization strategy",enum:["complexity","criticality","change-frequency","ml-confidence"],default:"complexity"},includeGhost:{type:"boolean",description:"Include ADR-059 ghost intent coverage analysis (detect untested behavioral intents)",default:!1},language:{type:"string",description:"Source language filter (java, csharp, go, rust, kotlin, swift, dart)"},coverageFormat:{type:"string",description:"Coverage format hint",enum:["lcov","json","jacoco","dotcover","tarpaulin","gocover","kover","xcresult"]}}};k();var Ht=class extends P{config={name:"qe/quality/evaluate",description:"Evaluate quality gates and provide deployment recommendations. Analyzes coverage, bugs, complexity, and security.",domain:"quality-assessment",schema:To,streaming:!0,timeout:12e4};async execute(e,t){let{metrics:n=So(),gateName:r="default",thresholds:i=Eo(),includeAdvice:s=!0,riskTolerance:a="medium"}=e;try{if(this.emitStream(t,{status:"evaluating",message:`Evaluating quality gate: ${r}`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let o=[];i.coverage&&n.coverage!==void 0&&o.push({name:"Coverage",passed:n.coverage>=i.coverage.min,value:n.coverage,threshold:i.coverage.min,severity:"high",message:n.coverage>=i.coverage.min?`Coverage ${n.coverage}% meets threshold`:`Coverage ${n.coverage}% below ${i.coverage.min}% threshold`}),i.testsPassing&&n.testsPassing!==void 0&&o.push({name:"Tests Passing",passed:n.testsPassing>=i.testsPassing.min,value:n.testsPassing,threshold:i.testsPassing.min,severity:"critical",message:n.testsPassing>=i.testsPassing.min?`${n.testsPassing}% tests passing`:`Only ${n.testsPassing}% tests passing`}),i.criticalBugs&&n.criticalBugs!==void 0&&o.push({name:"Critical Bugs",passed:n.criticalBugs<=i.criticalBugs.max,value:n.criticalBugs,threshold:i.criticalBugs.max,severity:"critical",message:n.criticalBugs<=i.criticalBugs.max?`${n.criticalBugs} critical bugs within threshold`:`${n.criticalBugs} critical bugs exceed threshold of ${i.criticalBugs.max}`}),i.securityVulnerabilities&&n.securityVulnerabilities!==void 0&&o.push({name:"Security Vulnerabilities",passed:n.securityVulnerabilities<=i.securityVulnerabilities.max,value:n.securityVulnerabilities,threshold:i.securityVulnerabilities.max,severity:"critical",message:n.securityVulnerabilities<=i.securityVulnerabilities.max?`${n.securityVulnerabilities} vulnerabilities within threshold`:`${n.securityVulnerabilities} vulnerabilities found`}),i.codeSmells&&n.codeSmells!==void 0&&o.push({name:"Code Smells",passed:n.codeSmells<=i.codeSmells.max,value:n.codeSmells,threshold:i.codeSmells.max,severity:"medium",message:n.codeSmells<=i.codeSmells.max?`${n.codeSmells} code smells within threshold`:`${n.codeSmells} code smells detected`});let l=o.filter(f=>f.passed).length,c=o.length,d=c>0?Math.round(l/c*100):100,m=wo(d,o),g=o.every(f=>f.passed||f.severity!=="critical"),p=s?Ro(g,d,o,a):void 0,h=Po(o,n);return this.emitStream(t,{status:"complete",message:`Quality evaluation complete: ${m} (${d}%)`,progress:100}),{success:!0,data:{passed:g,score:d,grade:m,checks:o,deploymentAdvice:p,recommendations:h}}}catch(o){return{success:!1,error:`Quality evaluation failed: ${w(o)}`}}}},To={type:"object",properties:{metrics:{type:"object",description:"Quality metrics to evaluate",properties:{coverage:{type:"number",description:"Code coverage percentage"},testsPassing:{type:"number",description:"Percentage of passing tests"},criticalBugs:{type:"number",description:"Number of critical bugs"},codeSmells:{type:"number",description:"Number of code smells"},securityVulnerabilities:{type:"number",description:"Number of security vulnerabilities"},technicalDebt:{type:"number",description:"Technical debt in hours"},duplications:{type:"number",description:"Code duplication percentage"},complexity:{type:"number",description:"Cyclomatic complexity"}}},gateName:{type:"string",description:"Name of the quality gate",default:"default"},thresholds:{type:"object",description:"Quality gate thresholds"},includeAdvice:{type:"boolean",description:"Include deployment advice",default:!0},riskTolerance:{type:"string",description:"Risk tolerance level",enum:["low","medium","high"],default:"medium"}}};function So(){return{coverage:80,testsPassing:95,criticalBugs:0,codeSmells:15,securityVulnerabilities:0,technicalDebt:4,duplications:3,complexity:8}}function Eo(){return{coverage:{min:80},testsPassing:{min:95},criticalBugs:{max:0},securityVulnerabilities:{max:0},codeSmells:{max:50},technicalDebt:{max:8}}}function wo(u,e){return e.some(n=>!n.passed&&n.severity==="critical")?"F":u>=90?"A":u>=80?"B":u>=70?"C":u>=60?"D":"F"}function Ro(u,e,t,n){let r=t.filter(d=>!d.passed&&d.severity==="critical"),i=t.filter(d=>!d.passed&&d.severity==="high"),s=r.length*.4+i.length*.2+(100-e)/100,a=Math.min(s,1),o,c={low:{block:.2,warn:.1},medium:{block:.4,warn:.2},high:{block:.6,warn:.4}}[n];return a>=c.block||r.length>0?o="blocked":a>=c.warn?o="warning":o="approved",{decision:o,confidence:Math.round((1-a)*100)/100,riskScore:Math.round(a*100)/100,reasons:[...r.map(d=>`Critical: ${d.name} - ${d.message}`),...i.map(d=>`High: ${d.name} - ${d.message}`)],conditions:o==="warning"?["Monitor closely after deployment","Prepare rollback plan"]:void 0,rollbackPlan:o!=="approved"?"Revert to previous version if issues detected":void 0}}function Po(u,e){let t=[],n=u.filter(r=>!r.passed);for(let r of n)t.push({type:r.severity==="critical"?"critical":r.severity==="high"?"warning":"improvement",title:`Fix ${r.name}`,description:r.message,impact:r.severity==="critical"||r.severity==="high"?"high":"medium",effort:"medium"});return(e.coverage||0)<90&&t.push({type:"improvement",title:"Increase test coverage",description:`Current coverage is ${e.coverage}%. Consider adding tests for critical paths.`,impact:"medium",effort:"medium"}),t}k();var Vt={codeComplexity:"High cyclomatic complexity increases defect probability",changeFrequency:"Frequently modified files are more prone to defects",bugHistory:"Previous defects in this area indicate higher risk",testCoverage:"Low test coverage increases undetected defect risk",developerExperience:"Code written by less experienced developers may have more issues",codeAge:"New code is more likely to have defects than mature, stable code",complexity:"High cyclomatic complexity increases defect probability",churn:"Frequently modified files are more prone to defects",history:"Previous defects in this area indicate higher risk",coverage:"Low test coverage increases undetected defect risk",coupling:"High coupling makes changes risky",age:"New code may have more defects than stable code"},Qt=class extends P{config={name:"qe/defects/predict",description:"Predict defect probability for files using ML models. Analyzes code complexity, change frequency, git history, and test coverage.",domain:"defect-intelligence",schema:xo,streaming:!0,timeout:18e4};predictorService=null;async getService(e){if(!this.predictorService){let t=e.memory;t?this.predictorService=new Cn(t):this.predictorService=new Cn(await F())}return this.predictorService}async execute(e,t){let{files:n=[],threshold:r=.5,minConfidence:i=.7,features:s=[{name:"codeComplexity",weight:.25},{name:"changeFrequency",weight:.2},{name:"developerExperience",weight:.15},{name:"testCoverage",weight:.2},{name:"codeAge",weight:.1},{name:"bugHistory",weight:.1}]}=e;try{if(this.emitStream(t,{status:"analyzing",message:`Analyzing ${n.length||"provided"} files using ML-based prediction`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};if(this.isDemoMode(t))return this.markAsDemoData(t,"Demo mode explicitly requested"),this.getDemoResult(n);let a=await this.getService(t),o=await a.predictDefects({files:n,features:s.map(p=>({name:p.name,weight:p.weight??.25})),threshold:r});if(!o.success)return{success:!1,error:`Defect prediction failed: ${o.error?.message||"Service unavailable"}. Ensure the defect-intelligence domain is properly initialized.`};this.markAsRealData();let d=o.value.predictions.filter(p=>p.probability>=1-i).map(p=>({file:p.file,probability:Math.round(p.probability*100)/100,riskLevel:Ao(p.riskLevel),factors:p.factors.map(h=>({name:h.name,contribution:h.contribution,description:Vt[h.name]||`${h.name} contributes to defect risk`})),recommendations:p.recommendations}));d.sort((p,h)=>h.probability-p.probability);let m=ko(d),g=await a.getModelMetrics();return this.emitStream(t,{status:"complete",message:`Analyzed ${n.length} files, ${d.length} with elevated risk`,progress:100}),{success:!0,data:{predictions:d,modelConfidence:o.value.modelConfidence,topRiskFactors:m,recommendations:Do(d),modelMetrics:{accuracy:g.accuracy,precision:g.precision,recall:g.recall,f1Score:g.f1Score}}}}catch(a){return{success:!1,error:`Defect prediction failed: ${w(a)}`}}}getDemoResult(e){let n=(e.length>0?e:["src/service.ts","src/handler.ts","src/utils.ts"]).map((r,i)=>({file:r,probability:Math.max(.9-i*.15,.35),riskLevel:i===0?"high":i===1?"medium":"low",factors:[{name:"codeComplexity",contribution:.35,description:Vt.codeComplexity},{name:"changeFrequency",contribution:.25,description:Vt.changeFrequency},{name:"testCoverage",contribution:.2,description:Vt.testCoverage}],recommendations:[`Increase test coverage for ${r}`,"Consider refactoring complex functions","Review recent changes for potential issues"]}));return{success:!0,data:{predictions:n,modelConfidence:.85,topRiskFactors:[{name:"High Complexity",impact:.35,affectedFiles:n.length},{name:"Frequent Changes",impact:.25,affectedFiles:Math.ceil(n.length*.7)},{name:"Low Coverage",impact:.2,affectedFiles:Math.ceil(n.length*.5)}],recommendations:["Focus testing on files with highest defect probability","Increase test coverage in high-risk areas","Review recent changes to frequently-modified files","Consider refactoring complex modules"],modelMetrics:{accuracy:.82,precision:.78,recall:.85,f1Score:.81}}}}resetInstanceCache(){this.predictorService=null}},xo={type:"object",properties:{files:{type:"array",description:"Specific files to analyze",items:{type:"string",description:"File path"}},target:{type:"string",description:"Target directory to analyze",default:"."},lookback:{type:"number",description:"Days of history to consider",minimum:7,maximum:365,default:30},threshold:{type:"number",description:"Risk threshold for classification (0-1)",minimum:0,maximum:1,default:.5},minConfidence:{type:"number",description:"Minimum prediction confidence (0-1)",minimum:0,maximum:1,default:.7},features:{type:"array",description:"Features to use for prediction",items:{type:"object",description:"Prediction feature",properties:{name:{type:"string",description:"Feature name"},weight:{type:"number",description:"Feature weight"}}}}}};function Ao(u){switch(u){case"critical":return"critical";case"high":return"high";case"medium":return"medium";default:return"low"}}function ko(u){let e=new Map;for(let n of u)for(let r of n.factors){let i=e.get(r.name)||{impact:0,count:0};i.impact+=r.contribution,i.count+=1,e.set(r.name,i)}let t=[];for(let[n,r]of e)t.push({name:Mo(n),impact:Math.round(r.impact/r.count*100)/100,affectedFiles:r.count});return t.sort((n,r)=>r.impact-n.impact),t.slice(0,5)}function Mo(u){return{codeComplexity:"High Complexity",changeFrequency:"Frequent Changes",bugHistory:"Bug History",testCoverage:"Low Coverage",developerExperience:"Developer Experience",codeAge:"Code Age"}[u]||u.replace(/([A-Z])/g," $1").trim()}function Do(u){let e=[],t=u.filter(i=>i.riskLevel==="critical").length,n=u.filter(i=>i.riskLevel==="high").length,r=u.length>0?u.reduce((i,s)=>i+s.probability,0)/u.length:0;return t>0&&(e.push(`CRITICAL: ${t} files require immediate attention`),e.push("Consider code review and comprehensive testing before deployment")),n>0&&(e.push(`High risk detected in ${n} files`),e.push("Increase test coverage in high-risk areas")),r>.5?(e.push("Overall defect risk is elevated - consider delaying release"),e.push("Run full regression test suite before deployment")):e.push("Focus testing on files with highest defect probability"),e.push("Review recent changes to frequently-modified files"),e.push("Consider refactoring complex modules"),[...new Set(e)]}k();var Wt=class extends P{config={name:"qe/requirements/validate",description:"Validate requirements for testability. Scores each requirement, detects ambiguity, and optionally generates BDD scenarios.",domain:"requirements-validation",schema:Io,streaming:!0,timeout:12e4};async execute(e,t){let{requirements:n,generateBDD:r=!1,checkAmbiguity:i=!0,minTestability:s=60}=e;try{if(this.emitStream(t,{status:"validating",message:`Validating ${n.length} requirements`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let a=[],o=[];for(let c of n){this.emitStream(t,{status:"processing",message:`Analyzing: ${c.title}`});let d=Oo(c),m=_o(c,s,d),g=i?Fo(c):void 0;a.push({requirementId:c.id,isValid:m.filter(p=>p.severity==="error").length===0,testabilityScore:d,errors:m,ambiguityReport:g}),r&&d.value>=s&&o.push(...No(c))}let l={total:n.length,valid:a.filter(c=>c.isValid).length,invalid:a.filter(c=>!c.isValid).length,avgTestability:a.reduce((c,d)=>c+d.testabilityScore.value,0)/n.length,blockers:a.filter(c=>c.errors.some(d=>d.severity==="error")).length};return this.emitStream(t,{status:"complete",message:`Validation complete: ${l.valid}/${l.total} valid`,progress:100}),{success:!0,data:{validationResults:a,summary:l,bddScenarios:o.length>0?o:void 0,recommendations:qo(a)}}}catch(a){return{success:!1,error:`Validation failed: ${w(a)}`}}}},Io={type:"object",properties:{requirements:{type:"array",description:"Requirements to validate",items:{type:"object",description:"Requirement input",properties:{id:{type:"string",description:"Requirement ID"},title:{type:"string",description:"Requirement title"},description:{type:"string",description:"Requirement description"},acceptanceCriteria:{type:"array",description:"Acceptance criteria",items:{type:"string",description:"Criterion"}},type:{type:"string",description:"Requirement type",enum:["user-story","functional","non-functional","technical"]}},required:["id","title","description"]}},generateBDD:{type:"boolean",description:"Generate BDD scenarios from requirements",default:!1},checkAmbiguity:{type:"boolean",description:"Check for ambiguous language",default:!0},minTestability:{type:"number",description:"Minimum testability score (0-100)",minimum:0,maximum:100,default:60}},required:["requirements"]};function Oo(u){let e=[],t=u.acceptanceCriteria&&u.acceptanceCriteria.length>0?90:40;e.push({name:"Acceptance Criteria",score:t,issues:t<70?["Missing or incomplete acceptance criteria"]:[]});let n=u.description.length,r=n>100?85:n>50?70:50;e.push({name:"Description Clarity",score:r,issues:r<70?["Description may be too brief"]:[]});let a=["should","must","when","then","verify","validate"].some(l=>u.description.toLowerCase().includes(l))?80:50;e.push({name:"Measurability",score:a,issues:a<70?["Requirement lacks measurable criteria"]:[]});let o=Math.round(e.reduce((l,c)=>l+c.score,0)/e.length);return{value:o,category:o>=80?"excellent":o>=70?"good":o>=50?"fair":"poor",factors:e}}function _o(u,e,t){let n=[];return t.value<e&&n.push({code:"LOW_TESTABILITY",message:`Testability score ${t.value} is below minimum ${e}`,severity:"error",suggestion:"Add clear acceptance criteria and measurable outcomes"}),(!u.acceptanceCriteria||u.acceptanceCriteria.length===0)&&n.push({code:"MISSING_AC",message:"No acceptance criteria defined",severity:"warning",suggestion:"Define specific, testable acceptance criteria"}),u.description.length<30&&n.push({code:"BRIEF_DESC",message:"Description is too brief",severity:"warning",suggestion:"Expand description with more context and details"}),n}function Fo(u){let e=[],t=["some","few","many","fast","slow","good","better","appropriate"];for(let n of t)u.description.toLowerCase().includes(n)&&e.push({term:n,context:`Found in: "${u.description.substring(0,50)}..."`,alternatives:Lo(n)});return{ambiguousTerms:e,overallScore:Math.max(0,100-e.length*15),suggestions:e.length>0?["Replace vague terms with specific, measurable criteria"]:["Requirement language is clear"]}}function Lo(u){return{some:["exactly N","at least N","between N and M"],few:["1-3","less than 5"],many:["more than 10","at least N"],fast:["within X milliseconds","response time < Xs"],slow:["longer than X seconds"],good:["score >= 80%","passes all criteria"],better:["improves by X%","exceeds baseline by N"],appropriate:["meets requirement X","validates against schema"]}[u]||["Be more specific"]}function No(u){let e=[];return e.push({id:`scenario-${u.id}-1`,feature:u.title,scenario:`Verify ${u.title}`,given:["the system is initialized","the user is authenticated"],when:["the user performs the action"],then:["the expected outcome is observed","the system state is updated"],tags:["@generated",`@${u.type||"functional"}`]}),u.acceptanceCriteria&&u.acceptanceCriteria.length>0&&u.acceptanceCriteria.forEach((t,n)=>{e.push({id:`scenario-${u.id}-ac${n+1}`,feature:u.title,scenario:`Acceptance Criteria: ${t.substring(0,50)}`,given:["the preconditions are met"],when:["the specified action is taken"],then:[t],tags:["@generated","@acceptance"]})}),e}function qo(u){let e=[],t=u.filter(r=>r.testabilityScore.value<60).length,n=u.filter(r=>r.errors.some(i=>i.code==="MISSING_AC")).length;return t>0&&e.push(`${t} requirements have low testability scores. Consider adding acceptance criteria.`),n>0&&e.push(`${n} requirements lack acceptance criteria. Define testable criteria for each.`),u.every(r=>r.isValid)&&e.push("All requirements are valid and testable."),e}import{existsSync as cr,readFileSync as ds}from"fs";import{join as lr,dirname as Go}from"path";import{fileURLToPath as $o}from"url";var Me=["Capability","Reliability","Usability","Charisma","Security","Scalability","Compatibility","Performance","Installability","Development"],De=["Capability","Reliability","Security","Performance","Development"];var zo=$o(import.meta.url),Bo=Go(zo),He=class{config;templateCache=null;constructor(e={}){this.config={enableSemanticAnalysis:e.enableSemanticAnalysis??!0,defaultOutputFormat:e.defaultOutputFormat??"html",templatePath:e.templatePath??this.findTemplatePath(),minimumCategories:e.minimumCategories??8}}findTemplatePath(){let e=[lr(process.cwd(),".claude/helpers/v3/quality-criteria/quality-criteria-reference-template.html"),lr(process.cwd(),"node_modules/agentic-qe/assets/agents/v3/helpers/quality-criteria/quality-criteria-reference-template.html"),lr(Bo,"../../../../../assets/agents/v3/helpers/quality-criteria/quality-criteria-reference-template.html")];for(let t of e)if(cr(t))return t;return e[0]}analyze(e){let t=e.epicContent||"";if(e.epicPath&&cr(e.epicPath)&&(t=ds(e.epicPath,"utf-8")),!t&&!e.epicPath)throw new Error("Either epicPath or epicContent is required for analysis");return{agentInvocation:{required:!0,agentType:"qe-quality-criteria-recommender",prompt:this.buildAgentPrompt({assessmentName:e.assessmentName,epicContent:t,epicPath:e.epicPath,sourcePaths:e.sourcePaths,outputFormat:e.outputFormat,outputPath:e.outputPath}),timeout:3e5,expectedOutput:"QualityCriteriaAnalysis",instructions:`Claude Code MUST spawn the qe-quality-criteria-recommender agent with this prompt. The agent will perform real semantic HTSM analysis using Claude's reasoning capabilities. Use: Task("HTSM Quality Criteria Analysis", { prompt: <this prompt> }, "qe-quality-criteria-recommender")`},message:"AGENT INVOCATION REQUIRED: This service cannot perform semantic HTSM analysis alone. Claude Code must spawn the qe-quality-criteria-recommender agent with the provided prompt."}}buildAgentPrompt(e){let{assessmentName:t,epicContent:n,epicPath:r,sourcePaths:i,outputFormat:s,outputPath:a}=e,o=i&&i.length>0?`
|
|
487
427
|
## Source Paths to Analyze
|
|
488
428
|
${i.map(c=>`- ${c}`).join(`
|
|
489
429
|
`)}
|
|
@@ -511,11 +451,11 @@ ${o}
|
|
|
511
451
|
Perform HTSM v6.3 Quality Criteria analysis on the above requirements.
|
|
512
452
|
|
|
513
453
|
### HTSM Categories to Analyze
|
|
514
|
-
${
|
|
454
|
+
${Me.map((c,d)=>`${d+1}. ${c}`).join(`
|
|
515
455
|
`)}
|
|
516
456
|
|
|
517
457
|
### Categories That CANNOT Be Omitted
|
|
518
|
-
${
|
|
458
|
+
${De.map(c=>`- ${c}`).join(`
|
|
519
459
|
`)}
|
|
520
460
|
|
|
521
461
|
### Evidence Classification
|
|
@@ -556,7 +496,7 @@ Return a complete QualityCriteriaAnalysis object with:
|
|
|
556
496
|
${l}
|
|
557
497
|
## Begin Analysis
|
|
558
498
|
|
|
559
|
-
Analyze the requirements above and return the complete QualityCriteriaAnalysis.`}validateEvidence(e){let t=[];for(let n of e)this.isValidSourceReference(n.sourceReference)||t.push(`Invalid source reference format: ${n.sourceReference}. Expected file:line format.`),["Direct","Inferred","Claimed"].includes(n.type)||t.push(`Invalid evidence type: ${n.type}. Must be Direct, Inferred, or Claimed.`),n.type==="Claimed"&&(!n.reasoning.includes("requires verification")&&!n.reasoning.includes("needs inspection")&&!n.reasoning.includes("needs code inspection")&&t.push(`Claimed evidence must state "requires verification": ${n.sourceReference}`),(n.reasoning.includes("could")||n.reasoning.includes("might"))&&t.push(`Claimed evidence must not speculate (no "could" or "might"): ${n.sourceReference}`)),n.reasoning.length<20&&t.push(`Reasoning too short for ${n.sourceReference}. Explain WHY it matters.`);return{valid:t.length===0,errors:t}}isValidSourceReference(e){if(e==="N/A (verified via Glob/Grep search)"||e==="Project search")return!0;let t=/^[\w\-./]+\.(ts|js|tsx|jsx|md|json|html|css|yaml|yml):\d+-\d+$/,n=/^[\w\-./]+\.(ts|js|tsx|jsx|md|json|html|css|yaml|yml)(\s*\(\d+\s*LOC\))?$/;return t.test(e)||n.test(e)}extractComponent(e){let t=e.match(/component:\s*["']?([^"'\n]+)["']?/i);if(t)return t[1].trim();let n=e.match(/^#\s+(.+)$/m);if(n)return n[1].trim()}generateHTML(e){if(!this.templateCache&&
|
|
499
|
+
Analyze the requirements above and return the complete QualityCriteriaAnalysis.`}validateEvidence(e){let t=[];for(let n of e)this.isValidSourceReference(n.sourceReference)||t.push(`Invalid source reference format: ${n.sourceReference}. Expected file:line format.`),["Direct","Inferred","Claimed"].includes(n.type)||t.push(`Invalid evidence type: ${n.type}. Must be Direct, Inferred, or Claimed.`),n.type==="Claimed"&&(!n.reasoning.includes("requires verification")&&!n.reasoning.includes("needs inspection")&&!n.reasoning.includes("needs code inspection")&&t.push(`Claimed evidence must state "requires verification": ${n.sourceReference}`),(n.reasoning.includes("could")||n.reasoning.includes("might"))&&t.push(`Claimed evidence must not speculate (no "could" or "might"): ${n.sourceReference}`)),n.reasoning.length<20&&t.push(`Reasoning too short for ${n.sourceReference}. Explain WHY it matters.`);return{valid:t.length===0,errors:t}}isValidSourceReference(e){if(e==="N/A (verified via Glob/Grep search)"||e==="Project search")return!0;let t=/^[\w\-./]+\.(ts|js|tsx|jsx|md|json|html|css|yaml|yml):\d+-\d+$/,n=/^[\w\-./]+\.(ts|js|tsx|jsx|md|json|html|css|yaml|yml)(\s*\(\d+\s*LOC\))?$/;return t.test(e)||n.test(e)}extractComponent(e){let t=e.match(/component:\s*["']?([^"'\n]+)["']?/i);if(t)return t[1].trim();let n=e.match(/^#\s+(.+)$/m);if(n)return n[1].trim()}generateHTML(e){if(!this.templateCache&&cr(this.config.templatePath)&&(this.templateCache=ds(this.config.templatePath,"utf-8")),!this.templateCache)return this.generateFallbackHTML(e);let t=this.templateCache;return t=t.replace(/\{EPIC_TITLE\}/g,e.epic),t=t.replace(/\{COMPONENT_NAME\}/g,e.component||"N/A"),t=t.replace(/\{DATE\}/g,e.timestamp.toISOString().split("T")[0]),t=t.replace(/\{COVERAGE_METRIC\}/g,e.coverageMetric),t}generateFallbackHTML(e){return`<!DOCTYPE html>
|
|
560
500
|
<html lang="en">
|
|
561
501
|
<head>
|
|
562
502
|
<meta charset="UTF-8">
|
|
@@ -590,7 +530,7 @@ Analyze the requirements above and return the complete QualityCriteriaAnalysis.`
|
|
|
590
530
|
</footer>
|
|
591
531
|
</body>
|
|
592
532
|
</html>`}generateMarkdown(e){let t=["# Quality Criteria Recommendations","",`**Epic:** ${e.epic}`,`**Component:** ${e.component||"N/A"}`,`**Date:** ${e.timestamp.toISOString().split("T")[0]}`,`**Coverage:** ${e.coverageMetric}`,"","## Executive Summary","",e.executiveSummary||"_Analysis pending. Run qe-quality-criteria-recommender agent for full semantic analysis._","","## Categories Analyzed","",...e.categoriesAnalyzed.map(n=>`- ${n}`),""];if(e.categoriesOmitted.length>0){t.push("## Categories Omitted"),t.push("");for(let n of e.categoriesOmitted)t.push(`- **${n.category}**: ${n.reason}`);t.push("")}if(e.recommendations.length>0){t.push("## Recommendations"),t.push("");for(let n of e.recommendations){t.push(`### ${n.category} (${n.priority})`),t.push(""),t.push(`**Why It Matters:** ${n.whyItMatters}`),t.push(""),t.push(`**Business Impact:** ${n.businessImpact}`),t.push(""),t.push("**Test Focus Areas:**");for(let r of n.testFocusAreas)t.push(`- ${r}`);t.push("")}}return t.push("---"),t.push(""),t.push("*Generated by Agentic QE \u2014 qe-quality-criteria-recommender*"),t.push("*Analysis Method: AI Semantic Understanding | Framework: James Bach's HTSM v6.3*"),t.join(`
|
|
593
|
-
`)}};function
|
|
533
|
+
`)}};function Kt(u){return new He(u)}k();k();import{existsSync as Uo,readFileSync as Ho}from"fs";var Ve=class extends P{config={name:"qe/requirements/quality-criteria",description:'HTSM v6.3 Quality Criteria analysis tool. For "analyze" action: Returns an agentInvocation that MUST be executed to get real semantic analysis. For "validate-evidence": Validates evidence points programmatically. For "format": Formats a completed analysis into HTML/JSON/Markdown.',domain:"requirements-validation",schema:Vo,streaming:!0,timeout:12e4};service=null;getService(){return this.service||(this.service=Kt()),this.service}async execute(e,t){let{assessmentName:n,epicPath:r,epicContent:i,sourcePaths:s,outputFormat:a="html",outputPath:o,evidencePoints:l,completedAnalysis:c,action:d="analyze"}=e;try{let m=this.getService();if(this.emitStream(t,{status:"starting",message:`Quality Criteria: ${d} - ${n}`,action:d}),this.isAborted(t))return{success:!1,error:"Operation aborted"};if(d==="validate-evidence"){if(!l||l.length===0)return{success:!1,error:"validate-evidence action requires evidencePoints array"};this.emitStream(t,{status:"validating",message:`Validating ${l.length} evidence points`});let f=m.validateEvidence(l);return{success:!0,data:{evidenceValidation:f,message:f.valid?`All ${l.length} evidence points are valid`:`Validation failed with ${f.errors.length} errors`}}}if(d==="format"){if(!c)return{success:!1,error:"format action requires completedAnalysis object"};this.emitStream(t,{status:"formatting",message:`Formatting analysis as ${a}`});let f,v,y;switch(a){case"html":f=m.generateHTML(c);break;case"json":v=JSON.stringify(c,null,2);break;case"markdown":y=m.generateMarkdown(c);break}return{success:!0,data:{html:f,json:v,markdown:y,message:`Analysis formatted as ${a}`}}}this.emitStream(t,{status:"preparing",message:"Preparing agent invocation for semantic HTSM analysis"});let g=i||"";if(r&&Uo(r)&&(g=Ho(r,"utf-8")),!g&&!r)return{success:!1,error:"Either epicPath or epicContent is required for analysis"};let h={required:!0,agentType:"qe-quality-criteria-recommender",prompt:this.buildAgentPrompt({assessmentName:n,epicContent:g,epicPath:r,sourcePaths:s,outputFormat:a,outputPath:o}),timeout:3e5,expectedOutput:"QualityCriteriaAnalysis",instructions:`Claude Code MUST spawn the qe-quality-criteria-recommender agent with this prompt. The agent will perform real semantic HTSM analysis using Claude's reasoning capabilities. Use: Task("HTSM Quality Criteria Analysis", { prompt: <this prompt> }, "qe-quality-criteria-recommender")`};return this.emitStream(t,{status:"agent-required",message:"Agent invocation prepared. Claude Code must spawn qe-quality-criteria-recommender agent.",agentType:"qe-quality-criteria-recommender"}),{success:!0,data:{agentInvocation:h,message:"AGENT INVOCATION REQUIRED: This tool cannot perform semantic HTSM analysis alone. Claude Code must spawn the qe-quality-criteria-recommender agent with the provided prompt."}}}catch(m){return{success:!1,error:`Quality Criteria tool failed: ${w(m)}`}}}buildAgentPrompt(e){let{assessmentName:t,epicContent:n,epicPath:r,sourcePaths:i,outputFormat:s,outputPath:a}=e,o=i&&i.length>0?`
|
|
594
534
|
## Source Paths to Analyze
|
|
595
535
|
${i.map(c=>`- ${c}`).join(`
|
|
596
536
|
`)}
|
|
@@ -619,11 +559,11 @@ ${o}
|
|
|
619
559
|
Perform HTSM v6.3 Quality Criteria analysis on the above requirements.
|
|
620
560
|
|
|
621
561
|
### HTSM Categories to Analyze
|
|
622
|
-
${
|
|
562
|
+
${Me.map((c,d)=>`${d+1}. ${c}`).join(`
|
|
623
563
|
`)}
|
|
624
564
|
|
|
625
565
|
### Categories That CANNOT Be Omitted
|
|
626
|
-
${
|
|
566
|
+
${De.map(c=>`- ${c}`).join(`
|
|
627
567
|
`)}
|
|
628
568
|
|
|
629
569
|
### Evidence Classification
|
|
@@ -664,16 +604,16 @@ Return a complete QualityCriteriaAnalysis object with:
|
|
|
664
604
|
${l}
|
|
665
605
|
## Begin Analysis
|
|
666
606
|
|
|
667
|
-
Analyze the requirements above and return the complete QualityCriteriaAnalysis.`}resetInstanceCache(){this.service=null}},ec={type:"object",properties:{assessmentName:{type:"string",description:"Assessment name (e.g., Epic title or feature name)"},epicPath:{type:"string",description:"Path to epic/requirements document"},epicContent:{type:"string",description:"Epic content as string (alternative to epicPath)"},sourcePaths:{type:"array",description:"Source code paths to analyze for evidence",items:{type:"string",description:"Source path glob pattern"}},outputFormat:{type:"string",description:"Output format for the report",enum:["html","json","markdown"],default:"html"},outputPath:{type:"string",description:"Path to save the output report"},evidencePoints:{type:"array",description:"Evidence points to validate (for validate-evidence action)",items:{type:"object",description:"Evidence point object",properties:{sourceReference:{type:"string",description:"Source reference in file:line format"},type:{type:"string",enum:["Direct","Inferred","Claimed"],description:"Evidence type"},qualityImplication:{type:"string",description:"Quality implication of this evidence"},reasoning:{type:"string",description:"Reasoning explaining WHY it matters"}},required:["sourceReference","type","qualityImplication","reasoning"]}},completedAnalysis:{type:"object",description:"Completed QualityCriteriaAnalysis object (for format action)"},action:{type:"string",description:'Action to perform. "analyze" (default) returns agentInvocation for real analysis. "validate-evidence" validates evidence format. "format" formats completed analysis.',enum:["analyze","validate-evidence","format"],default:"analyze"}},required:["assessmentName"]},rf=new Qe;k();import*as gr from"fs";import*as le from"path";var en=class extends x{config={name:"qe/code/analyze",description:"Analyze code using knowledge graph and semantic search. Supports indexing, searching, impact analysis, and dependency mapping.",domain:"code-intelligence",schema:tc,streaming:!0,timeout:3e5};knowledgeGraph=null;semanticAnalyzer=null;impactAnalyzer=null;async getKnowledgeGraph(e){if(!this.knowledgeGraph){let t=e.memory;this.knowledgeGraph=new Fr(t||await F())}return this.knowledgeGraph}async getSemanticAnalyzer(e){if(!this.semanticAnalyzer){let t=e.memory;this.semanticAnalyzer=new Nr(t||await F())}return this.semanticAnalyzer}async getImpactAnalyzer(e){if(!this.impactAnalyzer){let t=e.memory,n=await this.getKnowledgeGraph(e);this.impactAnalyzer=new Lr(t||await F(),n)}return this.impactAnalyzer}async execute(e,t){let{action:n,paths:r=["."],query:i,changedFiles:s=[],depth:a=3,incremental:o=!1}=e;try{if(this.emitStream(t,{status:"processing",message:`Executing ${n} action`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let l={action:n};switch(n){case"index":l.indexResult=await this.executeIndex(r,o,t);break;case"search":if(!i)return{success:!1,error:"Query is required for search action"};l.searchResult=await this.executeSearch(i,r,t);break;case"impact":if(s.length===0)return{success:!1,error:"changedFiles is required for impact action"};l.impactResult=await this.executeImpact(s,a,t);break;case"dependencies":l.dependencyResult=await this.executeDependencies(r,a,t);break;default:return{success:!1,error:`Unknown action: ${n}`}}return this.emitStream(t,{status:"complete",message:`${n} complete`,progress:100}),{success:!0,data:l}}catch(l){return{success:!1,error:`Code analysis failed: ${w(l)}`}}}async executeIndex(e,t,n){this.emitStream(n,{status:"indexing",message:`Indexing ${e.length} paths (${t?"incremental":"full"})`});let r=await this.getKnowledgeGraph(n),i=await this.expandPaths(e),s=await r.index({paths:i,incremental:t,includeTests:!0,languages:["typescript","javascript"]});if(!s.success)throw new Error(s.error?.message||"Indexing failed");return{filesIndexed:s.value.filesIndexed,nodesCreated:s.value.nodesCreated,edgesCreated:s.value.edgesCreated,duration:s.value.duration,errors:s.value.errors}}async executeSearch(e,t,n){let r=Date.now();if(this.isDemoMode(n)){let l=Date.now()-r;return this.markAsDemoData(n,"Demo mode explicitly requested"),this.getDemoSearchResult(e,l)}this.emitStream(n,{status:"searching",message:`Searching for: ${e}`});let s=await(await this.getSemanticAnalyzer(n)).search({query:e,type:"semantic",limit:20,scope:t.length>0&&t[0]!=="."?t:void 0}),a=Date.now()-r;return s.success?s.value.results.length===0?(this.markAsRealData(),{results:[],total:0,searchTime:a}):(this.markAsRealData(),{results:s.value.results.map(l=>({file:l.file,line:l.line,snippet:l.snippet.substring(0,200)+(l.snippet.length>200?"...":""),score:l.score,highlights:nc(l.snippet,e)})),total:s.value.total,searchTime:a}):{results:[],total:0,searchTime:a}}getDemoSearchResult(e,t){return{results:[{file:"src/services/UserService.ts",line:15,snippet:`export class ${e} { constructor() { /* initialization */ } }...`,score:.95,highlights:[e,`class ${e}`,`${e}Service`]},{file:"src/handlers/user-handler.ts",line:42,snippet:`const service = new ${e}(); await service.initialize()...`,score:.85,highlights:[`new ${e}()`,`service.${e.toLowerCase()}`]},{file:"tests/services/UserService.test.ts",line:8,snippet:`describe('${e}', () => { it('should initialize correctly'...`,score:.78,highlights:[`describe('${e}'`,`test ${e}`]}],total:3,searchTime:t}}getDemoImpactResult(e){let t=e[0]||"src/service.ts",n=t.split("/").pop()?.replace(".ts","")||"service";return{directImpact:[{file:`src/handlers/${n}-handler.ts`,reason:`Direct import from ${t}`,distance:0,riskScore:.75},{file:`src/controllers/${n}-controller.ts`,reason:`Uses exported functions from ${t}`,distance:0,riskScore:.65}],transitiveImpact:[{file:"src/routes/api.ts",reason:`Imports from ${n}-handler.ts`,distance:1,riskScore:.45},{file:"src/app.ts",reason:"Imports API routes",distance:2,riskScore:.25}],impactedTests:[`tests/${n}.test.ts`,`tests/${n}-handler.test.ts`,"tests/integration/api.test.ts"],riskLevel:"medium",recommendations:[`Review changes in ${t} for breaking changes`,"Run affected test suites before merging","Consider updating dependent documentation"]}}async executeImpact(e,t,n){if(this.isDemoMode(n))return this.markAsDemoData(n,"Demo mode explicitly requested"),this.getDemoImpactResult(e);this.emitStream(n,{status:"analyzing",message:`Analyzing impact of ${e.length} changed files`});try{let i=await(await this.getImpactAnalyzer(n)).analyzeImpact({changedFiles:e,depth:t,includeTests:!0});if(!i.success)return{directImpact:[],transitiveImpact:[],impactedTests:[],riskLevel:"low",recommendations:[`Impact analysis failed: ${i.error?.message||"Unknown error"}. Ensure the code index is built first using action: 'index'.`]};this.markAsRealData();let s=i.value;return{directImpact:s.directImpact,transitiveImpact:s.transitiveImpact,impactedTests:s.impactedTests,riskLevel:s.riskLevel,recommendations:s.recommendations}}catch(r){return{directImpact:[],transitiveImpact:[],impactedTests:[],riskLevel:"low",recommendations:[`Impact analysis error: ${r instanceof Error?r.message:"Unknown error"}. Check that files exist and index is built.`]}}}async executeDependencies(e,t,n){this.emitStream(n,{status:"mapping",message:`Mapping dependencies to depth ${t}`});let r=await this.getKnowledgeGraph(n),i=await this.expandPaths(e),s=await r.mapDependencies({files:i,direction:"both",depth:t});if(!s.success)throw new Error(s.error?.message||"Dependency mapping failed");let a=s.value,o=a.nodes.map(c=>({id:c.id,path:c.path,type:c.type,inDegree:c.inDegree,outDegree:c.outDegree})),l=a.edges.map(c=>({source:c.source,target:c.target,type:c.type}));return{nodes:o,edges:l,cycles:a.cycles,metrics:{totalNodes:a.metrics.totalNodes,totalEdges:a.metrics.totalEdges,avgDegree:a.metrics.avgDegree,maxDepth:a.metrics.maxDepth}}}async expandPaths(e){let t=[];for(let n of e){let r=le.isAbsolute(n)?n:le.resolve(process.cwd(),n);try{let i=await gr.promises.stat(r);if(i.isDirectory()){let s=await this.findSourceFiles(r);t.push(...s)}else i.isFile()&&t.push(r)}catch{}}return t}async findSourceFiles(e){let t=[],n=[".ts",".tsx",".js",".jsx"],r=["node_modules",".git","dist","build","coverage"];try{let i=await gr.promises.readdir(e,{withFileTypes:!0});for(let s of i){let a=le.join(e,s.name);if(s.isDirectory()){if(!r.includes(s.name)){let o=await this.findSourceFiles(a);t.push(...o)}}else if(s.isFile()){let o=le.extname(s.name);n.includes(o)&&t.push(a)}}}catch{}return t}},tc={type:"object",properties:{action:{type:"string",description:"Analysis action to perform",enum:["index","search","impact","dependencies"]},paths:{type:"array",description:"Paths to analyze",items:{type:"string",description:"File or directory path"},default:["."]},query:{type:"string",description:"Search query (for search action)"},changedFiles:{type:"array",description:"Changed files to analyze (for impact action)",items:{type:"string",description:"File path"}},depth:{type:"number",description:"Analysis depth",minimum:1,maximum:10,default:3},incremental:{type:"boolean",description:"Incremental indexing (for index action)",default:!1}},required:["action"]};function nc(u,e){let t=[],n=e.toLowerCase().split(/\s+/),r=u.toLowerCase();for(let i of n){if(i.length<2)continue;let s=0;for(;(s=r.indexOf(i,s))!==-1;){let a=Math.max(0,s-20),o=Math.min(u.length,s+i.length+20),l=u.substring(a,o);if(t.includes(l)||t.push(l),s+=i.length,t.length>=3)break}if(t.length>=3)break}return t}k();U();var gs=[{id:"secret-key-assignment",pattern:/(?:SECRET_KEY|secret_key|SECRET|PRIVATE_KEY)\s*=\s*['"][^'"]{4,}['"]/g,severity:"critical",title:"Hardcoded Secret Key",description:"Secret key assigned as string literal in source code",cweId:"CWE-798",remediation:'Use environment variables: SECRET_KEY = os.environ["SECRET_KEY"]'},{id:"cors-wildcard-credentials",pattern:/allow_origins\s*=\s*\[\s*["']\*["']\s*\]/g,severity:"high",title:"CORS Wildcard Origin",description:"CORS configured to allow all origins \u2014 combined with credentials this is a security risk",cweId:"CWE-942",remediation:"Restrict CORS origins to specific trusted domains"},{id:"cors-allow-credentials-wildcard",pattern:/allow_credentials\s*=\s*True/g,severity:"medium",title:"CORS Credentials Enabled",description:"CORS credentials enabled \u2014 verify origins are restricted",cweId:"CWE-942",remediation:'Ensure allow_origins does not include "*" when credentials are enabled'},{id:"token-hardcoded",pattern:/(?:token|TOKEN)\s*[:=]\s*['"][a-zA-Z0-9_\-.]{20,}['"]/g,severity:"high",title:"Hardcoded Token",description:"Hardcoded token found in source code",cweId:"CWE-798",remediation:"Use environment variables or secrets manager for tokens"}],tn=class extends x{config={name:"qe/security/scan",description:"Comprehensive security scanning including SAST, DAST, dependency analysis, and compliance validation.",domain:"security-compliance",schema:rc,streaming:!0,timeout:6e5};async execute(e,t){let{target:n=".",scanType:r=["sast","dependency"],compliance:i=[],dastUrl:s,depth:a="standard",failOnSeverity:o="critical"}=e,l=Date.now();try{if(this.emitStream(t,{status:"scanning",message:`Starting security scan (${r.join(", ")})`,depth:a}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let c=await ac(n,a);this.emitStream(t,{status:"discovered",message:`Found ${c.length} files to scan`});let d=[];if(r.includes("sast")||r.includes("secret")){this.emitStream(t,{status:"sast",message:"Running static analysis"});let y=await oc(c,r);d.push(...y)}if(r.includes("dependency")){this.emitStream(t,{status:"dependency",message:"Scanning dependencies"});let y=await cc(n);d.push(...y)}r.includes("dast")&&s&&(this.emitStream(t,{status:"dast",message:`Scanning ${s}`}),d.push(...hc(s)));let m=i.map(y=>fc(y,d)),p={critical:d.filter(y=>y.severity==="critical").length,high:d.filter(y=>y.severity==="high").length,medium:d.filter(y=>y.severity==="medium").length,low:d.filter(y=>y.severity==="low").length,informational:d.filter(y=>y.severity==="informational").length,totalFiles:c.length,scanDurationMs:Date.now()-l},g=["critical","high","medium","low","informational"],h=g.indexOf(o),v=(d.length>0?Math.min(...d.map(y=>g.indexOf(y.severity))):g.length)>h;return this.emitStream(t,{status:"complete",message:`Scan complete: ${d.length} vulnerabilities found in ${c.length} files`,progress:100}),{success:!0,data:{scanId:t.requestId,summary:p,vulnerabilities:d,complianceResults:m.length>0?m:void 0,recommendations:yc(d,p),passed:v}}}catch(c){return{success:!1,error:`Security scan failed: ${w(c)}`}}}},rc={type:"object",properties:{target:{type:"string",description:"Target directory or file to scan",default:"."},scanType:{type:"array",description:"Types of security scans to run",items:{type:"string",description:"Scan type",enum:["sast","dast","dependency","secret"]},default:["sast","dependency"]},compliance:{type:"array",description:"Compliance standards to validate against",items:{type:"string",description:"Standard",enum:["owasp","gdpr","hipaa","pci-dss","soc2"]}},dastUrl:{type:"string",description:"URL for DAST scanning"},depth:{type:"string",description:"Scan depth",enum:["quick","standard","deep"],default:"standard"},failOnSeverity:{type:"string",description:"Fail threshold severity",enum:["critical","high","medium","low"],default:"critical"}}},ic=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs",".py",".pyw",".java",".kt",".scala",".go",".rb",".php",".rs",".cs",".yaml",".yml",".json",".toml",".cfg",".ini",".env",".env.local",".env.production",".sh",".bash"]),sc=new Set(["node_modules",".git","__pycache__",".venv","venv","dist","build",".next",".nuxt","coverage",".tox"]);async function ac(u,e){let t=await import("fs"),n=await import("path"),r=n.resolve(u),i=[],s=e==="quick"?50:e==="standard"?500:2e3,a=e==="quick"?3:e==="standard"?8:20;function o(l,c){if(i.length>=s||c>a)return;let d;try{d=t.readdirSync(l,{withFileTypes:!0})}catch{return}for(let m of d){if(i.length>=s)break;let p=n.join(l,m.name);if(m.isDirectory()){let g=new Set([".github",".docker",".aws",".circleci",".gitlab"]);sc.has(m.name)||m.name.startsWith(".")&&!g.has(m.name)||o(p,c+1)}else if(m.isFile()){let g=n.extname(m.name).toLowerCase();(ic.has(g)||m.name==="Dockerfile"||m.name==="Makefile"||m.name.startsWith(".env"))&&i.push(p)}}}try{t.statSync(r).isFile()?i.push(r):o(r,0)}catch{}return i}async function oc(u,e){let t=await import("fs"),n=await import("path"),r=[],i=0,s=[];if(e.includes("sast")){for(let a of Br)s.push({id:a.id,pattern:new RegExp(a.pattern.source,a.pattern.flags),severity:a.severity,title:a.title,description:a.description,cweId:a.cweId,remediation:a.remediation,category:a.category});for(let a of gs)s.push({id:a.id,pattern:new RegExp(a.pattern.source,a.pattern.flags),severity:a.severity,title:a.title,description:a.description,cweId:a.cweId,remediation:a.remediation,category:"sensitive-data"})}if(e.includes("secret")){for(let a of $r)s.some(o=>o.id===a.id)||s.push({id:a.id,pattern:new RegExp(a.pattern.source,a.pattern.flags),severity:a.severity,title:a.title,description:a.description,cweId:a.cweId,remediation:a.remediation,category:a.category});for(let a of gs)s.some(o=>o.id===a.id)||s.push({...a,category:"sensitive-data"})}for(let a of u){let o;try{o=t.readFileSync(a,"utf-8")}catch{continue}if(o.includes("\0")||o.length>1e6)continue;let l=o.split(`
|
|
668
|
-
`),c=n.relative(process.cwd(),a);for(let d of s){let m=new RegExp(d.pattern.source,d.pattern.flags),
|
|
669
|
-
`).length,h=l[
|
|
670
|
-
`).map(e=>e.trim()).filter(e=>e&&!e.startsWith("#")).map(e=>e.split(/[>=<!~\[]/)[0].trim().toLowerCase()).filter(Boolean)}function hs(u,e){let t=[];for(let n of u){let r=dc[n];r&&t.push({id:`DEP-py-${n}-${r.cve}`,title:`Vulnerable Python dependency: ${n}`,severity:r.severity,category:"vulnerable-components",location:{file:e,dependency:{name:n,version:"any"}},description:r.desc,remediation:n==="python-jose"?"Migrate to PyJWT or joserfc":`Check for updates to ${n}`,cveId:r.cve,references:[`https://nvd.nist.gov/vuln/detail/${r.cve}`]})}return t}function gc(u,e){let t=u.split(".").map(Number),n=e.split(".").map(Number);for(let r=0;r<3;r++){let i=t[r]||0,s=n[r]||0;if(i<s)return-1;if(i>s)return 1}return 0}function hc(u){return[{id:"DAST-INFO-001",title:"DAST scan target noted",severity:"informational",category:"security-misconfiguration",location:{file:u},description:`DAST target ${u} recorded. Full DAST requires integration with a dynamic scanner (e.g., ZAP, Burp).`,remediation:"Configure a DAST tool to scan the live application",references:["https://owasp.org/www-project-zap/"]}]}function fc(u,e){let t=e.filter(n=>u==="owasp"?!0:u==="pci-dss"?n.category==="injection"||n.category==="sensitive-data":u==="gdpr"?n.category==="sensitive-data":!1);return{standard:u,passed:t.filter(n=>n.severity==="critical"||n.severity==="high").length===0,score:Math.max(0,100-t.length*15),violations:t.map(n=>({ruleId:n.id,ruleName:n.title,location:n.location,details:n.description,remediation:n.remediation}))}}function yc(u,e){let t=[];return e.critical>0&&t.push("URGENT: Address critical vulnerabilities immediately"),e.high>0&&t.push("Prioritize high-severity issues in next sprint"),u.some(n=>n.category==="injection")&&t.push("Review input validation across the application"),u.some(n=>n.category==="sensitive-data")&&t.push("Implement proper secrets management"),u.some(n=>n.category==="vulnerable-components")&&t.push("Run full dependency audit and update vulnerable packages"),t.length===0&&t.push("No critical issues found. Continue regular security reviews."),t}U();k();function fs(u){try{let e=new URL(u);if(!["http:","https:"].includes(e.protocol))return{valid:!1,error:`Invalid protocol: ${e.protocol}. Only http/https allowed.`};let t=e.hostname.toLowerCase(),n=[/^localhost$/i,/^127\./,/^10\./,/^172\.(1[6-9]|2[0-9]|3[01])\./,/^192\.168\./,/^0\.0\.0\.0$/,/^\[::1\]$/,/^169\.254\./];for(let r of n)if(r.test(t))return{valid:!1,error:`Blocked hostname: ${t}. Cannot access internal/private addresses.`};return{valid:!0}}catch{return{valid:!1,error:`Invalid URL format: ${u}`}}}var nn=class extends x{config={name:"qe/contracts/validate",description:"Validate API contracts, detect breaking changes, and verify provider-consumer compatibility.",domain:"contract-testing",schema:vc,streaming:!0,timeout:18e4};contractValidator=null;apiCompatibility=null;async getServices(e){if(!this.contractValidator||!this.apiCompatibility){let t=e.memory||await F();this.contractValidator=new Ur({memory:t}),this.apiCompatibility=new jr(t)}return{contractValidator:this.contractValidator,apiCompatibility:this.apiCompatibility}}async execute(e,t){let{contractPath:n,contractContent:r,providerUrl:i,consumerName:s,baselineVersion:a,baselineContent:o,checkBreakingChanges:l=!0,format:c="openapi"}=e,{contractValidator:d,apiCompatibility:m}=await this.getServices(t);try{if(!n&&!r)return{success:!1,error:"Either contractPath or contractContent is required"};if(this.emitStream(t,{status:"validating",message:`Validating ${c} contract`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let p=r||n||"",g=[],h,f,v;if(c==="openapi"){let b=await d.validateOpenAPI(p);if(b.success){let E=b.value;for(let S of E.errors)g.push({path:S.path,message:S.message,code:S.code,severity:"error"});for(let S of E.warnings)g.push({path:"",message:S,code:"WARNING",severity:"warning"});this.emitStream(t,{status:"analyzed",message:`Found ${E.endpointCount} endpoints, ${E.schemaCount} schemas`})}}else{let b=this.buildContractFromContent(p,c,s),E=await d.validateContract(b);if(E.success){let S=E.value;for(let T of S.errors)g.push(this.convertValidationError(T));for(let T of S.warnings)g.push({path:"",message:T,code:"WARNING",severity:"warning"})}}if(l&&(a||o)){this.emitStream(t,{status:"comparing",message:"Detecting breaking changes"});let b=this.buildContractFromContent(p,c,s),E=this.buildContractFromContent(o||p,c,s,a),S=await m.compareVersions(E,b);S.success?(h=S.value.breakingChanges.map(T=>this.convertBreakingChange(T)),v={isBackwardCompatible:S.value.isCompatible,breakingChangeCount:S.value.breakingChanges.length,nonBreakingChangeCount:S.value.nonBreakingChanges.length,deprecations:S.value.deprecations.map(T=>this.convertDeprecation(T))}):v=this.generateDefaultCompatibility(g,h)}else v=this.generateDefaultCompatibility(g,h);i&&(this.emitStream(t,{status:"verifying",message:"Verifying against provider"}),f=await this.verifyAgainstProvider(i,s||"default",p,c,d));let y=g.filter(b=>b.severity==="error").length===0,C=this.generateRecommendations(g,h,f);return this.emitStream(t,{status:"complete",message:y?"Contract is valid":`Found ${g.length} issues`,progress:100}),{success:!0,data:{isValid:y,validationErrors:g,breakingChanges:h,verificationResult:f,compatibility:v,recommendations:C}}}catch(p){return{success:!1,error:`Contract validation failed: ${w(p)}`}}}buildContractFromContent(e,t,n,r){let i=`contract-${Date.now()}`,s=zr.parse(r||"1.0.0"),a=[],o=[];if(t==="openapi")try{let l=P(e),d=l.components?.schemas||{};for(let[p,g]of Object.entries(d))a.push({id:p,name:p,type:"openapi",content:JSON.stringify(g)});let m=l.paths||{};for(let[p,g]of Object.entries(m))if(typeof g=="object"&&g!==null){let h=g,f=["get","post","put","patch","delete","head","options"];for(let v of f)v in h&&o.push({path:p,method:v.toUpperCase(),examples:[]})}}catch{}else if(t==="graphql")a.push({id:"graphql-schema",name:"GraphQL Schema",type:"graphql",content:e});else if(t==="pact")try{let c=P(e).interactions||[];for(let d of c){let m=d.request;m&&o.push({path:m.path||"/",method:(m.method||"GET").toUpperCase(),examples:[]})}}catch{}return{id:i,name:`${t}-contract`,version:s,type:t,provider:{name:"provider",version:"1.0.0"},consumers:[{name:n||"default",version:"1.0.0"}],endpoints:o,schemas:a}}convertValidationError(e){return{path:e.path,message:e.message,code:e.code,severity:"error"}}convertBreakingChange(e){return{type:e.type,location:e.location,description:e.description,impact:e.impact,affectedConsumers:e.affectedConsumers,migrationPath:e.migrationPath}}convertDeprecation(e){return{location:e.location,reason:e.reason,removalVersion:e.removalVersion,replacement:e.replacement}}generateDefaultCompatibility(e,t){return{isBackwardCompatible:!t||t.length===0,breakingChangeCount:t?.length||0,nonBreakingChangeCount:e.filter(n=>n.severity!=="error").length,deprecations:[]}}async verifyAgainstProvider(e,t,n,r,i){let s=[],a=[],o=fs(e);if(!o.valid)return{provider:e,consumer:t,passed:!1,failures:[{endpoint:e,type:"validation-error",expected:"Valid HTTP/HTTPS URL",actual:o.error||"Invalid URL",message:`Provider URL validation failed: ${o.error}`}],warnings:[]};let l=this.buildContractFromContent(n,r,t);for(let c of l.endpoints)try{let d=`${e}${c.path}`,m=fs(d);if(!m.valid){s.push({endpoint:`${c.method} ${c.path}`,type:"validation-error",expected:"Valid URL",actual:m.error||"Invalid URL",message:`URL validation failed: ${m.error}`});continue}let p=await fetch(d,{method:c.method==="GET"?"GET":"OPTIONS",headers:{Accept:"application/json"}});if(!p.ok&&p.status!==405&&(p.status===404?s.push({endpoint:`${c.method} ${c.path}`,type:"missing-endpoint",expected:"Endpoint should exist",actual:`Got ${p.status}`,message:"Endpoint not found at provider"}):a.push({endpoint:`${c.method} ${c.path}`,message:`Unexpected status ${p.status}`,severity:"medium"})),c.responseSchema&&p.ok){let g=await p.json(),h=l.schemas.find(f=>f.id===c.responseSchema);if(h){let f=await i.validateResponse(g,h);if(f.success&&!f.value.isValid)for(let v of f.value.errors)s.push({endpoint:`${c.method} ${c.path}`,type:"schema-mismatch",expected:`Schema ${c.responseSchema}`,actual:v.message,message:`Response does not match schema: ${v.message}`})}}}catch(d){a.push({endpoint:`${c.method} ${c.path}`,message:`Failed to verify: ${w(d)}`,severity:"high"})}return{provider:e,consumer:t,passed:s.length===0,failures:s,warnings:a}}generateRecommendations(e,t,n){let r=[],i=e.filter(a=>a.severity==="error").length;if(i>0&&r.push(`Fix ${i} validation error${i>1?"s":""} before deploying`),t&&t.length>0){let a=t.filter(o=>o.impact==="high").length;a>0&&r.push(`Address ${a} high-impact breaking change${a>1?"s":""} before release`),r.push("Coordinate with affected consumers before releasing breaking changes"),r.push("Consider versioning the API to maintain backward compatibility")}n&&(n.passed||(r.push(`Provider verification failed with ${n.failures.length} failure${n.failures.length>1?"s":""}`),n.failures.filter(l=>l.type==="missing-endpoint").length>0&&r.push("Ensure all contract endpoints are implemented in the provider"),n.failures.filter(l=>l.type==="schema-mismatch").length>0&&r.push("Update provider responses to match the contract schema")),n.warnings.length>0&&n.warnings.filter(o=>o.severity==="high").length>0&&r.push("Investigate high-severity verification warnings"));let s=e.filter(a=>a.severity==="warning").length;return s>0&&r.push(`Review ${s} warning${s>1?"s":""} for potential issues`),r.length===0&&r.push("Contract is valid and backward compatible"),r}},vc={type:"object",properties:{contractPath:{type:"string",description:"Path to contract file"},contractContent:{type:"string",description:"Contract content as string"},providerUrl:{type:"string",description:"Provider URL for verification"},consumerName:{type:"string",description:"Consumer name for contract"},baselineVersion:{type:"string",description:"Baseline version for breaking change detection"},baselineContent:{type:"string",description:"Baseline contract content for comparison"},checkBreakingChanges:{type:"boolean",description:"Check for breaking changes",default:!0},format:{type:"string",description:"Contract format",enum:["openapi","pact","graphql","asyncapi"],default:"openapi"}}};k();var rn=class extends x{config={name:"qe/visual/compare",description:"Visual regression testing with screenshot comparison, diff detection, and baseline management.",domain:"visual-accessibility",schema:bc,streaming:!0,timeout:3e5};visualTester=null;async getService(e){if(!this.visualTester){let t=e.memory;this.visualTester=Hr(t||await F())}return this.visualTester}async execute(e,t){let{urls:n,viewports:r=[{width:1920,height:1080,name:"desktop"}],baselineDir:i=".visual-baselines",threshold:s=.1,fullPage:a=!0}=e;try{if(this.emitStream(t,{status:"capturing",message:`Capturing ${n.length} URLs across ${r.length} viewports`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};this.markAsRealData();let o=await this.getService(t),l=[],c=[];for(let m of n)for(let p of r){this.emitStream(t,{status:"comparing",message:`Comparing ${m} at ${p.width}x${p.height}`});let g={width:p.width,height:p.height,deviceScaleFactor:1,isMobile:p.isMobile||!1,hasTouch:p.isMobile||!1},h=await o.captureScreenshot(m,{viewport:g,fullPage:a});if(!h.success){l.push({url:m,viewport:p,status:"failed",diffPercentage:100,diffPixels:0});continue}let f=h.value,v=await o.getBaseline(m,g);if(!v)await o.setBaseline(f),c.push(f.path.value),l.push({url:m,viewport:p,status:"new",diffPercentage:0,diffPixels:0,screenshotPath:f.path.value});else{let y=await o.compare(f,v.id);if(!y.success){l.push({url:m,viewport:p,status:"failed",diffPercentage:100,diffPixels:0});continue}let C=y.value,b=C.diffPercentage<=s;l.push({url:m,viewport:p,status:b?"passed":"failed",diffPercentage:C.diffPercentage,diffPixels:C.diffPixels,screenshotPath:f.path.value,baselinePath:v.path.value,diffImagePath:C.diffImagePath?.value,regions:C.regions?.map(E=>({x:E.x,y:E.y,width:E.width,height:E.height,changeType:E.changeType,significance:E.significance}))})}}let d={total:l.length,passed:l.filter(m=>m.status==="passed").length,failed:l.filter(m=>m.status==="failed").length,new:l.filter(m=>m.status==="new").length,avgDiffPercentage:l.length>0?l.reduce((m,p)=>m+p.diffPercentage,0)/l.length:0};return this.emitStream(t,{status:"complete",message:`Visual comparison complete: ${d.passed}/${d.total} passed`,progress:100}),{success:!0,data:{comparisons:l,summary:d,newBaselines:c,recommendations:Sc(l,d)}}}catch(o){return{success:!1,error:`Visual comparison failed: ${w(o)}`}}}},sn=class extends x{config={name:"qe/a11y/audit",description:"WCAG accessibility auditing with violation detection, contrast checking, and keyboard navigation testing.",domain:"visual-accessibility",schema:Cc,streaming:!0,timeout:18e4};accessibilityTester=null;async getService(e){if(!this.accessibilityTester){let t=e.memory;this.accessibilityTester=new Vr(t||await F(),{enableColorContrastCheck:!0,enableKeyboardCheck:!0})}return this.accessibilityTester}async execute(e,t){let{urls:n,standard:r="wcag21-aa",includeWarnings:i=!0,checkContrast:s=!0,checkKeyboard:a=!0}=e;try{if(this.emitStream(t,{status:"auditing",message:`Auditing ${n.length} URLs against ${r}`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};this.markAsRealData();let o=await this.getService(t),l=[],c=Tc(r);for(let g of n){this.emitStream(t,{status:"scanning",message:`Scanning ${g}`});let h=await o.audit(g,{wcagLevel:c,includeWarnings:i});if(!h.success){l.push({url:g,score:0,passed:!1,violations:[],warnings:[],passedRules:0});continue}let f=h.value,v=[];if(s){let S=await o.checkContrast(g);if(S.success){let T=S.value.filter(R=>!R.passes);T.length>0&&(v=T.map(R=>({id:"color-contrast",impact:"serious",description:"Elements must have sufficient color contrast",help:`Element ${R.element} has contrast ratio ${R.ratio}:1 but requires ${R.requiredRatio}:1`,helpUrl:"https://www.w3.org/WAI/WCAG22/Understanding/contrast-minimum",wcagCriteria:["1.4.3"],nodes:[{selector:R.element,html:`<${R.element.replace(".",' class="')}>...</${R.element.split(".")[0]}>`,failureSummary:`Contrast ratio ${R.ratio}:1 is below required ${R.requiredRatio}:1`,fixSuggestion:`Change foreground color to achieve at least ${R.requiredRatio}:1 contrast`}]})))}}let y=[];if(a){let S=await o.checkKeyboardNavigation(g);if(S.success){let T=S.value;for(let R of T.issues)y.push({id:R.type,impact:R.type==="no-focus-indicator"?"serious":"moderate",description:R.description,help:"Ensure keyboard navigation is fully supported",helpUrl:"https://www.w3.org/WAI/WCAG22/Understanding/focus-visible",wcagCriteria:["2.4.7"],nodes:[{selector:R.selector,html:`<element>${R.selector}</element>`,failureSummary:R.description,fixSuggestion:"Add visible focus styles with :focus or :focus-visible"}]});for(let R of T.traps)y.push({id:"keyboard-trap",impact:"critical",description:R.description,help:R.escapePath||"No escape path available",helpUrl:"https://www.w3.org/WAI/WCAG22/Understanding/no-keyboard-trap",wcagCriteria:["2.1.2"],nodes:[{selector:R.selector,html:`<element>${R.selector}</element>`,failureSummary:R.description,fixSuggestion:R.escapePath}]})}}let C=[...f.violations.map(S=>({id:S.id,impact:S.impact,description:S.description,help:S.help,helpUrl:S.helpUrl,wcagCriteria:S.wcagCriteria.map(T=>T.id),nodes:S.nodes.map(T=>({selector:T.selector,html:T.html,failureSummary:T.failureSummary,fixSuggestion:T.fixSuggestion}))})),...v,...y],b=f.incomplete.map(S=>({id:S.id,description:S.description,nodes:S.nodes.length})),E=C.some(S=>S.impact==="critical"||S.impact==="serious");l.push({url:g,score:f.score,passed:!E,violations:C,warnings:b,passedRules:f.passes.length})}let d={totalUrls:l.length,passingUrls:l.filter(g=>g.passed).length,avgScore:l.length>0?Math.round(l.reduce((g,h)=>g+h.score,0)/l.length):0,criticalViolations:l.reduce((g,h)=>g+h.violations.filter(f=>f.impact==="critical").length,0),seriousViolations:l.reduce((g,h)=>g+h.violations.filter(f=>f.impact==="serious").length,0),totalViolations:l.reduce((g,h)=>g+h.violations.length,0)},m=Ec(l),p=wc(m);return this.emitStream(t,{status:"complete",message:`Audit complete: avg score ${d.avgScore}%`,progress:100}),{success:!0,data:{audits:l,summary:d,topIssues:m,remediationPlan:p}}}catch(o){return{success:!1,error:`Accessibility audit failed: ${w(o)}`}}}},bc={type:"object",properties:{urls:{type:"array",description:"URLs to capture and compare",items:{type:"string",description:"URL"}},viewports:{type:"array",description:"Viewport configurations",items:{type:"object",description:"Viewport",properties:{width:{type:"number",description:"Width in pixels"},height:{type:"number",description:"Height in pixels"},name:{type:"string",description:"Viewport name"}}}},baselineDir:{type:"string",description:"Directory for baseline images",default:".visual-baselines"},threshold:{type:"number",description:"Acceptable diff percentage (0-1)",minimum:0,maximum:1,default:.1},fullPage:{type:"boolean",description:"Capture full page",default:!0},hideSelectors:{type:"array",description:"CSS selectors to hide before capture",items:{type:"string",description:"Selector"}},waitForSelector:{type:"string",description:"Wait for selector before capture"}},required:["urls"]},Cc={type:"object",properties:{urls:{type:"array",description:"URLs to audit",items:{type:"string",description:"URL"}},standard:{type:"string",description:"WCAG standard to validate against",enum:["wcag21-aa","wcag21-aaa","wcag22-aa","section508"],default:"wcag21-aa"},includeWarnings:{type:"boolean",description:"Include warnings in results",default:!0},checkContrast:{type:"boolean",description:"Check color contrast",default:!0},checkKeyboard:{type:"boolean",description:"Check keyboard navigation",default:!0},rules:{type:"array",description:"Specific rules to check",items:{type:"string",description:"Rule ID"}}},required:["urls"]};function Tc(u){return u==="wcag21-aaa"?"AAA":"AA"}function Sc(u,e){let t=[];return e.failed>0&&t.push(`Review ${e.failed} failed comparisons for intentional vs unintentional changes`),e.new>0&&t.push(`${e.new} new baselines created - review and approve if correct`),e.avgDiffPercentage>1&&t.push("Consider increasing diff threshold or reviewing major changes"),t.length>0?t:["All visual tests passed"]}function Ec(u){let e=new Map;for(let t of u)for(let n of t.violations){let r=e.get(n.id);r?(r.occurrences++,r.affectedUrls.includes(t.url)||r.affectedUrls.push(t.url)):e.set(n.id,{ruleId:n.id,description:n.description,occurrences:1,impact:n.impact,affectedUrls:[t.url]})}return Array.from(e.values()).sort((t,n)=>n.occurrences-t.occurrences)}function wc(u){return u.map((e,t)=>({violationId:e.ruleId,description:e.description,fix:`Fix ${e.ruleId} across ${e.occurrences} occurrences`,effort:e.occurrences>10?"moderate":"minor",priority:t+1}))}k();var an=class extends x{config={name:"qe/chaos/inject",description:"Inject faults for chaos engineering. Supports latency, errors, CPU/memory stress, network issues, and more.",domain:"chaos-resilience",schema:Rc,streaming:!0,timeout:3e5};chaosEngineer=null;async getService(e){if(!this.chaosEngineer){let t=e.memory||await F();this.chaosEngineer=new Qr({memory:t},{enableDryRun:!0,autoRollbackOnFailure:!0})}return this.chaosEngineer}async execute(e,t){let{faultType:n,target:r,duration:i=3e4,intensity:s=50,dryRun:a=!0,hypothesis:o,rollbackOnFailure:l=!0}=e,c=await this.getService(t);try{if(this.emitStream(t,{status:"preparing",message:`Preparing ${n} fault injection on ${r}`,dryRun:a}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let d=t.requestId||L(),m=this.buildExperiment(d,n,r,i,s,o,l);this.emitStream(t,{status:"verifying",message:"Verifying steady state"});let p=await c.verifySteadyState(m.steadyState),g=p.success&&p.value;if(!g&&!a)return{success:!1,error:"Steady state verification failed. System not in healthy state for chaos experiment."};let h=await c.createExperiment(m);if(!h.success)return{success:!1,error:`Failed to create experiment: ${h.error.message}`};this.emitStream(t,{status:"injecting",message:a?`[DRY RUN] Simulating ${n} fault`:`Injecting ${n} fault`});let f=!1,v,y="pending",C=[],b={faultDuration:i,targetAffected:!a};if(a)f=!1,y="completed",b=this.simulateMetrics(n,i,s),o&&(v=this.validateHypothesisText(o,b,C));else{let T=await c.runExperiment(d);if(T.success){let R=T.value;f=R.faultResults.some(D=>D.injected),v=R.hypothesisValidated,y=R.status;for(let D of R.incidents)C.push(this.convertIncident(D));b=this.extractMetrics(R,n,i)}else y="failed",C.push({type:"error",severity:"critical",message:T.error.message,timestamp:new Date().toISOString(),resolved:!1})}this.emitStream(t,{status:"monitoring",message:"Monitoring system behavior"});let E=this.collectIntensityIncidents(n,s,a);C.push(...E),!a&&C.some(T=>T.severity==="critical"&&!T.resolved)&&(y=l?"rolled-back":"failed");let S=this.generateRecommendations(n,b,C,v);return this.emitStream(t,{status:"complete",message:`Chaos experiment ${y}`,progress:100}),{success:!0,data:{experimentId:d,status:y,faultInjected:f,hypothesisValidated:v,steadyStateVerified:g,metrics:b,incidents:C,recommendations:S}}}catch(d){return{success:!1,error:`Chaos injection failed: ${w(d)}`}}}buildExperiment(e,t,n,r,i,s,a=!0){let o={id:`fault-${e}`,type:t,target:{type:"service",selector:n},duration:r,parameters:this.buildFaultParameters(t,i)},l={description:`Steady state for ${n}`,probes:[{name:"target-health",type:n.startsWith("http")?"http":"command",target:n.startsWith("http")?n:`echo "checking ${n}"`,expected:n.startsWith("http")?200:"OK",timeout:5e3}]},c=s||`System should remain stable under ${t} fault`;return{id:e,name:`${t}-experiment-${Date.now()}`,description:`Chaos experiment: ${t} on ${n}`,hypothesis:{statement:c,metrics:[{metric:t==="latency"?"response_time":"error_rate",operator:"lt",value:t==="latency"?5e3:50}],tolerances:[{metric:"availability",maxDeviation:20,unit:"percent"}]},steadyState:l,faults:[o],blastRadius:{scope:"single",maxAffected:1,excludeProduction:!0},rollbackPlan:{automatic:a,triggerConditions:[{type:"error-rate",condition:"error_rate > 50%"}],steps:[{order:1,action:"remove-fault",target:o.id,timeout:1e4}]},schedule:{type:"once"}}}buildFaultParameters(e,t){let n={};switch(e){case"latency":n.latencyMs=100+t*20;break;case"error":n.errorCode=500,n.errorRate=t/100;break;case"timeout":n.timeoutMs=5e3+t*250;break;case"cpu-stress":n.cpuPercent=t,n.cores=Math.max(1,Math.floor(t/25));break;case"memory-stress":n.memoryBytes=t/100*512*1024*1024;break;case"network-partition":n.partitionPercent=t;break;case"packet-loss":n.packetLossPercent=t;break;case"dns-failure":n.failureRate=t/100;break;case"process-kill":n.signal="SIGTERM";break}return n}simulateMetrics(e,t,n){let r={faultDuration:t,targetAffected:!1,recoveryTime:5e3+n*100};switch(e){case"latency":r.latencyP99=100+n*25;break;case"error":case"timeout":r.errorRate=n*.5;break;case"cpu-stress":case"memory-stress":r.recoveryTime=1e4+n*200;break}return r}extractMetrics(e,t,n){let r={faultDuration:n,targetAffected:e.faultResults.some(o=>o.injected&&o.affectedTargets>0)},i=e.metrics;e.endTime&&e.startTime&&(r.recoveryTime=e.endTime.getTime()-e.startTime.getTime());let s=i.find(o=>o.name.includes("latency")||o.name.includes("response"));s&&(r.latencyP99=s.value);let a=i.find(o=>o.name.includes("error")||o.name.includes("failure"));return a&&(r.errorRate=a.value),r}convertIncident(e){return{type:e.type,severity:e.severity,message:e.message,timestamp:e.timestamp instanceof Date?e.timestamp.toISOString():String(e.timestamp),resolved:e.resolved}}collectIntensityIncidents(e,t,n){let r=[];return n&&(t>70&&r.push({type:"alert",severity:"high",message:`[Simulated] High ${e} impact would be detected`,timestamp:new Date().toISOString(),resolved:!0}),t>90&&r.push({type:"degradation",severity:"critical",message:"[Simulated] Service degradation would occur",timestamp:new Date().toISOString(),resolved:!0})),r}validateHypothesisText(e,t,n){let r=e.toLowerCase();if(r.includes("recover")&&t.recoveryTime){let i=e.match(/(\d+)s/);if(i){let s=parseInt(i[1])*1e3;return t.recoveryTime<=s}}return r.includes("no critical")?!n.some(i=>i.severity==="critical"&&!i.resolved):r.includes("stable")||r.includes("remain")?!n.some(i=>i.severity==="critical"&&!i.resolved):!n.some(i=>i.severity==="critical"&&!i.resolved)}generateRecommendations(e,t,n,r){let i=[];switch(r===!1&&i.push("Hypothesis was not validated - review resilience patterns"),t.recoveryTime&&t.recoveryTime>3e4&&i.push("Recovery time exceeds 30s - consider adding circuit breakers"),t.errorRate&&t.errorRate>20&&i.push("High error rate observed - implement retry with backoff"),n.some(s=>s.severity==="critical")&&i.push("Critical incidents occurred - review fault tolerance mechanisms"),e){case"latency":t.latencyP99&&t.latencyP99>1e3&&i.push("P99 latency exceeds 1s - consider timeout configurations");break;case"network-partition":i.push("Ensure services can operate in degraded mode during network issues");break;case"cpu-stress":case"memory-stress":i.push("Review resource limits and auto-scaling policies");break;case"error":i.push("Implement proper error handling and fallback mechanisms");break;case"timeout":i.push("Configure appropriate timeout values and circuit breakers");break}return i.length===0&&i.push("System showed good resilience - continue regular chaos experiments"),i}},Rc={type:"object",properties:{faultType:{type:"string",description:"Type of fault to inject",enum:["latency","error","timeout","cpu-stress","memory-stress","network-partition","packet-loss","dns-failure","process-kill"]},target:{type:"string",description:"Target service, pod, or endpoint"},duration:{type:"number",description:"Fault duration in milliseconds",minimum:1e3,maximum:3e5,default:3e4},intensity:{type:"number",description:"Fault intensity (0-100)",minimum:0,maximum:100,default:50},dryRun:{type:"boolean",description:"Simulate without actual injection",default:!0},hypothesis:{type:"string",description:'Hypothesis to validate (e.g., "System should recover within 30s")'},rollbackOnFailure:{type:"boolean",description:"Auto-rollback on critical failure",default:!0}},required:["faultType","target"]};k();ze();var We=class extends x{config={name:"qe/learning/optimize",description:"Cross-domain learning, pattern recognition, strategy optimization, and knowledge transfer.",domain:"learning-optimization",schema:xc,streaming:!0,timeout:3e5};learningCoordinator=null;metricsOptimizer=null;transferSpecialist=null;async getServices(e){if(!this.learningCoordinator||!this.metricsOptimizer||!this.transferSpecialist){let t=e.memory||await F();this.learningCoordinator=new Wr({memory:t}),this.metricsOptimizer=new Xr(t),this.transferSpecialist=new Kr(t)}return{learningCoordinator:this.learningCoordinator,metricsOptimizer:this.metricsOptimizer,transferSpecialist:this.transferSpecialist}}async execute(e,t){let{action:n,domain:r,experienceIds:i,targetDomain:s,objective:a}=e;try{if(this.emitStream(t,{status:"processing",message:`Executing ${n} action`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let o={action:n};switch(n){case"learn":o.learnResult=await this.executeLearn(r,i,t);break;case"optimize":if(!a)return{success:!1,error:"Objective is required for optimize action"};o.optimizeResult=await this.executeOptimize(r,a,t);break;case"transfer":if(!r||!s)return{success:!1,error:"Both domain and targetDomain are required for transfer action"};o.transferResult=await this.executeTransfer(r,s,t);break;case"patterns":o.patternResult=await this.executePatterns(r,t);break;case"dashboard":o.dashboardResult=await this.executeDashboard(t);break;default:return{success:!1,error:`Unknown action: ${n}`}}return this.emitStream(t,{status:"complete",message:`${n} complete`,progress:100}),{success:!0,data:o}}catch(o){return{success:!1,error:`Learning optimization failed: ${w(o)}`}}}async executeLearn(e,t,n){let r=e||"learning-optimization";if(this.isDemoMode(n))return this.markAsDemoData(n,"Demo mode explicitly requested"),this.getDemoLearnResult(r);let{learningCoordinator:i}=await this.getServices(n);this.emitStream(n,{status:"learning",message:`Learning from ${t?.length||"recent"} experiences`});let s=$e.lastNDays(7),a=await i.mineExperiences(r,s),o=[],l=0,c=0;if(a.success){l=a.value.experienceCount;for(let d of a.value.patterns)o.push({id:d.id,type:d.type,name:d.name,description:d.description,confidence:d.confidence,usageCount:d.usageCount,successRate:d.successRate});c=a.value.successRate>.5?(a.value.successRate-.5)*20:0}return t&&t.length>0&&(l=t.length),o.length===0?(this.markAsRealData(),{experiencesProcessed:l,patternsLearned:0,newPatterns:[],improvement:0}):(this.markAsRealData(),{experiencesProcessed:l,patternsLearned:o.length,newPatterns:o,improvement:c})}getDemoLearnResult(e){return{experiencesProcessed:150,patternsLearned:12,newPatterns:[{id:`pattern-${e}-001`,type:"optimization",name:"Parallel Execution Pattern",description:`Optimal parallelism settings discovered for ${e}`,confidence:.92,usageCount:45,successRate:.87},{id:`pattern-${e}-002`,type:"retry",name:"Exponential Backoff Pattern",description:"Effective retry strategy for flaky operations",confidence:.88,usageCount:32,successRate:.91},{id:`pattern-${e}-003`,type:"caching",name:"Result Caching Pattern",description:"Cache frequently computed results for faster access",confidence:.85,usageCount:28,successRate:.82}],improvement:15.5}}async executeOptimize(e,t,n){let{learningCoordinator:r,metricsOptimizer:i}=await this.getServices(n);this.emitStream(n,{status:"optimizing",message:`Optimizing for ${t.metric}`});let s=e||"learning-optimization",a=$e.lastNDays(30),o=await r.mineExperiences(s,a),l=[];if(o.success&&o.value.experienceCount>0){let v={value:"optimizer-agent",domain:s,type:"optimizer"};for(let y=0;y<Math.min(o.value.experienceCount,20);y++)l.push({id:`exp-${y}`,agentId:v,domain:s,action:"optimize",state:{context:{},metrics:{}},result:{success:J()>.3,outcome:{[t.metric]:Z(70,100)},duration:Z(1e3,6e3)},reward:o.value.avgReward,timestamp:new Date})}let c={name:`${s}-current`,parameters:{parallelism:4,retryCount:3,timeout:3e4},expectedOutcome:{[t.metric]:70}},d=(t.constraints||[]).map(v=>({metric:v.metric,operator:v.operator,value:v.value})),m={metric:t.metric,direction:t.direction,constraints:d},p=c,g=0,h=.5,f=[];if(l.length>=20){let v=await i.optimizeStrategy(c,m,l);v.success&&(p={name:v.value.optimizedStrategy.name,parameters:v.value.optimizedStrategy.parameters,expectedOutcome:v.value.optimizedStrategy.expectedOutcome},g=v.value.improvement*100,h=v.value.confidence,f=v.value.validationResults)}else{let v={tags:[s,t.metric]},y=await i.recommendStrategy(v);y.success&&(p={name:y.value.name,parameters:y.value.parameters,expectedOutcome:y.value.expectedOutcome})}return{strategiesEvaluated:l.length>0?Math.min(l.length,12):1,bestStrategy:p,improvement:g,confidence:h,validationResults:f}}async executeTransfer(e,t,n){let{transferSpecialist:r}=await this.getServices(n);this.emitStream(n,{status:"transferring",message:`Transferring knowledge from ${e} to ${t}`});let i=await r.queryKnowledge({domain:e,minRelevance:.5,limit:50}),s=0,a=0,o=0,l=0;if(i.success){s=i.value.length;for(let d of i.value){let m=await r.transferKnowledge(d,t);m.success&&(a++,l+=m.value.relevanceScore,Math.abs(m.value.relevanceScore-d.relevanceScore)>.1&&o++)}}let c=s>0?a/s:0;return{sourcePatterns:s,transferredPatterns:a,adaptedPatterns:o,successRate:c,targetDomainUpdated:a>0}}async executePatterns(e,t){let{learningCoordinator:n}=await this.getServices(t);this.emitStream(t,{status:"analyzing",message:`Analyzing patterns${e?` for ${e}`:""}`});let r=await n.getPatternStats(e);if(!r.success)return{totalPatterns:0,byType:{},byDomain:{},topPatterns:[],avgConfidence:0,avgSuccessRate:0};let i=r.value,s=i.topPatterns.map(a=>({id:a.id,type:a.type,name:a.name,description:a.description,confidence:a.confidence,usageCount:a.usageCount,successRate:a.successRate}));return{totalPatterns:i.totalPatterns,byType:i.byType,byDomain:i.byDomain,topPatterns:s,avgConfidence:i.avgConfidence,avgSuccessRate:i.avgSuccessRate}}async executeDashboard(e){let{learningCoordinator:t,transferSpecialist:n}=await this.getServices(e);this.emitStream(e,{status:"aggregating",message:"Aggregating learning metrics"});let r=await t.getPatternStats(),i=await n.queryKnowledge({minRelevance:0,limit:1e3}),s=$e.lastNDays(1),a=["test-generation","test-execution","coverage-analysis","quality-assessment","defect-intelligence","learning-optimization"],o=0,l=[];for(let v of a){let y=await t.mineExperiences(v,s);y.success&&(o+=y.value.experienceCount,y.value.experienceCount>0&&l.push({domain:v,successRate:y.value.successRate}))}l.sort((v,y)=>y.successRate-v.successRate);let c=l.slice(0,3).map(v=>v.domain),d=r.success?r.value.totalPatterns:0,m=r.success?r.value.avgSuccessRate:0,p=m,g=[],h=new Date;for(let v=6;v>=0;v--){let y=new Date(h.getTime()-v*24*60*60*1e3),C=new Date(y.getTime()+1440*60*1e3),b=$e.create(y,C),E=0;for(let S of a.slice(0,3)){let T=await t.mineExperiences(S,b);T.success&&(E+=T.value.patterns.length)}g.push({timestamp:y.toISOString(),metric:"patterns-learned",value:E})}let f=[];return d>=100&&f.push({name:`Reached ${Math.floor(d/50)*50} patterns`,achievedAt:new Date(h.getTime()-2880*60*1e3).toISOString(),domain:"learning-optimization"}),m>=.8&&f.push({name:`${Math.round(m*100)}% pattern success rate`,achievedAt:new Date(h.getTime()-7200*60*1e3).toISOString(),domain:c[0]||"learning-optimization"}),{overallLearningRate:p,totalPatterns:d,totalKnowledge:i.success?i.value.length:0,experiencesLast24h:o,topPerformingDomains:c.length>0?c:["test-generation"],learningTrend:g,recentMilestones:f}}},xc={type:"object",properties:{action:{type:"string",description:"Learning action to perform",enum:["learn","optimize","transfer","patterns","dashboard"]},domain:{type:"string",description:"Source domain for learning/optimization",enum:["test-generation","test-execution","coverage-analysis","quality-assessment","defect-intelligence","requirements-validation","code-intelligence","security-compliance","contract-testing","visual-accessibility","chaos-resilience","learning-optimization"]},experienceIds:{type:"array",description:"Specific experience IDs to learn from",items:{type:"string",description:"Experience ID"}},targetDomain:{type:"string",description:"Target domain for knowledge transfer"},objective:{type:"object",description:"Optimization objective",properties:{metric:{type:"string",description:"Metric to optimize"},direction:{type:"string",description:"maximize or minimize",enum:["maximize","minimize"]},constraints:{type:"array",description:"Optimization constraints",items:{type:"object",description:"Constraint"}}}}},required:["action"]};k();var Pc={type:"object",properties:{action:{type:"string",enum:["dream","insights","apply","history","status"],description:"Action to perform: dream (run cycle), insights (view pending), apply (create pattern), history (view past), status (current state)"},durationMs:{type:"number",description:"Duration of dream cycle in milliseconds (default: 30000, max: 60000)",default:3e4},minPatterns:{type:"number",description:"Minimum patterns required to start dreaming (default: 10)",default:10},insightId:{type:"string",description:"Insight ID to apply (required for apply action)"},limit:{type:"number",description:"Maximum results to return (default: 20)",default:20},loadFromReasoningBank:{type:"boolean",description:"Load patterns from ReasoningBank before dreaming (default: true)",default:!0}},required:["action"]},Ke=class extends x{config={name:"qe/learning/dream",description:"Trigger dream cycles for pattern discovery. Dreams find novel associations between patterns through spreading activation, generating actionable insights.",domain:"learning-optimization",schema:Pc,streaming:!1,timeout:12e4};engine=null;engineConfig=null;async getEngine(e){return this.engine&&e&&!this.configsEqual(this.engineConfig,e)&&this.engine&&(await this.engine.close().catch(()=>{}),this.engine=null,this.engineConfig=null),this.engine||(this.engine=Mr(e),this.engineConfig=e||null,await this.engine.initialize()),this.engine}configsEqual(e,t){return e===t?!0:!e||!t?!1:e.maxDurationMs===t.maxDurationMs&&e.minConceptsRequired===t.minConceptsRequired}async loadPatternsFromReasoningBank(e){try{let t=await F(),n=ft(t);await n.initialize();try{let{getSharedRvfDualWriter:a}=await import("./shared-rvf-dual-writer-GML4EDYF.js"),o=await a();o&&n.setRvfDualWriter(o)}catch(a){process.env.DEBUG&&this.logger.info("RVF wiring skipped",{error:String(a)})}let r=await n.searchPatterns("",{limit:100,minConfidence:.3});if(!r.success||!r.value.length)return this.logger.info("No patterns found in ReasoningBank to load"),0;let i=r.value.map(a=>({id:a.pattern.id,name:a.pattern.name,description:a.pattern.description||`${a.pattern.patternType} pattern`,domain:a.pattern.qeDomain||"learning-optimization",patternType:a.pattern.patternType,confidence:a.pattern.confidence,successRate:a.pattern.successRate||.5})),s=await e.loadPatternsAsConcepts(i);return this.logger.info(`Loaded ${s} patterns as concepts from ReasoningBank`),s}catch(t){return this.logger.warn("Failed to load patterns from ReasoningBank",{error:String(t)}),0}}async execute(e,t){let{action:n}=e;try{switch(n){case"dream":return this.runDreamCycle(e,t);case"insights":return this.getPendingInsights(e,t);case"apply":return this.applyInsight(e,t);case"history":return this.getDreamHistory(e,t);case"status":return this.getDreamStatus(e,t);default:return{success:!1,error:`Unknown action: ${n}`,data:{action:n,success:!1,error:`Unknown action: ${n}`}}}}catch(r){let i=w(r);return{success:!1,error:i,data:{action:n,success:!1,error:i}}}}async runDreamCycle(e,t){let n=Math.min(e.durationMs||3e4,6e4),r=e.minPatterns||10,i=e.loadFromReasoningBank!==!1;this.logger.info(`Starting dream cycle (${n}ms, min: ${r} patterns)`);let s=await this.getEngine({maxDurationMs:n,minConceptsRequired:r});if(i){let c=await this.loadPatternsFromReasoningBank(s);this.logger.info(`Loaded ${c} patterns from ReasoningBank`)}let a=await s.dream(n),o={cycleId:a.cycle.id,status:a.cycle.status,durationMs:a.cycle.durationMs||0,conceptsProcessed:a.cycle.conceptsProcessed,associationsFound:a.cycle.associationsFound,insightsGenerated:a.cycle.insightsGenerated,activationStats:a.activationStats,patternsCreated:a.patternsCreated},l=a.insights.map(c=>({id:c.id,type:c.type,description:c.description,noveltyScore:c.noveltyScore,confidenceScore:c.confidenceScore,actionable:c.actionable,applied:c.applied||!1,suggestedAction:c.suggestedAction,createdAt:c.createdAt?.toISOString()||new Date().toISOString()}));return this.logger.info(`Dream cycle complete: ${a.cycle.insightsGenerated} insights, ${a.cycle.associationsFound} associations found`),{success:!0,data:{action:"dream",success:!0,dreamResult:o,insights:l}}}async getPendingInsights(e,t){let n=e.limit||20;return{success:!0,data:{action:"insights",success:!0,insights:(await(await this.getEngine()).getPendingInsights(n)).map(a=>({id:a.id,type:a.type,description:a.description,noveltyScore:a.noveltyScore,confidenceScore:a.confidenceScore,actionable:a.actionable,applied:a.applied||!1,suggestedAction:a.suggestedAction,createdAt:a.createdAt?.toISOString()||new Date().toISOString()}))}}}async applyInsight(e,t){if(!e.insightId)return{success:!1,error:"insightId is required for apply action",data:{action:"apply",success:!1,error:"insightId is required for apply action"}};try{let n=await this.getEngine(),i=(await n.getPendingInsights(100)).find(m=>m.id===e.insightId);if(!i)return{success:!1,error:`Insight not found or already applied: ${e.insightId}`,data:{action:"apply",success:!1,error:`Insight not found or already applied: ${e.insightId}`}};if(!i.actionable)return{success:!1,error:"Insight is not actionable",data:{action:"apply",success:!1,error:"Insight is not actionable"}};let s=await F(),a=ft(s);await a.initialize();try{let{getSharedRvfDualWriter:m}=await import("./shared-rvf-dual-writer-GML4EDYF.js"),p=await m();p&&a.setRvfDualWriter(p)}catch(m){process.env.DEBUG&&this.logger.info("RVF wiring skipped",{error:String(m)})}let o=this.mapInsightTypeToPatternType(i.type),l=await a.storePattern({patternType:o,name:`Dream Insight: ${i.type}`,description:`${i.description} (confidence: ${i.confidenceScore.toFixed(2)})`,template:{type:"workflow",content:i.suggestedAction||i.description,variables:[]},context:{tags:["dream-generated",i.type,...i.sourceConcepts.slice(0,3)],complexity:"medium"}});if(!l.success){let m=l.error?.message||"Unknown error";return{success:!1,error:`Failed to create pattern: ${m}`,data:{action:"apply",success:!1,error:`Failed to create pattern: ${m}`}}}let c=l.value.id;return await n.applyInsight(e.insightId),this.logger.info(`Applied insight ${e.insightId} \u2192 REAL pattern ${c} in ReasoningBank`),{success:!0,data:{action:"apply",success:!0,applyResult:{insightId:e.insightId,success:!0,patternId:c}}}}catch(n){let r=w(n);return{success:!1,error:r,data:{action:"apply",success:!1,error:r}}}}mapInsightTypeToPatternType(e){return{"cross-domain":"coverage-strategy","novel-path":"test-template",cluster:"refactor-safe","high-activation":"assertion-pattern",bridge:"mock-pattern"}[e]||"test-template"}async getDreamHistory(e,t){let n=e.limit||20;return{success:!0,data:{action:"history",success:!0,history:(await(await this.getEngine()).getDreamHistory(n)).map(a=>({id:a.id,startTime:a.startTime.toISOString(),endTime:a.endTime?.toISOString(),durationMs:a.durationMs,status:a.status,conceptsProcessed:a.conceptsProcessed,associationsFound:a.associationsFound,insightsGenerated:a.insightsGenerated}))}}}async getDreamStatus(e,t){let n=await this.getEngine(),r=n.isDreaming(),i=n.getCurrentCycle(),s=await n.getDreamHistory(100),a=await n.getPendingInsights(100),o=s.reduce((d,m)=>d+m.insightsGenerated,0),l=s[0];return{success:!0,data:{action:"status",success:!0,status:{isDreaming:r,currentCycle:i?{id:i.id,startTime:i.startTime.toISOString(),endTime:i.endTime?.toISOString(),durationMs:i.durationMs,status:i.status,conceptsProcessed:i.conceptsProcessed,associationsFound:i.associationsFound,insightsGenerated:i.insightsGenerated}:void 0,totalCycles:s.length,totalInsights:o,pendingInsights:a.length,lastDreamTime:l?.startTime.toISOString()}}}}resetInstanceCache(){this.engine&&(this.engine.close().catch(console.error),this.engine=null)}};k();var on=class extends x{config={name:"qe/analysis/token_usage",description:"Analyze token consumption patterns and identify optimization opportunities across agents and domains.",domain:"learning-optimization",schema:Ac,streaming:!1,timeout:3e4};async execute(e,t){let{operation:n,timeframe:r,agentId:i,domain:s}=e;try{if(this.isAborted(t))return{success:!1,error:"Operation aborted"};let a;switch(n){case"session":a=this.getSessionUsage(r);break;case"agent":a=this.getAgentUsage(i,r);break;case"domain":a=this.getDomainUsage(s,r);break;case"task":a=this.getTaskUsage(r);break;case"efficiency":a=this.getEfficiencyReport(r);break;case"dashboard":return{success:!0,data:{operation:"dashboard",timeframe:r||"all",summary:{totalTokens:0,totalCost:"$0.00",tokensSaved:0,savingsPercentage:0},optimization:{patternsReused:0,cacheHits:0,earlyExits:0,recommendations:[ni()]}}};default:return{success:!1,error:`Unknown operation: ${n}`}}return{success:!0,data:a}}catch(a){return{success:!1,error:`Token usage analysis failed: ${w(a)}`}}}getSessionUsage(e){let t=X.getSessionSummary(e),n={};for(let[i,s]of t.byAgent)n[i]={tokens:s.totalTokens,cost:B(s.totalCost),tasks:s.tasksExecuted};let r={};for(let[i,s]of t.byDomain)r[i]={tokens:s.totalTokens,cost:B(s.estimatedCostUsd||0)};return{operation:"session",timeframe:e||"all",summary:{totalTokens:t.totalUsage.totalTokens,totalCost:B(t.totalUsage.estimatedCostUsd||0),tokensSaved:t.optimizationStats.tokensSaved,savingsPercentage:t.optimizationStats.savingsPercentage},breakdown:{byAgent:Object.keys(n).length>0?n:void 0,byDomain:Object.keys(r).length>0?r:void 0},optimization:{patternsReused:t.optimizationStats.patternsReused,cacheHits:t.optimizationStats.cacheHits,earlyExits:t.optimizationStats.earlyExits,recommendations:this.generateSessionRecommendations(t)}}}getAgentUsage(e,t){let n=X.getAgentMetrics(e,t),r=X.getSessionSummary(t);if(e&&!Array.isArray(n)){let d=n,m=d.tasksExecuted>0?d.patternsReused/d.tasksExecuted:0;return{operation:"agent",timeframe:t||"all",summary:{totalTokens:d.totalTokens,totalCost:B(d.totalCost),tokensSaved:d.estimatedTokensSaved,savingsPercentage:this.calculateSavingsPercentage(d.totalTokens,d.estimatedTokensSaved)},optimization:{patternsReused:d.patternsReused,cacheHits:r.optimizationStats.cacheHits,earlyExits:r.optimizationStats.earlyExits,recommendations:this.generateAgentRecommendations(d)},details:{agentMetrics:{agentId:d.agentId,totalInputTokens:d.totalInputTokens,totalOutputTokens:d.totalOutputTokens,totalTokens:d.totalTokens,totalCost:B(d.totalCost),tasksExecuted:d.tasksExecuted,patternsReused:d.patternsReused,tokensSaved:d.estimatedTokensSaved,efficiency:Math.round(m*100)}}}}let i=Array.isArray(n)?n:[n],s={},a=0,o=0,l=0,c=0;for(let d of i)s[d.agentId]={tokens:d.totalTokens,cost:B(d.totalCost),tasks:d.tasksExecuted},a+=d.totalTokens,o+=d.totalCost,l+=d.estimatedTokensSaved,c+=d.patternsReused;return{operation:"agent",timeframe:t||"all",summary:{totalTokens:a,totalCost:B(o),tokensSaved:l,savingsPercentage:this.calculateSavingsPercentage(a,l)},breakdown:{byAgent:Object.keys(s).length>0?s:void 0},optimization:{patternsReused:c,cacheHits:r.optimizationStats.cacheHits,earlyExits:r.optimizationStats.earlyExits,recommendations:this.generateMultiAgentRecommendations(i)}}}getDomainUsage(e,t){let n=X.getDomainMetrics(e,t),r=X.getSessionSummary(t);if(e&&!(n instanceof Map)){let l=n;return{operation:"domain",timeframe:t||"all",summary:{totalTokens:l.totalTokens,totalCost:B(l.estimatedCostUsd||0),tokensSaved:r.optimizationStats.tokensSaved,savingsPercentage:r.optimizationStats.savingsPercentage},optimization:{patternsReused:r.optimizationStats.patternsReused,cacheHits:r.optimizationStats.cacheHits,earlyExits:r.optimizationStats.earlyExits,recommendations:this.generateDomainRecommendations(e,l)},details:{domainMetrics:{domain:e,inputTokens:l.inputTokens,outputTokens:l.outputTokens,totalTokens:l.totalTokens,cost:B(l.estimatedCostUsd||0)}}}}let i=n instanceof Map?n:new Map,s={},a=0,o=0;for(let[l,c]of i)s[l]={tokens:c.totalTokens,cost:B(c.estimatedCostUsd||0)},a+=c.totalTokens,o+=c.estimatedCostUsd||0;return{operation:"domain",timeframe:t||"all",summary:{totalTokens:a,totalCost:B(o),tokensSaved:r.optimizationStats.tokensSaved,savingsPercentage:r.optimizationStats.savingsPercentage},breakdown:{byDomain:Object.keys(s).length>0?s:void 0},optimization:{patternsReused:r.optimizationStats.patternsReused,cacheHits:r.optimizationStats.cacheHits,earlyExits:r.optimizationStats.earlyExits,recommendations:this.generateMultiDomainRecommendations(i)}}}getTaskUsage(e){let t=X.getTaskMetrics(e),n=X.getSessionSummary(e),r=t.slice(-100).map(i=>({taskId:i.taskId,agentId:i.agentId,domain:i.domain,operation:i.operation,tokens:i.usage.totalTokens,cost:B(i.usage.estimatedCostUsd||0),patternReused:i.patternReused,tokensSaved:i.tokensSaved||0,timestamp:new Date(i.timestamp).toISOString()}));return{operation:"task",timeframe:e||"all",summary:{totalTokens:n.totalUsage.totalTokens,totalCost:B(n.totalUsage.estimatedCostUsd||0),tokensSaved:n.optimizationStats.tokensSaved,savingsPercentage:n.optimizationStats.savingsPercentage},optimization:{patternsReused:n.optimizationStats.patternsReused,cacheHits:n.optimizationStats.cacheHits,earlyExits:n.optimizationStats.earlyExits,recommendations:[`${t.length} tasks analyzed in timeframe`]},details:{taskMetrics:r}}}getEfficiencyReport(e){let t=X.getEfficiencyReport(e),n=X.getSessionSummary(e);return{operation:"efficiency",timeframe:e||"all",summary:{totalTokens:t.totalTokensUsed,totalCost:B(t.totalTokensUsed*3e-6+t.totalTokensUsed*15e-6),tokensSaved:t.totalTokensSaved,savingsPercentage:t.savingsPercentage},optimization:{patternsReused:n.optimizationStats.patternsReused,cacheHits:n.optimizationStats.cacheHits,earlyExits:n.optimizationStats.earlyExits,recommendations:t.recommendations}}}generateSessionRecommendations(e){let t=[];if(e.totalUsage.totalTokens===0)return["No token usage recorded yet. Start executing tasks to track consumption."];let{patternsReused:n,cacheHits:r,earlyExits:i,savingsPercentage:s}=e.optimizationStats;return s<10&&t.push("Token savings below 10%. Enable pattern reuse and caching for better efficiency."),n===0&&e.byAgent.size>0&&t.push("No patterns reused. Consider enabling the pattern store for similar tasks."),r===0&&e.totalUsage.totalTokens>1e4&&t.push("No cache hits detected. Enable response caching to reduce API calls."),i===0&&e.byAgent.size>1&&t.push("Early exit optimization not used. Enable high-confidence pattern matching."),s>25&&t.push(`Excellent token efficiency! ${s.toFixed(1)}% savings achieved.`),t.length>0?t:["Token usage is within normal parameters."]}generateAgentRecommendations(e){let t=[];if(e.tasksExecuted===0)return["No tasks executed by this agent yet."];e.patternsReused/e.tasksExecuted<.1&&t.push("Low pattern reuse rate. Consider caching successful patterns.");let r=e.totalTokens/e.tasksExecuted;return r>5e3&&t.push(`High average tokens per task (${Math.round(r)}). Consider optimizing prompts.`),e.totalOutputTokens>e.totalInputTokens*2&&t.push("High output-to-input ratio. Request more concise responses."),t.length>0?t:["Agent token usage is efficient."]}generateMultiAgentRecommendations(e){let t=[];if(e.length===0)return["No agent data available."];let n=[...e].sort((s,a)=>a.totalTokens-s.totalTokens);n[0].totalTokens>0&&t.push(`Highest consumer: ${n[0].agentId} (${n[0].totalTokens.toLocaleString()} tokens)`);let r=e.reduce((s,a)=>s+a.totalTokens,0);return n[0].totalTokens/(r||1)>.5&&e.length>1&&t.push("Token usage imbalanced. Consider distributing workload across agents."),t}generateDomainRecommendations(e,t){let n=[];return t.totalTokens===0?[`No token usage recorded for ${e}.`]:(e==="test-generation"&&t.totalTokens>1e4&&n.push("Test generation consuming significant tokens. Consider batching test requests."),e==="code-intelligence"&&t.outputTokens>t.inputTokens*3&&n.push("Code intelligence generating verbose output. Consider summary-only mode."),n.length>0?n:[`${e} token usage is normal.`])}generateMultiDomainRecommendations(e){let t=[];if(e.size===0)return["No domain data available."];let n=Array.from(e.entries()).sort((r,i)=>i[1].totalTokens-r[1].totalTokens);return n[0][1].totalTokens>0&&t.push(`Highest consuming domain: ${n[0][0]} (${n[0][1].totalTokens.toLocaleString()} tokens)`),t}calculateSavingsPercentage(e,t){let n=e+t;return n===0?0:Math.round(t/n*1e4)/100}},Ac={type:"object",properties:{operation:{type:"string",description:"Type of analysis to perform",enum:["session","agent","domain","task","efficiency","dashboard"]},timeframe:{type:"string",description:"Time period to analyze",enum:["1h","24h","7d","30d"]},agentId:{type:"string",description:"Specific agent ID to analyze (for agent operation)"},domain:{type:"string",description:"Specific domain to analyze (for domain operation)",enum:["test-generation","test-execution","coverage-analysis","quality-assessment","defect-intelligence","requirements-validation","code-intelligence","security-compliance","contract-testing","visual-accessibility","chaos-resilience","learning-optimization"]}},required:["operation"]};k();var Xe={coverage:{line:0,branch:0,function:0,target:80,measured:!1},quality:{testsPassing:0,totalTests:0,securityScore:100,performanceScore:100},fleet:{activeAgents:0,availableAgents:[],maxAgents:8},resources:{timeRemaining:3600,memoryAvailable:4096,parallelSlots:4},context:{environment:"development",riskLevel:"medium"},patterns:{available:0,reusable:0}};var kc=[{name:"measure-coverage",description:"Run coverage analysis on the codebase to determine current coverage metrics",agentType:"qe-coverage-specialist",preconditions:{"coverage.measured":!1},effects:{"coverage.measured":!0},cost:2,estimatedDurationMs:3e4,successRate:.95,category:"coverage",qeDomain:"coverage-analysis"},{name:"analyze-coverage-gaps",description:"Identify uncovered code paths and prioritize them by risk and complexity",agentType:"qe-gap-detector",preconditions:{"coverage.measured":!0},effects:{"coverage.gapsIdentified":!0},cost:1.5,estimatedDurationMs:15e3,successRate:.9,category:"coverage",qeDomain:"coverage-analysis"},{name:"generate-coverage-tests",description:"Generate tests targeting identified coverage gaps using AI-powered analysis",agentType:"qe-test-generator",preconditions:{"coverage.gapsIdentified":!0},effects:{"coverage.line":{delta:10}},cost:4,estimatedDurationMs:6e4,successRate:.8,category:"coverage",qeDomain:"test-generation"},{name:"run-mutation-testing",description:"Run mutation testing to validate test effectiveness and find weak spots",agentType:"qe-mutation-tester",preconditions:{"coverage.line":{min:60}},effects:{"quality.mutationScore":{set:!0}},cost:5,estimatedDurationMs:12e4,successRate:.85,category:"coverage",qeDomain:"coverage-analysis"},{name:"prioritize-uncovered-paths",description:"Use sublinear O(log n) analysis to identify highest-risk uncovered paths",agentType:"qe-coverage-specialist",preconditions:{"coverage.gapsIdentified":!0},effects:{"coverage.riskPrioritized":!0},cost:1,estimatedDurationMs:1e4,successRate:.92,category:"coverage",qeDomain:"coverage-analysis"},{name:"generate-branch-tests",description:"Generate tests specifically targeting branch coverage improvements",agentType:"qe-test-generator",preconditions:{"coverage.measured":!0,"coverage.branch":{max:70}},effects:{"coverage.branch":{delta:8}},cost:3.5,estimatedDurationMs:45e3,successRate:.78,category:"coverage",qeDomain:"test-generation"}],Mc=[{name:"run-unit-tests",description:"Execute unit test suite with parallel execution",agentType:"qe-test-executor",preconditions:{},effects:{"quality.unitTestsRun":!0},cost:1,estimatedDurationMs:2e4,successRate:.95,category:"test",qeDomain:"test-execution"},{name:"run-integration-tests",description:"Execute integration test suite with real database connections",agentType:"qe-test-executor",preconditions:{"quality.unitTestsRun":!0},effects:{"quality.integrationTestsRun":!0},cost:2.5,estimatedDurationMs:45e3,successRate:.85,category:"test",qeDomain:"test-execution"},{name:"run-e2e-tests",description:"Execute end-to-end tests using Playwright or Cypress",agentType:"qe-e2e-tester",preconditions:{"quality.integrationTestsRun":!0},effects:{"quality.e2eTestsRun":!0},cost:4,estimatedDurationMs:9e4,successRate:.8,category:"test",qeDomain:"test-execution"},{name:"fix-failing-tests",description:"Analyze and fix failing tests based on error messages and stack traces",agentType:"qe-tdd-specialist",preconditions:{"quality.testsPassing":{max:90}},effects:{"quality.testsPassing":{delta:10}},cost:3,estimatedDurationMs:3e4,successRate:.75,category:"test",qeDomain:"test-generation"},{name:"fix-flaky-tests",description:"Identify and stabilize flaky tests by analyzing timing and async issues",agentType:"qe-flaky-hunter",preconditions:{"quality.flakyTests":{min:1}},effects:{"quality.flakyTests":{delta:-3}},cost:4,estimatedDurationMs:45e3,successRate:.7,category:"test",qeDomain:"test-execution"},{name:"generate-property-tests",description:"Generate property-based tests using fast-check or similar library",agentType:"qe-test-generator",preconditions:{"quality.unitTestsRun":!0},effects:{"quality.propertyTestsGenerated":!0},cost:3.5,estimatedDurationMs:4e4,successRate:.82,category:"test",qeDomain:"test-generation"},{name:"run-contract-tests",description:"Execute consumer-driven contract tests using Pact or similar",agentType:"qe-contract-tester",preconditions:{"context.hasApiContracts":!0},effects:{"quality.contractTestsRun":!0},cost:2,estimatedDurationMs:25e3,successRate:.88,category:"test",qeDomain:"contract-testing"}],Dc=[{name:"security-scan",description:"Run comprehensive security scan using SAST and dependency analysis",agentType:"qe-security-scanner",preconditions:{},effects:{"quality.securityScanned":!0},cost:2,estimatedDurationMs:3e4,successRate:.95,category:"security",qeDomain:"security-compliance"},{name:"fix-vulnerabilities",description:"Remediate identified security vulnerabilities and update dependencies",agentType:"qe-security-auditor",preconditions:{"quality.securityScanned":!0,"quality.vulnerabilities":{min:1}},effects:{"quality.vulnerabilities":{delta:-5},"quality.securityScore":{delta:10}},cost:5,estimatedDurationMs:6e4,successRate:.7,category:"security",qeDomain:"security-compliance"},{name:"owasp-audit",description:"Perform OWASP Top 10 security audit on the application",agentType:"qe-security-auditor",preconditions:{"quality.securityScanned":!0},effects:{"quality.owaspCompliant":!0},cost:3,estimatedDurationMs:45e3,successRate:.85,category:"security",qeDomain:"security-compliance"},{name:"scan-secrets",description:"Scan codebase for hardcoded secrets and credentials",agentType:"qe-security-scanner",preconditions:{},effects:{"quality.secretsScanned":!0},cost:1,estimatedDurationMs:15e3,successRate:.98,category:"security",qeDomain:"security-compliance"},{name:"run-dast",description:"Run dynamic application security testing against running application",agentType:"qe-security-auditor",preconditions:{"context.environment":"staging"},effects:{"quality.dastCompleted":!0},cost:4.5,estimatedDurationMs:12e4,successRate:.8,category:"security",qeDomain:"security-compliance"}],Ic=[{name:"run-benchmarks",description:"Execute performance benchmarks to establish baseline metrics",agentType:"qe-performance-tester",preconditions:{},effects:{"quality.benchmarked":!0},cost:2,estimatedDurationMs:45e3,successRate:.9,category:"performance",qeDomain:"chaos-resilience"},{name:"load-test",description:"Run load testing with simulated concurrent traffic",agentType:"qe-load-tester",preconditions:{"context.environment":"staging"},effects:{"quality.loadTested":!0},cost:3.5,estimatedDurationMs:12e4,successRate:.85,category:"performance",qeDomain:"chaos-resilience"},{name:"stress-test",description:"Run stress testing to find breaking points and system limits",agentType:"qe-chaos-engineer",preconditions:{"context.environment":"staging","quality.loadTested":!0},effects:{"quality.stressTested":!0},cost:4,estimatedDurationMs:9e4,successRate:.8,category:"performance",qeDomain:"chaos-resilience"},{name:"profile-memory",description:"Profile memory usage and identify memory leaks",agentType:"qe-performance-tester",preconditions:{"quality.benchmarked":!0},effects:{"quality.memoryProfiled":!0},cost:2.5,estimatedDurationMs:6e4,successRate:.88,category:"performance",qeDomain:"chaos-resilience"},{name:"optimize-slow-tests",description:"Identify and optimize slow-running tests to improve CI/CD speed",agentType:"qe-performance-tester",preconditions:{"quality.unitTestsRun":!0},effects:{"quality.testsOptimized":!0},cost:2,estimatedDurationMs:3e4,successRate:.82,category:"performance",qeDomain:"test-execution"}],_c=[{name:"analyze-complexity",description:"Measure cyclomatic and cognitive complexity of codebase",agentType:"code-analyzer",preconditions:{},effects:{"quality.complexityAnalyzed":!0},cost:1,estimatedDurationMs:15e3,successRate:.95,category:"analysis",qeDomain:"code-intelligence"},{name:"detect-code-smells",description:"Identify code smells and anti-patterns using static analysis",agentType:"code-analyzer",preconditions:{},effects:{"quality.smellsDetected":!0},cost:1.5,estimatedDurationMs:2e4,successRate:.9,category:"analysis",qeDomain:"code-intelligence"},{name:"analyze-dependencies",description:"Analyze dependency graph and identify circular or outdated dependencies",agentType:"code-analyzer",preconditions:{},effects:{"quality.dependenciesAnalyzed":!0},cost:1,estimatedDurationMs:15e3,successRate:.92,category:"analysis",qeDomain:"code-intelligence"},{name:"measure-technical-debt",description:"Calculate technical debt metrics and generate remediation plan",agentType:"code-analyzer",preconditions:{"quality.complexityAnalyzed":!0,"quality.smellsDetected":!0},effects:{"quality.technicalDebtMeasured":!0},cost:2,estimatedDurationMs:25e3,successRate:.88,category:"analysis",qeDomain:"code-intelligence"},{name:"build-knowledge-graph",description:"Build semantic knowledge graph of codebase for intelligent context retrieval",agentType:"qe-intelligence-builder",preconditions:{"quality.dependenciesAnalyzed":!0},effects:{"quality.knowledgeGraphBuilt":!0},cost:3,estimatedDurationMs:6e4,successRate:.85,category:"analysis",qeDomain:"code-intelligence"}],Oc=[{name:"spawn-test-agent",description:"Spawn additional test execution agent for parallel work",agentType:"queen-coordinator",preconditions:{"fleet.activeAgents":{max:10}},effects:{"fleet.activeAgents":{delta:1}},cost:.5,estimatedDurationMs:5e3,successRate:.95,category:"fleet",qeDomain:"test-execution"},{name:"optimize-fleet-topology",description:"Reconfigure fleet topology for optimal task distribution",agentType:"queen-coordinator",preconditions:{"fleet.activeAgents":{min:3}},effects:{"fleet.efficiency":{delta:15}},cost:1,estimatedDurationMs:1e4,successRate:.85,category:"fleet"},{name:"scale-down-fleet",description:"Reduce fleet size to conserve resources during low-activity periods",agentType:"queen-coordinator",preconditions:{"fleet.activeAgents":{min:5}},effects:{"fleet.activeAgents":{delta:-2}},cost:.3,estimatedDurationMs:3e3,successRate:.98,category:"fleet"},{name:"spawn-specialist-agent",description:"Spawn a specialized agent for specific domain work",agentType:"queen-coordinator",preconditions:{"fleet.activeAgents":{max:12},"context.specialistNeeded":!0},effects:{"fleet.activeAgents":{delta:1},"fleet.specialistAvailable":!0},cost:1,estimatedDurationMs:8e3,successRate:.9,category:"fleet"},{name:"rebalance-workload",description:"Redistribute tasks across agents based on current load",agentType:"queen-coordinator",preconditions:{"fleet.activeAgents":{min:2}},effects:{"fleet.workloadBalanced":!0},cost:.5,estimatedDurationMs:5e3,successRate:.92,category:"fleet"}],Fc=[{name:"generate-quality-report",description:"Generate comprehensive quality report combining all metrics",agentType:"qe-quality-gate",preconditions:{"coverage.measured":!0,"quality.unitTestsRun":!0},effects:{"quality.reported":!0},cost:1,estimatedDurationMs:1e4,successRate:.95,category:"quality",qeDomain:"quality-assessment"},{name:"enforce-quality-gate",description:"Check if all quality gates pass and report status",agentType:"qe-quality-gate",preconditions:{"quality.reported":!0},effects:{"quality.gatePassed":!0},cost:.5,estimatedDurationMs:5e3,successRate:.9,category:"quality",qeDomain:"quality-assessment"},{name:"validate-requirements",description:"Validate that tests cover all documented requirements",agentType:"qe-requirements-validator",preconditions:{"context.hasRequirements":!0},effects:{"quality.requirementsValidated":!0},cost:2,estimatedDurationMs:2e4,successRate:.88,category:"quality",qeDomain:"requirements-validation"},{name:"predict-defects",description:"Use ML-based defect prediction to identify high-risk code areas",agentType:"qe-defect-predictor",preconditions:{"quality.complexityAnalyzed":!0,"coverage.measured":!0},effects:{"quality.defectsPredicted":!0},cost:2.5,estimatedDurationMs:3e4,successRate:.82,category:"quality",qeDomain:"defect-intelligence"},{name:"generate-deployment-report",description:"Generate deployment readiness report with all quality metrics",agentType:"qe-quality-gate",preconditions:{"quality.gatePassed":!0,"quality.securityScanned":!0},effects:{"quality.deploymentReady":!0},cost:1.5,estimatedDurationMs:15e3,successRate:.9,category:"quality",qeDomain:"quality-assessment"}],Nc=[{name:"run-accessibility-audit",description:"Run WCAG 2.2 accessibility audit using axe-core or similar",agentType:"qe-accessibility-tester",preconditions:{"context.hasUI":!0},effects:{"quality.accessibilityAudited":!0},cost:2,estimatedDurationMs:3e4,successRate:.9,category:"quality",qeDomain:"visual-accessibility"},{name:"run-visual-regression",description:"Run visual regression testing with screenshot comparison",agentType:"qe-visual-tester",preconditions:{"context.hasUI":!0},effects:{"quality.visualRegressionRun":!0},cost:3,estimatedDurationMs:6e4,successRate:.85,category:"quality",qeDomain:"visual-accessibility"}],ys=[...kc,...Mc,...Dc,...Ic,..._c,...Oc,...Fc,...Nc];function Lc(u){return`action-${u}`}function vs(u){return{...u,id:Lc(u.name),executionCount:0}}function Ye(){return ys.map(vs)}var cn=[{name:"achieve-90-percent-coverage",description:"Reach 90% line coverage through targeted test generation",conditions:{"coverage.line":{min:90}},priority:1,qeDomain:"coverage-analysis"},{name:"all-tests-passing",description:"All tests green with 100% pass rate",conditions:{"quality.testsPassing":{min:100}},priority:1,qeDomain:"test-execution"},{name:"security-compliant",description:"Pass security audit with no critical vulnerabilities",conditions:{"quality.securityScanned":!0,"quality.vulnerabilities":{max:0}},priority:2,qeDomain:"security-compliance"},{name:"deployment-ready",description:"Ready for production deployment with all quality gates passed",conditions:{"coverage.line":{min:80},"quality.testsPassing":{min:100},"quality.securityScanned":!0,"quality.gatePassed":!0},priority:1},{name:"performance-validated",description:"Performance benchmarks and load tests completed successfully",conditions:{"quality.benchmarked":!0,"quality.loadTested":!0},priority:2,qeDomain:"chaos-resilience"},{name:"code-quality-excellent",description:"Excellent code quality with low complexity and no code smells",conditions:{"quality.complexityAnalyzed":!0,"quality.smellsDetected":!0,"quality.technicalDebtMeasured":!0},priority:3,qeDomain:"code-intelligence"},{name:"full-test-suite",description:"Complete test suite with unit, integration, and e2e tests",conditions:{"quality.unitTestsRun":!0,"quality.integrationTestsRun":!0,"quality.e2eTestsRun":!0},priority:2,qeDomain:"test-execution"},{name:"accessibility-compliant",description:"WCAG 2.2 compliant with visual regression coverage",conditions:{"quality.accessibilityAudited":!0,"quality.visualRegressionRun":!0},priority:2,qeDomain:"visual-accessibility"}];U();import{randomUUID as ge}from"crypto";var fr=class{data=[];cmp;constructor(e){this.cmp=e}get length(){return this.data.length}push(e){this.data.push(e),this.bubbleUp(this.data.length-1)}pop(){if(this.data.length===0)return;let e=this.data[0],t=this.data.pop();return this.data.length>0&&(this.data[0]=t,this.sinkDown(0)),e}bubbleUp(e){for(;e>0;){let t=e-1>>1;if(this.cmp(this.data[e],this.data[t])<0)[this.data[e],this.data[t]]=[this.data[t],this.data[e]],e=t;else break}}sinkDown(e){let t=this.data.length;for(;;){let n=e,r=2*e+1,i=2*e+2;if(r<t&&this.cmp(this.data[r],this.data[n])<0&&(n=r),i<t&&this.cmp(this.data[i],this.data[n])<0&&(n=i),n!==e)[this.data[e],this.data[n]]=[this.data[n],this.data[e]],e=n;else break}}},qc=new Set(["__proto__","constructor","prototype"]),ln=class{db=null;persistence=null;actions=new Map;initialized=!1;enablePlanReuse=!0;constructor(){}ensureDb(){if(!this.db)throw new Error("GOAPPlanner not initialized - call initialize() first");return this.db}async initialize(){if(this.initialized)return;this.persistence=kr(),this.persistence.isInitialized()||await this.persistence.initialize(),this.db=this.persistence.getDatabase(),this.ensureDb().prepare("SELECT COUNT(*) as count FROM goap_actions").get().count===0&&this.seedDefaultActions(),await this.loadActions(),this.initialized=!0,console.log(`[GOAPPlanner] Initialized: ${this.persistence.getDbPath()}`)}seedDefaultActions(){let e=Ye(),t=this.ensureDb(),n=t.prepare(`
|
|
607
|
+
Analyze the requirements above and return the complete QualityCriteriaAnalysis.`}resetInstanceCache(){this.service=null}},Vo={type:"object",properties:{assessmentName:{type:"string",description:"Assessment name (e.g., Epic title or feature name)"},epicPath:{type:"string",description:"Path to epic/requirements document"},epicContent:{type:"string",description:"Epic content as string (alternative to epicPath)"},sourcePaths:{type:"array",description:"Source code paths to analyze for evidence",items:{type:"string",description:"Source path glob pattern"}},outputFormat:{type:"string",description:"Output format for the report",enum:["html","json","markdown"],default:"html"},outputPath:{type:"string",description:"Path to save the output report"},evidencePoints:{type:"array",description:"Evidence points to validate (for validate-evidence action)",items:{type:"object",description:"Evidence point object",properties:{sourceReference:{type:"string",description:"Source reference in file:line format"},type:{type:"string",enum:["Direct","Inferred","Claimed"],description:"Evidence type"},qualityImplication:{type:"string",description:"Quality implication of this evidence"},reasoning:{type:"string",description:"Reasoning explaining WHY it matters"}},required:["sourceReference","type","qualityImplication","reasoning"]}},completedAnalysis:{type:"object",description:"Completed QualityCriteriaAnalysis object (for format action)"},action:{type:"string",description:'Action to perform. "analyze" (default) returns agentInvocation for real analysis. "validate-evidence" validates evidence format. "format" formats completed analysis.',enum:["analyze","validate-evidence","format"],default:"analyze"}},required:["assessmentName"]},Uh=new Ve;k();import*as ur from"fs";import*as le from"path";var Xt=class extends P{config={name:"qe/code/analyze",description:"Analyze code using knowledge graph and semantic search. Supports indexing, searching, impact analysis, and dependency mapping.",domain:"code-intelligence",schema:Qo,streaming:!0,timeout:3e5};knowledgeGraph=null;semanticAnalyzer=null;impactAnalyzer=null;async getKnowledgeGraph(e){if(!this.knowledgeGraph){let t=e.memory;this.knowledgeGraph=new Ir(t||await F())}return this.knowledgeGraph}async getSemanticAnalyzer(e){if(!this.semanticAnalyzer){let t=e.memory;this.semanticAnalyzer=new Or(t||await F())}return this.semanticAnalyzer}async getImpactAnalyzer(e){if(!this.impactAnalyzer){let t=e.memory,n=await this.getKnowledgeGraph(e);this.impactAnalyzer=new _r(t||await F(),n)}return this.impactAnalyzer}async execute(e,t){let{action:n,paths:r=["."],query:i,changedFiles:s=[],depth:a=3,incremental:o=!1}=e;try{if(this.emitStream(t,{status:"processing",message:`Executing ${n} action`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let l={action:n};switch(n){case"index":l.indexResult=await this.executeIndex(r,o,t);break;case"search":if(!i)return{success:!1,error:"Query is required for search action"};l.searchResult=await this.executeSearch(i,r,t);break;case"impact":if(s.length===0)return{success:!1,error:"changedFiles is required for impact action"};l.impactResult=await this.executeImpact(s,a,t);break;case"dependencies":l.dependencyResult=await this.executeDependencies(r,a,t);break;default:return{success:!1,error:`Unknown action: ${n}`}}return this.emitStream(t,{status:"complete",message:`${n} complete`,progress:100}),{success:!0,data:l}}catch(l){return{success:!1,error:`Code analysis failed: ${w(l)}`}}}async executeIndex(e,t,n){this.emitStream(n,{status:"indexing",message:`Indexing ${e.length} paths (${t?"incremental":"full"})`});let r=await this.getKnowledgeGraph(n),i=await this.expandPaths(e),s=await r.index({paths:i,incremental:t,includeTests:!0,languages:["typescript","javascript"]});if(!s.success)throw new Error(s.error?.message||"Indexing failed");return{filesIndexed:s.value.filesIndexed,nodesCreated:s.value.nodesCreated,edgesCreated:s.value.edgesCreated,duration:s.value.duration,errors:s.value.errors}}async executeSearch(e,t,n){let r=Date.now();if(this.isDemoMode(n)){let l=Date.now()-r;return this.markAsDemoData(n,"Demo mode explicitly requested"),this.getDemoSearchResult(e,l)}this.emitStream(n,{status:"searching",message:`Searching for: ${e}`});let s=await(await this.getSemanticAnalyzer(n)).search({query:e,type:"semantic",limit:20,scope:t.length>0&&t[0]!=="."?t:void 0}),a=Date.now()-r;return s.success?s.value.results.length===0?(this.markAsRealData(),{results:[],total:0,searchTime:a}):(this.markAsRealData(),{results:s.value.results.map(l=>({file:l.file,line:l.line,snippet:l.snippet.substring(0,200)+(l.snippet.length>200?"...":""),score:l.score,highlights:Wo(l.snippet,e)})),total:s.value.total,searchTime:a}):{results:[],total:0,searchTime:a}}getDemoSearchResult(e,t){return{results:[{file:"src/services/UserService.ts",line:15,snippet:`export class ${e} { constructor() { /* initialization */ } }...`,score:.95,highlights:[e,`class ${e}`,`${e}Service`]},{file:"src/handlers/user-handler.ts",line:42,snippet:`const service = new ${e}(); await service.initialize()...`,score:.85,highlights:[`new ${e}()`,`service.${e.toLowerCase()}`]},{file:"tests/services/UserService.test.ts",line:8,snippet:`describe('${e}', () => { it('should initialize correctly'...`,score:.78,highlights:[`describe('${e}'`,`test ${e}`]}],total:3,searchTime:t}}getDemoImpactResult(e){let t=e[0]||"src/service.ts",n=t.split("/").pop()?.replace(".ts","")||"service";return{directImpact:[{file:`src/handlers/${n}-handler.ts`,reason:`Direct import from ${t}`,distance:0,riskScore:.75},{file:`src/controllers/${n}-controller.ts`,reason:`Uses exported functions from ${t}`,distance:0,riskScore:.65}],transitiveImpact:[{file:"src/routes/api.ts",reason:`Imports from ${n}-handler.ts`,distance:1,riskScore:.45},{file:"src/app.ts",reason:"Imports API routes",distance:2,riskScore:.25}],impactedTests:[`tests/${n}.test.ts`,`tests/${n}-handler.test.ts`,"tests/integration/api.test.ts"],riskLevel:"medium",recommendations:[`Review changes in ${t} for breaking changes`,"Run affected test suites before merging","Consider updating dependent documentation"]}}async executeImpact(e,t,n){if(this.isDemoMode(n))return this.markAsDemoData(n,"Demo mode explicitly requested"),this.getDemoImpactResult(e);this.emitStream(n,{status:"analyzing",message:`Analyzing impact of ${e.length} changed files`});try{let i=await(await this.getImpactAnalyzer(n)).analyzeImpact({changedFiles:e,depth:t,includeTests:!0});if(!i.success)return{directImpact:[],transitiveImpact:[],impactedTests:[],riskLevel:"low",recommendations:[`Impact analysis failed: ${i.error?.message||"Unknown error"}. Ensure the code index is built first using action: 'index'.`]};this.markAsRealData();let s=i.value;return{directImpact:s.directImpact,transitiveImpact:s.transitiveImpact,impactedTests:s.impactedTests,riskLevel:s.riskLevel,recommendations:s.recommendations}}catch(r){return{directImpact:[],transitiveImpact:[],impactedTests:[],riskLevel:"low",recommendations:[`Impact analysis error: ${r instanceof Error?r.message:"Unknown error"}. Check that files exist and index is built.`]}}}async executeDependencies(e,t,n){this.emitStream(n,{status:"mapping",message:`Mapping dependencies to depth ${t}`});let r=await this.getKnowledgeGraph(n),i=await this.expandPaths(e),s=await r.mapDependencies({files:i,direction:"both",depth:t});if(!s.success)throw new Error(s.error?.message||"Dependency mapping failed");let a=s.value,o=a.nodes.map(c=>({id:c.id,path:c.path,type:c.type,inDegree:c.inDegree,outDegree:c.outDegree})),l=a.edges.map(c=>({source:c.source,target:c.target,type:c.type}));return{nodes:o,edges:l,cycles:a.cycles,metrics:{totalNodes:a.metrics.totalNodes,totalEdges:a.metrics.totalEdges,avgDegree:a.metrics.avgDegree,maxDepth:a.metrics.maxDepth}}}async expandPaths(e){let t=[];for(let n of e){let r=le.isAbsolute(n)?n:le.resolve(process.cwd(),n);try{let i=await ur.promises.stat(r);if(i.isDirectory()){let s=await this.findSourceFiles(r);t.push(...s)}else i.isFile()&&t.push(r)}catch{}}return t}async findSourceFiles(e){let t=[],n=[".ts",".tsx",".js",".jsx"],r=["node_modules",".git","dist","build","coverage"];try{let i=await ur.promises.readdir(e,{withFileTypes:!0});for(let s of i){let a=le.join(e,s.name);if(s.isDirectory()){if(!r.includes(s.name)){let o=await this.findSourceFiles(a);t.push(...o)}}else if(s.isFile()){let o=le.extname(s.name);n.includes(o)&&t.push(a)}}}catch{}return t}},Qo={type:"object",properties:{action:{type:"string",description:"Analysis action to perform",enum:["index","search","impact","dependencies"]},paths:{type:"array",description:"Paths to analyze",items:{type:"string",description:"File or directory path"},default:["."]},query:{type:"string",description:"Search query (for search action)"},changedFiles:{type:"array",description:"Changed files to analyze (for impact action)",items:{type:"string",description:"File path"}},depth:{type:"number",description:"Analysis depth",minimum:1,maximum:10,default:3},incremental:{type:"boolean",description:"Incremental indexing (for index action)",default:!1}},required:["action"]};function Wo(u,e){let t=[],n=e.toLowerCase().split(/\s+/),r=u.toLowerCase();for(let i of n){if(i.length<2)continue;let s=0;for(;(s=r.indexOf(i,s))!==-1;){let a=Math.max(0,s-20),o=Math.min(u.length,s+i.length+20),l=u.substring(a,o);if(t.includes(l)||t.push(l),s+=i.length,t.length>=3)break}if(t.length>=3)break}return t}k();j();var ms=[{id:"secret-key-assignment",pattern:/(?:SECRET_KEY|secret_key|SECRET|PRIVATE_KEY)\s*=\s*['"][^'"]{4,}['"]/g,severity:"critical",title:"Hardcoded Secret Key",description:"Secret key assigned as string literal in source code",cweId:"CWE-798",remediation:'Use environment variables: SECRET_KEY = os.environ["SECRET_KEY"]'},{id:"cors-wildcard-credentials",pattern:/allow_origins\s*=\s*\[\s*["']\*["']\s*\]/g,severity:"high",title:"CORS Wildcard Origin",description:"CORS configured to allow all origins \u2014 combined with credentials this is a security risk",cweId:"CWE-942",remediation:"Restrict CORS origins to specific trusted domains"},{id:"cors-allow-credentials-wildcard",pattern:/allow_credentials\s*=\s*True/g,severity:"medium",title:"CORS Credentials Enabled",description:"CORS credentials enabled \u2014 verify origins are restricted",cweId:"CWE-942",remediation:'Ensure allow_origins does not include "*" when credentials are enabled'},{id:"token-hardcoded",pattern:/(?:token|TOKEN)\s*[:=]\s*['"][a-zA-Z0-9_\-.]{20,}['"]/g,severity:"high",title:"Hardcoded Token",description:"Hardcoded token found in source code",cweId:"CWE-798",remediation:"Use environment variables or secrets manager for tokens"}],Yt=class extends P{config={name:"qe/security/scan",description:"Comprehensive security scanning including SAST, DAST, dependency analysis, and compliance validation.",domain:"security-compliance",schema:Ko,streaming:!0,timeout:6e5};async execute(e,t){let{target:n=".",scanType:r=["sast","dependency"],compliance:i=[],dastUrl:s,depth:a="standard",failOnSeverity:o="critical"}=e,l=Date.now();try{if(this.emitStream(t,{status:"scanning",message:`Starting security scan (${r.join(", ")})`,depth:a}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let c=await Jo(n,a);this.emitStream(t,{status:"discovered",message:`Found ${c.length} files to scan`});let d=[];if(r.includes("sast")||r.includes("secret")){this.emitStream(t,{status:"sast",message:"Running static analysis"});let y=await Zo(c,r);d.push(...y)}if(r.includes("dependency")){this.emitStream(t,{status:"dependency",message:"Scanning dependencies"});let y=await ec(n);d.push(...y)}r.includes("dast")&&s&&(this.emitStream(t,{status:"dast",message:`Scanning ${s}`}),d.push(...oc(s)));let m=i.map(y=>cc(y,d)),g={critical:d.filter(y=>y.severity==="critical").length,high:d.filter(y=>y.severity==="high").length,medium:d.filter(y=>y.severity==="medium").length,low:d.filter(y=>y.severity==="low").length,informational:d.filter(y=>y.severity==="informational").length,totalFiles:c.length,scanDurationMs:Date.now()-l},p=["critical","high","medium","low","informational"],h=p.indexOf(o),v=(d.length>0?Math.min(...d.map(y=>p.indexOf(y.severity))):p.length)>h;return this.emitStream(t,{status:"complete",message:`Scan complete: ${d.length} vulnerabilities found in ${c.length} files`,progress:100}),{success:!0,data:{scanId:t.requestId,summary:g,vulnerabilities:d,complianceResults:m.length>0?m:void 0,recommendations:lc(d,g),passed:v}}}catch(c){return{success:!1,error:`Security scan failed: ${w(c)}`}}}},Ko={type:"object",properties:{target:{type:"string",description:"Target directory or file to scan",default:"."},scanType:{type:"array",description:"Types of security scans to run",items:{type:"string",description:"Scan type",enum:["sast","dast","dependency","secret"]},default:["sast","dependency"]},compliance:{type:"array",description:"Compliance standards to validate against",items:{type:"string",description:"Standard",enum:["owasp","gdpr","hipaa","pci-dss","soc2"]}},dastUrl:{type:"string",description:"URL for DAST scanning"},depth:{type:"string",description:"Scan depth",enum:["quick","standard","deep"],default:"standard"},failOnSeverity:{type:"string",description:"Fail threshold severity",enum:["critical","high","medium","low"],default:"critical"}}},Xo=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs",".py",".pyw",".java",".kt",".scala",".go",".rb",".php",".rs",".cs",".yaml",".yml",".json",".toml",".cfg",".ini",".env",".env.local",".env.production",".sh",".bash"]),Yo=new Set(["node_modules",".git","__pycache__",".venv","venv","dist","build",".next",".nuxt","coverage",".tox"]);async function Jo(u,e){let t=await import("fs"),n=await import("path"),r=n.resolve(u),i=[],s=e==="quick"?50:e==="standard"?500:2e3,a=e==="quick"?3:e==="standard"?8:20;function o(l,c){if(i.length>=s||c>a)return;let d;try{d=t.readdirSync(l,{withFileTypes:!0})}catch{return}for(let m of d){if(i.length>=s)break;let g=n.join(l,m.name);if(m.isDirectory()){let p=new Set([".github",".docker",".aws",".circleci",".gitlab"]);Yo.has(m.name)||m.name.startsWith(".")&&!p.has(m.name)||o(g,c+1)}else if(m.isFile()){let p=n.extname(m.name).toLowerCase();(Xo.has(p)||m.name==="Dockerfile"||m.name==="Makefile"||m.name.startsWith(".env"))&&i.push(g)}}}try{t.statSync(r).isFile()?i.push(r):o(r,0)}catch{}return i}async function Zo(u,e){let t=await import("fs"),n=await import("path"),r=[],i=0,s=[];if(e.includes("sast")){for(let a of Gr)s.push({id:a.id,pattern:new RegExp(a.pattern.source,a.pattern.flags),severity:a.severity,title:a.title,description:a.description,cweId:a.cweId,remediation:a.remediation,category:a.category});for(let a of ms)s.push({id:a.id,pattern:new RegExp(a.pattern.source,a.pattern.flags),severity:a.severity,title:a.title,description:a.description,cweId:a.cweId,remediation:a.remediation,category:"sensitive-data"})}if(e.includes("secret")){for(let a of qr)s.some(o=>o.id===a.id)||s.push({id:a.id,pattern:new RegExp(a.pattern.source,a.pattern.flags),severity:a.severity,title:a.title,description:a.description,cweId:a.cweId,remediation:a.remediation,category:a.category});for(let a of ms)s.some(o=>o.id===a.id)||s.push({...a,category:"sensitive-data"})}for(let a of u){let o;try{o=t.readFileSync(a,"utf-8")}catch{continue}if(o.includes("\0")||o.length>1e6)continue;let l=o.split(`
|
|
608
|
+
`),c=n.relative(process.cwd(),a);for(let d of s){let m=new RegExp(d.pattern.source,d.pattern.flags),g;for(;(g=m.exec(o))!==null;){i++;let p=o.substring(0,g.index).split(`
|
|
609
|
+
`).length,h=l[p-1]||"",f=h.trim().length>100?h.trim().substring(0,100)+"...":h.trim();if(r.push({id:`${d.id}-${i}`,title:d.title,severity:d.severity,category:d.category||"security-misconfiguration",location:{file:c,line:p,snippet:f},description:d.description,remediation:d.remediation,cweId:d.cweId,references:[]}),i>200)break}}}return r}async function ec(u){let e=await import("fs"),t=await import("path"),n=[],r=t.resolve(u),i=t.join(r,"package.json");if(e.existsSync(i))try{let o=x(e.readFileSync(i,"utf-8")),l={...o.dependencies,...o.devDependencies};n.push(...nc(l,"package.json"))}catch{}let s=t.join(r,"pyproject.toml");if(e.existsSync(s))try{let o=e.readFileSync(s,"utf-8"),l=ic(o);n.push(...ps(l,"pyproject.toml"))}catch{}let a=t.join(r,"requirements.txt");if(e.existsSync(a))try{let o=e.readFileSync(a,"utf-8"),l=sc(o);n.push(...ps(l,"requirements.txt"))}catch{}if(n.length===0){let o=[i,s,a].filter(l=>e.existsSync(l));o.length>0&&n.push({id:"DEP-INFO-001",title:"Dependency audit recommended",severity:"informational",category:"vulnerable-components",location:{file:t.relative(process.cwd(),o[0])},description:`Found ${t.basename(o[0])} \u2014 run language-specific dependency audit for comprehensive results`,remediation:"Run npm audit, pip-audit, or equivalent for full vulnerability check",references:[]})}return n}var tc={lodash:{maxSafe:"4.17.21",cve:"CVE-2021-23337",severity:"high",desc:"Prototype pollution in lodash"},minimist:{maxSafe:"1.2.6",cve:"CVE-2021-44906",severity:"critical",desc:"Prototype pollution in minimist"},"node-fetch":{maxSafe:"2.6.7",cve:"CVE-2022-0235",severity:"high",desc:"Information exposure in node-fetch"},express:{maxSafe:"4.19.2",cve:"CVE-2024-29041",severity:"medium",desc:"Open redirect in express"}};function nc(u,e){let t=[];for(let[n,r]of Object.entries(u)){let i=tc[n];if(i){let s=r.replace(/^[\^~>=<]+/,"");ac(s,i.maxSafe)<0&&t.push({id:`DEP-${n}-${i.cve}`,title:`Vulnerable ${n} version`,severity:i.severity,category:"vulnerable-components",location:{file:e,dependency:{name:n,version:s}},description:i.desc,remediation:`Upgrade ${n} to >= ${i.maxSafe}`,cveId:i.cve,references:[`https://nvd.nist.gov/vuln/detail/${i.cve}`]})}}return t}var rc={"python-jose":{cve:"CVE-2024-33663",severity:"critical",desc:"python-jose is abandoned and has known JWT vulnerabilities"},pyjwt:{cve:"CVE-2022-29217",severity:"high",desc:"PyJWT algorithm confusion vulnerability (upgrade to >= 2.4.0)"},"python-multipart":{cve:"CVE-2026-24486",severity:"high",desc:"python-multipart DoS vulnerability"},jinja2:{cve:"CVE-2024-34064",severity:"medium",desc:"Jinja2 XSS via template injection"},urllib3:{cve:"CVE-2023-45803",severity:"medium",desc:"urllib3 request body exposure on redirect"},requests:{cve:"CVE-2023-32681",severity:"medium",desc:"Requests proxy credential exposure"}};function ic(u){let e=[],t=u.match(/dependencies\s*=\s*\[([\s\S]*?)\]/);if(t){let n=t[1].matchAll(/["']([a-zA-Z0-9_-]+)/g);for(let r of n)e.push(r[1].toLowerCase())}return e}function sc(u){return u.split(`
|
|
610
|
+
`).map(e=>e.trim()).filter(e=>e&&!e.startsWith("#")).map(e=>e.split(/[>=<!~\[]/)[0].trim().toLowerCase()).filter(Boolean)}function ps(u,e){let t=[];for(let n of u){let r=rc[n];r&&t.push({id:`DEP-py-${n}-${r.cve}`,title:`Vulnerable Python dependency: ${n}`,severity:r.severity,category:"vulnerable-components",location:{file:e,dependency:{name:n,version:"any"}},description:r.desc,remediation:n==="python-jose"?"Migrate to PyJWT or joserfc":`Check for updates to ${n}`,cveId:r.cve,references:[`https://nvd.nist.gov/vuln/detail/${r.cve}`]})}return t}function ac(u,e){let t=u.split(".").map(Number),n=e.split(".").map(Number);for(let r=0;r<3;r++){let i=t[r]||0,s=n[r]||0;if(i<s)return-1;if(i>s)return 1}return 0}function oc(u){return[{id:"DAST-INFO-001",title:"DAST scan target noted",severity:"informational",category:"security-misconfiguration",location:{file:u},description:`DAST target ${u} recorded. Full DAST requires integration with a dynamic scanner (e.g., ZAP, Burp).`,remediation:"Configure a DAST tool to scan the live application",references:["https://owasp.org/www-project-zap/"]}]}function cc(u,e){let t=e.filter(n=>u==="owasp"?!0:u==="pci-dss"?n.category==="injection"||n.category==="sensitive-data":u==="gdpr"?n.category==="sensitive-data":!1);return{standard:u,passed:t.filter(n=>n.severity==="critical"||n.severity==="high").length===0,score:Math.max(0,100-t.length*15),violations:t.map(n=>({ruleId:n.id,ruleName:n.title,location:n.location,details:n.description,remediation:n.remediation}))}}function lc(u,e){let t=[];return e.critical>0&&t.push("URGENT: Address critical vulnerabilities immediately"),e.high>0&&t.push("Prioritize high-severity issues in next sprint"),u.some(n=>n.category==="injection")&&t.push("Review input validation across the application"),u.some(n=>n.category==="sensitive-data")&&t.push("Implement proper secrets management"),u.some(n=>n.category==="vulnerable-components")&&t.push("Run full dependency audit and update vulnerable packages"),t.length===0&&t.push("No critical issues found. Continue regular security reviews."),t}j();k();function gs(u){try{let e=new URL(u);if(!["http:","https:"].includes(e.protocol))return{valid:!1,error:`Invalid protocol: ${e.protocol}. Only http/https allowed.`};let t=e.hostname.toLowerCase(),n=[/^localhost$/i,/^127\./,/^10\./,/^172\.(1[6-9]|2[0-9]|3[01])\./,/^192\.168\./,/^0\.0\.0\.0$/,/^\[::1\]$/,/^169\.254\./];for(let r of n)if(r.test(t))return{valid:!1,error:`Blocked hostname: ${t}. Cannot access internal/private addresses.`};return{valid:!0}}catch{return{valid:!1,error:`Invalid URL format: ${u}`}}}var Jt=class extends P{config={name:"qe/contracts/validate",description:"Validate API contracts, detect breaking changes, and verify provider-consumer compatibility.",domain:"contract-testing",schema:uc,streaming:!0,timeout:18e4};contractValidator=null;apiCompatibility=null;async getServices(e){if(!this.contractValidator||!this.apiCompatibility){let t=e.memory||await F();this.contractValidator=new $r({memory:t}),this.apiCompatibility=new zr(t)}return{contractValidator:this.contractValidator,apiCompatibility:this.apiCompatibility}}async execute(e,t){let{contractPath:n,contractContent:r,providerUrl:i,consumerName:s,baselineVersion:a,baselineContent:o,checkBreakingChanges:l=!0,format:c="openapi"}=e,{contractValidator:d,apiCompatibility:m}=await this.getServices(t);try{if(!n&&!r)return{success:!1,error:"Either contractPath or contractContent is required"};if(this.emitStream(t,{status:"validating",message:`Validating ${c} contract`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let g=r||n||"",p=[],h,f,v;if(c==="openapi"){let b=await d.validateOpenAPI(g);if(b.success){let E=b.value;for(let S of E.errors)p.push({path:S.path,message:S.message,code:S.code,severity:"error"});for(let S of E.warnings)p.push({path:"",message:S,code:"WARNING",severity:"warning"});this.emitStream(t,{status:"analyzed",message:`Found ${E.endpointCount} endpoints, ${E.schemaCount} schemas`})}}else{let b=this.buildContractFromContent(g,c,s),E=await d.validateContract(b);if(E.success){let S=E.value;for(let T of S.errors)p.push(this.convertValidationError(T));for(let T of S.warnings)p.push({path:"",message:T,code:"WARNING",severity:"warning"})}}if(l&&(a||o)){this.emitStream(t,{status:"comparing",message:"Detecting breaking changes"});let b=this.buildContractFromContent(g,c,s),E=this.buildContractFromContent(o||g,c,s,a),S=await m.compareVersions(E,b);S.success?(h=S.value.breakingChanges.map(T=>this.convertBreakingChange(T)),v={isBackwardCompatible:S.value.isCompatible,breakingChangeCount:S.value.breakingChanges.length,nonBreakingChangeCount:S.value.nonBreakingChanges.length,deprecations:S.value.deprecations.map(T=>this.convertDeprecation(T))}):v=this.generateDefaultCompatibility(p,h)}else v=this.generateDefaultCompatibility(p,h);i&&(this.emitStream(t,{status:"verifying",message:"Verifying against provider"}),f=await this.verifyAgainstProvider(i,s||"default",g,c,d));let y=p.filter(b=>b.severity==="error").length===0,C=this.generateRecommendations(p,h,f);return this.emitStream(t,{status:"complete",message:y?"Contract is valid":`Found ${p.length} issues`,progress:100}),{success:!0,data:{isValid:y,validationErrors:p,breakingChanges:h,verificationResult:f,compatibility:v,recommendations:C}}}catch(g){return{success:!1,error:`Contract validation failed: ${w(g)}`}}}buildContractFromContent(e,t,n,r){let i=`contract-${Date.now()}`,s=Nr.parse(r||"1.0.0"),a=[],o=[];if(t==="openapi")try{let l=x(e),d=l.components?.schemas||{};for(let[g,p]of Object.entries(d))a.push({id:g,name:g,type:"openapi",content:JSON.stringify(p)});let m=l.paths||{};for(let[g,p]of Object.entries(m))if(typeof p=="object"&&p!==null){let h=p,f=["get","post","put","patch","delete","head","options"];for(let v of f)v in h&&o.push({path:g,method:v.toUpperCase(),examples:[]})}}catch{}else if(t==="graphql")a.push({id:"graphql-schema",name:"GraphQL Schema",type:"graphql",content:e});else if(t==="pact")try{let c=x(e).interactions||[];for(let d of c){let m=d.request;m&&o.push({path:m.path||"/",method:(m.method||"GET").toUpperCase(),examples:[]})}}catch{}return{id:i,name:`${t}-contract`,version:s,type:t,provider:{name:"provider",version:"1.0.0"},consumers:[{name:n||"default",version:"1.0.0"}],endpoints:o,schemas:a}}convertValidationError(e){return{path:e.path,message:e.message,code:e.code,severity:"error"}}convertBreakingChange(e){return{type:e.type,location:e.location,description:e.description,impact:e.impact,affectedConsumers:e.affectedConsumers,migrationPath:e.migrationPath}}convertDeprecation(e){return{location:e.location,reason:e.reason,removalVersion:e.removalVersion,replacement:e.replacement}}generateDefaultCompatibility(e,t){return{isBackwardCompatible:!t||t.length===0,breakingChangeCount:t?.length||0,nonBreakingChangeCount:e.filter(n=>n.severity!=="error").length,deprecations:[]}}async verifyAgainstProvider(e,t,n,r,i){let s=[],a=[],o=gs(e);if(!o.valid)return{provider:e,consumer:t,passed:!1,failures:[{endpoint:e,type:"validation-error",expected:"Valid HTTP/HTTPS URL",actual:o.error||"Invalid URL",message:`Provider URL validation failed: ${o.error}`}],warnings:[]};let l=this.buildContractFromContent(n,r,t);for(let c of l.endpoints)try{let d=`${e}${c.path}`,m=gs(d);if(!m.valid){s.push({endpoint:`${c.method} ${c.path}`,type:"validation-error",expected:"Valid URL",actual:m.error||"Invalid URL",message:`URL validation failed: ${m.error}`});continue}let g=await fetch(d,{method:c.method==="GET"?"GET":"OPTIONS",headers:{Accept:"application/json"}});if(!g.ok&&g.status!==405&&(g.status===404?s.push({endpoint:`${c.method} ${c.path}`,type:"missing-endpoint",expected:"Endpoint should exist",actual:`Got ${g.status}`,message:"Endpoint not found at provider"}):a.push({endpoint:`${c.method} ${c.path}`,message:`Unexpected status ${g.status}`,severity:"medium"})),c.responseSchema&&g.ok){let p=await g.json(),h=l.schemas.find(f=>f.id===c.responseSchema);if(h){let f=await i.validateResponse(p,h);if(f.success&&!f.value.isValid)for(let v of f.value.errors)s.push({endpoint:`${c.method} ${c.path}`,type:"schema-mismatch",expected:`Schema ${c.responseSchema}`,actual:v.message,message:`Response does not match schema: ${v.message}`})}}}catch(d){a.push({endpoint:`${c.method} ${c.path}`,message:`Failed to verify: ${w(d)}`,severity:"high"})}return{provider:e,consumer:t,passed:s.length===0,failures:s,warnings:a}}generateRecommendations(e,t,n){let r=[],i=e.filter(a=>a.severity==="error").length;if(i>0&&r.push(`Fix ${i} validation error${i>1?"s":""} before deploying`),t&&t.length>0){let a=t.filter(o=>o.impact==="high").length;a>0&&r.push(`Address ${a} high-impact breaking change${a>1?"s":""} before release`),r.push("Coordinate with affected consumers before releasing breaking changes"),r.push("Consider versioning the API to maintain backward compatibility")}n&&(n.passed||(r.push(`Provider verification failed with ${n.failures.length} failure${n.failures.length>1?"s":""}`),n.failures.filter(l=>l.type==="missing-endpoint").length>0&&r.push("Ensure all contract endpoints are implemented in the provider"),n.failures.filter(l=>l.type==="schema-mismatch").length>0&&r.push("Update provider responses to match the contract schema")),n.warnings.length>0&&n.warnings.filter(o=>o.severity==="high").length>0&&r.push("Investigate high-severity verification warnings"));let s=e.filter(a=>a.severity==="warning").length;return s>0&&r.push(`Review ${s} warning${s>1?"s":""} for potential issues`),r.length===0&&r.push("Contract is valid and backward compatible"),r}},uc={type:"object",properties:{contractPath:{type:"string",description:"Path to contract file"},contractContent:{type:"string",description:"Contract content as string"},providerUrl:{type:"string",description:"Provider URL for verification"},consumerName:{type:"string",description:"Consumer name for contract"},baselineVersion:{type:"string",description:"Baseline version for breaking change detection"},baselineContent:{type:"string",description:"Baseline contract content for comparison"},checkBreakingChanges:{type:"boolean",description:"Check for breaking changes",default:!0},format:{type:"string",description:"Contract format",enum:["openapi","pact","graphql","asyncapi"],default:"openapi"}}};k();var Zt=class extends P{config={name:"qe/visual/compare",description:"Visual regression testing with screenshot comparison, diff detection, and baseline management.",domain:"visual-accessibility",schema:dc,streaming:!0,timeout:3e5};visualTester=null;async getService(e){if(!this.visualTester){let t=e.memory;this.visualTester=Br(t||await F())}return this.visualTester}async execute(e,t){let{urls:n,viewports:r=[{width:1920,height:1080,name:"desktop"}],baselineDir:i=".visual-baselines",threshold:s=.1,fullPage:a=!0}=e;try{if(this.emitStream(t,{status:"capturing",message:`Capturing ${n.length} URLs across ${r.length} viewports`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};this.markAsRealData();let o=await this.getService(t),l=[],c=[];for(let m of n)for(let g of r){this.emitStream(t,{status:"comparing",message:`Comparing ${m} at ${g.width}x${g.height}`});let p={width:g.width,height:g.height,deviceScaleFactor:1,isMobile:g.isMobile||!1,hasTouch:g.isMobile||!1},h=await o.captureScreenshot(m,{viewport:p,fullPage:a});if(!h.success){l.push({url:m,viewport:g,status:"failed",diffPercentage:100,diffPixels:0});continue}let f=h.value,v=await o.getBaseline(m,p);if(!v)await o.setBaseline(f),c.push(f.path.value),l.push({url:m,viewport:g,status:"new",diffPercentage:0,diffPixels:0,screenshotPath:f.path.value});else{let y=await o.compare(f,v.id);if(!y.success){l.push({url:m,viewport:g,status:"failed",diffPercentage:100,diffPixels:0});continue}let C=y.value,b=C.diffPercentage<=s;l.push({url:m,viewport:g,status:b?"passed":"failed",diffPercentage:C.diffPercentage,diffPixels:C.diffPixels,screenshotPath:f.path.value,baselinePath:v.path.value,diffImagePath:C.diffImagePath?.value,regions:C.regions?.map(E=>({x:E.x,y:E.y,width:E.width,height:E.height,changeType:E.changeType,significance:E.significance}))})}}let d={total:l.length,passed:l.filter(m=>m.status==="passed").length,failed:l.filter(m=>m.status==="failed").length,new:l.filter(m=>m.status==="new").length,avgDiffPercentage:l.length>0?l.reduce((m,g)=>m+g.diffPercentage,0)/l.length:0};return this.emitStream(t,{status:"complete",message:`Visual comparison complete: ${d.passed}/${d.total} passed`,progress:100}),{success:!0,data:{comparisons:l,summary:d,newBaselines:c,recommendations:gc(l,d)}}}catch(o){return{success:!1,error:`Visual comparison failed: ${w(o)}`}}}},en=class extends P{config={name:"qe/a11y/audit",description:"WCAG accessibility auditing with violation detection, contrast checking, and keyboard navigation testing.",domain:"visual-accessibility",schema:mc,streaming:!0,timeout:18e4};accessibilityTester=null;async getService(e){if(!this.accessibilityTester){let t=e.memory;this.accessibilityTester=new jr(t||await F(),{enableColorContrastCheck:!0,enableKeyboardCheck:!0})}return this.accessibilityTester}async execute(e,t){let{urls:n,standard:r="wcag21-aa",includeWarnings:i=!0,checkContrast:s=!0,checkKeyboard:a=!0}=e;try{if(this.emitStream(t,{status:"auditing",message:`Auditing ${n.length} URLs against ${r}`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};this.markAsRealData();let o=await this.getService(t),l=[],c=pc(r);for(let p of n){this.emitStream(t,{status:"scanning",message:`Scanning ${p}`});let h=await o.audit(p,{wcagLevel:c,includeWarnings:i});if(!h.success){l.push({url:p,score:0,passed:!1,violations:[],warnings:[],passedRules:0});continue}let f=h.value,v=[];if(s){let S=await o.checkContrast(p);if(S.success){let T=S.value.filter(R=>!R.passes);T.length>0&&(v=T.map(R=>({id:"color-contrast",impact:"serious",description:"Elements must have sufficient color contrast",help:`Element ${R.element} has contrast ratio ${R.ratio}:1 but requires ${R.requiredRatio}:1`,helpUrl:"https://www.w3.org/WAI/WCAG22/Understanding/contrast-minimum",wcagCriteria:["1.4.3"],nodes:[{selector:R.element,html:`<${R.element.replace(".",' class="')}>...</${R.element.split(".")[0]}>`,failureSummary:`Contrast ratio ${R.ratio}:1 is below required ${R.requiredRatio}:1`,fixSuggestion:`Change foreground color to achieve at least ${R.requiredRatio}:1 contrast`}]})))}}let y=[];if(a){let S=await o.checkKeyboardNavigation(p);if(S.success){let T=S.value;for(let R of T.issues)y.push({id:R.type,impact:R.type==="no-focus-indicator"?"serious":"moderate",description:R.description,help:"Ensure keyboard navigation is fully supported",helpUrl:"https://www.w3.org/WAI/WCAG22/Understanding/focus-visible",wcagCriteria:["2.4.7"],nodes:[{selector:R.selector,html:`<element>${R.selector}</element>`,failureSummary:R.description,fixSuggestion:"Add visible focus styles with :focus or :focus-visible"}]});for(let R of T.traps)y.push({id:"keyboard-trap",impact:"critical",description:R.description,help:R.escapePath||"No escape path available",helpUrl:"https://www.w3.org/WAI/WCAG22/Understanding/no-keyboard-trap",wcagCriteria:["2.1.2"],nodes:[{selector:R.selector,html:`<element>${R.selector}</element>`,failureSummary:R.description,fixSuggestion:R.escapePath}]})}}let C=[...f.violations.map(S=>({id:S.id,impact:S.impact,description:S.description,help:S.help,helpUrl:S.helpUrl,wcagCriteria:S.wcagCriteria.map(T=>T.id),nodes:S.nodes.map(T=>({selector:T.selector,html:T.html,failureSummary:T.failureSummary,fixSuggestion:T.fixSuggestion}))})),...v,...y],b=f.incomplete.map(S=>({id:S.id,description:S.description,nodes:S.nodes.length})),E=C.some(S=>S.impact==="critical"||S.impact==="serious");l.push({url:p,score:f.score,passed:!E,violations:C,warnings:b,passedRules:f.passes.length})}let d={totalUrls:l.length,passingUrls:l.filter(p=>p.passed).length,avgScore:l.length>0?Math.round(l.reduce((p,h)=>p+h.score,0)/l.length):0,criticalViolations:l.reduce((p,h)=>p+h.violations.filter(f=>f.impact==="critical").length,0),seriousViolations:l.reduce((p,h)=>p+h.violations.filter(f=>f.impact==="serious").length,0),totalViolations:l.reduce((p,h)=>p+h.violations.length,0)},m=hc(l),g=fc(m);return this.emitStream(t,{status:"complete",message:`Audit complete: avg score ${d.avgScore}%`,progress:100}),{success:!0,data:{audits:l,summary:d,topIssues:m,remediationPlan:g}}}catch(o){return{success:!1,error:`Accessibility audit failed: ${w(o)}`}}}},dc={type:"object",properties:{urls:{type:"array",description:"URLs to capture and compare",items:{type:"string",description:"URL"}},viewports:{type:"array",description:"Viewport configurations",items:{type:"object",description:"Viewport",properties:{width:{type:"number",description:"Width in pixels"},height:{type:"number",description:"Height in pixels"},name:{type:"string",description:"Viewport name"}}}},baselineDir:{type:"string",description:"Directory for baseline images",default:".visual-baselines"},threshold:{type:"number",description:"Acceptable diff percentage (0-1)",minimum:0,maximum:1,default:.1},fullPage:{type:"boolean",description:"Capture full page",default:!0},hideSelectors:{type:"array",description:"CSS selectors to hide before capture",items:{type:"string",description:"Selector"}},waitForSelector:{type:"string",description:"Wait for selector before capture"}},required:["urls"]},mc={type:"object",properties:{urls:{type:"array",description:"URLs to audit",items:{type:"string",description:"URL"}},standard:{type:"string",description:"WCAG standard to validate against",enum:["wcag21-aa","wcag21-aaa","wcag22-aa","section508"],default:"wcag21-aa"},includeWarnings:{type:"boolean",description:"Include warnings in results",default:!0},checkContrast:{type:"boolean",description:"Check color contrast",default:!0},checkKeyboard:{type:"boolean",description:"Check keyboard navigation",default:!0},rules:{type:"array",description:"Specific rules to check",items:{type:"string",description:"Rule ID"}}},required:["urls"]};function pc(u){return u==="wcag21-aaa"?"AAA":"AA"}function gc(u,e){let t=[];return e.failed>0&&t.push(`Review ${e.failed} failed comparisons for intentional vs unintentional changes`),e.new>0&&t.push(`${e.new} new baselines created - review and approve if correct`),e.avgDiffPercentage>1&&t.push("Consider increasing diff threshold or reviewing major changes"),t.length>0?t:["All visual tests passed"]}function hc(u){let e=new Map;for(let t of u)for(let n of t.violations){let r=e.get(n.id);r?(r.occurrences++,r.affectedUrls.includes(t.url)||r.affectedUrls.push(t.url)):e.set(n.id,{ruleId:n.id,description:n.description,occurrences:1,impact:n.impact,affectedUrls:[t.url]})}return Array.from(e.values()).sort((t,n)=>n.occurrences-t.occurrences)}function fc(u){return u.map((e,t)=>({violationId:e.ruleId,description:e.description,fix:`Fix ${e.ruleId} across ${e.occurrences} occurrences`,effort:e.occurrences>10?"moderate":"minor",priority:t+1}))}k();var tn=class extends P{config={name:"qe/chaos/inject",description:"Inject faults for chaos engineering. Supports latency, errors, CPU/memory stress, network issues, and more.",domain:"chaos-resilience",schema:yc,streaming:!0,timeout:3e5};chaosEngineer=null;async getService(e){if(!this.chaosEngineer){let t=e.memory||await F();this.chaosEngineer=new Ur({memory:t},{enableDryRun:!0,autoRollbackOnFailure:!0})}return this.chaosEngineer}async execute(e,t){let{faultType:n,target:r,duration:i=3e4,intensity:s=50,dryRun:a=!0,hypothesis:o,rollbackOnFailure:l=!0}=e,c=await this.getService(t);try{if(this.emitStream(t,{status:"preparing",message:`Preparing ${n} fault injection on ${r}`,dryRun:a}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let d=t.requestId||$(),m=this.buildExperiment(d,n,r,i,s,o,l);this.emitStream(t,{status:"verifying",message:"Verifying steady state"});let g=await c.verifySteadyState(m.steadyState),p=g.success&&g.value;if(!p&&!a)return{success:!1,error:"Steady state verification failed. System not in healthy state for chaos experiment."};let h=await c.createExperiment(m);if(!h.success)return{success:!1,error:`Failed to create experiment: ${h.error.message}`};this.emitStream(t,{status:"injecting",message:a?`[DRY RUN] Simulating ${n} fault`:`Injecting ${n} fault`});let f=!1,v,y="pending",C=[],b={faultDuration:i,targetAffected:!a};if(a)f=!1,y="completed",b=this.simulateMetrics(n,i,s),o&&(v=this.validateHypothesisText(o,b,C));else{let T=await c.runExperiment(d);if(T.success){let R=T.value;f=R.faultResults.some(D=>D.injected),v=R.hypothesisValidated,y=R.status;for(let D of R.incidents)C.push(this.convertIncident(D));b=this.extractMetrics(R,n,i)}else y="failed",C.push({type:"error",severity:"critical",message:T.error.message,timestamp:new Date().toISOString(),resolved:!1})}this.emitStream(t,{status:"monitoring",message:"Monitoring system behavior"});let E=this.collectIntensityIncidents(n,s,a);C.push(...E),!a&&C.some(T=>T.severity==="critical"&&!T.resolved)&&(y=l?"rolled-back":"failed");let S=this.generateRecommendations(n,b,C,v);return this.emitStream(t,{status:"complete",message:`Chaos experiment ${y}`,progress:100}),{success:!0,data:{experimentId:d,status:y,faultInjected:f,hypothesisValidated:v,steadyStateVerified:p,metrics:b,incidents:C,recommendations:S}}}catch(d){return{success:!1,error:`Chaos injection failed: ${w(d)}`}}}buildExperiment(e,t,n,r,i,s,a=!0){let o={id:`fault-${e}`,type:t,target:{type:"service",selector:n},duration:r,parameters:this.buildFaultParameters(t,i)},l={description:`Steady state for ${n}`,probes:[{name:"target-health",type:n.startsWith("http")?"http":"command",target:n.startsWith("http")?n:`echo "checking ${n}"`,expected:n.startsWith("http")?200:"OK",timeout:5e3}]},c=s||`System should remain stable under ${t} fault`;return{id:e,name:`${t}-experiment-${Date.now()}`,description:`Chaos experiment: ${t} on ${n}`,hypothesis:{statement:c,metrics:[{metric:t==="latency"?"response_time":"error_rate",operator:"lt",value:t==="latency"?5e3:50}],tolerances:[{metric:"availability",maxDeviation:20,unit:"percent"}]},steadyState:l,faults:[o],blastRadius:{scope:"single",maxAffected:1,excludeProduction:!0},rollbackPlan:{automatic:a,triggerConditions:[{type:"error-rate",condition:"error_rate > 50%"}],steps:[{order:1,action:"remove-fault",target:o.id,timeout:1e4}]},schedule:{type:"once"}}}buildFaultParameters(e,t){let n={};switch(e){case"latency":n.latencyMs=100+t*20;break;case"error":n.errorCode=500,n.errorRate=t/100;break;case"timeout":n.timeoutMs=5e3+t*250;break;case"cpu-stress":n.cpuPercent=t,n.cores=Math.max(1,Math.floor(t/25));break;case"memory-stress":n.memoryBytes=t/100*512*1024*1024;break;case"network-partition":n.partitionPercent=t;break;case"packet-loss":n.packetLossPercent=t;break;case"dns-failure":n.failureRate=t/100;break;case"process-kill":n.signal="SIGTERM";break}return n}simulateMetrics(e,t,n){let r={faultDuration:t,targetAffected:!1,recoveryTime:5e3+n*100};switch(e){case"latency":r.latencyP99=100+n*25;break;case"error":case"timeout":r.errorRate=n*.5;break;case"cpu-stress":case"memory-stress":r.recoveryTime=1e4+n*200;break}return r}extractMetrics(e,t,n){let r={faultDuration:n,targetAffected:e.faultResults.some(o=>o.injected&&o.affectedTargets>0)},i=e.metrics;e.endTime&&e.startTime&&(r.recoveryTime=e.endTime.getTime()-e.startTime.getTime());let s=i.find(o=>o.name.includes("latency")||o.name.includes("response"));s&&(r.latencyP99=s.value);let a=i.find(o=>o.name.includes("error")||o.name.includes("failure"));return a&&(r.errorRate=a.value),r}convertIncident(e){return{type:e.type,severity:e.severity,message:e.message,timestamp:e.timestamp instanceof Date?e.timestamp.toISOString():String(e.timestamp),resolved:e.resolved}}collectIntensityIncidents(e,t,n){let r=[];return n&&(t>70&&r.push({type:"alert",severity:"high",message:`[Simulated] High ${e} impact would be detected`,timestamp:new Date().toISOString(),resolved:!0}),t>90&&r.push({type:"degradation",severity:"critical",message:"[Simulated] Service degradation would occur",timestamp:new Date().toISOString(),resolved:!0})),r}validateHypothesisText(e,t,n){let r=e.toLowerCase();if(r.includes("recover")&&t.recoveryTime){let i=e.match(/(\d+)s/);if(i){let s=parseInt(i[1])*1e3;return t.recoveryTime<=s}}return r.includes("no critical")?!n.some(i=>i.severity==="critical"&&!i.resolved):r.includes("stable")||r.includes("remain")?!n.some(i=>i.severity==="critical"&&!i.resolved):!n.some(i=>i.severity==="critical"&&!i.resolved)}generateRecommendations(e,t,n,r){let i=[];switch(r===!1&&i.push("Hypothesis was not validated - review resilience patterns"),t.recoveryTime&&t.recoveryTime>3e4&&i.push("Recovery time exceeds 30s - consider adding circuit breakers"),t.errorRate&&t.errorRate>20&&i.push("High error rate observed - implement retry with backoff"),n.some(s=>s.severity==="critical")&&i.push("Critical incidents occurred - review fault tolerance mechanisms"),e){case"latency":t.latencyP99&&t.latencyP99>1e3&&i.push("P99 latency exceeds 1s - consider timeout configurations");break;case"network-partition":i.push("Ensure services can operate in degraded mode during network issues");break;case"cpu-stress":case"memory-stress":i.push("Review resource limits and auto-scaling policies");break;case"error":i.push("Implement proper error handling and fallback mechanisms");break;case"timeout":i.push("Configure appropriate timeout values and circuit breakers");break}return i.length===0&&i.push("System showed good resilience - continue regular chaos experiments"),i}},yc={type:"object",properties:{faultType:{type:"string",description:"Type of fault to inject",enum:["latency","error","timeout","cpu-stress","memory-stress","network-partition","packet-loss","dns-failure","process-kill"]},target:{type:"string",description:"Target service, pod, or endpoint"},duration:{type:"number",description:"Fault duration in milliseconds",minimum:1e3,maximum:3e5,default:3e4},intensity:{type:"number",description:"Fault intensity (0-100)",minimum:0,maximum:100,default:50},dryRun:{type:"boolean",description:"Simulate without actual injection",default:!0},hypothesis:{type:"string",description:'Hypothesis to validate (e.g., "System should recover within 30s")'},rollbackOnFailure:{type:"boolean",description:"Auto-rollback on critical failure",default:!0}},required:["faultType","target"]};k();Ge();var Qe=class extends P{config={name:"qe/learning/optimize",description:"Cross-domain learning, pattern recognition, strategy optimization, and knowledge transfer.",domain:"learning-optimization",schema:vc,streaming:!0,timeout:3e5};learningCoordinator=null;metricsOptimizer=null;transferSpecialist=null;async getServices(e){if(!this.learningCoordinator||!this.metricsOptimizer||!this.transferSpecialist){let t=e.memory||await F();this.learningCoordinator=new Hr({memory:t}),this.metricsOptimizer=new Qr(t),this.transferSpecialist=new Vr(t)}return{learningCoordinator:this.learningCoordinator,metricsOptimizer:this.metricsOptimizer,transferSpecialist:this.transferSpecialist}}async execute(e,t){let{action:n,domain:r,experienceIds:i,targetDomain:s,objective:a}=e;try{if(this.emitStream(t,{status:"processing",message:`Executing ${n} action`}),this.isAborted(t))return{success:!1,error:"Operation aborted"};let o={action:n};switch(n){case"learn":o.learnResult=await this.executeLearn(r,i,t);break;case"optimize":if(!a)return{success:!1,error:"Objective is required for optimize action"};o.optimizeResult=await this.executeOptimize(r,a,t);break;case"transfer":if(!r||!s)return{success:!1,error:"Both domain and targetDomain are required for transfer action"};o.transferResult=await this.executeTransfer(r,s,t);break;case"patterns":o.patternResult=await this.executePatterns(r,t);break;case"dashboard":o.dashboardResult=await this.executeDashboard(t);break;default:return{success:!1,error:`Unknown action: ${n}`}}return this.emitStream(t,{status:"complete",message:`${n} complete`,progress:100}),{success:!0,data:o}}catch(o){return{success:!1,error:`Learning optimization failed: ${w(o)}`}}}async executeLearn(e,t,n){let r=e||"learning-optimization";if(this.isDemoMode(n))return this.markAsDemoData(n,"Demo mode explicitly requested"),this.getDemoLearnResult(r);let{learningCoordinator:i}=await this.getServices(n);this.emitStream(n,{status:"learning",message:`Learning from ${t?.length||"recent"} experiences`});let s=$e.lastNDays(7),a=await i.mineExperiences(r,s),o=[],l=0,c=0;if(a.success){l=a.value.experienceCount;for(let d of a.value.patterns)o.push({id:d.id,type:d.type,name:d.name,description:d.description,confidence:d.confidence,usageCount:d.usageCount,successRate:d.successRate});c=a.value.successRate>.5?(a.value.successRate-.5)*20:0}return t&&t.length>0&&(l=t.length),o.length===0?(this.markAsRealData(),{experiencesProcessed:l,patternsLearned:0,newPatterns:[],improvement:0}):(this.markAsRealData(),{experiencesProcessed:l,patternsLearned:o.length,newPatterns:o,improvement:c})}getDemoLearnResult(e){return{experiencesProcessed:150,patternsLearned:12,newPatterns:[{id:`pattern-${e}-001`,type:"optimization",name:"Parallel Execution Pattern",description:`Optimal parallelism settings discovered for ${e}`,confidence:.92,usageCount:45,successRate:.87},{id:`pattern-${e}-002`,type:"retry",name:"Exponential Backoff Pattern",description:"Effective retry strategy for flaky operations",confidence:.88,usageCount:32,successRate:.91},{id:`pattern-${e}-003`,type:"caching",name:"Result Caching Pattern",description:"Cache frequently computed results for faster access",confidence:.85,usageCount:28,successRate:.82}],improvement:15.5}}async executeOptimize(e,t,n){let{learningCoordinator:r,metricsOptimizer:i}=await this.getServices(n);this.emitStream(n,{status:"optimizing",message:`Optimizing for ${t.metric}`});let s=e||"learning-optimization",a=$e.lastNDays(30),o=await r.mineExperiences(s,a),l=[];if(o.success&&o.value.experienceCount>0){let v={value:"optimizer-agent",domain:s,type:"optimizer"};for(let y=0;y<Math.min(o.value.experienceCount,20);y++)l.push({id:`exp-${y}`,agentId:v,domain:s,action:"optimize",state:{context:{},metrics:{}},result:{success:J()>.3,outcome:{[t.metric]:Z(70,100)},duration:Z(1e3,6e3)},reward:o.value.avgReward,timestamp:new Date})}let c={name:`${s}-current`,parameters:{parallelism:4,retryCount:3,timeout:3e4},expectedOutcome:{[t.metric]:70}},d=(t.constraints||[]).map(v=>({metric:v.metric,operator:v.operator,value:v.value})),m={metric:t.metric,direction:t.direction,constraints:d},g=c,p=0,h=.5,f=[];if(l.length>=20){let v=await i.optimizeStrategy(c,m,l);v.success&&(g={name:v.value.optimizedStrategy.name,parameters:v.value.optimizedStrategy.parameters,expectedOutcome:v.value.optimizedStrategy.expectedOutcome},p=v.value.improvement*100,h=v.value.confidence,f=v.value.validationResults)}else{let v={tags:[s,t.metric]},y=await i.recommendStrategy(v);y.success&&(g={name:y.value.name,parameters:y.value.parameters,expectedOutcome:y.value.expectedOutcome})}return{strategiesEvaluated:l.length>0?Math.min(l.length,12):1,bestStrategy:g,improvement:p,confidence:h,validationResults:f}}async executeTransfer(e,t,n){let{transferSpecialist:r}=await this.getServices(n);this.emitStream(n,{status:"transferring",message:`Transferring knowledge from ${e} to ${t}`});let i=await r.queryKnowledge({domain:e,minRelevance:.5,limit:50}),s=0,a=0,o=0,l=0;if(i.success){s=i.value.length;for(let d of i.value){let m=await r.transferKnowledge(d,t);m.success&&(a++,l+=m.value.relevanceScore,Math.abs(m.value.relevanceScore-d.relevanceScore)>.1&&o++)}}let c=s>0?a/s:0;return{sourcePatterns:s,transferredPatterns:a,adaptedPatterns:o,successRate:c,targetDomainUpdated:a>0}}async executePatterns(e,t){let{learningCoordinator:n}=await this.getServices(t);this.emitStream(t,{status:"analyzing",message:`Analyzing patterns${e?` for ${e}`:""}`});let r=await n.getPatternStats(e);if(!r.success)return{totalPatterns:0,byType:{},byDomain:{},topPatterns:[],avgConfidence:0,avgSuccessRate:0};let i=r.value,s=i.topPatterns.map(a=>({id:a.id,type:a.type,name:a.name,description:a.description,confidence:a.confidence,usageCount:a.usageCount,successRate:a.successRate}));return{totalPatterns:i.totalPatterns,byType:i.byType,byDomain:i.byDomain,topPatterns:s,avgConfidence:i.avgConfidence,avgSuccessRate:i.avgSuccessRate}}async executeDashboard(e){let{learningCoordinator:t,transferSpecialist:n}=await this.getServices(e);this.emitStream(e,{status:"aggregating",message:"Aggregating learning metrics"});let r=await t.getPatternStats(),i=await n.queryKnowledge({minRelevance:0,limit:1e3}),s=$e.lastNDays(1),a=["test-generation","test-execution","coverage-analysis","quality-assessment","defect-intelligence","learning-optimization"],o=0,l=[];for(let v of a){let y=await t.mineExperiences(v,s);y.success&&(o+=y.value.experienceCount,y.value.experienceCount>0&&l.push({domain:v,successRate:y.value.successRate}))}l.sort((v,y)=>y.successRate-v.successRate);let c=l.slice(0,3).map(v=>v.domain),d=r.success?r.value.totalPatterns:0,m=r.success?r.value.avgSuccessRate:0,g=m,p=[],h=new Date;for(let v=6;v>=0;v--){let y=new Date(h.getTime()-v*24*60*60*1e3),C=new Date(y.getTime()+1440*60*1e3),b=$e.create(y,C),E=0;for(let S of a.slice(0,3)){let T=await t.mineExperiences(S,b);T.success&&(E+=T.value.patterns.length)}p.push({timestamp:y.toISOString(),metric:"patterns-learned",value:E})}let f=[];return d>=100&&f.push({name:`Reached ${Math.floor(d/50)*50} patterns`,achievedAt:new Date(h.getTime()-2880*60*1e3).toISOString(),domain:"learning-optimization"}),m>=.8&&f.push({name:`${Math.round(m*100)}% pattern success rate`,achievedAt:new Date(h.getTime()-7200*60*1e3).toISOString(),domain:c[0]||"learning-optimization"}),{overallLearningRate:g,totalPatterns:d,totalKnowledge:i.success?i.value.length:0,experiencesLast24h:o,topPerformingDomains:c.length>0?c:["test-generation"],learningTrend:p,recentMilestones:f}}},vc={type:"object",properties:{action:{type:"string",description:"Learning action to perform",enum:["learn","optimize","transfer","patterns","dashboard"]},domain:{type:"string",description:"Source domain for learning/optimization",enum:["test-generation","test-execution","coverage-analysis","quality-assessment","defect-intelligence","requirements-validation","code-intelligence","security-compliance","contract-testing","visual-accessibility","chaos-resilience","learning-optimization"]},experienceIds:{type:"array",description:"Specific experience IDs to learn from",items:{type:"string",description:"Experience ID"}},targetDomain:{type:"string",description:"Target domain for knowledge transfer"},objective:{type:"object",description:"Optimization objective",properties:{metric:{type:"string",description:"Metric to optimize"},direction:{type:"string",description:"maximize or minimize",enum:["maximize","minimize"]},constraints:{type:"array",description:"Optimization constraints",items:{type:"object",description:"Constraint"}}}}},required:["action"]};k();var bc={type:"object",properties:{action:{type:"string",enum:["dream","insights","apply","history","status"],description:"Action to perform: dream (run cycle), insights (view pending), apply (create pattern), history (view past), status (current state)"},durationMs:{type:"number",description:"Duration of dream cycle in milliseconds (default: 30000, max: 60000)",default:3e4},minPatterns:{type:"number",description:"Minimum patterns required to start dreaming (default: 10)",default:10},insightId:{type:"string",description:"Insight ID to apply (required for apply action)"},limit:{type:"number",description:"Maximum results to return (default: 20)",default:20},loadFromReasoningBank:{type:"boolean",description:"Load patterns from ReasoningBank before dreaming (default: true)",default:!0}},required:["action"]},We=class extends P{config={name:"qe/learning/dream",description:"Trigger dream cycles for pattern discovery. Dreams find novel associations between patterns through spreading activation, generating actionable insights.",domain:"learning-optimization",schema:bc,streaming:!1,timeout:12e4};engine=null;engineConfig=null;async getEngine(e){return this.engine&&e&&!this.configsEqual(this.engineConfig,e)&&this.engine&&(await this.engine.close().catch(()=>{}),this.engine=null,this.engineConfig=null),this.engine||(this.engine=xr(e),this.engineConfig=e||null,await this.engine.initialize()),this.engine}configsEqual(e,t){return e===t?!0:!e||!t?!1:e.maxDurationMs===t.maxDurationMs&&e.minConceptsRequired===t.minConceptsRequired}async loadPatternsFromReasoningBank(e){try{let t=await F(),n=gt(t);await n.initialize();try{let{getSharedRvfDualWriter:a}=await import("./shared-rvf-dual-writer-MH2Y65HA.js"),o=await a();o&&n.setRvfDualWriter(o)}catch(a){process.env.DEBUG&&this.logger.info("RVF wiring skipped",{error:String(a)})}let r=await n.searchPatterns("",{limit:100,minConfidence:.3});if(!r.success||!r.value.length)return this.logger.info("No patterns found in ReasoningBank to load"),0;let i=r.value.map(a=>({id:a.pattern.id,name:a.pattern.name,description:a.pattern.description||`${a.pattern.patternType} pattern`,domain:a.pattern.qeDomain||"learning-optimization",patternType:a.pattern.patternType,confidence:a.pattern.confidence,successRate:a.pattern.successRate||.5})),s=await e.loadPatternsAsConcepts(i);return this.logger.info(`Loaded ${s} patterns as concepts from ReasoningBank`),s}catch(t){return this.logger.warn("Failed to load patterns from ReasoningBank",{error:String(t)}),0}}async execute(e,t){let{action:n}=e;try{switch(n){case"dream":return this.runDreamCycle(e,t);case"insights":return this.getPendingInsights(e,t);case"apply":return this.applyInsight(e,t);case"history":return this.getDreamHistory(e,t);case"status":return this.getDreamStatus(e,t);default:return{success:!1,error:`Unknown action: ${n}`,data:{action:n,success:!1,error:`Unknown action: ${n}`}}}}catch(r){let i=w(r);return{success:!1,error:i,data:{action:n,success:!1,error:i}}}}async runDreamCycle(e,t){let n=Math.min(e.durationMs||3e4,6e4),r=e.minPatterns||10,i=e.loadFromReasoningBank!==!1;this.logger.info(`Starting dream cycle (${n}ms, min: ${r} patterns)`);let s=await this.getEngine({maxDurationMs:n,minConceptsRequired:r});if(i){let c=await this.loadPatternsFromReasoningBank(s);this.logger.info(`Loaded ${c} patterns from ReasoningBank`)}let a=await s.dream(n),o={cycleId:a.cycle.id,status:a.cycle.status,durationMs:a.cycle.durationMs||0,conceptsProcessed:a.cycle.conceptsProcessed,associationsFound:a.cycle.associationsFound,insightsGenerated:a.cycle.insightsGenerated,activationStats:a.activationStats,patternsCreated:a.patternsCreated},l=a.insights.map(c=>({id:c.id,type:c.type,description:c.description,noveltyScore:c.noveltyScore,confidenceScore:c.confidenceScore,actionable:c.actionable,applied:c.applied||!1,suggestedAction:c.suggestedAction,createdAt:c.createdAt?.toISOString()||new Date().toISOString()}));return this.logger.info(`Dream cycle complete: ${a.cycle.insightsGenerated} insights, ${a.cycle.associationsFound} associations found`),{success:!0,data:{action:"dream",success:!0,dreamResult:o,insights:l}}}async getPendingInsights(e,t){let n=e.limit||20;return{success:!0,data:{action:"insights",success:!0,insights:(await(await this.getEngine()).getPendingInsights(n)).map(a=>({id:a.id,type:a.type,description:a.description,noveltyScore:a.noveltyScore,confidenceScore:a.confidenceScore,actionable:a.actionable,applied:a.applied||!1,suggestedAction:a.suggestedAction,createdAt:a.createdAt?.toISOString()||new Date().toISOString()}))}}}async applyInsight(e,t){if(!e.insightId)return{success:!1,error:"insightId is required for apply action",data:{action:"apply",success:!1,error:"insightId is required for apply action"}};try{let n=await this.getEngine(),i=(await n.getPendingInsights(100)).find(m=>m.id===e.insightId);if(!i)return{success:!1,error:`Insight not found or already applied: ${e.insightId}`,data:{action:"apply",success:!1,error:`Insight not found or already applied: ${e.insightId}`}};if(!i.actionable)return{success:!1,error:"Insight is not actionable",data:{action:"apply",success:!1,error:"Insight is not actionable"}};let s=await F(),a=gt(s);await a.initialize();try{let{getSharedRvfDualWriter:m}=await import("./shared-rvf-dual-writer-MH2Y65HA.js"),g=await m();g&&a.setRvfDualWriter(g)}catch(m){process.env.DEBUG&&this.logger.info("RVF wiring skipped",{error:String(m)})}let o=this.mapInsightTypeToPatternType(i.type),l=await a.storePattern({patternType:o,name:`Dream Insight: ${i.type}`,description:`${i.description} (confidence: ${i.confidenceScore.toFixed(2)})`,template:{type:"workflow",content:i.suggestedAction||i.description,variables:[]},context:{tags:["dream-generated",i.type,...i.sourceConcepts.slice(0,3)],complexity:"medium"}});if(!l.success){let m=l.error?.message||"Unknown error";return{success:!1,error:`Failed to create pattern: ${m}`,data:{action:"apply",success:!1,error:`Failed to create pattern: ${m}`}}}let c=l.value.id;return await n.applyInsight(e.insightId),this.logger.info(`Applied insight ${e.insightId} \u2192 REAL pattern ${c} in ReasoningBank`),{success:!0,data:{action:"apply",success:!0,applyResult:{insightId:e.insightId,success:!0,patternId:c}}}}catch(n){let r=w(n);return{success:!1,error:r,data:{action:"apply",success:!1,error:r}}}}mapInsightTypeToPatternType(e){return{"cross-domain":"coverage-strategy","novel-path":"test-template",cluster:"refactor-safe","high-activation":"assertion-pattern",bridge:"mock-pattern"}[e]||"test-template"}async getDreamHistory(e,t){let n=e.limit||20;return{success:!0,data:{action:"history",success:!0,history:(await(await this.getEngine()).getDreamHistory(n)).map(a=>({id:a.id,startTime:a.startTime.toISOString(),endTime:a.endTime?.toISOString(),durationMs:a.durationMs,status:a.status,conceptsProcessed:a.conceptsProcessed,associationsFound:a.associationsFound,insightsGenerated:a.insightsGenerated}))}}}async getDreamStatus(e,t){let n=await this.getEngine(),r=n.isDreaming(),i=n.getCurrentCycle(),s=await n.getDreamHistory(100),a=await n.getPendingInsights(100),o=s.reduce((d,m)=>d+m.insightsGenerated,0),l=s[0];return{success:!0,data:{action:"status",success:!0,status:{isDreaming:r,currentCycle:i?{id:i.id,startTime:i.startTime.toISOString(),endTime:i.endTime?.toISOString(),durationMs:i.durationMs,status:i.status,conceptsProcessed:i.conceptsProcessed,associationsFound:i.associationsFound,insightsGenerated:i.insightsGenerated}:void 0,totalCycles:s.length,totalInsights:o,pendingInsights:a.length,lastDreamTime:l?.startTime.toISOString()}}}}resetInstanceCache(){this.engine&&(this.engine.close().catch(console.error),this.engine=null)}};k();var nn=class extends P{config={name:"qe/analysis/token_usage",description:"Analyze token consumption patterns and identify optimization opportunities across agents and domains.",domain:"learning-optimization",schema:Cc,streaming:!1,timeout:3e4};async execute(e,t){let{operation:n,timeframe:r,agentId:i,domain:s}=e;try{if(this.isAborted(t))return{success:!1,error:"Operation aborted"};let a;switch(n){case"session":a=this.getSessionUsage(r);break;case"agent":a=this.getAgentUsage(i,r);break;case"domain":a=this.getDomainUsage(s,r);break;case"task":a=this.getTaskUsage(r);break;case"efficiency":a=this.getEfficiencyReport(r);break;case"dashboard":return{success:!0,data:{operation:"dashboard",timeframe:r||"all",summary:{totalTokens:0,totalCost:"$0.00",tokensSaved:0,savingsPercentage:0},optimization:{patternsReused:0,cacheHits:0,earlyExits:0,recommendations:[Zr()]}}};default:return{success:!1,error:`Unknown operation: ${n}`}}return{success:!0,data:a}}catch(a){return{success:!1,error:`Token usage analysis failed: ${w(a)}`}}}getSessionUsage(e){let t=X.getSessionSummary(e),n={};for(let[i,s]of t.byAgent)n[i]={tokens:s.totalTokens,cost:B(s.totalCost),tasks:s.tasksExecuted};let r={};for(let[i,s]of t.byDomain)r[i]={tokens:s.totalTokens,cost:B(s.estimatedCostUsd||0)};return{operation:"session",timeframe:e||"all",summary:{totalTokens:t.totalUsage.totalTokens,totalCost:B(t.totalUsage.estimatedCostUsd||0),tokensSaved:t.optimizationStats.tokensSaved,savingsPercentage:t.optimizationStats.savingsPercentage},breakdown:{byAgent:Object.keys(n).length>0?n:void 0,byDomain:Object.keys(r).length>0?r:void 0},optimization:{patternsReused:t.optimizationStats.patternsReused,cacheHits:t.optimizationStats.cacheHits,earlyExits:t.optimizationStats.earlyExits,recommendations:this.generateSessionRecommendations(t)}}}getAgentUsage(e,t){let n=X.getAgentMetrics(e,t),r=X.getSessionSummary(t);if(e&&!Array.isArray(n)){let d=n,m=d.tasksExecuted>0?d.patternsReused/d.tasksExecuted:0;return{operation:"agent",timeframe:t||"all",summary:{totalTokens:d.totalTokens,totalCost:B(d.totalCost),tokensSaved:d.estimatedTokensSaved,savingsPercentage:this.calculateSavingsPercentage(d.totalTokens,d.estimatedTokensSaved)},optimization:{patternsReused:d.patternsReused,cacheHits:r.optimizationStats.cacheHits,earlyExits:r.optimizationStats.earlyExits,recommendations:this.generateAgentRecommendations(d)},details:{agentMetrics:{agentId:d.agentId,totalInputTokens:d.totalInputTokens,totalOutputTokens:d.totalOutputTokens,totalTokens:d.totalTokens,totalCost:B(d.totalCost),tasksExecuted:d.tasksExecuted,patternsReused:d.patternsReused,tokensSaved:d.estimatedTokensSaved,efficiency:Math.round(m*100)}}}}let i=Array.isArray(n)?n:[n],s={},a=0,o=0,l=0,c=0;for(let d of i)s[d.agentId]={tokens:d.totalTokens,cost:B(d.totalCost),tasks:d.tasksExecuted},a+=d.totalTokens,o+=d.totalCost,l+=d.estimatedTokensSaved,c+=d.patternsReused;return{operation:"agent",timeframe:t||"all",summary:{totalTokens:a,totalCost:B(o),tokensSaved:l,savingsPercentage:this.calculateSavingsPercentage(a,l)},breakdown:{byAgent:Object.keys(s).length>0?s:void 0},optimization:{patternsReused:c,cacheHits:r.optimizationStats.cacheHits,earlyExits:r.optimizationStats.earlyExits,recommendations:this.generateMultiAgentRecommendations(i)}}}getDomainUsage(e,t){let n=X.getDomainMetrics(e,t),r=X.getSessionSummary(t);if(e&&!(n instanceof Map)){let l=n;return{operation:"domain",timeframe:t||"all",summary:{totalTokens:l.totalTokens,totalCost:B(l.estimatedCostUsd||0),tokensSaved:r.optimizationStats.tokensSaved,savingsPercentage:r.optimizationStats.savingsPercentage},optimization:{patternsReused:r.optimizationStats.patternsReused,cacheHits:r.optimizationStats.cacheHits,earlyExits:r.optimizationStats.earlyExits,recommendations:this.generateDomainRecommendations(e,l)},details:{domainMetrics:{domain:e,inputTokens:l.inputTokens,outputTokens:l.outputTokens,totalTokens:l.totalTokens,cost:B(l.estimatedCostUsd||0)}}}}let i=n instanceof Map?n:new Map,s={},a=0,o=0;for(let[l,c]of i)s[l]={tokens:c.totalTokens,cost:B(c.estimatedCostUsd||0)},a+=c.totalTokens,o+=c.estimatedCostUsd||0;return{operation:"domain",timeframe:t||"all",summary:{totalTokens:a,totalCost:B(o),tokensSaved:r.optimizationStats.tokensSaved,savingsPercentage:r.optimizationStats.savingsPercentage},breakdown:{byDomain:Object.keys(s).length>0?s:void 0},optimization:{patternsReused:r.optimizationStats.patternsReused,cacheHits:r.optimizationStats.cacheHits,earlyExits:r.optimizationStats.earlyExits,recommendations:this.generateMultiDomainRecommendations(i)}}}getTaskUsage(e){let t=X.getTaskMetrics(e),n=X.getSessionSummary(e),r=t.slice(-100).map(i=>({taskId:i.taskId,agentId:i.agentId,domain:i.domain,operation:i.operation,tokens:i.usage.totalTokens,cost:B(i.usage.estimatedCostUsd||0),patternReused:i.patternReused,tokensSaved:i.tokensSaved||0,timestamp:new Date(i.timestamp).toISOString()}));return{operation:"task",timeframe:e||"all",summary:{totalTokens:n.totalUsage.totalTokens,totalCost:B(n.totalUsage.estimatedCostUsd||0),tokensSaved:n.optimizationStats.tokensSaved,savingsPercentage:n.optimizationStats.savingsPercentage},optimization:{patternsReused:n.optimizationStats.patternsReused,cacheHits:n.optimizationStats.cacheHits,earlyExits:n.optimizationStats.earlyExits,recommendations:[`${t.length} tasks analyzed in timeframe`]},details:{taskMetrics:r}}}getEfficiencyReport(e){let t=X.getEfficiencyReport(e),n=X.getSessionSummary(e);return{operation:"efficiency",timeframe:e||"all",summary:{totalTokens:t.totalTokensUsed,totalCost:B(t.totalTokensUsed*3e-6+t.totalTokensUsed*15e-6),tokensSaved:t.totalTokensSaved,savingsPercentage:t.savingsPercentage},optimization:{patternsReused:n.optimizationStats.patternsReused,cacheHits:n.optimizationStats.cacheHits,earlyExits:n.optimizationStats.earlyExits,recommendations:t.recommendations}}}generateSessionRecommendations(e){let t=[];if(e.totalUsage.totalTokens===0)return["No token usage recorded yet. Start executing tasks to track consumption."];let{patternsReused:n,cacheHits:r,earlyExits:i,savingsPercentage:s}=e.optimizationStats;return s<10&&t.push("Token savings below 10%. Enable pattern reuse and caching for better efficiency."),n===0&&e.byAgent.size>0&&t.push("No patterns reused. Consider enabling the pattern store for similar tasks."),r===0&&e.totalUsage.totalTokens>1e4&&t.push("No cache hits detected. Enable response caching to reduce API calls."),i===0&&e.byAgent.size>1&&t.push("Early exit optimization not used. Enable high-confidence pattern matching."),s>25&&t.push(`Excellent token efficiency! ${s.toFixed(1)}% savings achieved.`),t.length>0?t:["Token usage is within normal parameters."]}generateAgentRecommendations(e){let t=[];if(e.tasksExecuted===0)return["No tasks executed by this agent yet."];e.patternsReused/e.tasksExecuted<.1&&t.push("Low pattern reuse rate. Consider caching successful patterns.");let r=e.totalTokens/e.tasksExecuted;return r>5e3&&t.push(`High average tokens per task (${Math.round(r)}). Consider optimizing prompts.`),e.totalOutputTokens>e.totalInputTokens*2&&t.push("High output-to-input ratio. Request more concise responses."),t.length>0?t:["Agent token usage is efficient."]}generateMultiAgentRecommendations(e){let t=[];if(e.length===0)return["No agent data available."];let n=[...e].sort((s,a)=>a.totalTokens-s.totalTokens);n[0].totalTokens>0&&t.push(`Highest consumer: ${n[0].agentId} (${n[0].totalTokens.toLocaleString()} tokens)`);let r=e.reduce((s,a)=>s+a.totalTokens,0);return n[0].totalTokens/(r||1)>.5&&e.length>1&&t.push("Token usage imbalanced. Consider distributing workload across agents."),t}generateDomainRecommendations(e,t){let n=[];return t.totalTokens===0?[`No token usage recorded for ${e}.`]:(e==="test-generation"&&t.totalTokens>1e4&&n.push("Test generation consuming significant tokens. Consider batching test requests."),e==="code-intelligence"&&t.outputTokens>t.inputTokens*3&&n.push("Code intelligence generating verbose output. Consider summary-only mode."),n.length>0?n:[`${e} token usage is normal.`])}generateMultiDomainRecommendations(e){let t=[];if(e.size===0)return["No domain data available."];let n=Array.from(e.entries()).sort((r,i)=>i[1].totalTokens-r[1].totalTokens);return n[0][1].totalTokens>0&&t.push(`Highest consuming domain: ${n[0][0]} (${n[0][1].totalTokens.toLocaleString()} tokens)`),t}calculateSavingsPercentage(e,t){let n=e+t;return n===0?0:Math.round(t/n*1e4)/100}},Cc={type:"object",properties:{operation:{type:"string",description:"Type of analysis to perform",enum:["session","agent","domain","task","efficiency","dashboard"]},timeframe:{type:"string",description:"Time period to analyze",enum:["1h","24h","7d","30d"]},agentId:{type:"string",description:"Specific agent ID to analyze (for agent operation)"},domain:{type:"string",description:"Specific domain to analyze (for domain operation)",enum:["test-generation","test-execution","coverage-analysis","quality-assessment","defect-intelligence","requirements-validation","code-intelligence","security-compliance","contract-testing","visual-accessibility","chaos-resilience","learning-optimization"]}},required:["operation"]};k();var Ke={coverage:{line:0,branch:0,function:0,target:80,measured:!1},quality:{testsPassing:0,totalTests:0,securityScore:100,performanceScore:100},fleet:{activeAgents:0,availableAgents:[],maxAgents:8},resources:{timeRemaining:3600,memoryAvailable:4096,parallelSlots:4},context:{environment:"development",riskLevel:"medium"},patterns:{available:0,reusable:0}};var Tc=[{name:"measure-coverage",description:"Run coverage analysis on the codebase to determine current coverage metrics",agentType:"qe-coverage-specialist",preconditions:{"coverage.measured":!1},effects:{"coverage.measured":!0},cost:2,estimatedDurationMs:3e4,successRate:.95,category:"coverage",qeDomain:"coverage-analysis"},{name:"analyze-coverage-gaps",description:"Identify uncovered code paths and prioritize them by risk and complexity",agentType:"qe-gap-detector",preconditions:{"coverage.measured":!0},effects:{"coverage.gapsIdentified":!0},cost:1.5,estimatedDurationMs:15e3,successRate:.9,category:"coverage",qeDomain:"coverage-analysis"},{name:"generate-coverage-tests",description:"Generate tests targeting identified coverage gaps using AI-powered analysis",agentType:"qe-test-generator",preconditions:{"coverage.gapsIdentified":!0},effects:{"coverage.line":{delta:10}},cost:4,estimatedDurationMs:6e4,successRate:.8,category:"coverage",qeDomain:"test-generation"},{name:"run-mutation-testing",description:"Run mutation testing to validate test effectiveness and find weak spots",agentType:"qe-mutation-tester",preconditions:{"coverage.line":{min:60}},effects:{"quality.mutationScore":{set:!0}},cost:5,estimatedDurationMs:12e4,successRate:.85,category:"coverage",qeDomain:"coverage-analysis"},{name:"prioritize-uncovered-paths",description:"Use sublinear O(log n) analysis to identify highest-risk uncovered paths",agentType:"qe-coverage-specialist",preconditions:{"coverage.gapsIdentified":!0},effects:{"coverage.riskPrioritized":!0},cost:1,estimatedDurationMs:1e4,successRate:.92,category:"coverage",qeDomain:"coverage-analysis"},{name:"generate-branch-tests",description:"Generate tests specifically targeting branch coverage improvements",agentType:"qe-test-generator",preconditions:{"coverage.measured":!0,"coverage.branch":{max:70}},effects:{"coverage.branch":{delta:8}},cost:3.5,estimatedDurationMs:45e3,successRate:.78,category:"coverage",qeDomain:"test-generation"}],Sc=[{name:"run-unit-tests",description:"Execute unit test suite with parallel execution",agentType:"qe-test-executor",preconditions:{},effects:{"quality.unitTestsRun":!0},cost:1,estimatedDurationMs:2e4,successRate:.95,category:"test",qeDomain:"test-execution"},{name:"run-integration-tests",description:"Execute integration test suite with real database connections",agentType:"qe-test-executor",preconditions:{"quality.unitTestsRun":!0},effects:{"quality.integrationTestsRun":!0},cost:2.5,estimatedDurationMs:45e3,successRate:.85,category:"test",qeDomain:"test-execution"},{name:"run-e2e-tests",description:"Execute end-to-end tests using Playwright or Cypress",agentType:"qe-e2e-tester",preconditions:{"quality.integrationTestsRun":!0},effects:{"quality.e2eTestsRun":!0},cost:4,estimatedDurationMs:9e4,successRate:.8,category:"test",qeDomain:"test-execution"},{name:"fix-failing-tests",description:"Analyze and fix failing tests based on error messages and stack traces",agentType:"qe-tdd-specialist",preconditions:{"quality.testsPassing":{max:90}},effects:{"quality.testsPassing":{delta:10}},cost:3,estimatedDurationMs:3e4,successRate:.75,category:"test",qeDomain:"test-generation"},{name:"fix-flaky-tests",description:"Identify and stabilize flaky tests by analyzing timing and async issues",agentType:"qe-flaky-hunter",preconditions:{"quality.flakyTests":{min:1}},effects:{"quality.flakyTests":{delta:-3}},cost:4,estimatedDurationMs:45e3,successRate:.7,category:"test",qeDomain:"test-execution"},{name:"generate-property-tests",description:"Generate property-based tests using fast-check or similar library",agentType:"qe-test-generator",preconditions:{"quality.unitTestsRun":!0},effects:{"quality.propertyTestsGenerated":!0},cost:3.5,estimatedDurationMs:4e4,successRate:.82,category:"test",qeDomain:"test-generation"},{name:"run-contract-tests",description:"Execute consumer-driven contract tests using Pact or similar",agentType:"qe-contract-tester",preconditions:{"context.hasApiContracts":!0},effects:{"quality.contractTestsRun":!0},cost:2,estimatedDurationMs:25e3,successRate:.88,category:"test",qeDomain:"contract-testing"}],Ec=[{name:"security-scan",description:"Run comprehensive security scan using SAST and dependency analysis",agentType:"qe-security-scanner",preconditions:{},effects:{"quality.securityScanned":!0},cost:2,estimatedDurationMs:3e4,successRate:.95,category:"security",qeDomain:"security-compliance"},{name:"fix-vulnerabilities",description:"Remediate identified security vulnerabilities and update dependencies",agentType:"qe-security-auditor",preconditions:{"quality.securityScanned":!0,"quality.vulnerabilities":{min:1}},effects:{"quality.vulnerabilities":{delta:-5},"quality.securityScore":{delta:10}},cost:5,estimatedDurationMs:6e4,successRate:.7,category:"security",qeDomain:"security-compliance"},{name:"owasp-audit",description:"Perform OWASP Top 10 security audit on the application",agentType:"qe-security-auditor",preconditions:{"quality.securityScanned":!0},effects:{"quality.owaspCompliant":!0},cost:3,estimatedDurationMs:45e3,successRate:.85,category:"security",qeDomain:"security-compliance"},{name:"scan-secrets",description:"Scan codebase for hardcoded secrets and credentials",agentType:"qe-security-scanner",preconditions:{},effects:{"quality.secretsScanned":!0},cost:1,estimatedDurationMs:15e3,successRate:.98,category:"security",qeDomain:"security-compliance"},{name:"run-dast",description:"Run dynamic application security testing against running application",agentType:"qe-security-auditor",preconditions:{"context.environment":"staging"},effects:{"quality.dastCompleted":!0},cost:4.5,estimatedDurationMs:12e4,successRate:.8,category:"security",qeDomain:"security-compliance"}],wc=[{name:"run-benchmarks",description:"Execute performance benchmarks to establish baseline metrics",agentType:"qe-performance-tester",preconditions:{},effects:{"quality.benchmarked":!0},cost:2,estimatedDurationMs:45e3,successRate:.9,category:"performance",qeDomain:"chaos-resilience"},{name:"load-test",description:"Run load testing with simulated concurrent traffic",agentType:"qe-load-tester",preconditions:{"context.environment":"staging"},effects:{"quality.loadTested":!0},cost:3.5,estimatedDurationMs:12e4,successRate:.85,category:"performance",qeDomain:"chaos-resilience"},{name:"stress-test",description:"Run stress testing to find breaking points and system limits",agentType:"qe-chaos-engineer",preconditions:{"context.environment":"staging","quality.loadTested":!0},effects:{"quality.stressTested":!0},cost:4,estimatedDurationMs:9e4,successRate:.8,category:"performance",qeDomain:"chaos-resilience"},{name:"profile-memory",description:"Profile memory usage and identify memory leaks",agentType:"qe-performance-tester",preconditions:{"quality.benchmarked":!0},effects:{"quality.memoryProfiled":!0},cost:2.5,estimatedDurationMs:6e4,successRate:.88,category:"performance",qeDomain:"chaos-resilience"},{name:"optimize-slow-tests",description:"Identify and optimize slow-running tests to improve CI/CD speed",agentType:"qe-performance-tester",preconditions:{"quality.unitTestsRun":!0},effects:{"quality.testsOptimized":!0},cost:2,estimatedDurationMs:3e4,successRate:.82,category:"performance",qeDomain:"test-execution"}],Rc=[{name:"analyze-complexity",description:"Measure cyclomatic and cognitive complexity of codebase",agentType:"code-analyzer",preconditions:{},effects:{"quality.complexityAnalyzed":!0},cost:1,estimatedDurationMs:15e3,successRate:.95,category:"analysis",qeDomain:"code-intelligence"},{name:"detect-code-smells",description:"Identify code smells and anti-patterns using static analysis",agentType:"code-analyzer",preconditions:{},effects:{"quality.smellsDetected":!0},cost:1.5,estimatedDurationMs:2e4,successRate:.9,category:"analysis",qeDomain:"code-intelligence"},{name:"analyze-dependencies",description:"Analyze dependency graph and identify circular or outdated dependencies",agentType:"code-analyzer",preconditions:{},effects:{"quality.dependenciesAnalyzed":!0},cost:1,estimatedDurationMs:15e3,successRate:.92,category:"analysis",qeDomain:"code-intelligence"},{name:"measure-technical-debt",description:"Calculate technical debt metrics and generate remediation plan",agentType:"code-analyzer",preconditions:{"quality.complexityAnalyzed":!0,"quality.smellsDetected":!0},effects:{"quality.technicalDebtMeasured":!0},cost:2,estimatedDurationMs:25e3,successRate:.88,category:"analysis",qeDomain:"code-intelligence"},{name:"build-knowledge-graph",description:"Build semantic knowledge graph of codebase for intelligent context retrieval",agentType:"qe-intelligence-builder",preconditions:{"quality.dependenciesAnalyzed":!0},effects:{"quality.knowledgeGraphBuilt":!0},cost:3,estimatedDurationMs:6e4,successRate:.85,category:"analysis",qeDomain:"code-intelligence"}],Pc=[{name:"spawn-test-agent",description:"Spawn additional test execution agent for parallel work",agentType:"queen-coordinator",preconditions:{"fleet.activeAgents":{max:10}},effects:{"fleet.activeAgents":{delta:1}},cost:.5,estimatedDurationMs:5e3,successRate:.95,category:"fleet",qeDomain:"test-execution"},{name:"optimize-fleet-topology",description:"Reconfigure fleet topology for optimal task distribution",agentType:"queen-coordinator",preconditions:{"fleet.activeAgents":{min:3}},effects:{"fleet.efficiency":{delta:15}},cost:1,estimatedDurationMs:1e4,successRate:.85,category:"fleet"},{name:"scale-down-fleet",description:"Reduce fleet size to conserve resources during low-activity periods",agentType:"queen-coordinator",preconditions:{"fleet.activeAgents":{min:5}},effects:{"fleet.activeAgents":{delta:-2}},cost:.3,estimatedDurationMs:3e3,successRate:.98,category:"fleet"},{name:"spawn-specialist-agent",description:"Spawn a specialized agent for specific domain work",agentType:"queen-coordinator",preconditions:{"fleet.activeAgents":{max:12},"context.specialistNeeded":!0},effects:{"fleet.activeAgents":{delta:1},"fleet.specialistAvailable":!0},cost:1,estimatedDurationMs:8e3,successRate:.9,category:"fleet"},{name:"rebalance-workload",description:"Redistribute tasks across agents based on current load",agentType:"queen-coordinator",preconditions:{"fleet.activeAgents":{min:2}},effects:{"fleet.workloadBalanced":!0},cost:.5,estimatedDurationMs:5e3,successRate:.92,category:"fleet"}],xc=[{name:"generate-quality-report",description:"Generate comprehensive quality report combining all metrics",agentType:"qe-quality-gate",preconditions:{"coverage.measured":!0,"quality.unitTestsRun":!0},effects:{"quality.reported":!0},cost:1,estimatedDurationMs:1e4,successRate:.95,category:"quality",qeDomain:"quality-assessment"},{name:"enforce-quality-gate",description:"Check if all quality gates pass and report status",agentType:"qe-quality-gate",preconditions:{"quality.reported":!0},effects:{"quality.gatePassed":!0},cost:.5,estimatedDurationMs:5e3,successRate:.9,category:"quality",qeDomain:"quality-assessment"},{name:"validate-requirements",description:"Validate that tests cover all documented requirements",agentType:"qe-requirements-validator",preconditions:{"context.hasRequirements":!0},effects:{"quality.requirementsValidated":!0},cost:2,estimatedDurationMs:2e4,successRate:.88,category:"quality",qeDomain:"requirements-validation"},{name:"predict-defects",description:"Use ML-based defect prediction to identify high-risk code areas",agentType:"qe-defect-predictor",preconditions:{"quality.complexityAnalyzed":!0,"coverage.measured":!0},effects:{"quality.defectsPredicted":!0},cost:2.5,estimatedDurationMs:3e4,successRate:.82,category:"quality",qeDomain:"defect-intelligence"},{name:"generate-deployment-report",description:"Generate deployment readiness report with all quality metrics",agentType:"qe-quality-gate",preconditions:{"quality.gatePassed":!0,"quality.securityScanned":!0},effects:{"quality.deploymentReady":!0},cost:1.5,estimatedDurationMs:15e3,successRate:.9,category:"quality",qeDomain:"quality-assessment"}],Ac=[{name:"run-accessibility-audit",description:"Run WCAG 2.2 accessibility audit using axe-core or similar",agentType:"qe-accessibility-tester",preconditions:{"context.hasUI":!0},effects:{"quality.accessibilityAudited":!0},cost:2,estimatedDurationMs:3e4,successRate:.9,category:"quality",qeDomain:"visual-accessibility"},{name:"run-visual-regression",description:"Run visual regression testing with screenshot comparison",agentType:"qe-visual-tester",preconditions:{"context.hasUI":!0},effects:{"quality.visualRegressionRun":!0},cost:3,estimatedDurationMs:6e4,successRate:.85,category:"quality",qeDomain:"visual-accessibility"}],hs=[...Tc,...Sc,...Ec,...wc,...Rc,...Pc,...xc,...Ac];function kc(u){return`action-${u}`}function fs(u){return{...u,id:kc(u.name),executionCount:0}}function Xe(){return hs.map(fs)}var rn=[{name:"achieve-90-percent-coverage",description:"Reach 90% line coverage through targeted test generation",conditions:{"coverage.line":{min:90}},priority:1,qeDomain:"coverage-analysis"},{name:"all-tests-passing",description:"All tests green with 100% pass rate",conditions:{"quality.testsPassing":{min:100}},priority:1,qeDomain:"test-execution"},{name:"security-compliant",description:"Pass security audit with no critical vulnerabilities",conditions:{"quality.securityScanned":!0,"quality.vulnerabilities":{max:0}},priority:2,qeDomain:"security-compliance"},{name:"deployment-ready",description:"Ready for production deployment with all quality gates passed",conditions:{"coverage.line":{min:80},"quality.testsPassing":{min:100},"quality.securityScanned":!0,"quality.gatePassed":!0},priority:1},{name:"performance-validated",description:"Performance benchmarks and load tests completed successfully",conditions:{"quality.benchmarked":!0,"quality.loadTested":!0},priority:2,qeDomain:"chaos-resilience"},{name:"code-quality-excellent",description:"Excellent code quality with low complexity and no code smells",conditions:{"quality.complexityAnalyzed":!0,"quality.smellsDetected":!0,"quality.technicalDebtMeasured":!0},priority:3,qeDomain:"code-intelligence"},{name:"full-test-suite",description:"Complete test suite with unit, integration, and e2e tests",conditions:{"quality.unitTestsRun":!0,"quality.integrationTestsRun":!0,"quality.e2eTestsRun":!0},priority:2,qeDomain:"test-execution"},{name:"accessibility-compliant",description:"WCAG 2.2 compliant with visual regression coverage",conditions:{"quality.accessibilityAudited":!0,"quality.visualRegressionRun":!0},priority:2,qeDomain:"visual-accessibility"}];j();import{randomUUID as ge}from"crypto";var mr=class{data=[];cmp;constructor(e){this.cmp=e}get length(){return this.data.length}push(e){this.data.push(e),this.bubbleUp(this.data.length-1)}pop(){if(this.data.length===0)return;let e=this.data[0],t=this.data.pop();return this.data.length>0&&(this.data[0]=t,this.sinkDown(0)),e}bubbleUp(e){for(;e>0;){let t=e-1>>1;if(this.cmp(this.data[e],this.data[t])<0)[this.data[e],this.data[t]]=[this.data[t],this.data[e]],e=t;else break}}sinkDown(e){let t=this.data.length;for(;;){let n=e,r=2*e+1,i=2*e+2;if(r<t&&this.cmp(this.data[r],this.data[n])<0&&(n=r),i<t&&this.cmp(this.data[i],this.data[n])<0&&(n=i),n!==e)[this.data[e],this.data[n]]=[this.data[n],this.data[e]],e=n;else break}}},Mc=new Set(["__proto__","constructor","prototype"]),sn=class{db=null;persistence=null;actions=new Map;initialized=!1;enablePlanReuse=!0;constructor(){}ensureDb(){if(!this.db)throw new Error("GOAPPlanner not initialized - call initialize() first");return this.db}async initialize(){if(this.initialized)return;this.persistence=Pr(),this.persistence.isInitialized()||await this.persistence.initialize(),this.db=this.persistence.getDatabase(),this.ensureDb().prepare("SELECT COUNT(*) as count FROM goap_actions").get().count===0&&this.seedDefaultActions(),await this.loadActions(),this.initialized=!0,console.log(`[GOAPPlanner] Initialized: ${this.persistence.getDbPath()}`)}seedDefaultActions(){let e=Xe(),t=this.ensureDb(),n=t.prepare(`
|
|
671
611
|
INSERT INTO goap_actions (id, name, description, category, preconditions, effects, cost, qe_domain, agent_type)
|
|
672
612
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
673
613
|
`);for(let i of e){let s=`action-${Date.now()}-${ge().slice(0,8)}`;n.run(s,i.name,i.description,i.category,JSON.stringify(i.preconditions),JSON.stringify(i.effects),i.cost,i.qeDomain??null,i.agentType??null)}let r=t.prepare(`
|
|
674
614
|
INSERT INTO goap_goals (id, name, description, conditions, priority, qe_domain)
|
|
675
615
|
VALUES (?, ?, ?, ?, ?, ?)
|
|
676
|
-
`);for(let i of
|
|
616
|
+
`);for(let i of rn){let s=`goal-${Date.now()}-${ge().slice(0,8)}`;r.run(s,i.name,i.description,JSON.stringify(i.conditions),i.priority,i.qeDomain??null)}console.log(`[GOAPPlanner] Seeded ${e.length} actions and ${rn.length} goals`)}async findPlan(e,t,n){await this.initialize();let r=Date.now();if(this.enablePlanReuse){let l=await this.findSimilarPlan(t,.75);if(l&&this.validatePlanForState(l,e))return this.recordPlanReuse(l.id,!0),{...l,id:`plan-${Date.now()}-${ge().slice(0,8)}`,initialState:this.cloneState(e),reusedFrom:l.id,status:"pending"}}let i=this.getAvailableActions(n),s=this.aStarSearch(e,t,i,n);if(!s)return null;let a={id:`plan-${Date.now()}-${ge().slice(0,8)}`,initialState:this.cloneState(e),goalState:t,actions:s,totalCost:s.reduce((l,c)=>l+c.cost,0),estimatedDurationMs:s.reduce((l,c)=>l+(c.estimatedDurationMs??0),0),status:"pending"};await this.storePlanSignature(a);let o=Date.now()-r;return o>500&&console.warn(`[GOAPPlanner] Plan finding took ${o}ms (target: <500ms)`),a}aStarSearch(e,t,n,r){if(!this.canAnyActionAffectGoal(n,t))return null;let i=new mr((p,h)=>p.f-h.f),s=new Set,a=new Map,o={state:this.cloneState(e),action:null,parent:null,g:0,h:this.calculateHeuristic(e,t),f:0,depth:0};o.f=o.g+o.h,i.push(o),a.set(this.hashState(e),0);let l=1e4,c=20,d=r?.maxCost??1/0,m=r?.maxDurationMs??1/0,g=0;for(;i.length>0&&g<l;){g++;let p=i.pop();if(this.meetsConditions(p.state,t))return this.reconstructPlan(p);let h=this.hashState(p.state);if(!s.has(h)&&(s.add(h),a.delete(h),!(p.depth>=c)))for(let f of n){if(!this.meetsConditions(p.state,f.preconditions))continue;let v=this.applyAction(p.state,f),y=this.hashState(v);if(s.has(y))continue;let C=p.g+this.getActionCost(f,p.state),b=this.calculateHeuristic(v,t),E=C+b;if(C>d||p.depth*1e3+(f.estimatedDurationMs??0)>m)continue;let T=a.get(y);T!==void 0&&C>=T||(a.set(y,C),i.push({state:v,action:f,parent:p,g:C,h:b,f:E,depth:p.depth+1}))}}return null}canAnyActionAffectGoal(e,t){let n=Object.keys(t);for(let r of e)for(let i of Object.keys(r.effects))for(let s of n)if(i===s||i.startsWith(s)||s.startsWith(i))return!0;return!1}reconstructPlan(e){let t=[],n=e;for(;n&&n.action;)t.unshift(n.action),n=n.parent;return t}applyAction(e,t){let n=this.cloneState(e);for(let[r,i]of Object.entries(t.effects))this.applyEffect(n,r,i);return n}applyEffect(e,t,n){if(typeof n=="string"||typeof n=="number"||typeof n=="boolean"){this.setStateValue(e,t,n);return}if(typeof n=="object"&&n!==null){let r=this.getStateValue(e,t);if("set"in n&&n.set!==void 0&&this.setStateValue(e,t,n.set),"delta"in n&&n.delta!==void 0&&typeof r=="number"){let i=Math.max(0,Math.min(100,r+n.delta));this.setStateValue(e,t,i)}}}meetsConditions(e,t){for(let[n,r]of Object.entries(t))if(!this.checkCondition(e,n,r))return!1;return!0}checkCondition(e,t,n){let r=this.getStateValue(e,t);return typeof n=="string"||typeof n=="number"||typeof n=="boolean"?r===n:!(typeof n=="object"&&n!==null&&("min"in n&&n.min!==void 0&&(typeof r!="number"||r<n.min)||"max"in n&&n.max!==void 0&&(typeof r!="number"||r>n.max)||"eq"in n&&n.eq!==void 0&&r!==n.eq))}calculateHeuristic(e,t){let n=0;for(let[r,i]of Object.entries(t)){let s=this.getStateValue(e,r);if(typeof i=="object"&&i!==null&&"min"in i){let a=i.min;typeof s=="number"&&s<a&&(n+=(a-s)/100)}if(typeof i=="object"&&i!==null&&"max"in i){let a=i.max;typeof s=="number"&&s>a&&(n+=(s-a)/100)}typeof i=="object"&&i!==null&&"eq"in i&&s!==i.eq&&(n+=1),(typeof i=="string"||typeof i=="number"||typeof i=="boolean")&&s!==i&&(n+=1)}return n}getStateValue(e,t){let n=t.split("."),r=e;for(let i of n){if(r==null)return;r=r[i]}return r}setStateValue(e,t,n){let r=t.split(".");for(let a of r)if(Mc.has(a)){console.warn(`[GOAPPlanner] Blocked prototype pollution attempt: ${t}`);return}let i=e;for(let a=0;a<r.length-1;a++){let o=r[a];Object.hasOwn(i,o)||Object.defineProperty(i,o,{value:Object.create(null),writable:!0,enumerable:!0,configurable:!0});let l=Object.getOwnPropertyDescriptor(i,o);if(!l)return;i=l.value}let s=r[r.length-1];Object.defineProperty(i,s,{value:n,writable:!0,enumerable:!0,configurable:!0})}hashState(e){let t={coverageLine:Math.round(e.coverage.line),coverageBranch:Math.round(e.coverage.branch),coverageFunc:Math.round(e.coverage.function),coverageMeasured:e.coverage.measured,testsPassing:Math.round(e.quality.testsPassing),securityScore:Math.round(e.quality.securityScore),performanceScore:Math.round(e.quality.performanceScore),activeAgents:e.fleet.activeAgents,availableAgents:[...e.fleet.availableAgents].sort().join(","),timeRemaining:Math.floor(e.resources.timeRemaining/60),parallelSlots:e.resources.parallelSlots,environment:e.context.environment,riskLevel:e.context.riskLevel};return JSON.stringify(t)}cloneState(e){return{coverage:{...e.coverage},quality:{...e.quality},fleet:{...e.fleet,availableAgents:[...e.fleet.availableAgents]},resources:{...e.resources},context:{...e.context},patterns:{...e.patterns}}}getActionCost(e,t){let n=e.cost;return e.successRate<1&&(n=n/e.successRate),t.context.riskLevel==="high"&&(e.category==="performance"||e.category==="fleet")&&(n*=1.5),n}async loadActions(){let e=this.ensureDb().prepare("SELECT * FROM goap_actions ORDER BY category, cost").all();this.actions.clear();for(let t of e){let n={id:t.id,name:t.name,description:t.description??void 0,agentType:t.agent_type,preconditions:x(t.preconditions),effects:x(t.effects),cost:t.cost,estimatedDurationMs:t.estimated_duration_ms??void 0,successRate:t.success_rate,executionCount:t.execution_count,category:t.category,qeDomain:t.qe_domain};this.actions.set(n.id,n)}}async addAction(e){await this.initialize();let t=`action-${Date.now()}-${ge().slice(0,8)}`;this.ensureDb().prepare(`
|
|
677
617
|
INSERT INTO goap_actions (
|
|
678
618
|
id, name, description, agent_type, preconditions, effects,
|
|
679
619
|
cost, estimated_duration_ms, success_rate, execution_count, category, qe_domain
|
|
@@ -687,7 +627,7 @@ Analyze the requirements above and return the complete QualityCriteriaAnalysis.`
|
|
|
687
627
|
id, goal_id, initial_state, goal_state, action_sequence,
|
|
688
628
|
total_cost, estimated_duration_ms, status, reused_from, similarity_score
|
|
689
629
|
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
690
|
-
`).run(e.id,e.goalId??null,JSON.stringify(e.initialState),JSON.stringify(e.goalState),JSON.stringify(e.actions.map(t=>t.id)),e.totalCost,e.estimatedDurationMs,e.status,e.reusedFrom??null,e.similarityScore??null)}async getPlan(e){await this.initialize();let t=this.ensureDb().prepare("SELECT * FROM goap_plans WHERE id = ?").get(e);if(!t)return null;let r=
|
|
630
|
+
`).run(e.id,e.goalId??null,JSON.stringify(e.initialState),JSON.stringify(e.goalState),JSON.stringify(e.actions.map(t=>t.id)),e.totalCost,e.estimatedDurationMs,e.status,e.reusedFrom??null,e.similarityScore??null)}async getPlan(e){await this.initialize();let t=this.ensureDb().prepare("SELECT * FROM goap_plans WHERE id = ?").get(e);if(!t)return null;let r=x(t.action_sequence).map(i=>this.actions.get(i)).filter(i=>i!==void 0);return{id:t.id,goalId:t.goal_id??void 0,initialState:x(t.initial_state),goalState:x(t.goal_state),actions:r,totalCost:t.total_cost,estimatedDurationMs:t.estimated_duration_ms??0,status:t.status,reusedFrom:t.reused_from??void 0,similarityScore:t.similarity_score??void 0}}async findSimilarPlan(e,t=.75){await this.initialize();let n=this.hashGoalConditions(e),r=this.ensureDb().prepare(`
|
|
691
631
|
SELECT * FROM goap_plan_signatures
|
|
692
632
|
WHERE goal_hash = ? AND success_rate >= 0.5
|
|
693
633
|
ORDER BY usage_count DESC, success_rate DESC
|
|
@@ -703,7 +643,7 @@ Analyze the requirements above and return the complete QualityCriteriaAnalysis.`
|
|
|
703
643
|
`).run(i,a,e)}validatePlanForState(e,t){let n=this.cloneState(t);for(let r of e.actions){if(!this.meetsConditions(n,r.preconditions))return!1;n=this.applyAction(n,r)}return!0}hashGoalConditions(e){let t=this.sortObjectKeys(e);return JSON.stringify(t)}sortObjectKeys(e){return e===null||typeof e!="object"?e:Array.isArray(e)?e.map(t=>this.sortObjectKeys(t)):Object.keys(e).sort().reduce((t,n)=>(t[n]=this.sortObjectKeys(e[n]),t),{})}extractStateVector(e){return[e.coverage.line/100,e.coverage.branch/100,e.coverage.function/100,e.coverage.measured?1:0,e.quality.testsPassing/100,e.quality.securityScore/100,e.quality.performanceScore/100,Math.min(e.fleet.activeAgents/10,1),Math.min(e.resources.timeRemaining/3600,1),Math.min(e.resources.parallelSlots/8,1)]}async addGoal(e){await this.initialize();let t=`goal-${Date.now()}-${ge().slice(0,8)}`;return this.ensureDb().prepare(`
|
|
704
644
|
INSERT INTO goap_goals (id, name, description, conditions, priority, qe_domain)
|
|
705
645
|
VALUES (?, ?, ?, ?, ?, ?)
|
|
706
|
-
`).run(t,e.name,e.description??null,JSON.stringify(e.conditions),e.priority,e.qeDomain??null),t}async getGoals(){return await this.initialize(),this.ensureDb().prepare("SELECT * FROM goap_goals ORDER BY priority DESC").all().map(t=>({id:t.id,name:t.name,description:t.description??void 0,conditions:
|
|
646
|
+
`).run(t,e.name,e.description??null,JSON.stringify(e.conditions),e.priority,e.qeDomain??null),t}async getGoals(){return await this.initialize(),this.ensureDb().prepare("SELECT * FROM goap_goals ORDER BY priority DESC").all().map(t=>({id:t.id,name:t.name,description:t.description??void 0,conditions:x(t.conditions),priority:t.priority,qeDomain:t.qe_domain}))}setPlanReuseEnabled(e){this.enablePlanReuse=e}isPlanReuseEnabled(){return this.enablePlanReuse}async getPlanReuseStats(){await this.initialize();let e=this.ensureDb(),t=e.prepare("SELECT COUNT(*) as count FROM goap_plan_signatures").get(),n=e.prepare("SELECT COUNT(*) as count FROM goap_plan_signatures WHERE usage_count > 0").get(),r=e.prepare("SELECT AVG(success_rate) as avg FROM goap_plan_signatures WHERE usage_count > 0").get();return{totalPlans:t.count,reusedPlans:n.count,reuseRate:t.count>0?n.count/t.count:0,avgSuccessRate:r.avg??0}}async close(){this.actions.clear(),this.db=null,this.persistence=null,this.initialized=!1}},dr=null;function he(){return dr||(dr=new sn),dr}Rs();Ge();te();k();j();import{randomUUID as pr}from"crypto";var Dc={maxRetries:2,stepTimeoutMs:6e4,replanOnFailure:!0,parallelExecution:!1,recordWorldState:!0,useUnified:!0},an=class{db;planner;spawner;config;currentExecution=null;initialized=!1;unifiedMemory=null;constructor(e,t,n,r){this.planner=e,this.spawner=t,this.config={...Dc,...r},this.config.useUnified||(this.db=Rr(n??":memory:",{walMode:!1}),this.db.pragma("journal_mode = WAL"))}async initialize(){if(!this.initialized){if(this.config.useUnified)try{this.unifiedMemory=z(),await this.unifiedMemory.initialize(),this.db=this.unifiedMemory.getDatabase(),console.log(`[PlanExecutor] Using unified storage: ${this.unifiedMemory.getDbPath()}`)}catch(e){console.warn("[PlanExecutor] Failed to initialize unified storage, falling back to in-memory:",e),this.db=new(await import("./better-sqlite3-K2VWFDKT.js")).default(":memory:"),this.db.pragma("journal_mode = WAL"),this.unifiedMemory=null,this.createTables()}else this.createTables();this.initialized=!0}}createTables(){this.db.exec(`
|
|
707
647
|
CREATE TABLE IF NOT EXISTS execution_results (
|
|
708
648
|
id TEXT PRIMARY KEY,
|
|
709
649
|
plan_id TEXT NOT NULL,
|
|
@@ -738,14 +678,14 @@ Analyze the requirements above and return the complete QualityCriteriaAnalysis.`
|
|
|
738
678
|
CREATE INDEX IF NOT EXISTS idx_exec_results_plan ON execution_results(plan_id);
|
|
739
679
|
CREATE INDEX IF NOT EXISTS idx_exec_steps_execution ON executed_steps(execution_id);
|
|
740
680
|
CREATE INDEX IF NOT EXISTS idx_exec_steps_action ON executed_steps(action_id);
|
|
741
|
-
`)}async execute(e,t){return await this.initialize(),this.executeWithCallbacks(e,()=>{},()=>{},t)}async executeWithCallbacks(e,t,n,r){await this.initialize();let i=Date.now(),s=`exec-${Date.now()}-${
|
|
681
|
+
`)}async execute(e,t){return await this.initialize(),this.executeWithCallbacks(e,()=>{},()=>{},t)}async executeWithCallbacks(e,t,n,r){await this.initialize();let i=Date.now(),s=`exec-${Date.now()}-${pr().slice(0,8)}`;this.currentExecution={planId:e.id,cancelled:!1};let a={planId:e.id,status:"completed",stepsCompleted:0,stepsFailed:0,totalDurationMs:0,steps:[]},o=r?this.cloneState(r):this.cloneState(e.initialState),l=e.actions.map((c,d)=>({id:`step-${Date.now()}-${pr().slice(0,8)}`,planId:e.id,action:c,stepOrder:d,status:"pending"}));try{for(let c of l){if(this.currentExecution?.cancelled){a.status="cancelled",a.error="Execution was cancelled";break}this.config.recordWorldState&&(c.worldStateBefore=this.cloneState(o)),t(c);let d=!1,m,g=0,p,h,f=Date.now();for(let y=0;y<=this.config.maxRetries;y++){let C=await this.executeStep(c,o);if(C.success){d=!0,o=C.newState,p=C.output,h=C.agentId;break}m=C.error,g=y,y<this.config.maxRetries&&await this.delay(Math.min(1e3*Math.pow(2,y),5e3))}let v={...c,status:d?"completed":"failed",retries:g,startedAt:new Date(f),completedAt:new Date,durationMs:Date.now()-f,agentId:h,agentOutput:p,worldStateAfter:this.config.recordWorldState?this.cloneState(o):void 0,error:m};if(a.steps.push(v),n(v),d)a.stepsCompleted++,await this.updateActionStats(c.action.id,!0,v.durationMs??0);else if(a.stepsFailed++,await this.updateActionStats(c.action.id,!1,0),this.config.replanOnFailure){let y=await this.replanFromFailure(e,c.stepOrder,o);if(y){let C=await this.executeWithCallbacks(y,t,n,o);a.steps.push(...C.steps),a.stepsCompleted+=C.stepsCompleted,a.stepsFailed+=C.stepsFailed,C.status==="completed"&&C.finalWorldState?o=C.finalWorldState:(a.status="partial",a.error=`Replanning partially succeeded: ${C.error||"unknown error"}`)}else{a.status="failed",a.error=`Step ${c.stepOrder} failed and replanning unsuccessful: ${m}`;break}}else{a.status="failed",a.error=`Step ${c.stepOrder} failed: ${m}`;break}}return a.finalWorldState=o,a.totalDurationMs=Date.now()-i,await this.persistExecutionResult(s,a),a}finally{this.currentExecution=null}}async executeStep(e,t){let n=e.action;if(!this.meetsConditions(t,n.preconditions))return{success:!1,newState:t,error:`Preconditions not met for action: ${n.name}`};let r=this.buildTaskDescription(n);try{let i=new Promise((o,l)=>setTimeout(()=>l(new Error(`Step timeout after ${this.config.stepTimeoutMs}ms`)),this.config.stepTimeoutMs)),s=this.spawner.spawn(n.agentType,r),a=await Promise.race([s,i]);return a.success?{success:!0,newState:this.applyEffects(t,n.effects),output:a.output,agentId:a.agentId}:{success:!1,newState:t,agentId:a.agentId,error:a.error||"Agent execution failed"}}catch(i){return{success:!1,newState:t,error:w(i)}}}buildTaskDescription(e){let t=`Execute action: ${e.name}`;e.description&&(t+=`
|
|
742
682
|
|
|
743
683
|
Description: ${e.description}`),t+=`
|
|
744
684
|
|
|
745
685
|
Expected effects:`;for(let[n,r]of Object.entries(e.effects))typeof r=="object"&&r!==null?"delta"in r?t+=`
|
|
746
686
|
- ${n}: change by ${r.delta}`:"set"in r&&(t+=`
|
|
747
687
|
- ${n}: set to ${r.set}`):t+=`
|
|
748
|
-
- ${n}: ${r}`;return t}async replanFromFailure(e,t,n){try{let i=[e.actions[t].id];return await this.planner.findPlan(n,e.goalState,{excludedActions:i})}catch(r){return console.error("[PlanExecutor] Replanning failed:",r),null}}async cancel(){this.currentExecution&&(this.currentExecution.cancelled=!0)}isExecuting(){return this.currentExecution!==null}async getExecutionHistory(e,t=100){await this.initialize();let n="SELECT * FROM execution_results",r=[];e&&(n+=" WHERE plan_id = ?",r.push(e)),n+=" ORDER BY created_at DESC LIMIT ?",r.push(t);let i=this.db.prepare(n).all(...r);return Promise.all(i.map(async s=>{let a=await this.getExecutedSteps(s.id);return{planId:s.plan_id,status:s.status,stepsCompleted:s.steps_completed,stepsFailed:s.steps_failed,totalDurationMs:s.total_duration_ms,finalWorldState:s.final_world_state?
|
|
688
|
+
- ${n}: ${r}`;return t}async replanFromFailure(e,t,n){try{let i=[e.actions[t].id];return await this.planner.findPlan(n,e.goalState,{excludedActions:i})}catch(r){return console.error("[PlanExecutor] Replanning failed:",r),null}}async cancel(){this.currentExecution&&(this.currentExecution.cancelled=!0)}isExecuting(){return this.currentExecution!==null}async getExecutionHistory(e,t=100){await this.initialize();let n="SELECT * FROM execution_results",r=[];e&&(n+=" WHERE plan_id = ?",r.push(e)),n+=" ORDER BY created_at DESC LIMIT ?",r.push(t);let i=this.db.prepare(n).all(...r);return Promise.all(i.map(async s=>{let a=await this.getExecutedSteps(s.id);return{planId:s.plan_id,status:s.status,stepsCompleted:s.steps_completed,stepsFailed:s.steps_failed,totalDurationMs:s.total_duration_ms,finalWorldState:s.final_world_state?x(s.final_world_state):void 0,error:s.error_message??void 0,steps:a}}))}async getExecutedSteps(e){return this.db.prepare("SELECT * FROM executed_steps WHERE execution_id = ? ORDER BY step_order").all(e).map(n=>({id:n.id,planId:n.plan_id,action:{id:n.action_id,name:"",agentType:"",preconditions:{},effects:{},cost:1,successRate:1,executionCount:0,category:"analysis"},stepOrder:n.step_order,status:n.status,durationMs:n.duration_ms??void 0,agentId:n.agent_id??void 0,error:n.error_message??void 0,retries:n.retries,startedAt:new Date(n.started_at),completedAt:n.completed_at?new Date(n.completed_at):void 0,agentOutput:n.agent_output??void 0,worldStateBefore:n.world_state_before?x(n.world_state_before):void 0,worldStateAfter:n.world_state_after?x(n.world_state_after):void 0}))}async persistExecutionResult(e,t){this.db.prepare(`
|
|
749
689
|
INSERT INTO execution_results (
|
|
750
690
|
id, plan_id, status, steps_completed, steps_failed,
|
|
751
691
|
total_duration_ms, final_world_state, error_message
|
|
@@ -756,4 +696,4 @@ Expected effects:`;for(let[n,r]of Object.entries(e.effects))typeof r=="object"&&
|
|
|
756
696
|
retries, started_at, completed_at, duration_ms, agent_id,
|
|
757
697
|
agent_output, world_state_before, world_state_after, error_message
|
|
758
698
|
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
759
|
-
`);for(let r of t.steps)n.run(r.id,e,r.planId,r.action.id,r.stepOrder,r.status,r.retries,r.startedAt.toISOString(),r.completedAt?.toISOString()??null,r.durationMs??null,r.agentId??null,r.agentOutput??null,r.worldStateBefore?JSON.stringify(r.worldStateBefore):null,r.worldStateAfter?JSON.stringify(r.worldStateAfter):null,r.error??null)}async updateActionStats(e,t,n){try{"updateActionStats"in this.planner&&await this.planner.updateActionStats(e,t,n)}catch(r){console.warn("[PlanExecutor] Failed to update action stats:",r)}}meetsConditions(e,t){for(let[n,r]of Object.entries(t))if(!this.checkCondition(e,n,r))return!1;return!0}checkCondition(e,t,n){let r=this.getStateValue(e,t);return typeof n=="string"||typeof n=="number"||typeof n=="boolean"?r===n:!(typeof n=="object"&&n!==null&&("min"in n&&n.min!==void 0&&(typeof r!="number"||r<n.min)||"max"in n&&n.max!==void 0&&(typeof r!="number"||r>n.max)||"eq"in n&&n.eq!==void 0&&r!==n.eq))}applyEffects(e,t){let n=this.cloneState(e);for(let[r,i]of Object.entries(t))this.applyEffect(n,r,i);return n}applyEffect(e,t,n){if(typeof n=="string"||typeof n=="number"||typeof n=="boolean"){this.setStateValue(e,t,n);return}if(typeof n=="object"&&n!==null){let r=this.getStateValue(e,t);if("set"in n&&n.set!==void 0&&this.setStateValue(e,t,n.set),"delta"in n&&n.delta!==void 0&&typeof r=="number"){let i=Math.max(0,Math.min(100,r+n.delta));this.setStateValue(e,t,i)}}}getStateValue(e,t){let n=t.split("."),r=e;for(let i of n){if(r==null)return;r=r[i]}return r}setStateValue(e,t,n){let r=t.split("."),i=new Set(["__proto__","constructor","prototype"]);for(let o of r)if(i.has(o)){console.warn(`[PlanExecutor] Blocked prototype pollution attempt: ${t}`);return}let s=e;for(let o=0;o<r.length-1;o++){let l=r[o];Object.hasOwn(s,l)||Object.defineProperty(s,l,{value:Object.create(null),writable:!0,enumerable:!0,configurable:!0});let c=Object.getOwnPropertyDescriptor(s,l);if(!c)return;s=c.value}let a=r[r.length-1];Object.defineProperty(s,a,{value:n,writable:!0,enumerable:!0,configurable:!0})}cloneState(e){return{coverage:{...e.coverage},quality:{...e.quality},fleet:{...e.fleet,availableAgents:[...e.fleet.availableAgents]},resources:{...e.resources},context:{...e.context},patterns:{...e.patterns}}}delay(e){return new Promise(t=>setTimeout(t,e))}async close(){this.currentExecution&&await this.cancel(),this.db&&(this.unifiedMemory?console.log("[PlanExecutor] Detached from unified storage (not closing shared connection)"):(this.db.close(),console.log("[PlanExecutor] Database closed"))),this.unifiedMemory=null,this.initialized=!1}},dn=class{successRate;executionDelay;constructor(e){this.successRate=e?.successRate??1,this.executionDelay=e?.executionDelay??100}async spawn(e,t){await new Promise(i=>setTimeout(i,this.executionDelay));let n=J()<this.successRate,r=`mock-agent-${yr().slice(0,8)}`;return n?{agentId:r,output:`Successfully executed task for ${e}: ${t.slice(0,50)}...`,success:!0}:{agentId:r,output:"",success:!1,error:`Simulated failure for ${e}`}}};function Je(u,e){let t=new dn({successRate:e?.successRate??1});return new un(u,t,e?.dbPath,e?.config)}var Ze=class extends x{planner=null;config={name:"qe/planning/goap_plan",description:'Find optimal action plan to achieve a QE goal using A* search. Supports named goals (e.g., "achieve-90-percent-coverage") or custom goal conditions.',domain:"coordination",schema:this.buildSchema()};buildSchema(){return{type:"object",properties:{goal:{type:"string",description:'Goal name (e.g., "achieve-90-percent-coverage") or custom goal conditions as JSON object'},currentState:{type:"object",description:"Current world state (auto-detected if not provided). Contains coverage, quality, fleet, resources, context, and patterns."},constraints:{type:"object",description:"Plan constraints",properties:{maxCost:{type:"number",description:"Maximum total cost allowed"},maxDurationMs:{type:"number",description:"Maximum total duration in milliseconds"},requiredAgentTypes:{type:"array",description:"Only use actions that these agent types can execute",items:{type:"string",description:"Agent type"}},excludedActions:{type:"array",description:"Exclude these specific action IDs",items:{type:"string",description:"Action ID"}}}}},required:["goal"]}}async getPlanner(){return this.planner||(this.planner=he(),await this.planner.initialize()),this.planner}resetInstanceCache(){this.planner=null}async execute(e,t){try{let n=await this.getPlanner(),r,i;if(typeof e.goal=="string"){let l=await n.getGoals(),c=l.find(d=>d.name===e.goal);if(!c){let d=l.map(m=>m.name).join(", ");return{success:!1,error:`Unknown goal: ${e.goal}. Available goals: ${d||"none (seed actions first)"}`}}r=c.conditions,i=c.name}else r=e.goal,i="custom";let s=e.currentState||await this.detectCurrentState(),a=e.constraints?{maxCost:e.constraints.maxCost,maxDurationMs:e.constraints.maxDurationMs,requiredAgentTypes:e.constraints.requiredAgentTypes,excludedActions:e.constraints.excludedActions}:void 0,o=await n.findPlan(s,r,a);return o?(this.markAsRealData(),{success:!0,data:{planId:o.id,goal:e.goal,actions:o.actions.map(l=>({name:l.name,agentType:l.agentType,cost:l.cost,category:l.category,description:l.description})),totalCost:o.totalCost,estimatedDurationMs:o.estimatedDurationMs,stepCount:o.actions.length,reusedFrom:o.reusedFrom,similarityScore:o.similarityScore}}):{success:!1,error:"No valid plan found for the given goal and constraints. Try relaxing constraints or seeding more actions."}}catch(n){return{success:!1,error:w(n)}}}async detectCurrentState(){return{...Xe}}};k();var et=class extends x{planner=null;executor=null;config={name:"qe/planning/goap_execute",description:"Execute a GOAP plan, spawning agents to perform each action step. Supports dry-run mode to simulate execution without actual agent spawning.",domain:"coordination",schema:this.buildSchema(),timeout:3e5};buildSchema(){return{type:"object",properties:{planId:{type:"string",description:"ID of plan to execute (from goap_plan result)"},dryRun:{type:"boolean",description:"Simulate execution without spawning agents (default: false)",default:!1},stepByStep:{type:"boolean",description:"Execute one step at a time (default: false)",default:!1},maxRetries:{type:"number",description:"Max retries per failed step (default: 2)",default:2,minimum:0,maximum:5}},required:["planId"]}}async getPlanner(){return this.planner||(this.planner=he(),await this.planner.initialize()),this.planner}async getExecutor(){if(!this.executor){let e=await this.getPlanner();this.executor=Je(e,{successRate:.95,config:{maxRetries:2,stepTimeoutMs:6e4,replanOnFailure:!0,parallelExecution:!1,recordWorldState:!0}}),await this.executor.initialize()}return this.executor}resetInstanceCache(){this.planner=null,this.executor=null}async execute(e,t){try{let r=await(await this.getPlanner()).getPlan(e.planId);if(!r)return{success:!1,error:`Plan not found: ${e.planId}. Create a plan first using goap_plan.`};if(e.dryRun)return this.markAsRealData(),{success:!0,data:{planId:r.id,mode:"dry-run",status:"completed",stepsCompleted:r.actions.length,stepsFailed:0,totalDurationMs:r.estimatedDurationMs,steps:r.actions.map((a,o)=>({action:a.name,status:"would-execute",retries:0,durationMs:a.estimatedDurationMs}))}};let i=await this.getExecutor();if(i.isExecuting())return{success:!1,error:"Another plan is currently executing. Wait for completion or cancel it."};let s=await i.execute(r,r.initialState);return this.markAsRealData(),{success:s.status==="completed",data:{planId:s.planId,mode:"execution",status:s.status,stepsCompleted:s.stepsCompleted,stepsFailed:s.stepsFailed,totalDurationMs:s.totalDurationMs,steps:s.steps.map(a=>({action:a.action.name,status:a.status,retries:a.retries,durationMs:a.durationMs,error:a.error})),error:s.error},error:s.status!=="completed"?s.error:void 0}}catch(n){return{success:!1,error:w(n)}}}};k();var tt=class extends x{planner=null;executor=null;config={name:"qe/planning/goap_status",description:"Get GOAP system status: world state, available goals, actions, or plans. Use to understand current state and available planning options.",domain:"coordination",schema:this.buildSchema()};buildSchema(){return{type:"object",properties:{type:{type:"string",description:"What to get status of",enum:["world","goals","actions","plans","execution"]},filter:{type:"object",description:"Optional filters",properties:{category:{type:"string",description:"Filter actions by category (test, security, coverage, etc.)"},status:{type:"string",description:"Filter plans by status (pending, executing, completed, failed)"},limit:{type:"number",description:"Maximum number of results (default: 20)",default:20,minimum:1,maximum:100}}}},required:["type"]}}async getPlanner(){return this.planner||(this.planner=he(),await this.planner.initialize()),this.planner}async getExecutor(){if(!this.executor){let e=await this.getPlanner();this.executor=Je(e),await this.executor.initialize()}return this.executor}resetInstanceCache(){this.planner=null,this.executor=null}async execute(e,t){try{switch(e.type){case"world":return this.getWorldState();case"goals":return this.getGoals();case"actions":return this.getActions(e.filter?.category,e.filter?.limit);case"plans":return this.getPlans(e.filter?.status,e.filter?.limit);case"execution":return this.getExecutionStatus();default:return{success:!1,error:`Unknown status type: ${e.type}`}}}catch(n){return{success:!1,error:w(n)}}}async getWorldState(){let e={...Xe};return this.markAsRealData(),{success:!0,data:{type:"world",data:{coverage:{line:e.coverage.line,branch:e.coverage.branch,function:e.coverage.function,measured:e.coverage.measured},quality:{testsPassing:e.quality.testsPassing,securityScore:e.quality.securityScore,performanceScore:e.quality.performanceScore},fleet:{activeAgents:e.fleet.activeAgents,maxAgents:e.fleet.maxAgents},resources:{timeRemaining:e.resources.timeRemaining,parallelSlots:e.resources.parallelSlots}}}}}async getGoals(){let t=await(await this.getPlanner()).getGoals();return this.markAsRealData(),{success:!0,data:{type:"goals",data:{goals:t.map(n=>({id:n.id,name:n.name,description:n.description,priority:n.priority,conditionCount:Object.keys(n.conditions).length})),count:t.length}}}}async getActions(e,t=50){let n=await this.getPlanner(),r=[],i=Ye(),s=e?i.filter(o=>o.category===e):i;r=s.slice(0,t).map((o,l)=>({id:`action-${l}`,name:o.name,category:o.category,agentType:o.agentType,cost:o.cost,successRate:o.successRate}));let a={};for(let o of i)a[o.category]=(a[o.category]||0)+1;return this.markAsRealData(),{success:!0,data:{type:"actions",data:{actions:r,count:s.length,byCategory:a}}}}async getPlans(e,t=20){let r=await(await this.getPlanner()).getPlanReuseStats();return this.markAsRealData(),{success:!0,data:{type:"plans",data:{plans:[],count:0,reuseStats:{totalPlans:r.totalPlans,reusedPlans:r.reusedPlans,reuseRate:r.reuseRate,avgSuccessRate:r.avgSuccessRate}}}}}async getExecutionStatus(){let t=(await this.getExecutor()).isExecuting();return this.markAsRealData(),{success:!0,data:{type:"execution",data:{isExecuting:t,message:t?"Plan execution in progress":"No active execution"}}}}};k();ze();ee();k();k();ze();var nt={HEALTH:"qe/mincut/health",ANALYZE:"qe/mincut/analyze",STRENGTHEN:"qe/mincut/strengthen"};function Tr(){return Sn()}function Vc(){return En()}var vr=class extends x{config={name:nt.HEALTH,description:"Analyze swarm topology health using MinCut algorithms. Reports connectivity, weak points, and health trends.",domain:"coordination",schema:{type:"object",properties:{agents:{type:"array",description:"Agent vertices to add to the graph before analysis"},edges:{type:"array",description:"Edges to add between agents"},includeWeakVertices:{type:"boolean",description:"Include detailed weak vertex analysis",default:!0},includeHistory:{type:"boolean",description:"Include historical health data",default:!1}},additionalProperties:!0}};async execute(e,t){let n=Tr(),r=Vc(),i=ie();if(e.agents)for(let l of e.agents)n.hasVertex(l.id)||n.addVertex({id:l.id,type:"agent",domain:l.domain,weight:l.weight??1,createdAt:new Date});if(e.edges)for(let l of e.edges)n.hasVertex(l.source)&&n.hasVertex(l.target)&&(n.hasEdge(l.source,l.target)||n.addEdge({source:l.source,target:l.target,weight:l.weight??1,type:"coordination",bidirectional:!0}));let s=r.checkHealth(),a=e.includeWeakVertices!==!1?i.findWeakVertices(n):[],o={health:{status:s.status,minCutValue:s.minCutValue,healthyThreshold:s.healthyThreshold,warningThreshold:s.warningThreshold,weakVertexCount:s.weakVertexCount,trend:s.trend},topology:{vertexCount:n.vertexCount,edgeCount:n.edgeCount,isConnected:n.isConnected()}};return e.includeWeakVertices!==!1&&a.length>0&&(o.weakVertices=a.map(l=>({id:l.vertexId,domain:l.vertex?.domain,weightedDegree:l.weightedDegree,riskScore:l.riskScore,reason:l.reason}))),e.includeHistory&&(o.history=s.history.map(l=>({timestamp:l.timestamp,value:l.value}))),this.markAsRealData(),{success:!0,data:o,metadata:this.createMetadata(t.startTime,t.requestId)}}},br=class extends x{config={name:nt.ANALYZE,description:"Deep analysis of swarm topology using MinCut algorithms. Identifies weak points, suggests improvements.",domain:"coordination",schema:{type:"object",properties:{weaknessThreshold:{type:"number",description:"Threshold for weak vertex detection"},includePartitioningPoints:{type:"boolean",description:"Include analysis of potential partitioning points",default:!1}},additionalProperties:!0}};async execute(e,t){let n=Tr(),r=ie(),i=r.getMinCutValue(n),s=r.getMinDegreeVertex(n),a=r.findWeakVertices(n,e.weaknessThreshold),o=r.suggestEdgeAdditions(n,2),l={minCutValue:i,minDegreeVertex:s,weakVertices:a.map(c=>({id:c.vertexId,weightedDegree:c.weightedDegree,riskScore:c.riskScore,reason:c.reason,suggestions:c.suggestions.map(d=>({type:d.type,priority:d.priority,estimatedImprovement:d.estimatedImprovement}))})),suggestedEdges:o.map(c=>({source:c.source,target:c.target,weight:c.weight}))};return e.includePartitioningPoints&&(l.partitioningPoints=r.findPartitioningPoints(n)),this.markAsRealData(),{success:!0,data:l,metadata:this.createMetadata(t.startTime,t.requestId)}}},Cr=class extends x{config={name:nt.STRENGTHEN,description:"Strengthen swarm topology by adding edges between weak and strong vertices.",domain:"coordination",schema:{type:"object",properties:{targetImprovement:{type:"number",description:"Target improvement in MinCut value",default:1},targetVertices:{type:"array",description:"Specific vertices to strengthen"},apply:{type:"boolean",description:"Apply changes (true) or simulate (false)",default:!1}},additionalProperties:!0}};async execute(e,t){let n=Tr(),r=ie(),i=r.getMinCutValue(n),s=e.targetImprovement??1,a=r.suggestEdgeAdditions(n,s),o=[];if(e.apply)for(let c of a)n.addEdge({source:c.source,target:c.target,weight:c.weight,type:"coordination",bidirectional:!0}),o.push({type:"add_edge",source:c.source,target:c.target,weight:c.weight});else for(let c of a)o.push({type:"add_edge",source:c.source,target:c.target,weight:c.weight});let l=r.getMinCutValue(n);return this.markAsRealData(),{success:!0,data:{beforeMinCut:i,afterMinCut:e.apply?l:i+s,improvement:e.apply?l-i:s,actionsApplied:o,applied:e.apply??!1},metadata:this.createMetadata(t.startTime,t.requestId)}}},Ts=[new vr,new br,new Cr];k();var Sr=null,mn=null;async function rt(){return Sr||mn||(mn=(async()=>{let u=kt({embedding:{model:"all-MiniLM-L6-v2",cacheSize:1e3,normalize:!0,hyperbolic:!1,curvature:-1},autoInitialize:!1});return await u.initialize(),Sr=u,console.error("[EmbeddingTool] ONNX adapter initialized"),u})(),mn)}var _e=class extends x{config={name:"qe/embeddings/generate",description:"Generate a vector embedding for text using local ONNX model",domain:"learning-optimization",schema:{type:"object",properties:{text:{type:"string",description:"Text to generate embedding for",minLength:1,maxLength:1e4},hyperbolic:{type:"boolean",description:"Use hyperbolic space for hierarchical data",default:!1}},required:["text"]}};async execute(e,t){let n=performance.now();try{let r=await rt(),i=await r.generateEmbedding(e.text);e.hyperbolic&&(i=r.toHyperbolic(i));let s=performance.now()-n;return this.markAsRealData(),{success:!0,data:{embedding:Array.from(i.vector),dimension:i.dimensions,isHyperbolic:i.isHyperbolic,latencyMs:s,model:i.model}}}catch(r){return{success:!1,error:`Embedding generation failed: ${w(r)}`}}}},Oe=class extends x{config={name:"qe/embeddings/compare",description:"Compare semantic similarity between two texts",domain:"learning-optimization",schema:{type:"object",properties:{text1:{type:"string",description:"First text to compare",minLength:1},text2:{type:"string",description:"Second text to compare",minLength:1},metric:{type:"string",description:"Similarity metric",enum:["cosine","euclidean","poincare"],default:"cosine"}},required:["text1","text2"]}};async execute(e,t){let n=performance.now();try{let r=await rt(),i=e.metric||"cosine",s=i==="cosine"?"cosine":i==="euclidean"?"euclidean":"poincare",a=await r.compareSimilarity(e.text1,e.text2,s),o=performance.now()-n;return this.markAsRealData(),{success:!0,data:{similarity:a,metric:i,isSimilar:a>.7,latencyMs:o}}}catch(r){return{success:!1,error:`Similarity comparison failed: ${w(r)}`}}}},Fe=class extends x{config={name:"qe/embeddings/search",description:"Search for semantically similar texts using vector search",domain:"learning-optimization",schema:{type:"object",properties:{query:{type:"string",description:"Query text to search for",minLength:1},namespace:{type:"string",description:"Namespace to search in",default:"default"},topK:{type:"number",description:"Number of results to return",minimum:1,maximum:100,default:10},threshold:{type:"number",description:"Minimum similarity threshold (0-1)",minimum:0,maximum:1,default:.5}},required:["query"]}};async execute(e,t){let n=performance.now();try{let i=await(await rt()).searchByText(e.query,{metric:"cosine",topK:e.topK??10,threshold:e.threshold??.5,namespace:e.namespace}),s=performance.now()-n;return this.markAsRealData(),{success:!0,data:{results:i.map(a=>({text:a.text,score:a.score,metadata:a.metadata})),totalFound:i.length,latencyMs:s}}}catch(r){return{success:!1,error:`Search failed: ${w(r)}`}}}},Ne=class extends x{config={name:"qe/embeddings/store",description:"Store text with its embedding for later retrieval",domain:"learning-optimization",schema:{type:"object",properties:{text:{type:"string",description:"Text to store",minLength:1},id:{type:"string",description:"Optional ID for the stored embedding"},namespace:{type:"string",description:"Namespace for organization",default:"default"},metadata:{type:"object",description:"Additional metadata to store"}},required:["text"]}};async execute(e,t){let n=performance.now();try{let r=await rt(),i=e.namespace||"default",s=await r.generateAndStore(e.text,{id:e.id,namespace:i,customData:e.metadata}),a=performance.now()-n;return this.markAsRealData(),{success:!0,data:{id:s.id,namespace:s.namespace||i,latencyMs:a}}}catch(r){return{success:!1,error:`Store failed: ${w(r)}`}}}},Le=class extends x{config={name:"qe/embeddings/stats",description:"Get ONNX embedding system statistics",domain:"learning-optimization",schema:{type:"object",properties:{}}};async execute(e,t){try{let n=await rt(),r=n.getStats(),i=await n.getHealth(),s=r.cacheHits+r.cacheMisses,a=s>0?r.cacheHits/s:0;return this.markAsRealData(),{success:!0,data:{totalGenerated:r.totalGenerated,vectorsStored:r.vectorsStored,cache:{hits:r.cacheHits,misses:r.cacheMisses,hitRate:a},model:{name:r.currentModel,dimension:r.currentModel==="all-MiniLM-L6-v2"?384:768},healthy:i.available}}}catch(n){return{success:!1,error:`Stats failed: ${w(n)}`}}}},Qc=new _e,Wc=new Oe,Kc=new Fe,Xc=new Ne,Yc=new Le;k();var Jc={type:"object",properties:{nodes:{type:"array",description:"Array of nodes to check for coherence. Each node must have an id and embedding vector."},energyThreshold:{type:"number",description:"Custom energy threshold for contradiction detection (default: 0.4)",minimum:0,maximum:1}},required:["nodes"]},it=class extends x{config={name:"qe/coherence/check",description:"Check mathematical coherence of beliefs/facts using Prime Radiant sheaf cohomology. Detects contradictions and computes coherence energy for multi-agent coordination.",domain:"learning-optimization",schema:Jc,streaming:!1,timeout:3e4};coherenceService=null;async getService(){return this.coherenceService||(this.coherenceService=await se(ae)),this.coherenceService}resetInstanceCache(){this.coherenceService&&(this.coherenceService.dispose(),this.coherenceService=null)}async execute(e,t){let n=Date.now(),{nodes:r,energyThreshold:i=.4}=e;if(!r||r.length===0)return{success:!1,error:"At least one node is required for coherence check"};for(let s of r)if(!s.embedding||!Array.isArray(s.embedding))return{success:!1,error:`Node ${s.id} has invalid embedding - must be an array of numbers`};try{let s=await this.getService(),a=r.map(m=>({id:m.id,embedding:m.embedding,weight:m.weight??1,metadata:m.metadata})),o=await s.checkCoherence(a),l=[...o.recommendations,...this.generateAdditionalRecommendations(o,i)],c=o.contradictions.map(m=>({nodeIds:m.nodeIds,severity:String(m.severity),description:m.description||`Contradiction between nodes ${m.nodeIds[0]} and ${m.nodeIds[1]}`})),d=Date.now()-n;return this.markAsRealData(),{success:!0,data:{isCoherent:o.isCoherent,energy:o.energy,lane:o.lane,contradictions:c,recommendations:l,nodeCount:r.length,executionTimeMs:d,usedFallback:o.usedFallback}}}catch(s){return s instanceof Error&&s.message.includes("WASM")?(this.markAsDemoData(t,"WASM module unavailable"),{success:!0,data:{isCoherent:!0,energy:.1,lane:"reflex",contradictions:[],recommendations:["WASM module unavailable - coherence check running in fallback mode","Install prime-radiant-advanced-wasm for full coherence verification"],nodeCount:r.length,executionTimeMs:Date.now()-n,usedFallback:!0}}):{success:!1,error:w(s)}}}generateAdditionalRecommendations(e,t){let n=[];switch(e.energy>t&&n.push(`High coherence energy (${e.energy.toFixed(3)}) detected - review contradicting beliefs`),e.lane){case"reflex":n.push("Low energy - safe for immediate execution");break;case"retrieval":n.push("Moderate energy - consider fetching additional context");break;case"heavy":n.push("High energy - deep analysis recommended");break;case"human":n.push("Critical energy - escalate to Queen coordinator");break}return n}};Pr();k();var D0=pt.create("qe-unified-memory");var Zc={"test-suites":{dimensions:oe.DIMENSIONS,M:8,efConstruction:100,efSearch:50,metric:"cosine",namespace:"test-suites-hnsw",maxElements:1e5},coverage:{dimensions:oe.DIMENSIONS,M:16,efConstruction:200,efSearch:100,metric:"cosine",namespace:"coverage-hnsw",maxElements:1e5},defects:{dimensions:oe.DIMENSIONS,M:32,efConstruction:400,efSearch:200,metric:"cosine",namespace:"defects-hnsw",maxElements:1e5},quality:{dimensions:oe.DIMENSIONS,M:16,efConstruction:200,efSearch:100,metric:"cosine",namespace:"quality-hnsw",maxElements:1e5},learning:{dimensions:oe.DIMENSIONS,M:24,efConstruction:300,efSearch:150,metric:"cosine",namespace:"learning-hnsw",maxElements:1e5},coordination:{dimensions:oe.DIMENSIONS,M:8,efConstruction:100,efSearch:50,metric:"cosine",namespace:"coordination-hnsw",maxElements:5e4}},el={enableHNSW:{"test-suites":!0,coverage:!0,defects:!0,quality:!0,learning:!0,coordination:!0},defaultNamespace:"qe-unified",enableCrossDomainSearch:!0,embeddingDimension:oe.DIMENSIONS};Pr();k();import{randomUUID as tl}from"crypto";var Er=pt.create("MemoryAuditor"),wr={batchSize:50,energyThreshold:.4,hotspotThreshold:.6,maxRecommendations:10},pn=class{constructor(e,t,n=wr){this.coherenceService=e;this.eventBus=t;this.config=n}coherenceService;eventBus;config;isAuditing=!1;async auditPatterns(e){let t=Date.now();await this.emitEvent("memory:audit_started",{totalPatterns:e.length,timestamp:new Date});try{let n=this.groupByDomain(e),r=[],i=0,s=0;for(let[p,g]of Object.entries(n)){if(g.length<2)continue;let h=this.patternsToNodes(g),f=await this.coherenceService.checkCoherence(h);s+=f.energy,i+=f.contradictions.length,f.energy>this.config.hotspotThreshold&&r.push({domain:p,patternIds:g.map(v=>v.id),energy:f.energy,description:this.describeHotspot(f,p)})}let a=Object.keys(n).length,o=a>0?s/a:0,l=await this.identifyHotspots(e),c=await this.generateRecommendations(l,e),d=Date.now()-t,m={totalPatterns:e.length,scannedPatterns:e.length,contradictionCount:i,globalEnergy:o,hotspots:l,recommendations:c,duration:d,timestamp:new Date};return await this.emitEvent("memory:audit_completed",{result:m,timestamp:new Date}),m}catch(n){try{await this.emitEvent("memory:audit_failed",{error:w(n),timestamp:new Date})}catch(r){Er.warn("Failed to emit audit_failed event",{error:w(r)})}throw n}}async identifyHotspots(e){let t=[],n=this.groupByDomain(e);for(let[r,i]of Object.entries(n)){if(i.length<2)continue;let s=this.patternsToNodes(i),a=await this.coherenceService.checkCoherence(s);a.energy>this.config.hotspotThreshold&&t.push({domain:r,patternIds:i.map(o=>o.id),energy:a.energy,description:this.describeHotspot(a,r)})}return t}async generateRecommendations(e,t){let n=[],r=new Map(t.map(i=>[i.id,i]));for(let i of e){let s=i.patternIds.map(c=>r.get(c)).filter(c=>c!==void 0),a=this.findDuplicates(s);a.length>0&&n.push({type:"merge",patternIds:a,reason:`Detected ${a.length} similar patterns in ${i.domain} domain`,priority:"high"});let o=this.findOutdated(s);o.length>0&&n.push({type:"remove",patternIds:o,reason:`Found ${o.length} outdated patterns with low usage/success`,priority:"medium"}),i.energy>.7&&n.push({type:"review",patternIds:i.patternIds,reason:`Critical coherence energy (${i.energy.toFixed(2)}) in ${i.domain}`,priority:"high"});let l=this.findBroadPatterns(s);l.length>0&&n.push({type:"split",patternIds:l,reason:`Found ${l.length} overly generic patterns that should be specialized`,priority:"low"})}return n.sort((i,s)=>this.priorityValue(s.priority)-this.priorityValue(i.priority)).slice(0,this.config.maxRecommendations)}async runBackgroundAudit(e){if(this.isAuditing){Er.warn("Audit already in progress, skipping");return}this.isAuditing=!0;try{await this.emitEvent("memory:audit_progress",{status:"fetching_patterns",timestamp:new Date});let t=await e();await this.emitEvent("memory:audit_progress",{status:"analyzing_coherence",totalPatterns:t.length,timestamp:new Date});let n=await this.auditPatterns(t);await this.emitEvent("memory:audit_progress",{status:"completed",result:n,timestamp:new Date})}catch(t){await this.emitEvent("memory:audit_progress",{status:"failed",error:w(t),timestamp:new Date})}finally{this.isAuditing=!1}}groupByDomain(e){let t={};for(let n of e){let r=n.qeDomain;t[r]||(t[r]=[]),t[r].push(n)}return t}patternsToNodes(e){return e.map(t=>({id:t.id,embedding:t.embedding||this.createFallbackEmbedding(t),weight:t.qualityScore,metadata:{name:t.name,description:t.description,domain:t.qeDomain,confidence:t.confidence,usageCount:t.usageCount,successRate:t.successRate}}))}createFallbackEmbedding(e){let t=`${e.name} ${e.description}`,n=[];for(let r=0;r<64;r++){let i=t.charCodeAt(r%t.length);n.push(i/255*2-1)}return n}describeHotspot(e,t){let n=e.energy.toFixed(2),r=e.contradictions.length;return r>0?`${t} has ${r} contradiction(s) with energy ${n}`:`${t} has high coherence energy (${n}) indicating potential inconsistencies`}findDuplicates(e){let t=[],n=new Map;for(let r of e){let i=this.normalizeText(`${r.name} ${r.description}`);n.has(i)||n.set(i,[]),n.get(i).push(r.id)}for(let[r,i]of n)i.length>1&&t.push(...i.slice(1));return t}findOutdated(e){return e.filter(t=>t.usageCount<5&&t.successRate<.5).map(t=>t.id)}findBroadPatterns(e){return e.filter(t=>{let n=/generic|general|common|basic/i.test(t.name),r=t.context?.tags,i=!r||r.length<2;return n||i}).map(t=>t.id)}normalizeText(e){return e.toLowerCase().replace(/[^a-z0-9\s]/g,"").replace(/\s+/g," ").trim()}priorityValue(e){switch(e){case"high":return 3;case"medium":return 2;case"low":return 1;default:return 0}}async emitEvent(e,t){if(this.eventBus)try{await this.eventBus.publish({id:`memory-audit-${Date.now()}-${tl().split("-")[0]}`,type:e,source:"learning-optimization",timestamp:new Date,payload:t})}catch(n){Er.warn("Failed to emit event",{eventType:e,error:w(n)})}}};function Rr(u,e,t){return new pn(u,e,{...wr,...t})}k();var nl={type:"object",properties:{namespace:{type:"string",description:"Namespace to audit (default: qe-patterns)",default:"qe-patterns"},maxPatterns:{type:"number",description:"Maximum patterns to scan (default: 1000)",default:1e3,minimum:1,maximum:1e4},energyThreshold:{type:"number",description:"Energy threshold for flagging issues (default: 0.4)",default:.4,minimum:0,maximum:1},includeDetails:{type:"boolean",description:"Include detailed pattern information in results",default:!1}},required:[]},st=class extends x{config={name:"qe/coherence/audit",description:"Audit QE memory for contradictions and coherence issues. Scans patterns, detects hotspots, and generates remediation recommendations.",domain:"learning-optimization",schema:nl,streaming:!1,timeout:6e4};coherenceService=null;auditor=null;async getService(){return this.coherenceService||(this.coherenceService=await se(ae)),this.coherenceService}resetInstanceCache(){this.coherenceService&&(this.coherenceService.dispose(),this.coherenceService=null),this.auditor=null}async execute(e,t){let{namespace:n="qe-patterns",maxPatterns:r=1e3,energyThreshold:i=.4}=e;try{let s=await this.getService();this.auditor||(this.auditor=Rr(s,void 0,{energyThreshold:i,hotspotThreshold:i+.2,maxRecommendations:10}));let a=await F(),o=Tn(a,{namespace:n,embeddingDimension:384});await o.initialize();let l=await o.search("",{limit:r,useVectorSearch:!1}),c=l.success?l.value.map(p=>p.pattern):[],d;c.length>0?d=await this.auditor.auditPatterns(c):d={totalPatterns:0,scannedPatterns:0,contradictionCount:0,globalEnergy:0,hotspots:[],recommendations:[],duration:0,timestamp:new Date};let m=this.calculateHealthScore(d);return this.markAsRealData(),{success:!0,data:{totalPatterns:d.totalPatterns,scannedPatterns:d.scannedPatterns,contradictionCount:d.contradictionCount,globalEnergy:d.globalEnergy,hotspots:d.hotspots.map(p=>({domain:p.domain,patternIds:p.patternIds,energy:p.energy,description:p.description})),recommendations:d.recommendations.map(p=>({type:p.type,patternIds:p.patternIds,reason:p.reason,priority:p.priority})),durationMs:d.duration,timestamp:d.timestamp.toISOString(),healthScore:m}}}catch(s){return s instanceof Error&&s.message.includes("WASM")?(this.markAsDemoData(t,"WASM module unavailable"),{success:!0,data:{totalPatterns:0,scannedPatterns:0,contradictionCount:0,globalEnergy:0,hotspots:[],recommendations:[{type:"review",patternIds:[],reason:"WASM module unavailable - install prime-radiant-advanced-wasm for full audit",priority:"medium"}],durationMs:0,timestamp:new Date().toISOString(),healthScore:100}}):{success:!1,error:w(s)}}}calculateHealthScore(e){let t=100;t-=Math.min(30,e.contradictionCount*5),t-=Math.min(30,e.globalEnergy*50),t-=Math.min(20,e.hotspots.length*5);let n=e.recommendations.filter(r=>r.priority==="high").length;return t-=Math.min(20,n*5),Math.max(0,Math.round(t))}};k();var rl={type:"object",properties:{votes:{type:"array",description:"Array of agent votes to verify for consensus"},confidenceThreshold:{type:"number",description:"Minimum confidence threshold (0-1, default: 0.5)",default:.5,minimum:0,maximum:1}},required:["votes"]},at=class extends x{config={name:"qe/coherence/consensus",description:"Verify multi-agent consensus mathematically using spectral analysis. Detects false consensus where agents appear to agree but have divergent beliefs.",domain:"learning-optimization",schema:rl,streaming:!1,timeout:3e4};coherenceService=null;async getService(){return this.coherenceService||(this.coherenceService=await se(ae)),this.coherenceService}resetInstanceCache(){this.coherenceService&&(this.coherenceService.dispose(),this.coherenceService=null)}async execute(e,t){let n=Date.now(),{votes:r,confidenceThreshold:i=.5}=e;if(!r||r.length===0)return{success:!1,error:"At least one vote is required for consensus verification"};if(r.length<2)return{success:!1,error:"At least two votes are required to verify consensus"};try{let s=await this.getService(),a=r.map(m=>({agentId:m.agentId,agentType:m.agentType||"worker",verdict:m.verdict,confidence:m.confidence,reasoning:m.reasoning,timestamp:new Date})),o=await s.verifyConsensus(a),l=o.recommendation,c=r.reduce((m,p)=>m+p.confidence,0)/r.length;c<i&&(l=`Low average confidence (${(c*100).toFixed(1)}%) - consider gathering more evidence. `+l);let d=Date.now()-n;return this.markAsRealData(),{success:!0,data:{isValid:o.isValid,isFalseConsensus:o.isFalseConsensus,confidence:o.confidence,fiedlerValue:o.fiedlerValue,collapseRisk:o.collapseRisk,recommendation:l,usedFallback:o.usedFallback,executionTimeMs:d}}}catch(s){if(s instanceof Error&&s.message.includes("WASM")){let a=this.simpleMajorityAnalysis(r);return this.markAsDemoData(t,"WASM module unavailable"),{success:!0,data:{...a,recommendation:"Running in fallback mode (simple analysis). Install prime-radiant-advanced-wasm for spectral consensus analysis.",usedFallback:!0,executionTimeMs:Date.now()-n}}}return{success:!1,error:w(s)}}}simpleMajorityAnalysis(e){let t=new Map;for(let s of e){let a=String(s.verdict);t.set(a,(t.get(a)||0)+1)}let n=0;for(let s of t.values())s>n&&(n=s);let r=n/e.length,i=e.reduce((s,a)=>s+a.confidence,0)/e.length;return{isValid:r>=.5&&i>=.5,isFalseConsensus:!1,confidence:i,fiedlerValue:0,collapseRisk:1-r}}};k();var il={type:"object",properties:{swarmState:{type:"object",description:"Current state of the swarm including agents and task info"},riskThreshold:{type:"number",description:"Risk threshold for warning (0-1, default: 0.5)",default:.5,minimum:0,maximum:1}},required:["swarmState"]},ot=class extends x{config={name:"qe/coherence/collapse",description:"Predict swarm collapse risk using spectral analysis. Identifies vulnerable vertices and provides mitigation recommendations.",domain:"learning-optimization",schema:il,streaming:!1,timeout:3e4};coherenceService=null;async getService(){return this.coherenceService||(this.coherenceService=await se(ae)),this.coherenceService}resetInstanceCache(){this.coherenceService&&(this.coherenceService.dispose(),this.coherenceService=null)}async execute(e,t){let n=Date.now(),{swarmState:r,riskThreshold:i=.5}=e;if(!r)return{success:!1,error:"swarmState is required"};if(!r.agents||r.agents.length<1)return{success:!1,error:"At least one agent is required in swarmState"};try{let s=await this.getService(),a={agents:r.agents.map(g=>({agentId:g.agentId,agentType:g.agentType||"worker",health:Number.isFinite(g.health)?g.health:1,beliefs:[],lastActivity:new Date,errorCount:g.errorCount??0,successRate:Number.isFinite(g.successRate)?g.successRate:1})),activeTasks:Number.isFinite(r.activeTasks)?r.activeTasks:0,pendingTasks:Number.isFinite(r.pendingTasks)?r.pendingTasks:0,errorRate:Number.isFinite(r.errorRate)?r.errorRate:0,utilization:Number.isFinite(r.utilization)?r.utilization:0,timestamp:new Date},o=await s.predictCollapse(a),l=Number.isFinite(o.risk)?o.risk:0,c=this.categorizeRisk(l),d=[...o.recommendations,...this.generateAdditionalRecommendations(o,r)],m=Date.now()-n;this.markAsRealData();let p=c==="high"||c==="critical"||c==="medium"&&l>=i;return{success:!0,data:{risk:l,isAtRisk:p,riskLevel:c,fiedlerValue:o.fiedlerValue,collapseImminent:o.collapseImminent,weakVertices:o.weakVertices,recommendations:d,executionTimeMs:m,usedFallback:o.usedFallback}}}catch(s){if(s instanceof Error&&s.message.includes("WASM")){let a=this.heuristicAnalysis(r,i);return this.markAsDemoData(t,"WASM module unavailable"),{success:!0,data:{...a,recommendations:["Running in fallback mode (heuristic analysis)","Install prime-radiant-advanced-wasm for spectral collapse prediction",...a.recommendations],usedFallback:!0,executionTimeMs:Date.now()-n}}}return{success:!1,error:w(s)}}}categorizeRisk(e){return!Number.isFinite(e)||e<.25?"low":e<.5?"medium":e<.75?"high":"critical"}generateAdditionalRecommendations(e,t){let n=[];t.errorRate>.1&&n.push(`High system error rate (${(t.errorRate*100).toFixed(1)}%) - investigate root causes`),t.utilization>.85&&n.push(`High resource utilization (${(t.utilization*100).toFixed(1)}%) - consider scaling`),t.pendingTasks>t.activeTasks*2&&n.push(`Large task backlog (${t.pendingTasks} pending) - may need more agents`);let r=t.agents.filter(i=>i.health<.5);return r.length>0&&n.push(`${r.length} agent(s) with low health - consider replacement`),e.risk>=.75&&n.unshift("\u26A0\uFE0F CRITICAL: Immediate action required to prevent collapse"),n}heuristicAnalysis(e,t){let n=0,r=[],i=[],s=Number.isFinite(e.errorRate)?e.errorRate:0,a=Number.isFinite(e.utilization)?e.utilization:0,o=Number.isFinite(e.pendingTasks)?e.pendingTasks:0,l=Number.isFinite(e.activeTasks)?e.activeTasks:0,c=e.agents.map(h=>Number.isFinite(h.health)?h.health:1),d=c.length>0?c.reduce((h,f)=>h+f,0)/c.length:1;n+=(1-d)*.3,n+=Math.min(.25,s*2.5),a>.7&&(n+=(a-.7)*.5);let m=o/Math.max(1,l);m>1&&(n+=Math.min(.2,(m-1)*.1)),e.agents.forEach((h,f)=>{(c[f]<.5||(h.errorCount??0)>5)&&i.push(h.agentId)}),n=Math.min(1,n),n>=t&&(r.push("Consider reducing task load"),r.push("Monitor agent health closely")),i.length>0&&r.push(`Reinforce weak agents: ${i.join(", ")}`),n<.25&&r.push("Swarm appears stable - continue normal operations");let p=this.categorizeRisk(n),g=p==="high"||p==="critical"||p==="medium"&&n>=t;return{risk:n,isAtRisk:g,riskLevel:p,fiedlerValue:0,collapseImminent:n>=.75,weakVertices:i,recommendations:r}}};var Ss=[new it,new st,new at,new ot],Es={COHERENCE_CHECK:"qe/coherence/check",COHERENCE_AUDIT:"qe/coherence/audit",COHERENCE_CONSENSUS:"qe/coherence/consensus",COHERENCE_COLLAPSE:"qe/coherence/collapse"};var ct=(T=>(T.PROBLEM_UNDERSTANDING="H1.1-problem-understanding",T.RULE_OF_THREE="H1.2-rule-of-three",T.PROBLEM_COMPLEXITY="H1.3-problem-complexity",T.USER_NEEDS_IDENTIFICATION="H2.1-user-needs-identification",T.USER_NEEDS_SUITABILITY="H2.2-user-needs-suitability",T.USER_NEEDS_VALIDATION="H2.3-user-needs-validation",T.BUSINESS_NEEDS_IDENTIFICATION="H3.1-business-needs-identification",T.USER_VS_BUSINESS_BALANCE="H3.2-user-vs-business-balance",T.KPI_IMPACT_ANALYSIS="H3.3-kpi-impact-analysis",T.ORACLE_PROBLEM_DETECTION="H4.1-oracle-problem-detection",T.WHAT_MUST_NOT_CHANGE="H4.2-what-must-not-change",T.SUPPORTING_DATA_ANALYSIS="H4.3-supporting-data-analysis",T.GUI_FLOW_IMPACT="H5.1-gui-flow-impact",T.USER_FEELINGS_IMPACT="H5.2-user-feelings-impact",T.CROSS_FUNCTIONAL_IMPACT="H5.3-cross-functional-impact",T.DATA_DEPENDENT_IMPACT="H5.4-data-dependent-impact",T.COMPETITIVE_ANALYSIS="H6.1-competitive-analysis",T.DOMAIN_INSPIRATION="H6.2-domain-inspiration",T.INNOVATIVE_SOLUTIONS="H6.3-innovative-solutions",T.EXACTNESS_AND_CLARITY="H7.1-exactness-and-clarity",T.INTUITIVE_DESIGN="H7.2-intuitive-design",T.COUNTER_INTUITIVE_DESIGN="H7.3-counter-intuitive-design",T.CONSISTENCY_ANALYSIS="H7.4-consistency-analysis",T))(ct||{});var gn=class{enabledHeuristics;minConfidence;constructor(e={}){this.enabledHeuristics=e.enabledHeuristics||Object.values(ct),this.minConfidence=e.minConfidence||.7}async applyAll(e,t,n,r){let i=[];for(let s of this.enabledHeuristics){let a=await this.apply(s,e,t,n,r);i.push(a)}return i}async apply(e,t,n,r,i){let s=this.getHeuristicCategory(e),a=[],o=[],l=[],c=75;switch(e){case"H7.4-consistency-analysis":t.domMetrics?.semanticStructure?.hasHeader&&t.domMetrics?.semanticStructure?.hasFooter?(c=85,a.push("Consistent page structure with header and footer")):(c=60,l.push("Add consistent header/footer structure"));break;case"H7.2-intuitive-design":let d=t.domMetrics?.semanticStructure?.hasNav,m=t.accessibility?.focusableElementsCount||0;d&&m>10?(c=82,a.push("Intuitive navigation and interaction design")):(c=55,o.push({description:"Navigation or interaction patterns unclear",severity:"medium"}));break;case"H7.1-exactness-and-clarity":c=70;let p=t.domMetrics?.semanticStructure,g=[p?.hasHeader,p?.hasMain,p?.hasNav,p?.hasFooter].filter(Boolean).length;c=50+g*10,g>=3?a.push("Strong visual hierarchy with semantic HTML elements"):g>=2?(a.push("Moderate visual hierarchy - some semantic elements present"),l.push("Add more semantic HTML5 elements for clarity")):(o.push({description:"Weak visual hierarchy - missing semantic structure",severity:"high"}),l.push("Implement semantic HTML5: header, nav, main, footer")),t.metadata?.description&&t.metadata.description.length>20&&(c+=10,a.push("Page has descriptive metadata"));break;case"H7.3-counter-intuitive-design":c=85;let h=!t.domMetrics?.semanticStructure?.hasNav&&(t.domMetrics?.interactiveElements||0)>10,f=!t.domMetrics?.semanticStructure?.hasHeader&&!t.domMetrics?.semanticStructure?.hasFooter;h&&(c=45,o.push({description:"Navigation structure may be counter-intuitive",severity:"high"}),l.push("Add semantic navigation elements")),f&&(c-=15,o.push({description:"Page structure lacks expected header/footer",severity:"medium"})),c>75&&a.push("No counter-intuitive design patterns detected");break;case"H5.2-user-feelings-impact":let v=t.accessibility?.altTextsCoverage||0,y=t.performance?.loadTime||0,C=t.accessibility?.ariaLabelsCount||0,b=t.accessibility?.focusableElementsCount||0;c=60,v>=90?(c+=20,a.push("Excellent accessibility (90%+ alt coverage) creates inclusive, positive experience")):v>=70?(c+=12,a.push("Good accessibility creates generally positive user feelings")):v<50&&(c-=15,o.push({description:"Poor accessibility (<50% alt coverage) frustrates users with disabilities",severity:"high"}),l.push("Improve alt text coverage to at least 80% for better accessibility")),C>5&&(c+=8,a.push("Strong ARIA labeling enhances screen reader experience")),y<1500?(c+=15,a.push("Very fast load time (<1.5s) delights users")):y<2500?(c+=8,a.push("Fast load time enhances user satisfaction")):y>4e3?(c-=20,o.push({description:"Very slow load time (>4s) causes significant frustration",severity:"critical"}),l.push("Optimize page load time - target under 2.5 seconds")):y>3e3&&(c-=12,o.push({description:"Slow load time causes user frustration",severity:"high"})),t.errorIndicators?.hasErrorMessages&&(c-=12,o.push({description:"Visible errors reduce user confidence and satisfaction",severity:"high"}),l.push("Review and fix visible error messages")),b>20?(c+=5,a.push("Rich interactive elements provide user control and engagement")):b<5&&(c-=8,o.push({description:"Limited interactivity may feel restrictive",severity:"medium"})),c=Math.max(20,Math.min(100,c));break;case"H5.1-gui-flow-impact":let E=t.domMetrics?.interactiveElements||0,S=t.domMetrics?.forms||0;E>20&&(c=75,a.push(`${E} interactive elements provide user control`)),S>0&&(a.push(`${S} forms impact user input flows`),c=Math.min(100,c+10)),E===0&&(c=30,o.push({description:"Limited user interaction capability",severity:"high"}));break;case"H5.3-cross-functional-impact":c=70,t.accessibility&&(t.accessibility.altTextsCoverage||0)<100&&a.push("Content team needed for alt text creation"),t.performance&&(t.performance.loadTime||0)>2e3&&a.push("Engineering team needed for performance optimization"),n.complexity==="complex"&&a.push("QA team needed for comprehensive testing"),c=70+a.length*5;break;case"H5.4-data-dependent-impact":t.domMetrics?.forms&&t.domMetrics.forms>0?(c=75,a.push(`${t.domMetrics.forms} forms depend on backend data processing`)):(c=50,a.push("Limited data-dependent features"));break;case"H1.1-problem-understanding":c=n.clarityScore,n.clarityScore>80?a.push("Problem is well-defined"):o.push({description:"Problem clarity needs improvement",severity:"medium"}),a.push(...n.breakdown);break;case"H1.2-rule-of-three":c=n.potentialFailures.length>=3?85:60,a.push(`${n.potentialFailures.length} potential failure modes identified`),n.potentialFailures.length<3&&l.push("Identify at least 3 potential failure modes (Rule of Three)");break;case"H1.3-problem-complexity":c=n.complexity==="simple"?90:n.complexity==="moderate"?75:60,a.push(`Problem complexity: ${n.complexity}`);break;case"H2.1-user-needs-identification":c=r.alignmentScore,a.push(`${r.needs.length} user needs identified`);let T=r.needs.filter(N=>N.priority==="must-have").length;a.push(`${T} must-have features`),r.challenges.length>0&&o.push({description:`${r.challenges.length} user need challenges found`,severity:"medium"});break;case"H2.2-user-needs-suitability":c=r.suitability==="excellent"?95:r.suitability==="good"?80:r.suitability==="adequate"?65:45,a.push(`User needs suitability: ${r.suitability}`);break;case"H2.3-user-needs-validation":let R=r.needs.filter(N=>N.addressed).length;c=r.needs.length>0?R/r.needs.length*100:50,a.push(`${R}/${r.needs.length} needs validated and addressed`);break;case"H3.1-business-needs-identification":c=i.alignmentScore,a.push(`Primary goal: ${i.primaryGoal}`),a.push(`${i.kpisAffected.length} KPIs affected`),a.push(`${i.crossTeamImpact.length} cross-team impacts`);break;case"H3.2-user-vs-business-balance":let D=100-Math.abs(r.alignmentScore-i.alignmentScore);c=D,D>80?a.push("Good balance between user and business needs"):(o.push({description:"Imbalance between user and business priorities",severity:"medium"}),l.push("Align user and business objectives more closely"));break;case"H3.3-kpi-impact-analysis":c=i.impactsKPIs?85:50,a.push(`KPIs impacted: ${i.kpisAffected.join(", ")}`),i.compromisesUX&&(o.push({description:"Business ease compromises user experience",severity:"high"}),c-=20);break;case"H4.1-oracle-problem-detection":c=75,a.push("Oracle problem detection capability active");break;case"H4.2-what-must-not-change":c=80,t.domMetrics?.semanticStructure?.hasMain&&a.push("Main content structure is immutable"),t.accessibility&&(t.accessibility.focusableElementsCount||0)>0&&a.push("Keyboard navigation support must be maintained");break;case"H4.3-supporting-data-analysis":c=75,(t.domMetrics?.forms||0)>0||(t.domMetrics?.interactiveElements||0)>20?(c=82,a.push("Sufficient data points for informed decision-making")):(c=60,o.push({description:"Limited data for comprehensive analysis",severity:"medium"}),l.push("Collect more user interaction data"));break;case"H6.1-competitive-analysis":c=70,a.push("Competitive analysis capability available"),t.domMetrics?.semanticStructure?.hasNav&&t.domMetrics?.interactiveElements&&t.domMetrics.interactiveElements>15?(c=78,a.push("Navigation and interaction patterns follow industry standards")):l.push("Compare interaction patterns with leading competitors");break;case"H6.2-domain-inspiration":c=72,t.accessibility&&(t.accessibility.ariaLabelsCount||0)>0?(c=80,a.push("Modern accessibility patterns show domain inspiration")):l.push("Research domain-specific design patterns and best practices");break;case"H6.3-innovative-solutions":c=65,(t.accessibility?.landmarkRoles||0)>3?(c=75,a.push("Advanced accessibility features show innovative thinking")):l.push("Explore innovative UX patterns to differentiate experience");break;default:s==="user-needs"?c=r.alignmentScore:s==="business-needs"?c=i.alignmentScore:s==="problem"&&(c=n.clarityScore);break}return{id:e,name:this.getHeuristicName(e),category:s,applied:!0,score:Math.min(100,Math.max(0,c)),findings:a,issues:o,recommendations:l}}getHeuristicCategory(e){return e.includes("problem")?"problem":e.includes("user-needs")||e.includes("user-vs")?"user-needs":e.includes("business")?"business-needs":e.includes("oracle")||e.includes("balance")||e.includes("what-must")||e.includes("supporting-data")?"balance":e.includes("impact")||e.includes("gui-flow")||e.includes("feelings")||e.includes("cross-functional")||e.includes("data-dependent")?"impact":e.includes("competitive")||e.includes("inspiration")||e.includes("innovative")?"creativity":"design"}getHeuristicName(e){return{"H1.1-problem-understanding":"Problem Understanding","H1.2-rule-of-three":"Rule of Three","H1.3-problem-complexity":"Problem Complexity","H2.1-user-needs-identification":"User Needs Identification","H2.2-user-needs-suitability":"User Needs Suitability","H2.3-user-needs-validation":"User Needs Validation","H3.1-business-needs-identification":"Business Needs Identification","H3.2-user-vs-business-balance":"User vs Business Balance","H3.3-kpi-impact-analysis":"KPI Impact Analysis","H4.1-oracle-problem-detection":"Oracle Problem Detection","H4.2-what-must-not-change":"What Must Not Change","H4.3-supporting-data-analysis":"Supporting Data Analysis","H5.1-gui-flow-impact":"GUI Flow Impact","H5.2-user-feelings-impact":"User Feelings Impact","H5.3-cross-functional-impact":"Cross-Functional Impact","H5.4-data-dependent-impact":"Data-Dependent Impact","H6.1-competitive-analysis":"Competitive Analysis","H6.2-domain-inspiration":"Domain Inspiration","H6.3-innovative-solutions":"Innovative Solutions","H7.1-exactness-and-clarity":"Exactness & Clarity","H7.2-intuitive-design":"Intuitive Design","H7.3-counter-intuitive-design":"Counter-Intuitive Design","H7.4-consistency-analysis":"Consistency Analysis"}[e]||e}};var hn=class{minSeverity;constructor(e="medium"){this.minSeverity=e}detect(e,t,n){let r=[];Math.abs(t.alignmentScore-n.alignmentScore)>20&&r.push({type:"user-vs-business",description:"Significant gap between user needs and business objectives",severity:"high",stakeholders:["Users","Business"],resolutionApproach:["Gather supporting data from both perspectives","Facilitate discussion between stakeholders","Find compromise solutions that address both needs"]}),(t.challenges.length>0||n.compromisesUX)&&r.push({type:"unclear-criteria",description:"Quality criteria unclear due to conflicting information",severity:"medium",missingInfo:t.challenges,resolutionApproach:["Collect missing information from stakeholders","Define clear acceptance criteria"]});let i=(e.title||"").toLowerCase(),s=(e.metadata?.description||"").toLowerCase();return(i.includes("hotel")||i.includes("booking")||i.includes("travel")||i.includes("shop")||i.includes("store")||s.includes("book"))&&(n.kpisAffected.some(a=>a.toLowerCase().includes("conversion")||a.toLowerCase().includes("engagement"))&&r.push({type:"user-vs-business",description:"Potential conflict between conversion optimization (business) and user experience quality (user trust)",severity:"medium",stakeholders:["Marketing","Product","Users"],resolutionApproach:["A/B test aggressive vs. subtle conversion tactics","Measure both conversion rate and user satisfaction metrics","Balance urgency messaging with transparent communication"]}),r.push({type:"unclear-criteria",description:"Unclear criteria for price display timing - when to show fees, taxes, and final price",severity:"medium",stakeholders:["Users","Legal","Business"],resolutionApproach:["Define regulatory compliance requirements for price display","Balance business desire for competitive base pricing vs user need for full price transparency","Establish clear standards for fee disclosure timing"]})),(i.includes("blog")||i.includes("article")||i.includes("news")||i.includes("magazine")||i.includes("testing"))&&r.push({type:"user-vs-business",description:"Content depth (user need) vs. publication frequency (business engagement goals) trade-off",severity:"low",stakeholders:["Readers","Content Team","Editorial"],resolutionApproach:["Define content quality standards and acceptance criteria","Balance editorial calendar with quality thresholds","Consider mix of in-depth and quick-read content formats"]}),(i.includes("health")||i.includes("medical")||i.includes("patient")||i.includes("care")||i.includes("nhs"))&&(r.push({type:"stakeholder-conflict",description:"Healthcare compliance requirements may conflict with streamlined user experience",severity:"medium",stakeholders:["Patients","Healthcare Providers","Compliance","Legal"],resolutionApproach:["Map regulatory requirements to UX touchpoints","Identify where compliance can be achieved without friction","Engage compliance team early in UX design reviews","Document consent and data handling requirements clearly"]}),e.accessibility&&(e.accessibility.altTextsCoverage||0)<80&&r.push({type:"technical-constraint",description:"Healthcare accessibility requirements not fully met - critical for patient inclusivity",severity:"high",stakeholders:["Patients","Accessibility Team","Legal"],resolutionApproach:["Prioritize WCAG 2.1 AA compliance for healthcare content","Ensure screen reader compatibility for medical information","Test with assistive technology users"]})),(i.includes("bank")||i.includes("finance")||i.includes("payment")||i.includes("money"))&&r.push({type:"stakeholder-conflict",description:"Security requirements vs user convenience - authentication friction vs fraud prevention",severity:"high",stakeholders:["Users","Security Team","Product","Compliance"],resolutionApproach:["Implement risk-based authentication to reduce friction for trusted sessions","Use biometrics where available for convenient yet secure access","A/B test authentication flows for security effectiveness and user completion rates"]}),((e.domMetrics?.totalElements||0)>500||(e.domMetrics?.interactiveElements||0)>50)&&r.push({type:"technical-constraint",description:"Platform technical limitations may restrict advanced UX features or accessibility enhancements",severity:"low",stakeholders:["Development","Product","Users"],resolutionApproach:["Evaluate platform capabilities and constraints","Prioritize features based on user impact vs. implementation complexity","Consider gradual enhancement approach"]}),e.performance&&(e.performance.loadTime||0)>3e3&&r.push({type:"technical-constraint",description:"Performance optimization needed but may require trade-offs with visual richness",severity:"medium",stakeholders:["Users","Development","Design"],resolutionApproach:["Profile and identify performance bottlenecks","Consider progressive loading for visual elements","Balance image quality with load time"]}),r.filter(a=>this.meetsMinimumSeverity(a.severity))}meetsMinimumSeverity(e){let t=["low","medium","high","critical"],n=t.indexOf(this.minSeverity);return t.indexOf(e)>=n}};var fn=class u{static LOAD_TIME_FEELINGS=[[4001,1/0,"Impatient - Very slow load time causes significant frustration"],[3001,4e3,"Impatient - Slow load time causes frustration"],[2001,3e3,"Mildly Annoyed - Noticeable load time"],[0,1499,"Delighted - Fast load time enhances experience"],[1500,1999,"Satisfied - Good load time meets expectations"]];static DOMAIN_REQUIREMENTS=[[["health","medical","care"],["Must comply with healthcare accessibility standards","Must protect patient data privacy"]],[["bank","finance","payment"],["Must maintain PCI DSS compliance for payment data","Must support secure authentication flows"]]];static VISIBLE_SCORE_ADJUSTMENTS=[[["Positive","Satisfied","Delighted"],20],[["Oriented"],10],[["Frustrated","Confused","Impatient"],-15],[["Disoriented"],-10]];analyze(e,t){let n=this.analyzeEndUserFlow(e),r=this.analyzeInternalFlow(e),i=this.analyzeUserFeelings(e),s=this.analyzePerformance(e),a=this.analyzeSecurity(e),o=this.analyzeImmutableRequirements(e,t),l=this.calculateVisibleScore(n,i),c=this.calculateInvisibleScore(s,a),d=Math.round((l+c)/2);return{visible:{guiFlow:{forEndUser:n,forInternalUser:r},userFeelings:i,score:l},invisible:{performance:s,security:a,score:c},immutableRequirements:o,overallImpactScore:d}}analyzeEndUserFlow(e){let t=[],n=e.domMetrics?.interactiveElements||0,r=e.domMetrics?.forms||0;return n>0&&t.push(`${n} interactive elements affect user journey`),r>0&&t.push(`${r} forms impact user input flows`),e.domMetrics?.semanticStructure?.hasNav&&t.push("Navigation structure enables exploration flow"),e.domMetrics?.semanticStructure?.hasMain&&t.push("Clear main content area guides user focus"),t}analyzeInternalFlow(e){let t=[];return(e.domMetrics?.forms||0)>0&&t.push("Form submissions create data processing workflows"),e.domMetrics?.semanticStructure?.hasAside&&t.push("Sidebar content may require separate management"),t}analyzeUserFeelings(e){let t=[],n=e.accessibility?.altTextsCoverage||0;n>80?t.push("Positive - Good accessibility creates inclusive experience"):n>=50?t.push("Neutral - Moderate accessibility; some users may struggle"):n<50&&t.push("Frustrated - Poor accessibility excludes some users");let r=e.performance?.loadTime||0;for(let[i,s,a]of u.LOAD_TIME_FEELINGS)if(r>=i&&r<=s){t.push(a);break}return e.errorIndicators?.hasErrorMessages&&t.push("Confused - Visible errors reduce confidence"),this.analyzeStructureFeelings(e,t),t}analyzeStructureFeelings(e,t){let n=e.domMetrics?.semanticStructure;if(!n)return;let r=[n.hasHeader,n.hasNav,n.hasMain,n.hasFooter].filter(Boolean).length;r>=3?t.push("Oriented - Clear page structure helps navigation"):r<2&&t.push("Disoriented - Unclear page structure may confuse users")}analyzePerformance(e){let t=[],n=e.performance?.loadTime||0;return n>2e3&&t.push(`Load time ${n}ms impacts user retention`),e.metadata?.viewport||t.push("Missing viewport tag affects mobile performance"),e.performance?.firstContentfulPaint&&e.performance.firstContentfulPaint>2500&&t.push(`First Contentful Paint ${e.performance.firstContentfulPaint}ms delays perceived readiness`),t}analyzeSecurity(e){let t=[];return(e.domMetrics?.forms||0)>0&&t.push("Form data handling requires secure transmission"),e.accessibility&&(e.accessibility.ariaLabelsCount||0)>0&&t.push("ARIA labels may expose internal element names - review for sensitive info"),t}analyzeImmutableRequirements(e,t){let n=[];e.domMetrics?.semanticStructure?.hasMain&&n.push("Must maintain main content accessibility"),e.accessibility&&(e.accessibility.focusableElementsCount||0)>0&&n.push("Must support keyboard navigation"),t.complexity==="complex"&&n.push("Must maintain system stability with complex interactions");let r=(e.title||"").toLowerCase();for(let[i,s]of u.DOMAIN_REQUIREMENTS)i.some(a=>r.includes(a))&&n.push(...s);return n}calculateVisibleScore(e,t){let n=50;e.length>0&&(n+=15);for(let[r,i]of u.VISIBLE_SCORE_ADJUSTMENTS)t.some(s=>r.some(a=>s.includes(a)))&&(n+=i);return Math.max(0,Math.min(100,n))}calculateInvisibleScore(e,t){let n=50;return e.length===0&&(n+=20),t.length===0&&(n+=10),e.length>2&&(n-=15),Math.max(0,Math.min(100,n))}};k();var sl={type:"object",properties:{target:{type:"string",description:"Target URL or identifier to analyze"},context:{type:"object",description:"Pre-collected QX context (optional)"},mode:{type:"string",description:"Analysis mode: full, quick, or targeted",enum:["full","quick","targeted"],default:"full"},heuristics:{type:"array",description:"Specific heuristics to apply (default: all)"},minOracleSeverity:{type:"string",description:"Minimum oracle problem severity to report",enum:["low","medium","high","critical"],default:"medium"},includeCreativity:{type:"boolean",description:"Include creativity analysis from diverse domains",default:!0},includeDesign:{type:"boolean",description:"Include design quality analysis",default:!0}},required:["target"]},lt=class extends x{config={name:"qe/qx/analyze",description:"Comprehensive Quality Experience (QX) analysis combining QA and UX perspectives. Applies 23+ programmatic heuristics, detects oracle problems, and analyzes impacts. QX = Marriage between QA (Quality Advocacy) and UX (User Experience).",domain:"quality-assessment",schema:sl,streaming:!0,timeout:18e4};async execute(e,t){let{target:n,context:r=this.createMinimalContext(n),mode:i="full",heuristics:s,minOracleSeverity:a="medium",includeCreativity:o=!0,includeDesign:l=!0}=e;try{this.emitStream(t,{status:"starting",message:`Starting QX analysis for: ${n}`,phase:"initialization"}),this.emitStream(t,{status:"analyzing",phase:"problem-analysis"});let c=this.analyzeProblem(r);if(this.isAborted(t))return{success:!1,error:"Operation aborted"};this.emitStream(t,{status:"analyzing",phase:"user-needs"});let d=this.analyzeUserNeeds(r,c);this.emitStream(t,{status:"analyzing",phase:"business-needs"});let m=this.analyzeBusinessNeeds(r,c);this.emitStream(t,{status:"analyzing",phase:"creativity"});let p=o?this.analyzeCreativity(r,c):this.createMinimalCreativityAnalysis();this.emitStream(t,{status:"analyzing",phase:"design"});let g=l?this.analyzeDesign(r):this.createMinimalDesignAnalysis();this.emitStream(t,{status:"analyzing",phase:"oracle-detection"});let f=new hn(a).detect(r,d,m);this.emitStream(t,{status:"analyzing",phase:"impact-analysis"});let y=new fn().analyze(r,c);this.emitStream(t,{status:"analyzing",phase:"heuristics",count:23});let b=await new gn({enabledHeuristics:s||Object.values(ct)}).applyAll(r,c,d,m);this.emitStream(t,{status:"analyzing",phase:"recommendations"});let E=this.generateRecommendations(c,d,m,f,y,b),S=this.calculateOverallScore(c,d,m,p,g,y,b),T=this.scoreToGrade(S),R={overallScore:S,grade:T,timestamp:new Date().toISOString(),target:n,problemAnalysis:c,userNeeds:d,businessNeeds:m,creativityAnalysis:p,designAnalysis:g,oracleProblems:f,impactAnalysis:y,heuristics:b,recommendations:E,context:r};return this.emitStream(t,{status:"complete",score:S,grade:T,heuristicsApplied:b.length,oracleProblemsFound:f.length}),{success:!0,data:R,metadata:this.createMetadata(t.startTime,t.requestId)}}catch(c){return{success:!1,error:`QX analysis failed: ${w(c)}`}}}analyzeProblem(e){let t=e.title||"Untitled page",n=e.metadata?.description||"",r=e.errorIndicators?.hasErrorMessages||!1,i=`Evaluate quality experience of "${t}"`;n&&(i+=` - ${n.substring(0,100)}`);let s=e.domMetrics?.totalElements||0,a=e.domMetrics?.interactiveElements||0,o=e.domMetrics?.forms||0,l;s>500||a>50||o>3?l="complex":s>200||a>20||o>1?l="moderate":l="simple";let c=[];e.domMetrics?.semanticStructure?.hasNav&&c.push("Navigation structure"),o>0&&c.push(`Form interactions (${o} forms)`),a>0&&c.push(`User interactions (${a} elements)`),e.accessibility&&c.push("Accessibility compliance"),e.performance&&c.push("Performance metrics");let d=[],m=t.toLowerCase();for((m.includes("health")||m.includes("care")||m.includes("nhs"))&&(d.push({description:"Healthcare information may not be accessible to users with visual impairments",severity:"high",likelihood:"likely"}),d.push({description:"Patient journey complexity may cause confusion during registration or booking",severity:"medium",likelihood:"possible"}),d.push({description:"Emergency contact information may not be prominently visible",severity:"high",likelihood:"possible"})),e.domMetrics?.semanticStructure?.hasMain||d.push({description:"Missing main content landmark - users may struggle to find primary content",severity:"medium",likelihood:"likely"}),e.accessibility&&(e.accessibility.altTextsCoverage||0)<80&&d.push({description:"Poor image alt text coverage - screen reader users affected",severity:"high",likelihood:"very-likely"}),r&&d.push({description:"Visible error messages detected - potential usability issues",severity:"medium",likelihood:"likely"}),e.performance&&(e.performance.loadTime||0)>3e3&&d.push({description:"Slow load time - user frustration and abandonment risk",severity:"high",likelihood:"very-likely"});d.length<3;)l==="complex"?d.push({description:"Complex interaction flows may confuse first-time users",severity:"medium",likelihood:"possible"}):l==="moderate"?d.push({description:"Multiple interactive elements increase cognitive load",severity:"low",likelihood:"possible"}):d.push({description:"Limited interactivity may not meet user expectations",severity:"low",likelihood:"possible"});let p=50;return t&&t!=="Untitled page"&&(p+=15),n&&(p+=15),c.length>=3&&(p+=10),e.domMetrics?.semanticStructure?.hasMain&&(p+=10),p=Math.min(100,p),{problemStatement:i,complexity:l,breakdown:c,potentialFailures:d.slice(0,5),clarityScore:p}}analyzeUserNeeds(e,t){let n=[],r=[],i=e.domMetrics?.semanticStructure,s=e.accessibility,a=e.domMetrics?.interactiveElements||0,o=e.domMetrics?.forms||0;i?.hasNav?n.push({description:"Clear navigation to find content",priority:"must-have",addressed:!0}):(r.push("Missing navigation structure - users cannot easily explore site"),n.push({description:"Clear navigation to find content",priority:"must-have",addressed:!1})),a>0&&n.push({description:"Interactive elements for engagement",priority:"must-have",addressed:!0}),s&&(s.focusableElementsCount||0)>0?n.push({description:"Keyboard navigation support",priority:"must-have",addressed:!0}):(r.push("Limited keyboard navigation - inaccessible to some users"),n.push({description:"Keyboard navigation support",priority:"must-have",addressed:!1})),i?.hasHeader&&n.push({description:"Consistent page header for orientation",priority:"should-have",addressed:!0}),i?.hasFooter&&n.push({description:"Footer with supporting information",priority:"should-have",addressed:!0}),s&&(s.altTextsCoverage||0)>50?n.push({description:"Image descriptions for screen readers",priority:"should-have",addressed:!0}):s&&(s.altTextsCoverage||0)<50&&(r.push("Poor alt text coverage - images not accessible"),n.push({description:"Image descriptions for screen readers",priority:"should-have",addressed:!1})),e.performance&&(e.performance.loadTime||0)<3e3?n.push({description:"Fast page load time",priority:"should-have",addressed:!0}):e.performance&&(e.performance.loadTime||0)>=3e3&&(r.push("Slow load time - user frustration risk"),n.push({description:"Fast page load time",priority:"should-have",addressed:!1})),i?.hasAside&&n.push({description:"Supplementary content sections",priority:"nice-to-have",addressed:!0}),s&&(s.landmarkRoles||0)>3&&n.push({description:"Rich ARIA landmarks for navigation",priority:"nice-to-have",addressed:!0}),o>0&&n.push({description:"Form interactions for user input",priority:"nice-to-have",addressed:!0});let l=n.filter(m=>m.priority==="must-have"&&m.addressed).length,c;r.length===0&&l>=3?c="excellent":r.length<=1&&l>=2?c="good":r.length<=2&&l>=2?c="adequate":c="poor";let d=40;return d+=l*10,d+=n.filter(m=>m.priority==="should-have"&&m.addressed).length*5,d+=n.filter(m=>m.priority==="nice-to-have"&&m.addressed).length*2,d-=r.length*8,d=Math.max(0,Math.min(100,d)),{needs:n,suitability:c,challenges:r,alignmentScore:d}}analyzeBusinessNeeds(e,t){let n=e.domMetrics?.forms||0,r=e.domMetrics?.interactiveElements||0,i=e.performance,s=e.errorIndicators?.hasErrorMessages||!1,a,o=[];n>2?(a="business-ease",o=["Form completion rate","Lead generation","User sign-ups"]):r>30?(a="user-experience",o=["Time on site","Click-through rate","User engagement"]):(a="balanced",o=["Content consumption","Bounce rate","Page views"]);let l=(e.title||"").toLowerCase();(l.includes("health")||l.includes("care"))&&o.push("Patient satisfaction","Appointment completion rate","Information accessibility");let c=[];n>0&&(c.push({team:"Marketing",impactType:"positive",description:"Form conversion optimization needed"}),c.push({team:"Development",impactType:"neutral",description:"Form validation and submission handling"})),e.accessibility&&(e.accessibility.altTextsCoverage||0)<100&&c.push({team:"Content",impactType:"negative",description:"Image alt text creation required"}),i&&(i.loadTime||0)>2e3&&c.push({team:"Engineering",impactType:"negative",description:"Performance optimization needed"}),t.complexity==="complex"&&c.push({team:"QA",impactType:"neutral",description:"Comprehensive testing strategy required"});let d=!1;s&&(d=!0),e.accessibility&&(e.accessibility.altTextsCoverage||0)<50&&(d=!0),i&&(i.loadTime||0)>4e3&&(d=!0);let m=50;return o.length>0&&(m+=15),c.length>0&&(m+=10),d||(m+=20),m=Math.min(100,m),{primaryGoal:a,kpisAffected:o,crossTeamImpact:c,compromisesUX:d,impactsKPIs:o.length>0,alignmentScore:m}}analyzeCreativity(e,t){let n=[];(t.complexity==="complex"||t.complexity==="moderate")&&(n.push({description:"Question fundamental assumptions about user mental models and expected workflows",inspirationSource:"philosophy",applicability:"high",novelty:"moderately-novel"}),e.errorIndicators?.hasErrorMessages&&n.push({description:"Apply diagnostic testing - systematically isolate error sources through controlled scenarios",inspirationSource:"medicine",applicability:"high",novelty:"moderately-novel"})),e.domMetrics?.forms&&e.domMetrics.forms>0&&n.push({description:"Test checkout/form flows like fashion retail - focus on friction points, abandonment triggers",inspirationSource:"e-commerce",applicability:"high",novelty:"incremental"}),n.push({description:"Analyze through diverse demographic lenses (age, gender, culture, ability) for inclusive testing",inspirationSource:"social science",applicability:"high",novelty:"moderately-novel"}),e.domMetrics?.interactiveElements&&e.domMetrics.interactiveElements>20&&n.push({description:'Test for "game-breaking" exploits - unexpected interaction sequences, boundary conditions',inspirationSource:"gaming",applicability:"medium",novelty:"highly-novel"});let r=[...new Set(n.map(a=>a.inspirationSource))],i=["Unexperienced user perspective (fresh eyes)","Power user perspective (efficiency focus)","Accessibility perspective (assistive tech users)","International perspective (cultural differences)"],s=50;return s+=n.length*8,s+=r.length*5,s=Math.min(100,s),{innovativeApproaches:n,domainsExplored:r,perspectives:i,creativityScore:s,notes:["Creativity draws from diverse domains to uncover unconventional testing approaches","Higher complexity problems benefit from cross-disciplinary inspiration",`Applied ${n.length} creative approaches from ${r.length} domains`]}}analyzeDesign(e){let t=[],n=[];e.domMetrics?.semanticStructure?.hasNav&&t.push("Navigation structure clearly defined with semantic <nav> element"),e.domMetrics?.semanticStructure?.hasMain&&t.push("Main content area clearly identified"),e.domMetrics?.semanticStructure?.hasHeader&&e.domMetrics?.semanticStructure?.hasFooter&&t.push("Header and footer provide clear page structure");let r=e.accessibility?.ariaLabelsCount||0,i=e.domMetrics?.interactiveElements||0;i>0&&r<i*.5&&n.push("Many interactive elements lack ARIA labels for clarity");let s=50+t.length*15-n.length*10;s=Math.max(0,Math.min(100,s));let a=s>=80?"excellent":s>=60?"good":s>=40?"adequate":"poor",o=[],l=[],c=!0;e.domMetrics?.semanticStructure?.hasNav&&o.push("Standard navigation placement"),e.domMetrics?.semanticStructure?.hasHeader&&o.push("Header follows common layout conventions"),!e.domMetrics?.semanticStructure?.hasNav&&i>10&&(c=!1,l.push("Non-standard navigation pattern may confuse users from different regions"));let d=50+o.length*15;c||(d-=20),d=Math.max(0,Math.min(100,d));let m=Math.round((s+d)/2);return{exactness:{clarity:a,clearElements:t,unclearElements:n,score:s},intuitive:{followsConventions:c,intuitivePatterns:o,culturalIssues:l,score:d},counterIntuitive:{deviations:[],innovativeJustification:!1,freshEyesPerspective:!0,issuesCount:0},overallDesignScore:m}}generateRecommendations(e,t,n,r,i,s){let a=[],o=1;for(let l of s){for(let c of l.issues)(c.severity==="critical"||c.severity==="high")&&a.push({principle:l.name,recommendation:c.description,severity:c.severity,impact:c.severity==="critical"?90:75,effort:"medium",priority:o++,category:"qx"});for(let c of l.recommendations)a.push({principle:l.name,recommendation:c,severity:"medium",impact:60,effort:"medium",priority:o++,category:"qx"})}for(let l of r)a.push({principle:`Oracle: ${l.type}`,recommendation:l.description,severity:l.severity,impact:l.severity==="critical"?95:l.severity==="high"?80:60,effort:"high",priority:o++,category:"process",evidence:l.resolutionApproach});for(let l of t.challenges)a.push({principle:"User Needs",recommendation:l,severity:"medium",impact:65,effort:"medium",priority:o++,category:"ux"});return a.sort((l,c)=>{let d={critical:0,high:1,medium:2,low:3},m=d[l.severity]-d[c.severity];return m!==0?m:c.impact-l.impact}).slice(0,15)}calculateOverallScore(e,t,n,r,i,s,a){let o=a.reduce((c,d)=>c+d.score,0)/a.length||0,l=e.clarityScore*.1+t.alignmentScore*.2+n.alignmentScore*.15+r.creativityScore*.1+i.overallDesignScore*.15+(100-s.overallImpactScore)*.1+o*.2;return Math.round(Math.max(0,Math.min(100,l)))}scoreToGrade(e){return e>=90?"A":e>=80?"B":e>=70?"C":e>=60?"D":"F"}createMinimalContext(e){return{url:e,title:e}}createMinimalCreativityAnalysis(){return{innovativeApproaches:[],domainsExplored:[],perspectives:[],creativityScore:50,notes:["Creativity analysis skipped"]}}createMinimalDesignAnalysis(){return{exactness:{clarity:"adequate",clearElements:[],unclearElements:[],score:50},intuitive:{followsConventions:!0,intuitivePatterns:[],culturalIssues:[],score:50},counterIntuitive:{deviations:[],innovativeJustification:!1,freshEyesPerspective:!1,issuesCount:0},overallDesignScore:50}}emitStream(e,t){e.streaming&&e.onStream&&e.onStream(t)}isAborted(e){return e.abortSignal?.aborted||!1}createMetadata(e,t){return{executionTime:Date.now()-e,timestamp:new Date().toISOString(),requestId:t}}},rw=new lt;var Aw={TEST_GENERATE:"qe/tests/generate",TEST_EXECUTE:"qe/tests/execute",COVERAGE_ANALYZE:"qe/coverage/analyze",COVERAGE_GAPS:"qe/coverage/gaps",QUALITY_EVALUATE:"qe/quality/evaluate",DEFECT_PREDICT:"qe/defects/predict",REQUIREMENTS_VALIDATE:"qe/requirements/validate",QUALITY_CRITERIA:"qe/requirements/quality-criteria",CODE_ANALYZE:"qe/code/analyze",SECURITY_SCAN:"qe/security/scan",CONTRACT_VALIDATE:"qe/contracts/validate",VISUAL_COMPARE:"qe/visual/compare",A11Y_AUDIT:"qe/a11y/audit",CHAOS_INJECT:"qe/chaos/inject",LEARNING_OPTIMIZE:"qe/learning/optimize",LEARNING_DREAM:"qe/learning/dream",TOKEN_USAGE:"qe/analysis/token_usage",GOAP_PLAN:"qe/planning/goap_plan",GOAP_EXECUTE:"qe/planning/goap_execute",GOAP_STATUS:"qe/planning/goap_status",...nt,EMBEDDING_GENERATE:"qe/embeddings/generate",EMBEDDING_COMPARE:"qe/embeddings/compare",EMBEDDING_SEARCH:"qe/embeddings/search",EMBEDDING_STORE:"qe/embeddings/store",EMBEDDING_STATS:"qe/embeddings/stats",...Es,QX_ANALYZE:"qe/qx/analyze",TEST_SCHEDULE:"qe/tests/schedule",LOAD_TEST:"qe/tests/load",URL_VALIDATE:"qe/security/url-validate",BROWSER_WORKFLOW:"qe/workflows/browser-load"},kw=[new jt,new Ht,new Qt,new Wt,new Kt,new Yt,new Jt,new Qe,new en,new tn,new nn,new rn,new sn,new an,new We,new Ke,new on,new Ze,new et,new tt,...Ts,new _e,new Oe,new Fe,new Ne,new Le,...Ss,new lt,new Zr,new ei,new ti,new Jr];k();var Hw=xr.filter(u=>u!=="coordination"),yn={fleetId:null,kernel:null,queen:null,router:null,workflowOrchestrator:null,initialized:!1,initTime:null,topology:"hierarchical",agentLevels:new Map};function je(){return yn}function $i(){return yn.initialized&&yn.kernel!==null&&yn.queen!==null}export{Kl as a,Lt as b,je as c,$i as d};
|
|
699
|
+
`);for(let r of t.steps)n.run(r.id,e,r.planId,r.action.id,r.stepOrder,r.status,r.retries,r.startedAt.toISOString(),r.completedAt?.toISOString()??null,r.durationMs??null,r.agentId??null,r.agentOutput??null,r.worldStateBefore?JSON.stringify(r.worldStateBefore):null,r.worldStateAfter?JSON.stringify(r.worldStateAfter):null,r.error??null)}async updateActionStats(e,t,n){try{"updateActionStats"in this.planner&&await this.planner.updateActionStats(e,t,n)}catch(r){console.warn("[PlanExecutor] Failed to update action stats:",r)}}meetsConditions(e,t){for(let[n,r]of Object.entries(t))if(!this.checkCondition(e,n,r))return!1;return!0}checkCondition(e,t,n){let r=this.getStateValue(e,t);return typeof n=="string"||typeof n=="number"||typeof n=="boolean"?r===n:!(typeof n=="object"&&n!==null&&("min"in n&&n.min!==void 0&&(typeof r!="number"||r<n.min)||"max"in n&&n.max!==void 0&&(typeof r!="number"||r>n.max)||"eq"in n&&n.eq!==void 0&&r!==n.eq))}applyEffects(e,t){let n=this.cloneState(e);for(let[r,i]of Object.entries(t))this.applyEffect(n,r,i);return n}applyEffect(e,t,n){if(typeof n=="string"||typeof n=="number"||typeof n=="boolean"){this.setStateValue(e,t,n);return}if(typeof n=="object"&&n!==null){let r=this.getStateValue(e,t);if("set"in n&&n.set!==void 0&&this.setStateValue(e,t,n.set),"delta"in n&&n.delta!==void 0&&typeof r=="number"){let i=Math.max(0,Math.min(100,r+n.delta));this.setStateValue(e,t,i)}}}getStateValue(e,t){let n=t.split("."),r=e;for(let i of n){if(r==null)return;r=r[i]}return r}setStateValue(e,t,n){let r=t.split("."),i=new Set(["__proto__","constructor","prototype"]);for(let o of r)if(i.has(o)){console.warn(`[PlanExecutor] Blocked prototype pollution attempt: ${t}`);return}let s=e;for(let o=0;o<r.length-1;o++){let l=r[o];Object.hasOwn(s,l)||Object.defineProperty(s,l,{value:Object.create(null),writable:!0,enumerable:!0,configurable:!0});let c=Object.getOwnPropertyDescriptor(s,l);if(!c)return;s=c.value}let a=r[r.length-1];Object.defineProperty(s,a,{value:n,writable:!0,enumerable:!0,configurable:!0})}cloneState(e){return{coverage:{...e.coverage},quality:{...e.quality},fleet:{...e.fleet,availableAgents:[...e.fleet.availableAgents]},resources:{...e.resources},context:{...e.context},patterns:{...e.patterns}}}delay(e){return new Promise(t=>setTimeout(t,e))}async close(){this.currentExecution&&await this.cancel(),this.db&&(this.unifiedMemory?console.log("[PlanExecutor] Detached from unified storage (not closing shared connection)"):(this.db.close(),console.log("[PlanExecutor] Database closed"))),this.unifiedMemory=null,this.initialized=!1}},on=class{successRate;executionDelay;constructor(e){this.successRate=e?.successRate??1,this.executionDelay=e?.executionDelay??100}async spawn(e,t){await new Promise(i=>setTimeout(i,this.executionDelay));let n=J()<this.successRate,r=`mock-agent-${pr().slice(0,8)}`;return n?{agentId:r,output:`Successfully executed task for ${e}: ${t.slice(0,50)}...`,success:!0}:{agentId:r,output:"",success:!1,error:`Simulated failure for ${e}`}}};function Ye(u,e){let t=new on({successRate:e?.successRate??1});return new an(u,t,e?.dbPath,e?.config)}var Je=class extends P{planner=null;config={name:"qe/planning/goap_plan",description:'Find optimal action plan to achieve a QE goal using A* search. Supports named goals (e.g., "achieve-90-percent-coverage") or custom goal conditions.',domain:"coordination",schema:this.buildSchema()};buildSchema(){return{type:"object",properties:{goal:{type:"string",description:'Goal name (e.g., "achieve-90-percent-coverage") or custom goal conditions as JSON object'},currentState:{type:"object",description:"Current world state (auto-detected if not provided). Contains coverage, quality, fleet, resources, context, and patterns."},constraints:{type:"object",description:"Plan constraints",properties:{maxCost:{type:"number",description:"Maximum total cost allowed"},maxDurationMs:{type:"number",description:"Maximum total duration in milliseconds"},requiredAgentTypes:{type:"array",description:"Only use actions that these agent types can execute",items:{type:"string",description:"Agent type"}},excludedActions:{type:"array",description:"Exclude these specific action IDs",items:{type:"string",description:"Action ID"}}}}},required:["goal"]}}async getPlanner(){return this.planner||(this.planner=he(),await this.planner.initialize()),this.planner}resetInstanceCache(){this.planner=null}async execute(e,t){try{let n=await this.getPlanner(),r,i;if(typeof e.goal=="string"){let l=await n.getGoals(),c=l.find(d=>d.name===e.goal);if(!c){let d=l.map(m=>m.name).join(", ");return{success:!1,error:`Unknown goal: ${e.goal}. Available goals: ${d||"none (seed actions first)"}`}}r=c.conditions,i=c.name}else r=e.goal,i="custom";let s=e.currentState||await this.detectCurrentState(),a=e.constraints?{maxCost:e.constraints.maxCost,maxDurationMs:e.constraints.maxDurationMs,requiredAgentTypes:e.constraints.requiredAgentTypes,excludedActions:e.constraints.excludedActions}:void 0,o=await n.findPlan(s,r,a);return o?(this.markAsRealData(),{success:!0,data:{planId:o.id,goal:e.goal,actions:o.actions.map(l=>({name:l.name,agentType:l.agentType,cost:l.cost,category:l.category,description:l.description})),totalCost:o.totalCost,estimatedDurationMs:o.estimatedDurationMs,stepCount:o.actions.length,reusedFrom:o.reusedFrom,similarityScore:o.similarityScore}}):{success:!1,error:"No valid plan found for the given goal and constraints. Try relaxing constraints or seeding more actions."}}catch(n){return{success:!1,error:w(n)}}}async detectCurrentState(){return{...Ke}}};k();var Ze=class extends P{planner=null;executor=null;config={name:"qe/planning/goap_execute",description:"Execute a GOAP plan, spawning agents to perform each action step. Supports dry-run mode to simulate execution without actual agent spawning.",domain:"coordination",schema:this.buildSchema(),timeout:3e5};buildSchema(){return{type:"object",properties:{planId:{type:"string",description:"ID of plan to execute (from goap_plan result)"},dryRun:{type:"boolean",description:"Simulate execution without spawning agents (default: false)",default:!1},stepByStep:{type:"boolean",description:"Execute one step at a time (default: false)",default:!1},maxRetries:{type:"number",description:"Max retries per failed step (default: 2)",default:2,minimum:0,maximum:5}},required:["planId"]}}async getPlanner(){return this.planner||(this.planner=he(),await this.planner.initialize()),this.planner}async getExecutor(){if(!this.executor){let e=await this.getPlanner();this.executor=Ye(e,{successRate:.95,config:{maxRetries:2,stepTimeoutMs:6e4,replanOnFailure:!0,parallelExecution:!1,recordWorldState:!0}}),await this.executor.initialize()}return this.executor}resetInstanceCache(){this.planner=null,this.executor=null}async execute(e,t){try{let r=await(await this.getPlanner()).getPlan(e.planId);if(!r)return{success:!1,error:`Plan not found: ${e.planId}. Create a plan first using goap_plan.`};if(e.dryRun)return this.markAsRealData(),{success:!0,data:{planId:r.id,mode:"dry-run",status:"completed",stepsCompleted:r.actions.length,stepsFailed:0,totalDurationMs:r.estimatedDurationMs,steps:r.actions.map((a,o)=>({action:a.name,status:"would-execute",retries:0,durationMs:a.estimatedDurationMs}))}};let i=await this.getExecutor();if(i.isExecuting())return{success:!1,error:"Another plan is currently executing. Wait for completion or cancel it."};let s=await i.execute(r,r.initialState);return this.markAsRealData(),{success:s.status==="completed",data:{planId:s.planId,mode:"execution",status:s.status,stepsCompleted:s.stepsCompleted,stepsFailed:s.stepsFailed,totalDurationMs:s.totalDurationMs,steps:s.steps.map(a=>({action:a.action.name,status:a.status,retries:a.retries,durationMs:a.durationMs,error:a.error})),error:s.error},error:s.status!=="completed"?s.error:void 0}}catch(n){return{success:!1,error:w(n)}}}};k();var et=class extends P{planner=null;executor=null;config={name:"qe/planning/goap_status",description:"Get GOAP system status: world state, available goals, actions, or plans. Use to understand current state and available planning options.",domain:"coordination",schema:this.buildSchema()};buildSchema(){return{type:"object",properties:{type:{type:"string",description:"What to get status of",enum:["world","goals","actions","plans","execution"]},filter:{type:"object",description:"Optional filters",properties:{category:{type:"string",description:"Filter actions by category (test, security, coverage, etc.)"},status:{type:"string",description:"Filter plans by status (pending, executing, completed, failed)"},limit:{type:"number",description:"Maximum number of results (default: 20)",default:20,minimum:1,maximum:100}}}},required:["type"]}}async getPlanner(){return this.planner||(this.planner=he(),await this.planner.initialize()),this.planner}async getExecutor(){if(!this.executor){let e=await this.getPlanner();this.executor=Ye(e),await this.executor.initialize()}return this.executor}resetInstanceCache(){this.planner=null,this.executor=null}async execute(e,t){try{switch(e.type){case"world":return this.getWorldState();case"goals":return this.getGoals();case"actions":return this.getActions(e.filter?.category,e.filter?.limit);case"plans":return this.getPlans(e.filter?.status,e.filter?.limit);case"execution":return this.getExecutionStatus();default:return{success:!1,error:`Unknown status type: ${e.type}`}}}catch(n){return{success:!1,error:w(n)}}}async getWorldState(){let e={...Ke};return this.markAsRealData(),{success:!0,data:{type:"world",data:{coverage:{line:e.coverage.line,branch:e.coverage.branch,function:e.coverage.function,measured:e.coverage.measured},quality:{testsPassing:e.quality.testsPassing,securityScore:e.quality.securityScore,performanceScore:e.quality.performanceScore},fleet:{activeAgents:e.fleet.activeAgents,maxAgents:e.fleet.maxAgents},resources:{timeRemaining:e.resources.timeRemaining,parallelSlots:e.resources.parallelSlots}}}}}async getGoals(){let t=await(await this.getPlanner()).getGoals();return this.markAsRealData(),{success:!0,data:{type:"goals",data:{goals:t.map(n=>({id:n.id,name:n.name,description:n.description,priority:n.priority,conditionCount:Object.keys(n.conditions).length})),count:t.length}}}}async getActions(e,t=50){let n=await this.getPlanner(),r=[],i=Xe(),s=e?i.filter(o=>o.category===e):i;r=s.slice(0,t).map((o,l)=>({id:`action-${l}`,name:o.name,category:o.category,agentType:o.agentType,cost:o.cost,successRate:o.successRate}));let a={};for(let o of i)a[o.category]=(a[o.category]||0)+1;return this.markAsRealData(),{success:!0,data:{type:"actions",data:{actions:r,count:s.length,byCategory:a}}}}async getPlans(e,t=20){let r=await(await this.getPlanner()).getPlanReuseStats();return this.markAsRealData(),{success:!0,data:{type:"plans",data:{plans:[],count:0,reuseStats:{totalPlans:r.totalPlans,reusedPlans:r.reusedPlans,reuseRate:r.reuseRate,avgSuccessRate:r.avgSuccessRate}}}}}async getExecutionStatus(){let t=(await this.getExecutor()).isExecuting();return this.markAsRealData(),{success:!0,data:{type:"execution",data:{isExecuting:t,message:t?"Plan execution in progress":"No active execution"}}}}};k();Ge();te();k();k();Ge();var tt={HEALTH:"qe/mincut/health",ANALYZE:"qe/mincut/analyze",STRENGTHEN:"qe/mincut/strengthen"};function yr(){return vn()}function qc(){return bn()}var gr=class extends P{config={name:tt.HEALTH,description:"Analyze swarm topology health using MinCut algorithms. Reports connectivity, weak points, and health trends.",domain:"coordination",schema:{type:"object",properties:{agents:{type:"array",description:"Agent vertices to add to the graph before analysis"},edges:{type:"array",description:"Edges to add between agents"},includeWeakVertices:{type:"boolean",description:"Include detailed weak vertex analysis",default:!0},includeHistory:{type:"boolean",description:"Include historical health data",default:!1}},additionalProperties:!0}};async execute(e,t){let n=yr(),r=qc(),i=ie();if(e.agents)for(let l of e.agents)n.hasVertex(l.id)||n.addVertex({id:l.id,type:"agent",domain:l.domain,weight:l.weight??1,createdAt:new Date});if(e.edges)for(let l of e.edges)n.hasVertex(l.source)&&n.hasVertex(l.target)&&(n.hasEdge(l.source,l.target)||n.addEdge({source:l.source,target:l.target,weight:l.weight??1,type:"coordination",bidirectional:!0}));let s=r.checkHealth(),a=e.includeWeakVertices!==!1?i.findWeakVertices(n):[],o={health:{status:s.status,minCutValue:s.minCutValue,healthyThreshold:s.healthyThreshold,warningThreshold:s.warningThreshold,weakVertexCount:s.weakVertexCount,trend:s.trend},topology:{vertexCount:n.vertexCount,edgeCount:n.edgeCount,isConnected:n.isConnected()}};return e.includeWeakVertices!==!1&&a.length>0&&(o.weakVertices=a.map(l=>({id:l.vertexId,domain:l.vertex?.domain,weightedDegree:l.weightedDegree,riskScore:l.riskScore,reason:l.reason}))),e.includeHistory&&(o.history=s.history.map(l=>({timestamp:l.timestamp,value:l.value}))),this.markAsRealData(),{success:!0,data:o,metadata:this.createMetadata(t.startTime,t.requestId)}}},hr=class extends P{config={name:tt.ANALYZE,description:"Deep analysis of swarm topology using MinCut algorithms. Identifies weak points, suggests improvements.",domain:"coordination",schema:{type:"object",properties:{weaknessThreshold:{type:"number",description:"Threshold for weak vertex detection"},includePartitioningPoints:{type:"boolean",description:"Include analysis of potential partitioning points",default:!1}},additionalProperties:!0}};async execute(e,t){let n=yr(),r=ie(),i=r.getMinCutValue(n),s=r.getMinDegreeVertex(n),a=r.findWeakVertices(n,e.weaknessThreshold),o=r.suggestEdgeAdditions(n,2),l={minCutValue:i,minDegreeVertex:s,weakVertices:a.map(c=>({id:c.vertexId,weightedDegree:c.weightedDegree,riskScore:c.riskScore,reason:c.reason,suggestions:c.suggestions.map(d=>({type:d.type,priority:d.priority,estimatedImprovement:d.estimatedImprovement}))})),suggestedEdges:o.map(c=>({source:c.source,target:c.target,weight:c.weight}))};return e.includePartitioningPoints&&(l.partitioningPoints=r.findPartitioningPoints(n)),this.markAsRealData(),{success:!0,data:l,metadata:this.createMetadata(t.startTime,t.requestId)}}},fr=class extends P{config={name:tt.STRENGTHEN,description:"Strengthen swarm topology by adding edges between weak and strong vertices.",domain:"coordination",schema:{type:"object",properties:{targetImprovement:{type:"number",description:"Target improvement in MinCut value",default:1},targetVertices:{type:"array",description:"Specific vertices to strengthen"},apply:{type:"boolean",description:"Apply changes (true) or simulate (false)",default:!1}},additionalProperties:!0}};async execute(e,t){let n=yr(),r=ie(),i=r.getMinCutValue(n),s=e.targetImprovement??1,a=r.suggestEdgeAdditions(n,s),o=[];if(e.apply)for(let c of a)n.addEdge({source:c.source,target:c.target,weight:c.weight,type:"coordination",bidirectional:!0}),o.push({type:"add_edge",source:c.source,target:c.target,weight:c.weight});else for(let c of a)o.push({type:"add_edge",source:c.source,target:c.target,weight:c.weight});let l=r.getMinCutValue(n);return this.markAsRealData(),{success:!0,data:{beforeMinCut:i,afterMinCut:e.apply?l:i+s,improvement:e.apply?l-i:s,actionsApplied:o,applied:e.apply??!1},metadata:this.createMetadata(t.startTime,t.requestId)}}},bs=[new gr,new hr,new fr];k();var vr=null,cn=null;async function nt(){return vr||cn||(cn=(async()=>{let u=Rt({embedding:{model:"all-MiniLM-L6-v2",cacheSize:1e3,normalize:!0,hyperbolic:!1,curvature:-1},autoInitialize:!1});return await u.initialize(),vr=u,console.error("[EmbeddingTool] ONNX adapter initialized"),u})(),cn)}var Ie=class extends P{config={name:"qe/embeddings/generate",description:"Generate a vector embedding for text using local ONNX model",domain:"learning-optimization",schema:{type:"object",properties:{text:{type:"string",description:"Text to generate embedding for",minLength:1,maxLength:1e4},hyperbolic:{type:"boolean",description:"Use hyperbolic space for hierarchical data",default:!1}},required:["text"]}};async execute(e,t){let n=performance.now();try{let r=await nt(),i=await r.generateEmbedding(e.text);e.hyperbolic&&(i=r.toHyperbolic(i));let s=performance.now()-n;return this.markAsRealData(),{success:!0,data:{embedding:Array.from(i.vector),dimension:i.dimensions,isHyperbolic:i.isHyperbolic,latencyMs:s,model:i.model}}}catch(r){return{success:!1,error:`Embedding generation failed: ${w(r)}`}}}},Oe=class extends P{config={name:"qe/embeddings/compare",description:"Compare semantic similarity between two texts",domain:"learning-optimization",schema:{type:"object",properties:{text1:{type:"string",description:"First text to compare",minLength:1},text2:{type:"string",description:"Second text to compare",minLength:1},metric:{type:"string",description:"Similarity metric",enum:["cosine","euclidean","poincare"],default:"cosine"}},required:["text1","text2"]}};async execute(e,t){let n=performance.now();try{let r=await nt(),i=e.metric||"cosine",s=i==="cosine"?"cosine":i==="euclidean"?"euclidean":"poincare",a=await r.compareSimilarity(e.text1,e.text2,s),o=performance.now()-n;return this.markAsRealData(),{success:!0,data:{similarity:a,metric:i,isSimilar:a>.7,latencyMs:o}}}catch(r){return{success:!1,error:`Similarity comparison failed: ${w(r)}`}}}},_e=class extends P{config={name:"qe/embeddings/search",description:"Search for semantically similar texts using vector search",domain:"learning-optimization",schema:{type:"object",properties:{query:{type:"string",description:"Query text to search for",minLength:1},namespace:{type:"string",description:"Namespace to search in",default:"default"},topK:{type:"number",description:"Number of results to return",minimum:1,maximum:100,default:10},threshold:{type:"number",description:"Minimum similarity threshold (0-1)",minimum:0,maximum:1,default:.5}},required:["query"]}};async execute(e,t){let n=performance.now();try{let i=await(await nt()).searchByText(e.query,{metric:"cosine",topK:e.topK??10,threshold:e.threshold??.5,namespace:e.namespace}),s=performance.now()-n;return this.markAsRealData(),{success:!0,data:{results:i.map(a=>({text:a.text,score:a.score,metadata:a.metadata})),totalFound:i.length,latencyMs:s}}}catch(r){return{success:!1,error:`Search failed: ${w(r)}`}}}},Fe=class extends P{config={name:"qe/embeddings/store",description:"Store text with its embedding for later retrieval",domain:"learning-optimization",schema:{type:"object",properties:{text:{type:"string",description:"Text to store",minLength:1},id:{type:"string",description:"Optional ID for the stored embedding"},namespace:{type:"string",description:"Namespace for organization",default:"default"},metadata:{type:"object",description:"Additional metadata to store"}},required:["text"]}};async execute(e,t){let n=performance.now();try{let r=await nt(),i=e.namespace||"default",s=await r.generateAndStore(e.text,{id:e.id,namespace:i,customData:e.metadata}),a=performance.now()-n;return this.markAsRealData(),{success:!0,data:{id:s.id,namespace:s.namespace||i,latencyMs:a}}}catch(r){return{success:!1,error:`Store failed: ${w(r)}`}}}},Le=class extends P{config={name:"qe/embeddings/stats",description:"Get ONNX embedding system statistics",domain:"learning-optimization",schema:{type:"object",properties:{}}};async execute(e,t){try{let n=await nt(),r=n.getStats(),i=await n.getHealth(),s=r.cacheHits+r.cacheMisses,a=s>0?r.cacheHits/s:0;return this.markAsRealData(),{success:!0,data:{totalGenerated:r.totalGenerated,vectorsStored:r.vectorsStored,cache:{hits:r.cacheHits,misses:r.cacheMisses,hitRate:a},model:{name:r.currentModel,dimension:r.currentModel==="all-MiniLM-L6-v2"?384:768},healthy:i.available}}}catch(n){return{success:!1,error:`Stats failed: ${w(n)}`}}}},Gc=new Ie,$c=new Oe,zc=new _e,Bc=new Fe,jc=new Le;k();var Uc={type:"object",properties:{nodes:{type:"array",description:"Array of nodes to check for coherence. Each node must have an id and embedding vector."},energyThreshold:{type:"number",description:"Custom energy threshold for contradiction detection (default: 0.4)",minimum:0,maximum:1}},required:["nodes"]},rt=class extends P{config={name:"qe/coherence/check",description:"Check mathematical coherence of beliefs/facts using Prime Radiant sheaf cohomology. Detects contradictions and computes coherence energy for multi-agent coordination.",domain:"learning-optimization",schema:Uc,streaming:!1,timeout:3e4};coherenceService=null;async getService(){return this.coherenceService||(this.coherenceService=await se(ae)),this.coherenceService}resetInstanceCache(){this.coherenceService&&(this.coherenceService.dispose(),this.coherenceService=null)}async execute(e,t){let n=Date.now(),{nodes:r,energyThreshold:i=.4}=e;if(!r||r.length===0)return{success:!1,error:"At least one node is required for coherence check"};for(let s of r)if(!s.embedding||!Array.isArray(s.embedding))return{success:!1,error:`Node ${s.id} has invalid embedding - must be an array of numbers`};try{let s=await this.getService(),a=r.map(m=>({id:m.id,embedding:m.embedding,weight:m.weight??1,metadata:m.metadata})),o=await s.checkCoherence(a),l=[...o.recommendations,...this.generateAdditionalRecommendations(o,i)],c=o.contradictions.map(m=>({nodeIds:m.nodeIds,severity:String(m.severity),description:m.description||`Contradiction between nodes ${m.nodeIds[0]} and ${m.nodeIds[1]}`})),d=Date.now()-n;return this.markAsRealData(),{success:!0,data:{isCoherent:o.isCoherent,energy:o.energy,lane:o.lane,contradictions:c,recommendations:l,nodeCount:r.length,executionTimeMs:d,usedFallback:o.usedFallback}}}catch(s){return s instanceof Error&&s.message.includes("WASM")?(this.markAsDemoData(t,"WASM module unavailable"),{success:!0,data:{isCoherent:!0,energy:.1,lane:"reflex",contradictions:[],recommendations:["WASM module unavailable - coherence check running in fallback mode","Install prime-radiant-advanced-wasm for full coherence verification"],nodeCount:r.length,executionTimeMs:Date.now()-n,usedFallback:!0}}):{success:!1,error:w(s)}}}generateAdditionalRecommendations(e,t){let n=[];switch(e.energy>t&&n.push(`High coherence energy (${e.energy.toFixed(3)}) detected - review contradicting beliefs`),e.lane){case"reflex":n.push("Low energy - safe for immediate execution");break;case"retrieval":n.push("Moderate energy - consider fetching additional context");break;case"heavy":n.push("High energy - deep analysis recommended");break;case"human":n.push("Critical energy - escalate to Queen coordinator");break}return n}};wr();k();var v0=dt.create("qe-unified-memory");var Hc={"test-suites":{dimensions:oe.DIMENSIONS,M:8,efConstruction:100,efSearch:50,metric:"cosine",namespace:"test-suites-hnsw",maxElements:1e5},coverage:{dimensions:oe.DIMENSIONS,M:16,efConstruction:200,efSearch:100,metric:"cosine",namespace:"coverage-hnsw",maxElements:1e5},defects:{dimensions:oe.DIMENSIONS,M:32,efConstruction:400,efSearch:200,metric:"cosine",namespace:"defects-hnsw",maxElements:1e5},quality:{dimensions:oe.DIMENSIONS,M:16,efConstruction:200,efSearch:100,metric:"cosine",namespace:"quality-hnsw",maxElements:1e5},learning:{dimensions:oe.DIMENSIONS,M:24,efConstruction:300,efSearch:150,metric:"cosine",namespace:"learning-hnsw",maxElements:1e5},coordination:{dimensions:oe.DIMENSIONS,M:8,efConstruction:100,efSearch:50,metric:"cosine",namespace:"coordination-hnsw",maxElements:5e4}},Vc={enableHNSW:{"test-suites":!0,coverage:!0,defects:!0,quality:!0,learning:!0,coordination:!0},defaultNamespace:"qe-unified",enableCrossDomainSearch:!0,embeddingDimension:oe.DIMENSIONS};wr();k();import{randomUUID as Qc}from"crypto";var br=dt.create("MemoryAuditor"),Cr={batchSize:50,energyThreshold:.4,hotspotThreshold:.6,maxRecommendations:10},ln=class{constructor(e,t,n=Cr){this.coherenceService=e;this.eventBus=t;this.config=n}coherenceService;eventBus;config;isAuditing=!1;async auditPatterns(e){let t=Date.now();await this.emitEvent("memory:audit_started",{totalPatterns:e.length,timestamp:new Date});try{let n=this.groupByDomain(e),r=[],i=0,s=0;for(let[g,p]of Object.entries(n)){if(p.length<2)continue;let h=this.patternsToNodes(p),f=await this.coherenceService.checkCoherence(h);s+=f.energy,i+=f.contradictions.length,f.energy>this.config.hotspotThreshold&&r.push({domain:g,patternIds:p.map(v=>v.id),energy:f.energy,description:this.describeHotspot(f,g)})}let a=Object.keys(n).length,o=a>0?s/a:0,l=await this.identifyHotspots(e),c=await this.generateRecommendations(l,e),d=Date.now()-t,m={totalPatterns:e.length,scannedPatterns:e.length,contradictionCount:i,globalEnergy:o,hotspots:l,recommendations:c,duration:d,timestamp:new Date};return await this.emitEvent("memory:audit_completed",{result:m,timestamp:new Date}),m}catch(n){try{await this.emitEvent("memory:audit_failed",{error:w(n),timestamp:new Date})}catch(r){br.warn("Failed to emit audit_failed event",{error:w(r)})}throw n}}async identifyHotspots(e){let t=[],n=this.groupByDomain(e);for(let[r,i]of Object.entries(n)){if(i.length<2)continue;let s=this.patternsToNodes(i),a=await this.coherenceService.checkCoherence(s);a.energy>this.config.hotspotThreshold&&t.push({domain:r,patternIds:i.map(o=>o.id),energy:a.energy,description:this.describeHotspot(a,r)})}return t}async generateRecommendations(e,t){let n=[],r=new Map(t.map(i=>[i.id,i]));for(let i of e){let s=i.patternIds.map(c=>r.get(c)).filter(c=>c!==void 0),a=this.findDuplicates(s);a.length>0&&n.push({type:"merge",patternIds:a,reason:`Detected ${a.length} similar patterns in ${i.domain} domain`,priority:"high"});let o=this.findOutdated(s);o.length>0&&n.push({type:"remove",patternIds:o,reason:`Found ${o.length} outdated patterns with low usage/success`,priority:"medium"}),i.energy>.7&&n.push({type:"review",patternIds:i.patternIds,reason:`Critical coherence energy (${i.energy.toFixed(2)}) in ${i.domain}`,priority:"high"});let l=this.findBroadPatterns(s);l.length>0&&n.push({type:"split",patternIds:l,reason:`Found ${l.length} overly generic patterns that should be specialized`,priority:"low"})}return n.sort((i,s)=>this.priorityValue(s.priority)-this.priorityValue(i.priority)).slice(0,this.config.maxRecommendations)}async runBackgroundAudit(e){if(this.isAuditing){br.warn("Audit already in progress, skipping");return}this.isAuditing=!0;try{await this.emitEvent("memory:audit_progress",{status:"fetching_patterns",timestamp:new Date});let t=await e();await this.emitEvent("memory:audit_progress",{status:"analyzing_coherence",totalPatterns:t.length,timestamp:new Date});let n=await this.auditPatterns(t);await this.emitEvent("memory:audit_progress",{status:"completed",result:n,timestamp:new Date})}catch(t){await this.emitEvent("memory:audit_progress",{status:"failed",error:w(t),timestamp:new Date})}finally{this.isAuditing=!1}}groupByDomain(e){let t={};for(let n of e){let r=n.qeDomain;t[r]||(t[r]=[]),t[r].push(n)}return t}patternsToNodes(e){return e.map(t=>({id:t.id,embedding:t.embedding||this.createFallbackEmbedding(t),weight:t.qualityScore,metadata:{name:t.name,description:t.description,domain:t.qeDomain,confidence:t.confidence,usageCount:t.usageCount,successRate:t.successRate}}))}createFallbackEmbedding(e){let t=`${e.name} ${e.description}`,n=[];for(let r=0;r<64;r++){let i=t.charCodeAt(r%t.length);n.push(i/255*2-1)}return n}describeHotspot(e,t){let n=e.energy.toFixed(2),r=e.contradictions.length;return r>0?`${t} has ${r} contradiction(s) with energy ${n}`:`${t} has high coherence energy (${n}) indicating potential inconsistencies`}findDuplicates(e){let t=[],n=new Map;for(let r of e){let i=this.normalizeText(`${r.name} ${r.description}`);n.has(i)||n.set(i,[]),n.get(i).push(r.id)}for(let[r,i]of n)i.length>1&&t.push(...i.slice(1));return t}findOutdated(e){return e.filter(t=>t.usageCount<5&&t.successRate<.5).map(t=>t.id)}findBroadPatterns(e){return e.filter(t=>{let n=/generic|general|common|basic/i.test(t.name),r=t.context?.tags,i=!r||r.length<2;return n||i}).map(t=>t.id)}normalizeText(e){return e.toLowerCase().replace(/[^a-z0-9\s]/g,"").replace(/\s+/g," ").trim()}priorityValue(e){switch(e){case"high":return 3;case"medium":return 2;case"low":return 1;default:return 0}}async emitEvent(e,t){if(this.eventBus)try{await this.eventBus.publish({id:`memory-audit-${Date.now()}-${Qc().split("-")[0]}`,type:e,source:"learning-optimization",timestamp:new Date,payload:t})}catch(n){br.warn("Failed to emit event",{eventType:e,error:w(n)})}}};function Tr(u,e,t){return new ln(u,e,{...Cr,...t})}k();var Wc={type:"object",properties:{namespace:{type:"string",description:"Namespace to audit (default: qe-patterns)",default:"qe-patterns"},maxPatterns:{type:"number",description:"Maximum patterns to scan (default: 1000)",default:1e3,minimum:1,maximum:1e4},energyThreshold:{type:"number",description:"Energy threshold for flagging issues (default: 0.4)",default:.4,minimum:0,maximum:1},includeDetails:{type:"boolean",description:"Include detailed pattern information in results",default:!1}},required:[]},it=class extends P{config={name:"qe/coherence/audit",description:"Audit QE memory for contradictions and coherence issues. Scans patterns, detects hotspots, and generates remediation recommendations.",domain:"learning-optimization",schema:Wc,streaming:!1,timeout:6e4};coherenceService=null;auditor=null;async getService(){return this.coherenceService||(this.coherenceService=await se(ae)),this.coherenceService}resetInstanceCache(){this.coherenceService&&(this.coherenceService.dispose(),this.coherenceService=null),this.auditor=null}async execute(e,t){let{namespace:n="qe-patterns",maxPatterns:r=1e3,energyThreshold:i=.4}=e;try{let s=await this.getService();this.auditor||(this.auditor=Tr(s,void 0,{energyThreshold:i,hotspotThreshold:i+.2,maxRecommendations:10}));let a=await F(),o=yn(a,{namespace:n,embeddingDimension:384});await o.initialize();let l=await o.search("",{limit:r,useVectorSearch:!1}),c=l.success?l.value.map(g=>g.pattern):[],d;c.length>0?d=await this.auditor.auditPatterns(c):d={totalPatterns:0,scannedPatterns:0,contradictionCount:0,globalEnergy:0,hotspots:[],recommendations:[],duration:0,timestamp:new Date};let m=this.calculateHealthScore(d);return this.markAsRealData(),{success:!0,data:{totalPatterns:d.totalPatterns,scannedPatterns:d.scannedPatterns,contradictionCount:d.contradictionCount,globalEnergy:d.globalEnergy,hotspots:d.hotspots.map(g=>({domain:g.domain,patternIds:g.patternIds,energy:g.energy,description:g.description})),recommendations:d.recommendations.map(g=>({type:g.type,patternIds:g.patternIds,reason:g.reason,priority:g.priority})),durationMs:d.duration,timestamp:d.timestamp.toISOString(),healthScore:m}}}catch(s){return s instanceof Error&&s.message.includes("WASM")?(this.markAsDemoData(t,"WASM module unavailable"),{success:!0,data:{totalPatterns:0,scannedPatterns:0,contradictionCount:0,globalEnergy:0,hotspots:[],recommendations:[{type:"review",patternIds:[],reason:"WASM module unavailable - install prime-radiant-advanced-wasm for full audit",priority:"medium"}],durationMs:0,timestamp:new Date().toISOString(),healthScore:100}}):{success:!1,error:w(s)}}}calculateHealthScore(e){let t=100;t-=Math.min(30,e.contradictionCount*5),t-=Math.min(30,e.globalEnergy*50),t-=Math.min(20,e.hotspots.length*5);let n=e.recommendations.filter(r=>r.priority==="high").length;return t-=Math.min(20,n*5),Math.max(0,Math.round(t))}};k();var Kc={type:"object",properties:{votes:{type:"array",description:"Array of agent votes to verify for consensus"},confidenceThreshold:{type:"number",description:"Minimum confidence threshold (0-1, default: 0.5)",default:.5,minimum:0,maximum:1}},required:["votes"]},st=class extends P{config={name:"qe/coherence/consensus",description:"Verify multi-agent consensus mathematically using spectral analysis. Detects false consensus where agents appear to agree but have divergent beliefs.",domain:"learning-optimization",schema:Kc,streaming:!1,timeout:3e4};coherenceService=null;async getService(){return this.coherenceService||(this.coherenceService=await se(ae)),this.coherenceService}resetInstanceCache(){this.coherenceService&&(this.coherenceService.dispose(),this.coherenceService=null)}async execute(e,t){let n=Date.now(),{votes:r,confidenceThreshold:i=.5}=e;if(!r||r.length===0)return{success:!1,error:"At least one vote is required for consensus verification"};if(r.length<2)return{success:!1,error:"At least two votes are required to verify consensus"};try{let s=await this.getService(),a=r.map(m=>({agentId:m.agentId,agentType:m.agentType||"worker",verdict:m.verdict,confidence:m.confidence,reasoning:m.reasoning,timestamp:new Date})),o=await s.verifyConsensus(a),l=o.recommendation,c=r.reduce((m,g)=>m+g.confidence,0)/r.length;c<i&&(l=`Low average confidence (${(c*100).toFixed(1)}%) - consider gathering more evidence. `+l);let d=Date.now()-n;return this.markAsRealData(),{success:!0,data:{isValid:o.isValid,isFalseConsensus:o.isFalseConsensus,confidence:o.confidence,fiedlerValue:o.fiedlerValue,collapseRisk:o.collapseRisk,recommendation:l,usedFallback:o.usedFallback,executionTimeMs:d}}}catch(s){if(s instanceof Error&&s.message.includes("WASM")){let a=this.simpleMajorityAnalysis(r);return this.markAsDemoData(t,"WASM module unavailable"),{success:!0,data:{...a,recommendation:"Running in fallback mode (simple analysis). Install prime-radiant-advanced-wasm for spectral consensus analysis.",usedFallback:!0,executionTimeMs:Date.now()-n}}}return{success:!1,error:w(s)}}}simpleMajorityAnalysis(e){let t=new Map;for(let s of e){let a=String(s.verdict);t.set(a,(t.get(a)||0)+1)}let n=0;for(let s of t.values())s>n&&(n=s);let r=n/e.length,i=e.reduce((s,a)=>s+a.confidence,0)/e.length;return{isValid:r>=.5&&i>=.5,isFalseConsensus:!1,confidence:i,fiedlerValue:0,collapseRisk:1-r}}};k();var Xc={type:"object",properties:{swarmState:{type:"object",description:"Current state of the swarm including agents and task info"},riskThreshold:{type:"number",description:"Risk threshold for warning (0-1, default: 0.5)",default:.5,minimum:0,maximum:1}},required:["swarmState"]},at=class extends P{config={name:"qe/coherence/collapse",description:"Predict swarm collapse risk using spectral analysis. Identifies vulnerable vertices and provides mitigation recommendations.",domain:"learning-optimization",schema:Xc,streaming:!1,timeout:3e4};coherenceService=null;async getService(){return this.coherenceService||(this.coherenceService=await se(ae)),this.coherenceService}resetInstanceCache(){this.coherenceService&&(this.coherenceService.dispose(),this.coherenceService=null)}async execute(e,t){let n=Date.now(),{swarmState:r,riskThreshold:i=.5}=e;if(!r)return{success:!1,error:"swarmState is required"};if(!r.agents||r.agents.length<1)return{success:!1,error:"At least one agent is required in swarmState"};try{let s=await this.getService(),a={agents:r.agents.map(p=>({agentId:p.agentId,agentType:p.agentType||"worker",health:Number.isFinite(p.health)?p.health:1,beliefs:[],lastActivity:new Date,errorCount:p.errorCount??0,successRate:Number.isFinite(p.successRate)?p.successRate:1})),activeTasks:Number.isFinite(r.activeTasks)?r.activeTasks:0,pendingTasks:Number.isFinite(r.pendingTasks)?r.pendingTasks:0,errorRate:Number.isFinite(r.errorRate)?r.errorRate:0,utilization:Number.isFinite(r.utilization)?r.utilization:0,timestamp:new Date},o=await s.predictCollapse(a),l=Number.isFinite(o.risk)?o.risk:0,c=this.categorizeRisk(l),d=[...o.recommendations,...this.generateAdditionalRecommendations(o,r)],m=Date.now()-n;this.markAsRealData();let g=c==="high"||c==="critical"||c==="medium"&&l>=i;return{success:!0,data:{risk:l,isAtRisk:g,riskLevel:c,fiedlerValue:o.fiedlerValue,collapseImminent:o.collapseImminent,weakVertices:o.weakVertices,recommendations:d,executionTimeMs:m,usedFallback:o.usedFallback}}}catch(s){if(s instanceof Error&&s.message.includes("WASM")){let a=this.heuristicAnalysis(r,i);return this.markAsDemoData(t,"WASM module unavailable"),{success:!0,data:{...a,recommendations:["Running in fallback mode (heuristic analysis)","Install prime-radiant-advanced-wasm for spectral collapse prediction",...a.recommendations],usedFallback:!0,executionTimeMs:Date.now()-n}}}return{success:!1,error:w(s)}}}categorizeRisk(e){return!Number.isFinite(e)||e<.25?"low":e<.5?"medium":e<.75?"high":"critical"}generateAdditionalRecommendations(e,t){let n=[];t.errorRate>.1&&n.push(`High system error rate (${(t.errorRate*100).toFixed(1)}%) - investigate root causes`),t.utilization>.85&&n.push(`High resource utilization (${(t.utilization*100).toFixed(1)}%) - consider scaling`),t.pendingTasks>t.activeTasks*2&&n.push(`Large task backlog (${t.pendingTasks} pending) - may need more agents`);let r=t.agents.filter(i=>i.health<.5);return r.length>0&&n.push(`${r.length} agent(s) with low health - consider replacement`),e.risk>=.75&&n.unshift("\u26A0\uFE0F CRITICAL: Immediate action required to prevent collapse"),n}heuristicAnalysis(e,t){let n=0,r=[],i=[],s=Number.isFinite(e.errorRate)?e.errorRate:0,a=Number.isFinite(e.utilization)?e.utilization:0,o=Number.isFinite(e.pendingTasks)?e.pendingTasks:0,l=Number.isFinite(e.activeTasks)?e.activeTasks:0,c=e.agents.map(h=>Number.isFinite(h.health)?h.health:1),d=c.length>0?c.reduce((h,f)=>h+f,0)/c.length:1;n+=(1-d)*.3,n+=Math.min(.25,s*2.5),a>.7&&(n+=(a-.7)*.5);let m=o/Math.max(1,l);m>1&&(n+=Math.min(.2,(m-1)*.1)),e.agents.forEach((h,f)=>{(c[f]<.5||(h.errorCount??0)>5)&&i.push(h.agentId)}),n=Math.min(1,n),n>=t&&(r.push("Consider reducing task load"),r.push("Monitor agent health closely")),i.length>0&&r.push(`Reinforce weak agents: ${i.join(", ")}`),n<.25&&r.push("Swarm appears stable - continue normal operations");let g=this.categorizeRisk(n),p=g==="high"||g==="critical"||g==="medium"&&n>=t;return{risk:n,isAtRisk:p,riskLevel:g,fiedlerValue:0,collapseImminent:n>=.75,weakVertices:i,recommendations:r}}};var Cs=[new rt,new it,new st,new at],Ts={COHERENCE_CHECK:"qe/coherence/check",COHERENCE_AUDIT:"qe/coherence/audit",COHERENCE_CONSENSUS:"qe/coherence/consensus",COHERENCE_COLLAPSE:"qe/coherence/collapse"};var ot=(T=>(T.PROBLEM_UNDERSTANDING="H1.1-problem-understanding",T.RULE_OF_THREE="H1.2-rule-of-three",T.PROBLEM_COMPLEXITY="H1.3-problem-complexity",T.USER_NEEDS_IDENTIFICATION="H2.1-user-needs-identification",T.USER_NEEDS_SUITABILITY="H2.2-user-needs-suitability",T.USER_NEEDS_VALIDATION="H2.3-user-needs-validation",T.BUSINESS_NEEDS_IDENTIFICATION="H3.1-business-needs-identification",T.USER_VS_BUSINESS_BALANCE="H3.2-user-vs-business-balance",T.KPI_IMPACT_ANALYSIS="H3.3-kpi-impact-analysis",T.ORACLE_PROBLEM_DETECTION="H4.1-oracle-problem-detection",T.WHAT_MUST_NOT_CHANGE="H4.2-what-must-not-change",T.SUPPORTING_DATA_ANALYSIS="H4.3-supporting-data-analysis",T.GUI_FLOW_IMPACT="H5.1-gui-flow-impact",T.USER_FEELINGS_IMPACT="H5.2-user-feelings-impact",T.CROSS_FUNCTIONAL_IMPACT="H5.3-cross-functional-impact",T.DATA_DEPENDENT_IMPACT="H5.4-data-dependent-impact",T.COMPETITIVE_ANALYSIS="H6.1-competitive-analysis",T.DOMAIN_INSPIRATION="H6.2-domain-inspiration",T.INNOVATIVE_SOLUTIONS="H6.3-innovative-solutions",T.EXACTNESS_AND_CLARITY="H7.1-exactness-and-clarity",T.INTUITIVE_DESIGN="H7.2-intuitive-design",T.COUNTER_INTUITIVE_DESIGN="H7.3-counter-intuitive-design",T.CONSISTENCY_ANALYSIS="H7.4-consistency-analysis",T))(ot||{});var un=class{enabledHeuristics;minConfidence;constructor(e={}){this.enabledHeuristics=e.enabledHeuristics||Object.values(ot),this.minConfidence=e.minConfidence||.7}async applyAll(e,t,n,r){let i=[];for(let s of this.enabledHeuristics){let a=await this.apply(s,e,t,n,r);i.push(a)}return i}async apply(e,t,n,r,i){let s=this.getHeuristicCategory(e),a=[],o=[],l=[],c=75;switch(e){case"H7.4-consistency-analysis":t.domMetrics?.semanticStructure?.hasHeader&&t.domMetrics?.semanticStructure?.hasFooter?(c=85,a.push("Consistent page structure with header and footer")):(c=60,l.push("Add consistent header/footer structure"));break;case"H7.2-intuitive-design":let d=t.domMetrics?.semanticStructure?.hasNav,m=t.accessibility?.focusableElementsCount||0;d&&m>10?(c=82,a.push("Intuitive navigation and interaction design")):(c=55,o.push({description:"Navigation or interaction patterns unclear",severity:"medium"}));break;case"H7.1-exactness-and-clarity":c=70;let g=t.domMetrics?.semanticStructure,p=[g?.hasHeader,g?.hasMain,g?.hasNav,g?.hasFooter].filter(Boolean).length;c=50+p*10,p>=3?a.push("Strong visual hierarchy with semantic HTML elements"):p>=2?(a.push("Moderate visual hierarchy - some semantic elements present"),l.push("Add more semantic HTML5 elements for clarity")):(o.push({description:"Weak visual hierarchy - missing semantic structure",severity:"high"}),l.push("Implement semantic HTML5: header, nav, main, footer")),t.metadata?.description&&t.metadata.description.length>20&&(c+=10,a.push("Page has descriptive metadata"));break;case"H7.3-counter-intuitive-design":c=85;let h=!t.domMetrics?.semanticStructure?.hasNav&&(t.domMetrics?.interactiveElements||0)>10,f=!t.domMetrics?.semanticStructure?.hasHeader&&!t.domMetrics?.semanticStructure?.hasFooter;h&&(c=45,o.push({description:"Navigation structure may be counter-intuitive",severity:"high"}),l.push("Add semantic navigation elements")),f&&(c-=15,o.push({description:"Page structure lacks expected header/footer",severity:"medium"})),c>75&&a.push("No counter-intuitive design patterns detected");break;case"H5.2-user-feelings-impact":let v=t.accessibility?.altTextsCoverage||0,y=t.performance?.loadTime||0,C=t.accessibility?.ariaLabelsCount||0,b=t.accessibility?.focusableElementsCount||0;c=60,v>=90?(c+=20,a.push("Excellent accessibility (90%+ alt coverage) creates inclusive, positive experience")):v>=70?(c+=12,a.push("Good accessibility creates generally positive user feelings")):v<50&&(c-=15,o.push({description:"Poor accessibility (<50% alt coverage) frustrates users with disabilities",severity:"high"}),l.push("Improve alt text coverage to at least 80% for better accessibility")),C>5&&(c+=8,a.push("Strong ARIA labeling enhances screen reader experience")),y<1500?(c+=15,a.push("Very fast load time (<1.5s) delights users")):y<2500?(c+=8,a.push("Fast load time enhances user satisfaction")):y>4e3?(c-=20,o.push({description:"Very slow load time (>4s) causes significant frustration",severity:"critical"}),l.push("Optimize page load time - target under 2.5 seconds")):y>3e3&&(c-=12,o.push({description:"Slow load time causes user frustration",severity:"high"})),t.errorIndicators?.hasErrorMessages&&(c-=12,o.push({description:"Visible errors reduce user confidence and satisfaction",severity:"high"}),l.push("Review and fix visible error messages")),b>20?(c+=5,a.push("Rich interactive elements provide user control and engagement")):b<5&&(c-=8,o.push({description:"Limited interactivity may feel restrictive",severity:"medium"})),c=Math.max(20,Math.min(100,c));break;case"H5.1-gui-flow-impact":let E=t.domMetrics?.interactiveElements||0,S=t.domMetrics?.forms||0;E>20&&(c=75,a.push(`${E} interactive elements provide user control`)),S>0&&(a.push(`${S} forms impact user input flows`),c=Math.min(100,c+10)),E===0&&(c=30,o.push({description:"Limited user interaction capability",severity:"high"}));break;case"H5.3-cross-functional-impact":c=70,t.accessibility&&(t.accessibility.altTextsCoverage||0)<100&&a.push("Content team needed for alt text creation"),t.performance&&(t.performance.loadTime||0)>2e3&&a.push("Engineering team needed for performance optimization"),n.complexity==="complex"&&a.push("QA team needed for comprehensive testing"),c=70+a.length*5;break;case"H5.4-data-dependent-impact":t.domMetrics?.forms&&t.domMetrics.forms>0?(c=75,a.push(`${t.domMetrics.forms} forms depend on backend data processing`)):(c=50,a.push("Limited data-dependent features"));break;case"H1.1-problem-understanding":c=n.clarityScore,n.clarityScore>80?a.push("Problem is well-defined"):o.push({description:"Problem clarity needs improvement",severity:"medium"}),a.push(...n.breakdown);break;case"H1.2-rule-of-three":c=n.potentialFailures.length>=3?85:60,a.push(`${n.potentialFailures.length} potential failure modes identified`),n.potentialFailures.length<3&&l.push("Identify at least 3 potential failure modes (Rule of Three)");break;case"H1.3-problem-complexity":c=n.complexity==="simple"?90:n.complexity==="moderate"?75:60,a.push(`Problem complexity: ${n.complexity}`);break;case"H2.1-user-needs-identification":c=r.alignmentScore,a.push(`${r.needs.length} user needs identified`);let T=r.needs.filter(L=>L.priority==="must-have").length;a.push(`${T} must-have features`),r.challenges.length>0&&o.push({description:`${r.challenges.length} user need challenges found`,severity:"medium"});break;case"H2.2-user-needs-suitability":c=r.suitability==="excellent"?95:r.suitability==="good"?80:r.suitability==="adequate"?65:45,a.push(`User needs suitability: ${r.suitability}`);break;case"H2.3-user-needs-validation":let R=r.needs.filter(L=>L.addressed).length;c=r.needs.length>0?R/r.needs.length*100:50,a.push(`${R}/${r.needs.length} needs validated and addressed`);break;case"H3.1-business-needs-identification":c=i.alignmentScore,a.push(`Primary goal: ${i.primaryGoal}`),a.push(`${i.kpisAffected.length} KPIs affected`),a.push(`${i.crossTeamImpact.length} cross-team impacts`);break;case"H3.2-user-vs-business-balance":let D=100-Math.abs(r.alignmentScore-i.alignmentScore);c=D,D>80?a.push("Good balance between user and business needs"):(o.push({description:"Imbalance between user and business priorities",severity:"medium"}),l.push("Align user and business objectives more closely"));break;case"H3.3-kpi-impact-analysis":c=i.impactsKPIs?85:50,a.push(`KPIs impacted: ${i.kpisAffected.join(", ")}`),i.compromisesUX&&(o.push({description:"Business ease compromises user experience",severity:"high"}),c-=20);break;case"H4.1-oracle-problem-detection":c=75,a.push("Oracle problem detection capability active");break;case"H4.2-what-must-not-change":c=80,t.domMetrics?.semanticStructure?.hasMain&&a.push("Main content structure is immutable"),t.accessibility&&(t.accessibility.focusableElementsCount||0)>0&&a.push("Keyboard navigation support must be maintained");break;case"H4.3-supporting-data-analysis":c=75,(t.domMetrics?.forms||0)>0||(t.domMetrics?.interactiveElements||0)>20?(c=82,a.push("Sufficient data points for informed decision-making")):(c=60,o.push({description:"Limited data for comprehensive analysis",severity:"medium"}),l.push("Collect more user interaction data"));break;case"H6.1-competitive-analysis":c=70,a.push("Competitive analysis capability available"),t.domMetrics?.semanticStructure?.hasNav&&t.domMetrics?.interactiveElements&&t.domMetrics.interactiveElements>15?(c=78,a.push("Navigation and interaction patterns follow industry standards")):l.push("Compare interaction patterns with leading competitors");break;case"H6.2-domain-inspiration":c=72,t.accessibility&&(t.accessibility.ariaLabelsCount||0)>0?(c=80,a.push("Modern accessibility patterns show domain inspiration")):l.push("Research domain-specific design patterns and best practices");break;case"H6.3-innovative-solutions":c=65,(t.accessibility?.landmarkRoles||0)>3?(c=75,a.push("Advanced accessibility features show innovative thinking")):l.push("Explore innovative UX patterns to differentiate experience");break;default:s==="user-needs"?c=r.alignmentScore:s==="business-needs"?c=i.alignmentScore:s==="problem"&&(c=n.clarityScore);break}return{id:e,name:this.getHeuristicName(e),category:s,applied:!0,score:Math.min(100,Math.max(0,c)),findings:a,issues:o,recommendations:l}}getHeuristicCategory(e){return e.includes("problem")?"problem":e.includes("user-needs")||e.includes("user-vs")?"user-needs":e.includes("business")?"business-needs":e.includes("oracle")||e.includes("balance")||e.includes("what-must")||e.includes("supporting-data")?"balance":e.includes("impact")||e.includes("gui-flow")||e.includes("feelings")||e.includes("cross-functional")||e.includes("data-dependent")?"impact":e.includes("competitive")||e.includes("inspiration")||e.includes("innovative")?"creativity":"design"}getHeuristicName(e){return{"H1.1-problem-understanding":"Problem Understanding","H1.2-rule-of-three":"Rule of Three","H1.3-problem-complexity":"Problem Complexity","H2.1-user-needs-identification":"User Needs Identification","H2.2-user-needs-suitability":"User Needs Suitability","H2.3-user-needs-validation":"User Needs Validation","H3.1-business-needs-identification":"Business Needs Identification","H3.2-user-vs-business-balance":"User vs Business Balance","H3.3-kpi-impact-analysis":"KPI Impact Analysis","H4.1-oracle-problem-detection":"Oracle Problem Detection","H4.2-what-must-not-change":"What Must Not Change","H4.3-supporting-data-analysis":"Supporting Data Analysis","H5.1-gui-flow-impact":"GUI Flow Impact","H5.2-user-feelings-impact":"User Feelings Impact","H5.3-cross-functional-impact":"Cross-Functional Impact","H5.4-data-dependent-impact":"Data-Dependent Impact","H6.1-competitive-analysis":"Competitive Analysis","H6.2-domain-inspiration":"Domain Inspiration","H6.3-innovative-solutions":"Innovative Solutions","H7.1-exactness-and-clarity":"Exactness & Clarity","H7.2-intuitive-design":"Intuitive Design","H7.3-counter-intuitive-design":"Counter-Intuitive Design","H7.4-consistency-analysis":"Consistency Analysis"}[e]||e}};var dn=class{minSeverity;constructor(e="medium"){this.minSeverity=e}detect(e,t,n){let r=[];Math.abs(t.alignmentScore-n.alignmentScore)>20&&r.push({type:"user-vs-business",description:"Significant gap between user needs and business objectives",severity:"high",stakeholders:["Users","Business"],resolutionApproach:["Gather supporting data from both perspectives","Facilitate discussion between stakeholders","Find compromise solutions that address both needs"]}),(t.challenges.length>0||n.compromisesUX)&&r.push({type:"unclear-criteria",description:"Quality criteria unclear due to conflicting information",severity:"medium",missingInfo:t.challenges,resolutionApproach:["Collect missing information from stakeholders","Define clear acceptance criteria"]});let i=(e.title||"").toLowerCase(),s=(e.metadata?.description||"").toLowerCase();return(i.includes("hotel")||i.includes("booking")||i.includes("travel")||i.includes("shop")||i.includes("store")||s.includes("book"))&&(n.kpisAffected.some(a=>a.toLowerCase().includes("conversion")||a.toLowerCase().includes("engagement"))&&r.push({type:"user-vs-business",description:"Potential conflict between conversion optimization (business) and user experience quality (user trust)",severity:"medium",stakeholders:["Marketing","Product","Users"],resolutionApproach:["A/B test aggressive vs. subtle conversion tactics","Measure both conversion rate and user satisfaction metrics","Balance urgency messaging with transparent communication"]}),r.push({type:"unclear-criteria",description:"Unclear criteria for price display timing - when to show fees, taxes, and final price",severity:"medium",stakeholders:["Users","Legal","Business"],resolutionApproach:["Define regulatory compliance requirements for price display","Balance business desire for competitive base pricing vs user need for full price transparency","Establish clear standards for fee disclosure timing"]})),(i.includes("blog")||i.includes("article")||i.includes("news")||i.includes("magazine")||i.includes("testing"))&&r.push({type:"user-vs-business",description:"Content depth (user need) vs. publication frequency (business engagement goals) trade-off",severity:"low",stakeholders:["Readers","Content Team","Editorial"],resolutionApproach:["Define content quality standards and acceptance criteria","Balance editorial calendar with quality thresholds","Consider mix of in-depth and quick-read content formats"]}),(i.includes("health")||i.includes("medical")||i.includes("patient")||i.includes("care")||i.includes("nhs"))&&(r.push({type:"stakeholder-conflict",description:"Healthcare compliance requirements may conflict with streamlined user experience",severity:"medium",stakeholders:["Patients","Healthcare Providers","Compliance","Legal"],resolutionApproach:["Map regulatory requirements to UX touchpoints","Identify where compliance can be achieved without friction","Engage compliance team early in UX design reviews","Document consent and data handling requirements clearly"]}),e.accessibility&&(e.accessibility.altTextsCoverage||0)<80&&r.push({type:"technical-constraint",description:"Healthcare accessibility requirements not fully met - critical for patient inclusivity",severity:"high",stakeholders:["Patients","Accessibility Team","Legal"],resolutionApproach:["Prioritize WCAG 2.1 AA compliance for healthcare content","Ensure screen reader compatibility for medical information","Test with assistive technology users"]})),(i.includes("bank")||i.includes("finance")||i.includes("payment")||i.includes("money"))&&r.push({type:"stakeholder-conflict",description:"Security requirements vs user convenience - authentication friction vs fraud prevention",severity:"high",stakeholders:["Users","Security Team","Product","Compliance"],resolutionApproach:["Implement risk-based authentication to reduce friction for trusted sessions","Use biometrics where available for convenient yet secure access","A/B test authentication flows for security effectiveness and user completion rates"]}),((e.domMetrics?.totalElements||0)>500||(e.domMetrics?.interactiveElements||0)>50)&&r.push({type:"technical-constraint",description:"Platform technical limitations may restrict advanced UX features or accessibility enhancements",severity:"low",stakeholders:["Development","Product","Users"],resolutionApproach:["Evaluate platform capabilities and constraints","Prioritize features based on user impact vs. implementation complexity","Consider gradual enhancement approach"]}),e.performance&&(e.performance.loadTime||0)>3e3&&r.push({type:"technical-constraint",description:"Performance optimization needed but may require trade-offs with visual richness",severity:"medium",stakeholders:["Users","Development","Design"],resolutionApproach:["Profile and identify performance bottlenecks","Consider progressive loading for visual elements","Balance image quality with load time"]}),r.filter(a=>this.meetsMinimumSeverity(a.severity))}meetsMinimumSeverity(e){let t=["low","medium","high","critical"],n=t.indexOf(this.minSeverity);return t.indexOf(e)>=n}};var mn=class u{static LOAD_TIME_FEELINGS=[[4001,1/0,"Impatient - Very slow load time causes significant frustration"],[3001,4e3,"Impatient - Slow load time causes frustration"],[2001,3e3,"Mildly Annoyed - Noticeable load time"],[0,1499,"Delighted - Fast load time enhances experience"],[1500,1999,"Satisfied - Good load time meets expectations"]];static DOMAIN_REQUIREMENTS=[[["health","medical","care"],["Must comply with healthcare accessibility standards","Must protect patient data privacy"]],[["bank","finance","payment"],["Must maintain PCI DSS compliance for payment data","Must support secure authentication flows"]]];static VISIBLE_SCORE_ADJUSTMENTS=[[["Positive","Satisfied","Delighted"],20],[["Oriented"],10],[["Frustrated","Confused","Impatient"],-15],[["Disoriented"],-10]];analyze(e,t){let n=this.analyzeEndUserFlow(e),r=this.analyzeInternalFlow(e),i=this.analyzeUserFeelings(e),s=this.analyzePerformance(e),a=this.analyzeSecurity(e),o=this.analyzeImmutableRequirements(e,t),l=this.calculateVisibleScore(n,i),c=this.calculateInvisibleScore(s,a),d=Math.round((l+c)/2);return{visible:{guiFlow:{forEndUser:n,forInternalUser:r},userFeelings:i,score:l},invisible:{performance:s,security:a,score:c},immutableRequirements:o,overallImpactScore:d}}analyzeEndUserFlow(e){let t=[],n=e.domMetrics?.interactiveElements||0,r=e.domMetrics?.forms||0;return n>0&&t.push(`${n} interactive elements affect user journey`),r>0&&t.push(`${r} forms impact user input flows`),e.domMetrics?.semanticStructure?.hasNav&&t.push("Navigation structure enables exploration flow"),e.domMetrics?.semanticStructure?.hasMain&&t.push("Clear main content area guides user focus"),t}analyzeInternalFlow(e){let t=[];return(e.domMetrics?.forms||0)>0&&t.push("Form submissions create data processing workflows"),e.domMetrics?.semanticStructure?.hasAside&&t.push("Sidebar content may require separate management"),t}analyzeUserFeelings(e){let t=[],n=e.accessibility?.altTextsCoverage||0;n>80?t.push("Positive - Good accessibility creates inclusive experience"):n>=50?t.push("Neutral - Moderate accessibility; some users may struggle"):n<50&&t.push("Frustrated - Poor accessibility excludes some users");let r=e.performance?.loadTime||0;for(let[i,s,a]of u.LOAD_TIME_FEELINGS)if(r>=i&&r<=s){t.push(a);break}return e.errorIndicators?.hasErrorMessages&&t.push("Confused - Visible errors reduce confidence"),this.analyzeStructureFeelings(e,t),t}analyzeStructureFeelings(e,t){let n=e.domMetrics?.semanticStructure;if(!n)return;let r=[n.hasHeader,n.hasNav,n.hasMain,n.hasFooter].filter(Boolean).length;r>=3?t.push("Oriented - Clear page structure helps navigation"):r<2&&t.push("Disoriented - Unclear page structure may confuse users")}analyzePerformance(e){let t=[],n=e.performance?.loadTime||0;return n>2e3&&t.push(`Load time ${n}ms impacts user retention`),e.metadata?.viewport||t.push("Missing viewport tag affects mobile performance"),e.performance?.firstContentfulPaint&&e.performance.firstContentfulPaint>2500&&t.push(`First Contentful Paint ${e.performance.firstContentfulPaint}ms delays perceived readiness`),t}analyzeSecurity(e){let t=[];return(e.domMetrics?.forms||0)>0&&t.push("Form data handling requires secure transmission"),e.accessibility&&(e.accessibility.ariaLabelsCount||0)>0&&t.push("ARIA labels may expose internal element names - review for sensitive info"),t}analyzeImmutableRequirements(e,t){let n=[];e.domMetrics?.semanticStructure?.hasMain&&n.push("Must maintain main content accessibility"),e.accessibility&&(e.accessibility.focusableElementsCount||0)>0&&n.push("Must support keyboard navigation"),t.complexity==="complex"&&n.push("Must maintain system stability with complex interactions");let r=(e.title||"").toLowerCase();for(let[i,s]of u.DOMAIN_REQUIREMENTS)i.some(a=>r.includes(a))&&n.push(...s);return n}calculateVisibleScore(e,t){let n=50;e.length>0&&(n+=15);for(let[r,i]of u.VISIBLE_SCORE_ADJUSTMENTS)t.some(s=>r.some(a=>s.includes(a)))&&(n+=i);return Math.max(0,Math.min(100,n))}calculateInvisibleScore(e,t){let n=50;return e.length===0&&(n+=20),t.length===0&&(n+=10),e.length>2&&(n-=15),Math.max(0,Math.min(100,n))}};k();var Yc={type:"object",properties:{target:{type:"string",description:"Target URL or identifier to analyze"},context:{type:"object",description:"Pre-collected QX context (optional)"},mode:{type:"string",description:"Analysis mode: full, quick, or targeted",enum:["full","quick","targeted"],default:"full"},heuristics:{type:"array",description:"Specific heuristics to apply (default: all)"},minOracleSeverity:{type:"string",description:"Minimum oracle problem severity to report",enum:["low","medium","high","critical"],default:"medium"},includeCreativity:{type:"boolean",description:"Include creativity analysis from diverse domains",default:!0},includeDesign:{type:"boolean",description:"Include design quality analysis",default:!0}},required:["target"]},ct=class extends P{config={name:"qe/qx/analyze",description:"Comprehensive Quality Experience (QX) analysis combining QA and UX perspectives. Applies 23+ programmatic heuristics, detects oracle problems, and analyzes impacts. QX = Marriage between QA (Quality Advocacy) and UX (User Experience).",domain:"quality-assessment",schema:Yc,streaming:!0,timeout:18e4};async execute(e,t){let{target:n,context:r=this.createMinimalContext(n),mode:i="full",heuristics:s,minOracleSeverity:a="medium",includeCreativity:o=!0,includeDesign:l=!0}=e;try{this.emitStream(t,{status:"starting",message:`Starting QX analysis for: ${n}`,phase:"initialization"}),this.emitStream(t,{status:"analyzing",phase:"problem-analysis"});let c=this.analyzeProblem(r);if(this.isAborted(t))return{success:!1,error:"Operation aborted"};this.emitStream(t,{status:"analyzing",phase:"user-needs"});let d=this.analyzeUserNeeds(r,c);this.emitStream(t,{status:"analyzing",phase:"business-needs"});let m=this.analyzeBusinessNeeds(r,c);this.emitStream(t,{status:"analyzing",phase:"creativity"});let g=o?this.analyzeCreativity(r,c):this.createMinimalCreativityAnalysis();this.emitStream(t,{status:"analyzing",phase:"design"});let p=l?this.analyzeDesign(r):this.createMinimalDesignAnalysis();this.emitStream(t,{status:"analyzing",phase:"oracle-detection"});let f=new dn(a).detect(r,d,m);this.emitStream(t,{status:"analyzing",phase:"impact-analysis"});let y=new mn().analyze(r,c);this.emitStream(t,{status:"analyzing",phase:"heuristics",count:23});let b=await new un({enabledHeuristics:s||Object.values(ot)}).applyAll(r,c,d,m);this.emitStream(t,{status:"analyzing",phase:"recommendations"});let E=this.generateRecommendations(c,d,m,f,y,b),S=this.calculateOverallScore(c,d,m,g,p,y,b),T=this.scoreToGrade(S),R={overallScore:S,grade:T,timestamp:new Date().toISOString(),target:n,problemAnalysis:c,userNeeds:d,businessNeeds:m,creativityAnalysis:g,designAnalysis:p,oracleProblems:f,impactAnalysis:y,heuristics:b,recommendations:E,context:r};return this.emitStream(t,{status:"complete",score:S,grade:T,heuristicsApplied:b.length,oracleProblemsFound:f.length}),{success:!0,data:R,metadata:this.createMetadata(t.startTime,t.requestId)}}catch(c){return{success:!1,error:`QX analysis failed: ${w(c)}`}}}analyzeProblem(e){let t=e.title||"Untitled page",n=e.metadata?.description||"",r=e.errorIndicators?.hasErrorMessages||!1,i=`Evaluate quality experience of "${t}"`;n&&(i+=` - ${n.substring(0,100)}`);let s=e.domMetrics?.totalElements||0,a=e.domMetrics?.interactiveElements||0,o=e.domMetrics?.forms||0,l;s>500||a>50||o>3?l="complex":s>200||a>20||o>1?l="moderate":l="simple";let c=[];e.domMetrics?.semanticStructure?.hasNav&&c.push("Navigation structure"),o>0&&c.push(`Form interactions (${o} forms)`),a>0&&c.push(`User interactions (${a} elements)`),e.accessibility&&c.push("Accessibility compliance"),e.performance&&c.push("Performance metrics");let d=[],m=t.toLowerCase();for((m.includes("health")||m.includes("care")||m.includes("nhs"))&&(d.push({description:"Healthcare information may not be accessible to users with visual impairments",severity:"high",likelihood:"likely"}),d.push({description:"Patient journey complexity may cause confusion during registration or booking",severity:"medium",likelihood:"possible"}),d.push({description:"Emergency contact information may not be prominently visible",severity:"high",likelihood:"possible"})),e.domMetrics?.semanticStructure?.hasMain||d.push({description:"Missing main content landmark - users may struggle to find primary content",severity:"medium",likelihood:"likely"}),e.accessibility&&(e.accessibility.altTextsCoverage||0)<80&&d.push({description:"Poor image alt text coverage - screen reader users affected",severity:"high",likelihood:"very-likely"}),r&&d.push({description:"Visible error messages detected - potential usability issues",severity:"medium",likelihood:"likely"}),e.performance&&(e.performance.loadTime||0)>3e3&&d.push({description:"Slow load time - user frustration and abandonment risk",severity:"high",likelihood:"very-likely"});d.length<3;)l==="complex"?d.push({description:"Complex interaction flows may confuse first-time users",severity:"medium",likelihood:"possible"}):l==="moderate"?d.push({description:"Multiple interactive elements increase cognitive load",severity:"low",likelihood:"possible"}):d.push({description:"Limited interactivity may not meet user expectations",severity:"low",likelihood:"possible"});let g=50;return t&&t!=="Untitled page"&&(g+=15),n&&(g+=15),c.length>=3&&(g+=10),e.domMetrics?.semanticStructure?.hasMain&&(g+=10),g=Math.min(100,g),{problemStatement:i,complexity:l,breakdown:c,potentialFailures:d.slice(0,5),clarityScore:g}}analyzeUserNeeds(e,t){let n=[],r=[],i=e.domMetrics?.semanticStructure,s=e.accessibility,a=e.domMetrics?.interactiveElements||0,o=e.domMetrics?.forms||0;i?.hasNav?n.push({description:"Clear navigation to find content",priority:"must-have",addressed:!0}):(r.push("Missing navigation structure - users cannot easily explore site"),n.push({description:"Clear navigation to find content",priority:"must-have",addressed:!1})),a>0&&n.push({description:"Interactive elements for engagement",priority:"must-have",addressed:!0}),s&&(s.focusableElementsCount||0)>0?n.push({description:"Keyboard navigation support",priority:"must-have",addressed:!0}):(r.push("Limited keyboard navigation - inaccessible to some users"),n.push({description:"Keyboard navigation support",priority:"must-have",addressed:!1})),i?.hasHeader&&n.push({description:"Consistent page header for orientation",priority:"should-have",addressed:!0}),i?.hasFooter&&n.push({description:"Footer with supporting information",priority:"should-have",addressed:!0}),s&&(s.altTextsCoverage||0)>50?n.push({description:"Image descriptions for screen readers",priority:"should-have",addressed:!0}):s&&(s.altTextsCoverage||0)<50&&(r.push("Poor alt text coverage - images not accessible"),n.push({description:"Image descriptions for screen readers",priority:"should-have",addressed:!1})),e.performance&&(e.performance.loadTime||0)<3e3?n.push({description:"Fast page load time",priority:"should-have",addressed:!0}):e.performance&&(e.performance.loadTime||0)>=3e3&&(r.push("Slow load time - user frustration risk"),n.push({description:"Fast page load time",priority:"should-have",addressed:!1})),i?.hasAside&&n.push({description:"Supplementary content sections",priority:"nice-to-have",addressed:!0}),s&&(s.landmarkRoles||0)>3&&n.push({description:"Rich ARIA landmarks for navigation",priority:"nice-to-have",addressed:!0}),o>0&&n.push({description:"Form interactions for user input",priority:"nice-to-have",addressed:!0});let l=n.filter(m=>m.priority==="must-have"&&m.addressed).length,c;r.length===0&&l>=3?c="excellent":r.length<=1&&l>=2?c="good":r.length<=2&&l>=2?c="adequate":c="poor";let d=40;return d+=l*10,d+=n.filter(m=>m.priority==="should-have"&&m.addressed).length*5,d+=n.filter(m=>m.priority==="nice-to-have"&&m.addressed).length*2,d-=r.length*8,d=Math.max(0,Math.min(100,d)),{needs:n,suitability:c,challenges:r,alignmentScore:d}}analyzeBusinessNeeds(e,t){let n=e.domMetrics?.forms||0,r=e.domMetrics?.interactiveElements||0,i=e.performance,s=e.errorIndicators?.hasErrorMessages||!1,a,o=[];n>2?(a="business-ease",o=["Form completion rate","Lead generation","User sign-ups"]):r>30?(a="user-experience",o=["Time on site","Click-through rate","User engagement"]):(a="balanced",o=["Content consumption","Bounce rate","Page views"]);let l=(e.title||"").toLowerCase();(l.includes("health")||l.includes("care"))&&o.push("Patient satisfaction","Appointment completion rate","Information accessibility");let c=[];n>0&&(c.push({team:"Marketing",impactType:"positive",description:"Form conversion optimization needed"}),c.push({team:"Development",impactType:"neutral",description:"Form validation and submission handling"})),e.accessibility&&(e.accessibility.altTextsCoverage||0)<100&&c.push({team:"Content",impactType:"negative",description:"Image alt text creation required"}),i&&(i.loadTime||0)>2e3&&c.push({team:"Engineering",impactType:"negative",description:"Performance optimization needed"}),t.complexity==="complex"&&c.push({team:"QA",impactType:"neutral",description:"Comprehensive testing strategy required"});let d=!1;s&&(d=!0),e.accessibility&&(e.accessibility.altTextsCoverage||0)<50&&(d=!0),i&&(i.loadTime||0)>4e3&&(d=!0);let m=50;return o.length>0&&(m+=15),c.length>0&&(m+=10),d||(m+=20),m=Math.min(100,m),{primaryGoal:a,kpisAffected:o,crossTeamImpact:c,compromisesUX:d,impactsKPIs:o.length>0,alignmentScore:m}}analyzeCreativity(e,t){let n=[];(t.complexity==="complex"||t.complexity==="moderate")&&(n.push({description:"Question fundamental assumptions about user mental models and expected workflows",inspirationSource:"philosophy",applicability:"high",novelty:"moderately-novel"}),e.errorIndicators?.hasErrorMessages&&n.push({description:"Apply diagnostic testing - systematically isolate error sources through controlled scenarios",inspirationSource:"medicine",applicability:"high",novelty:"moderately-novel"})),e.domMetrics?.forms&&e.domMetrics.forms>0&&n.push({description:"Test checkout/form flows like fashion retail - focus on friction points, abandonment triggers",inspirationSource:"e-commerce",applicability:"high",novelty:"incremental"}),n.push({description:"Analyze through diverse demographic lenses (age, gender, culture, ability) for inclusive testing",inspirationSource:"social science",applicability:"high",novelty:"moderately-novel"}),e.domMetrics?.interactiveElements&&e.domMetrics.interactiveElements>20&&n.push({description:'Test for "game-breaking" exploits - unexpected interaction sequences, boundary conditions',inspirationSource:"gaming",applicability:"medium",novelty:"highly-novel"});let r=[...new Set(n.map(a=>a.inspirationSource))],i=["Unexperienced user perspective (fresh eyes)","Power user perspective (efficiency focus)","Accessibility perspective (assistive tech users)","International perspective (cultural differences)"],s=50;return s+=n.length*8,s+=r.length*5,s=Math.min(100,s),{innovativeApproaches:n,domainsExplored:r,perspectives:i,creativityScore:s,notes:["Creativity draws from diverse domains to uncover unconventional testing approaches","Higher complexity problems benefit from cross-disciplinary inspiration",`Applied ${n.length} creative approaches from ${r.length} domains`]}}analyzeDesign(e){let t=[],n=[];e.domMetrics?.semanticStructure?.hasNav&&t.push("Navigation structure clearly defined with semantic <nav> element"),e.domMetrics?.semanticStructure?.hasMain&&t.push("Main content area clearly identified"),e.domMetrics?.semanticStructure?.hasHeader&&e.domMetrics?.semanticStructure?.hasFooter&&t.push("Header and footer provide clear page structure");let r=e.accessibility?.ariaLabelsCount||0,i=e.domMetrics?.interactiveElements||0;i>0&&r<i*.5&&n.push("Many interactive elements lack ARIA labels for clarity");let s=50+t.length*15-n.length*10;s=Math.max(0,Math.min(100,s));let a=s>=80?"excellent":s>=60?"good":s>=40?"adequate":"poor",o=[],l=[],c=!0;e.domMetrics?.semanticStructure?.hasNav&&o.push("Standard navigation placement"),e.domMetrics?.semanticStructure?.hasHeader&&o.push("Header follows common layout conventions"),!e.domMetrics?.semanticStructure?.hasNav&&i>10&&(c=!1,l.push("Non-standard navigation pattern may confuse users from different regions"));let d=50+o.length*15;c||(d-=20),d=Math.max(0,Math.min(100,d));let m=Math.round((s+d)/2);return{exactness:{clarity:a,clearElements:t,unclearElements:n,score:s},intuitive:{followsConventions:c,intuitivePatterns:o,culturalIssues:l,score:d},counterIntuitive:{deviations:[],innovativeJustification:!1,freshEyesPerspective:!0,issuesCount:0},overallDesignScore:m}}generateRecommendations(e,t,n,r,i,s){let a=[],o=1;for(let l of s){for(let c of l.issues)(c.severity==="critical"||c.severity==="high")&&a.push({principle:l.name,recommendation:c.description,severity:c.severity,impact:c.severity==="critical"?90:75,effort:"medium",priority:o++,category:"qx"});for(let c of l.recommendations)a.push({principle:l.name,recommendation:c,severity:"medium",impact:60,effort:"medium",priority:o++,category:"qx"})}for(let l of r)a.push({principle:`Oracle: ${l.type}`,recommendation:l.description,severity:l.severity,impact:l.severity==="critical"?95:l.severity==="high"?80:60,effort:"high",priority:o++,category:"process",evidence:l.resolutionApproach});for(let l of t.challenges)a.push({principle:"User Needs",recommendation:l,severity:"medium",impact:65,effort:"medium",priority:o++,category:"ux"});return a.sort((l,c)=>{let d={critical:0,high:1,medium:2,low:3},m=d[l.severity]-d[c.severity];return m!==0?m:c.impact-l.impact}).slice(0,15)}calculateOverallScore(e,t,n,r,i,s,a){let o=a.reduce((c,d)=>c+d.score,0)/a.length||0,l=e.clarityScore*.1+t.alignmentScore*.2+n.alignmentScore*.15+r.creativityScore*.1+i.overallDesignScore*.15+(100-s.overallImpactScore)*.1+o*.2;return Math.round(Math.max(0,Math.min(100,l)))}scoreToGrade(e){return e>=90?"A":e>=80?"B":e>=70?"C":e>=60?"D":"F"}createMinimalContext(e){return{url:e,title:e}}createMinimalCreativityAnalysis(){return{innovativeApproaches:[],domainsExplored:[],perspectives:[],creativityScore:50,notes:["Creativity analysis skipped"]}}createMinimalDesignAnalysis(){return{exactness:{clarity:"adequate",clearElements:[],unclearElements:[],score:50},intuitive:{followsConventions:!0,intuitivePatterns:[],culturalIssues:[],score:50},counterIntuitive:{deviations:[],innovativeJustification:!1,freshEyesPerspective:!1,issuesCount:0},overallDesignScore:50}}emitStream(e,t){e.streaming&&e.onStream&&e.onStream(t)}isAborted(e){return e.abortSignal?.aborted||!1}createMetadata(e,t){return{executionTime:Date.now()-e,timestamp:new Date().toISOString(),requestId:t}}},UE=new ct;var hw={TEST_GENERATE:"qe/tests/generate",TEST_EXECUTE:"qe/tests/execute",COVERAGE_ANALYZE:"qe/coverage/analyze",COVERAGE_GAPS:"qe/coverage/gaps",QUALITY_EVALUATE:"qe/quality/evaluate",DEFECT_PREDICT:"qe/defects/predict",REQUIREMENTS_VALIDATE:"qe/requirements/validate",QUALITY_CRITERIA:"qe/requirements/quality-criteria",CODE_ANALYZE:"qe/code/analyze",SECURITY_SCAN:"qe/security/scan",CONTRACT_VALIDATE:"qe/contracts/validate",VISUAL_COMPARE:"qe/visual/compare",A11Y_AUDIT:"qe/a11y/audit",CHAOS_INJECT:"qe/chaos/inject",LEARNING_OPTIMIZE:"qe/learning/optimize",LEARNING_DREAM:"qe/learning/dream",TOKEN_USAGE:"qe/analysis/token_usage",GOAP_PLAN:"qe/planning/goap_plan",GOAP_EXECUTE:"qe/planning/goap_execute",GOAP_STATUS:"qe/planning/goap_status",...tt,EMBEDDING_GENERATE:"qe/embeddings/generate",EMBEDDING_COMPARE:"qe/embeddings/compare",EMBEDDING_SEARCH:"qe/embeddings/search",EMBEDDING_STORE:"qe/embeddings/store",EMBEDDING_STATS:"qe/embeddings/stats",...Ts,QX_ANALYZE:"qe/qx/analyze",TEST_SCHEDULE:"qe/tests/schedule",LOAD_TEST:"qe/tests/load",URL_VALIDATE:"qe/security/url-validate",BROWSER_WORKFLOW:"qe/workflows/browser-load"},fw=[new $t,new zt,new jt,new Ut,new Ht,new Qt,new Wt,new Ve,new Xt,new Yt,new Jt,new Zt,new en,new tn,new Qe,new We,new nn,new Je,new Ze,new et,...bs,new Ie,new Oe,new _e,new Fe,new Le,...Cs,new ct,new Xr,new Yr,new Jr,new Kr];k();var Iw=Er.filter(u=>u!=="coordination"),pn={fleetId:null,kernel:null,queen:null,router:null,workflowOrchestrator:null,initialized:!1,initTime:null,topology:"hierarchical",agentLevels:new Map};function je(){return pn}function Gi(){return pn.initialized&&pn.kernel!==null&&pn.queen!==null}export{Ll as a,Ot as b,je as c,Gi as d};
|