agentic-qe 3.10.4 → 3.10.5
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/qcsd-development-swarm/SKILL.md +27 -6
- package/.claude/skills/skills-manifest.json +1 -1
- package/CHANGELOG.md +71 -0
- package/dist/arena/arena.d.ts +68 -0
- package/dist/arena/arena.js +169 -0
- package/dist/arena/mutator.d.ts +23 -0
- package/dist/arena/mutator.js +112 -0
- package/dist/arena/rng.d.ts +15 -0
- package/dist/arena/rng.js +34 -0
- package/dist/arena/runner.d.ts +44 -0
- package/dist/arena/runner.js +79 -0
- package/dist/cli/bundle.js +7 -7
- package/dist/cli/chunks/adapter-XZVL3DHO.js +2 -0
- package/dist/cli/chunks/{agent-booster-wasm-EJPDSWON.js → agent-booster-wasm-3BC5LIEB.js} +2 -2
- package/dist/cli/chunks/{agent-handler-2DZB7LGI.js → agent-handler-QLXWVZZF.js} +2 -2
- package/dist/cli/chunks/{agent-memory-branch-SSFYAVIK.js → agent-memory-branch-3U5PDYW7.js} +2 -2
- package/dist/cli/chunks/aqe-learning-engine-YIL25K6W.js +2 -0
- package/dist/cli/chunks/arena-BMJQK4RD.js +18 -0
- package/dist/cli/chunks/arena-XENAGV4I.js +4 -0
- package/dist/cli/chunks/{audit-42XG5JFB.js → audit-WPIRUJNZ.js} +2 -2
- package/dist/cli/chunks/base-YCYV23Q3.js +2 -0
- package/dist/cli/chunks/{hnswlib-node-3TZFES5I.js → better-sqlite3-6AGIBSVE.js} +2 -2
- package/dist/cli/chunks/{brain-handler-LFHX2TYP.js → brain-handler-PHSWG5PR.js} +3 -3
- package/dist/cli/chunks/{branch-enumerator-AX7DKGV7.js → branch-enumerator-LNSYT34I.js} +2 -2
- package/dist/cli/chunks/{browser-4NYLZ7FA.js → browser-M5BVQMBI.js} +2 -2
- package/dist/cli/chunks/browser-workflow-ALCOCRA2.js +2 -0
- package/dist/cli/chunks/{chunk-Q53M4LI7.js → chunk-24A7KD3D.js} +1 -1
- package/dist/cli/chunks/{chunk-HTLAPMTK.js → chunk-253TDTPH.js} +1 -1
- package/dist/cli/chunks/{chunk-EGTOSQZK.js → chunk-2RLRPKCG.js} +2 -2
- package/dist/cli/chunks/{chunk-2G2PVVQG.js → chunk-2UQWVF4P.js} +2 -2
- package/dist/cli/chunks/{chunk-KGPAWNNR.js → chunk-2Z7HIT5I.js} +1 -1
- package/dist/cli/chunks/{chunk-KJ56OXH4.js → chunk-3BGGNHHZ.js} +1 -1
- package/dist/cli/chunks/{chunk-VJ2D6FST.js → chunk-3JWV4GE6.js} +2 -2
- package/dist/cli/chunks/{chunk-XBFEHVBO.js → chunk-3KGUP2SD.js} +2 -2
- package/dist/cli/chunks/{chunk-JRBGHWAM.js → chunk-3WOQY6UL.js} +2 -2
- package/dist/cli/chunks/{chunk-V5G3SMAJ.js → chunk-4FTO3TPH.js} +2 -2
- package/dist/cli/chunks/{chunk-L6VNEEN6.js → chunk-4K7T6AKM.js} +1 -1
- package/dist/cli/chunks/{chunk-WIYWDON4.js → chunk-4Z7XH4JE.js} +2 -2
- package/dist/cli/chunks/{chunk-ISRTT4I7.js → chunk-54IPDQIZ.js} +8 -8
- package/dist/cli/chunks/{chunk-IYFMDIYZ.js → chunk-56RA6YPN.js} +2 -2
- package/dist/cli/chunks/{chunk-M4ARHDY4.js → chunk-5D7GLMT3.js} +1 -1
- package/dist/cli/chunks/{chunk-6SCIX2W2.js → chunk-66LOFIBP.js} +2 -2
- package/dist/cli/chunks/{chunk-K7K4TFJM.js → chunk-6SAU7GXO.js} +1 -1
- package/dist/cli/chunks/{chunk-KUFC4DBX.js → chunk-75MP7JMV.js} +1 -1
- package/dist/cli/chunks/{chunk-PISW5HUX.js → chunk-7DU35D4M.js} +1 -1
- package/dist/cli/chunks/{chunk-MIQBRVK2.js → chunk-7JZCEQFR.js} +1 -1
- package/dist/cli/chunks/{chunk-XVA56PXZ.js → chunk-A3BDPU5F.js} +4 -4
- package/dist/cli/chunks/{chunk-DAIM72HV.js → chunk-A7HGS7FW.js} +2 -2
- package/dist/cli/chunks/{chunk-EWI37TJA.js → chunk-AMBIOEMO.js} +1 -1
- package/dist/cli/chunks/{chunk-IPAQ4HVX.js → chunk-AVQD7KEN.js} +2 -2
- package/dist/cli/chunks/{chunk-FDFJJFQT.js → chunk-AZCKTAUI.js} +2 -2
- package/dist/cli/chunks/{chunk-JYR3X4OC.js → chunk-B4F5EPNR.js} +1 -1
- package/dist/cli/chunks/{chunk-LYKSIOOT.js → chunk-BB7MEGXD.js} +2 -2
- package/dist/cli/chunks/{chunk-N4CXUGXE.js → chunk-BSRCL6RU.js} +2 -2
- package/dist/cli/chunks/{chunk-IAK76TIZ.js → chunk-CS3UB2OL.js} +1 -1
- package/dist/cli/chunks/{chunk-RUC3FCRK.js → chunk-CTG3GJIM.js} +2 -2
- package/dist/cli/chunks/{chunk-AMW27FSS.js → chunk-CUAM34RQ.js} +3 -3
- package/dist/cli/chunks/{chunk-M2PSXKTG.js → chunk-CUY2EUSQ.js} +2 -2
- package/dist/cli/chunks/{chunk-3UGUX34A.js → chunk-D3Q4443B.js} +1 -1
- package/dist/cli/chunks/{chunk-NJYI7HX7.js → chunk-D4WDJ4ZF.js} +2 -2
- package/dist/cli/chunks/{chunk-U27GVYXA.js → chunk-D7NKRCIL.js} +2 -2
- package/dist/cli/chunks/{chunk-7BQXEYRV.js → chunk-DBR4TQPK.js} +2 -2
- package/dist/cli/chunks/{chunk-USB7GCIC.js → chunk-DIJ74M7V.js} +1 -1
- package/dist/cli/chunks/{chunk-XJXCSCCP.js → chunk-DJQYZ4RZ.js} +1 -1
- package/dist/cli/chunks/{chunk-VJOPNK2L.js → chunk-DN65ILSI.js} +2 -2
- package/dist/cli/chunks/{chunk-Y2EDDV5U.js → chunk-DWLGFYXV.js} +2 -2
- package/dist/cli/chunks/{chunk-OKKTDHHF.js → chunk-EIL7FQC4.js} +4 -4
- package/dist/cli/chunks/{chunk-GDMH7NPV.js → chunk-FE3FGMNB.js} +2 -2
- package/dist/cli/chunks/{chunk-SXMGNMFL.js → chunk-FLYFNNSN.js} +3 -3
- package/dist/cli/chunks/{chunk-N244P4MM.js → chunk-FNJZBIR3.js} +2 -2
- package/dist/cli/chunks/{chunk-PZCSJZVJ.js → chunk-FPWA73N6.js} +2 -2
- package/dist/cli/chunks/{chunk-MQ5WMWUK.js → chunk-FW3C4LWU.js} +2 -2
- package/dist/cli/chunks/{chunk-YSLE6NNG.js → chunk-G4GX6YKX.js} +2 -2
- package/dist/cli/chunks/{chunk-F34OO2Q7.js → chunk-G5UIGH4C.js} +3 -3
- package/dist/cli/chunks/{chunk-UXJVR323.js → chunk-G6FP3S3G.js} +2 -2
- package/dist/cli/chunks/{chunk-SZKFT6CD.js → chunk-GDUGW6FZ.js} +2 -2
- package/dist/cli/chunks/{chunk-ZM4QGYGK.js → chunk-GKG6IQP6.js} +3 -3
- package/dist/cli/chunks/{chunk-F77X5DAF.js → chunk-GMU7P5O3.js} +2 -2
- package/dist/cli/chunks/{chunk-EMZ3DXMG.js → chunk-GTVXVYKE.js} +2 -2
- package/dist/cli/chunks/{chunk-KCXE2LZU.js → chunk-HHEHGERJ.js} +2 -2
- package/dist/cli/chunks/{chunk-GILL32E2.js → chunk-HKJ3LG3N.js} +2 -2
- package/dist/cli/chunks/{chunk-E6CGBOZY.js → chunk-HNYSBE5J.js} +2 -2
- package/dist/cli/chunks/{chunk-UWAUYDW4.js → chunk-HPKYIK7R.js} +2 -2
- package/dist/cli/chunks/{chunk-3ISX5B77.js → chunk-HRORJ352.js} +2 -2
- package/dist/cli/chunks/{chunk-PLD4IGDL.js → chunk-IIFCTJOF.js} +2 -2
- package/dist/cli/chunks/{chunk-C2446H7G.js → chunk-IOE6LDPF.js} +2 -2
- package/dist/cli/chunks/{chunk-UFKVKNAA.js → chunk-IRS4HKAR.js} +1 -1
- package/dist/cli/chunks/{chunk-4BX72XG4.js → chunk-IT7CEHAJ.js} +2 -2
- package/dist/cli/chunks/{chunk-GLMDRGJD.js → chunk-IUKERFLT.js} +1 -1
- package/dist/cli/chunks/{chunk-LKK3NIHC.js → chunk-IVKSZNMI.js} +1 -1
- package/dist/cli/chunks/{chunk-WI5WXYIS.js → chunk-IWRORKD7.js} +2 -2
- package/dist/cli/chunks/{chunk-5T2HDET6.js → chunk-J533CJUN.js} +3 -3
- package/dist/cli/chunks/{chunk-OO7KJ34Y.js → chunk-JPOEI7CJ.js} +2 -2
- package/dist/cli/chunks/{chunk-B6CT4ILU.js → chunk-JY7T2AQQ.js} +4 -4
- package/dist/cli/chunks/{chunk-TBJ566KV.js → chunk-K5KKZWED.js} +2 -2
- package/dist/cli/chunks/{chunk-RJKYPWFD.js → chunk-KIMJPTHD.js} +2 -2
- package/dist/cli/chunks/{chunk-MHWYQHGN.js → chunk-MEN3UW7W.js} +1 -1
- package/dist/cli/chunks/{chunk-KWZEBHAP.js → chunk-MFQIJ3HV.js} +2 -2
- package/dist/cli/chunks/{chunk-MDWJXSBA.js → chunk-MGCW5FWH.js} +2 -2
- package/dist/cli/chunks/{chunk-TWAWEP4X.js → chunk-MIMJVKJJ.js} +3 -3
- package/dist/cli/chunks/{chunk-N3MM4Z33.js → chunk-MJRYHHOG.js} +2 -2
- package/dist/cli/chunks/{chunk-K7CW2X6U.js → chunk-MRXKIXVV.js} +2 -2
- package/dist/cli/chunks/{chunk-XDZXLEJK.js → chunk-MWPFUBXS.js} +2 -2
- package/dist/cli/chunks/{chunk-ND6YSW5N.js → chunk-N2TJXGHG.js} +1 -1
- package/dist/cli/chunks/{chunk-6WF2MOQB.js → chunk-NGSA53GC.js} +2 -2
- package/dist/cli/chunks/{chunk-AIBE3J4A.js → chunk-NKW7VOZV.js} +1 -1
- package/dist/cli/chunks/{chunk-D7IWGQTW.js → chunk-O5OOUMBB.js} +2 -2
- package/dist/cli/chunks/{chunk-O3SG32PS.js → chunk-OATHXZYW.js} +1 -1
- package/dist/cli/chunks/{chunk-QPMAXDJ2.js → chunk-OJNG6ZXG.js} +2 -2
- package/dist/cli/chunks/{chunk-LHPR7ROV.js → chunk-PGNQR2VM.js} +1 -1
- package/dist/cli/chunks/{chunk-M3MKP5VN.js → chunk-PPM5D7LH.js} +1 -1
- package/dist/cli/chunks/{chunk-MKZQBBCU.js → chunk-PYBVFG6T.js} +2 -2
- package/dist/cli/chunks/{chunk-BEFRQOLH.js → chunk-Q6BKJZTG.js} +2 -2
- package/dist/cli/chunks/chunk-QAW6RVAR.js +699 -0
- package/dist/cli/chunks/{chunk-MQIAN57O.js → chunk-QTDZS4U6.js} +2 -2
- package/dist/cli/chunks/{chunk-NZGLDOU4.js → chunk-R573V37S.js} +2 -2
- package/dist/cli/chunks/{chunk-OV4BLIKJ.js → chunk-RCAIOTIF.js} +2 -2
- package/dist/cli/chunks/{chunk-TCV5DASI.js → chunk-RFNEEDPQ.js} +2 -2
- package/dist/cli/chunks/{chunk-M5DBKHM4.js → chunk-RFVZMNYX.js} +2 -2
- package/dist/cli/chunks/{chunk-MWV4KPOB.js → chunk-RLU7764Y.js} +2 -2
- package/dist/cli/chunks/chunk-RLZDXQNM.js +2 -0
- package/dist/cli/chunks/{chunk-6OLHPWSN.js → chunk-RONMVGCT.js} +2 -2
- package/dist/cli/chunks/{chunk-STMMZXS6.js → chunk-RR55MLD4.js} +1 -1
- package/dist/cli/chunks/{chunk-VDKMBOUK.js → chunk-RUQV3BTV.js} +1 -1
- package/dist/cli/chunks/{chunk-OIFJH7TF.js → chunk-RZ7D5SHS.js} +1 -1
- package/dist/cli/chunks/{chunk-2B6ETC7C.js → chunk-S73KENCH.js} +2 -2
- package/dist/cli/chunks/{chunk-4FTLYIMW.js → chunk-S7FGTHFE.js} +2 -2
- package/dist/cli/chunks/{chunk-SVILIQQQ.js → chunk-S7HQOGVD.js} +1 -1
- package/dist/cli/chunks/{chunk-Z4BTPQLG.js → chunk-SK6YRNXI.js} +2 -2
- package/dist/cli/chunks/{chunk-GS33ZRJH.js → chunk-SXQIH2QA.js} +2 -2
- package/dist/cli/chunks/{chunk-MU4P4P4E.js → chunk-TISBFSDJ.js} +1 -1
- package/dist/cli/chunks/{chunk-5Q3L4QEE.js → chunk-TMD6IC6D.js} +2 -2
- package/dist/cli/chunks/{chunk-LOFA3U4X.js → chunk-TMTLWSSA.js} +1 -1
- package/dist/cli/chunks/{chunk-UW3ZSFFB.js → chunk-UOIT5JZ6.js} +2 -2
- package/dist/cli/chunks/{chunk-FQ7I4JBQ.js → chunk-UTORITJT.js} +2 -2
- package/dist/cli/chunks/{chunk-AZJYDM2K.js → chunk-VB7DZVCI.js} +1 -1
- package/dist/cli/chunks/{chunk-VRE2EBFI.js → chunk-VC256KH2.js} +2 -2
- package/dist/cli/chunks/{chunk-WYMQ6FZR.js → chunk-VESYE5YO.js} +3 -3
- package/dist/cli/chunks/{chunk-DPKECIKN.js → chunk-VKWDMOR4.js} +2 -2
- package/dist/cli/chunks/{chunk-SC6UFGJ6.js → chunk-VWN66V7U.js} +2 -2
- package/dist/cli/chunks/{chunk-2TYO4VZH.js → chunk-W5C7R2LS.js} +3 -3
- package/dist/cli/chunks/{chunk-D7PI4CYZ.js → chunk-W7KGHW4T.js} +2 -2
- package/dist/cli/chunks/{chunk-7VO5IEJ2.js → chunk-WFZ4DRIC.js} +2 -2
- package/dist/cli/chunks/{chunk-NSRDP7RD.js → chunk-WFZUKXV5.js} +2 -2
- package/dist/cli/chunks/{chunk-SJC7OKF3.js → chunk-X4B3R3ZZ.js} +2 -2
- package/dist/cli/chunks/{chunk-5FNNCVXR.js → chunk-XI6ZZMX7.js} +1 -1
- package/dist/cli/chunks/{chunk-K72J52JO.js → chunk-YEO2Z3UX.js} +2 -2
- package/dist/cli/chunks/{chunk-PMWWWYUM.js → chunk-YZD4VIE5.js} +1 -1
- package/dist/cli/chunks/{chunk-F6QPAVWS.js → chunk-YZFNPTGN.js} +2 -2
- package/dist/cli/chunks/{chunk-5T4J3IPG.js → chunk-ZCYKWEAM.js} +2 -2
- package/dist/cli/chunks/{chunk-PWJZZCHJ.js → chunk-ZG3DSWUA.js} +1 -1
- package/dist/cli/chunks/{chunk-2L5VFVCG.js → chunk-ZS4BGJJV.js} +1 -1
- package/dist/cli/chunks/{chunk-ICF5RPQU.js → chunk-ZT7JSFGT.js} +2 -2
- package/dist/cli/chunks/{chunk-MFWWPRBV.js → chunk-ZTC64OJE.js} +2 -2
- package/dist/cli/chunks/{chunk-G5FPWH5O.js → chunk-ZUBJBAUD.js} +15 -15
- package/dist/cli/chunks/{ci-2BLMQNX3.js → ci-M2BSQBLL.js} +2 -2
- package/dist/cli/chunks/{ci-output-XK4PPSN7.js → ci-output-Z4TMK6GZ.js} +2 -2
- package/dist/cli/chunks/{circuit-breaker-W7X4NPFE.js → circuit-breaker-E3G4GGWB.js} +2 -2
- package/dist/cli/chunks/{claude-flow-setup-GLBLSYNJ.js → claude-flow-setup-MASRQU54.js} +2 -2
- package/dist/cli/chunks/client-RPB6RYVY.js +2 -0
- package/dist/cli/chunks/{cline-installer-7WX7DBGI.js → cline-installer-P3BWAKQA.js} +2 -2
- package/dist/cli/chunks/{code-SP3HAQWG.js → code-7HY5HQAV.js} +2 -2
- package/dist/cli/chunks/{code-index-extractor-44HH36UG.js → code-index-extractor-MBVKLOEU.js} +2 -2
- package/dist/cli/chunks/{codex-installer-LMXRWLPU.js → codex-installer-WZ6QO2PH.js} +2 -2
- package/dist/cli/chunks/{completions-GL5FTZAN.js → completions-TOJC2UFP.js} +2 -2
- package/dist/cli/chunks/{complexity-analyzer-CQMYGETL.js → complexity-analyzer-QYVDIAAW.js} +2 -2
- package/dist/cli/chunks/{continuedev-installer-CYVYS5B7.js → continuedev-installer-J72CV7P4.js} +2 -2
- package/dist/cli/chunks/{copilot-installer-M7XVII2A.js → copilot-installer-ACDA3GEA.js} +2 -2
- package/dist/cli/chunks/core-handlers-QFJT5NX6.js +2 -0
- package/dist/cli/chunks/{cost-tracker-S4ET4FH3.js → cost-tracker-BAYQJELE.js} +2 -2
- package/dist/cli/chunks/{coverage-DFVSSQ4A.js → coverage-QD3XJV6W.js} +3 -3
- package/dist/cli/chunks/cross-domain-router-5GJ7WZKX.js +2 -0
- package/dist/cli/chunks/{cursor-installer-KWDSQPQC.js → cursor-installer-SPGZ4TQM.js} +2 -2
- package/dist/cli/chunks/{daemon-2HD54QVO.js → daemon-3EVOL2UH.js} +3 -3
- package/dist/cli/chunks/{daemon-CRX46BBO.js → daemon-N4JKD5SO.js} +4 -4
- package/dist/cli/chunks/{dag-attention-scheduler-SCP6WPZB.js → dag-attention-scheduler-3BVLL3L5.js} +2 -2
- package/dist/cli/chunks/{detect-XS2GDCEX.js → detect-SWACKB45.js} +2 -2
- package/dist/cli/chunks/{dist-node-U43MVQ3F.js → dist-node-LU4E7PI6.js} +2 -2
- package/dist/cli/chunks/{domain-handler-HITMDULH.js → domain-handler-5AKKAC43.js} +2 -2
- package/dist/cli/chunks/{domain-transfer-TJF7DNI4.js → domain-transfer-LB6H7RPX.js} +2 -2
- package/dist/cli/chunks/dream-C6VNLTON.js +2 -0
- package/dist/cli/chunks/{embed-and-insert-pattern-JKG33YZK.js → embed-and-insert-pattern-7RBA5NDK.js} +2 -2
- package/dist/cli/chunks/{eval-NF5Y4W37.js → eval-ZZFPRENX.js} +5 -5
- package/dist/cli/chunks/{experience-capture-middleware-VMMFYJ4D.js → experience-capture-middleware-HRO3EGIW.js} +3 -3
- package/dist/cli/chunks/{fast-paths-W2Q53IR2.js → fast-paths-IRRNQBTY.js} +2 -2
- package/dist/cli/chunks/{feature-flags-B4PBMQJO.js → feature-flags-R5N5IWI2.js} +2 -2
- package/dist/cli/chunks/{feature-flags-PVI7A4RE.js → feature-flags-W54ABAUA.js} +2 -2
- package/dist/cli/chunks/{file-discovery-E4L3I33I.js → file-discovery-6CIDLVID.js} +2 -2
- package/dist/cli/chunks/{fleet-LE5SHVLK.js → fleet-YTFN64WE.js} +3 -3
- package/dist/cli/chunks/{gnn-wrapper-MWWJBLOH.js → gnn-wrapper-RXMPLMV2.js} +2 -2
- package/dist/cli/chunks/{heartbeat-handler-XOUVNPQK.js → heartbeat-handler-HQQWEEQQ.js} +4 -4
- package/dist/cli/chunks/heartbeat-scheduler-4SBO27BG.js +2 -0
- package/dist/cli/chunks/hnsw-adapter-W7G6VNXW.js +2 -0
- package/dist/cli/chunks/hnsw-index-LENA5QML.js +2 -0
- package/dist/cli/chunks/{hnsw-legacy-bridge-W3T5ZDDP.js → hnsw-legacy-bridge-GPZIKYFD.js} +2 -2
- package/dist/cli/chunks/{better-sqlite3-PX5JM3DG.js → hnswlib-node-P6HSEFLW.js} +2 -2
- package/dist/cli/chunks/hooks-AYLAGFOK.js +285 -0
- package/dist/cli/chunks/hybrid-router-IXHIC45P.js +2 -0
- package/dist/cli/chunks/{hypergraph-engine-VDFK3JYH.js → hypergraph-engine-56FMXI3T.js} +2 -2
- package/dist/cli/chunks/{hypergraph-handler-EUDGEF25.js → hypergraph-handler-APEVT5IE.js} +3 -3
- package/dist/cli/chunks/impact-analyzer-DKGVMYU6.js +2 -0
- package/dist/cli/chunks/{init-handler-MZEAJOZK.js → init-handler-5DWF4REQ.js} +6 -6
- package/dist/cli/chunks/init-wizard-BBY3LY3F.js +2 -0
- package/dist/cli/chunks/kernel-7CUW7G62.js +2 -0
- package/dist/cli/chunks/{kilocode-installer-ECBYWT6M.js → kilocode-installer-XKAUA5VA.js} +2 -2
- package/dist/cli/chunks/{kiro-installer-KYFCSYTG.js → kiro-installer-NI2KIYJE.js} +2 -2
- package/dist/cli/chunks/knowledge-graph-Q5CP47IP.js +2 -0
- package/dist/cli/chunks/{learning-4RAFMDSB.js → learning-ZIUMUNXZ.js} +3 -3
- package/dist/cli/chunks/{llm-router-JHBNLYP3.js → llm-router-IL52EF2V.js} +4 -4
- package/dist/cli/chunks/llm-router-service-MTXCX7TO.js +2 -0
- package/dist/cli/chunks/{load-4DVQML7P.js → load-B5LFYD6O.js} +2 -2
- package/dist/cli/chunks/load-test-YBWXASBO.js +2 -0
- package/dist/cli/chunks/{mcp-LCWMU4GZ.js → mcp-K6GZLWBC.js} +2 -2
- package/dist/cli/chunks/{memory-3DTJAURT.js → memory-NCQRVSN6.js} +5 -5
- package/dist/cli/chunks/memory-backend-52LANEA3.js +2 -0
- package/dist/cli/chunks/{memory-handlers-BL6E3XAK.js → memory-handlers-KFW3HYAP.js} +2 -2
- package/dist/cli/chunks/{multi-model-executor-AVR5SZOO.js → multi-model-executor-R4LBSJWK.js} +2 -2
- package/dist/cli/chunks/{opencode-installer-DW2426QM.js → opencode-installer-I6CBR3PV.js} +2 -2
- package/dist/cli/chunks/{orchestrator-AHF4W5GS.js → orchestrator-5FXUCES6.js} +10 -10
- package/dist/cli/chunks/{pipeline-N6THEWYE.js → pipeline-GDKCTXJH.js} +2 -2
- package/dist/cli/chunks/{platform-MRCFQF7X.js → platform-ZFY3F4T3.js} +2 -2
- package/dist/cli/chunks/{plugin-6YKUN5QM.js → plugin-HQMEN3OS.js} +2 -2
- package/dist/cli/chunks/{prime-radiant-advanced-wasm-2YPAHSVS.js → prime-radiant-advanced-wasm-LSJGF4CV.js} +2 -2
- package/dist/cli/chunks/protocol-executor-TRYUS77M.js +2 -0
- package/dist/cli/chunks/{protocol-handler-Y2NMUKWQ.js → protocol-handler-BMDNIGPP.js} +2 -2
- package/dist/cli/chunks/{prove-DZUNWBFD.js → prove-ABVGAG4Z.js} +2 -2
- package/dist/cli/chunks/provider-manager-6XQQN7FX.js +2 -0
- package/dist/cli/chunks/qe-reasoning-bank-3IUPE4DJ.js +2 -0
- package/dist/cli/chunks/{quality-AIFQMGUV.js → quality-ENJXPNP5.js} +2 -2
- package/dist/cli/chunks/queen-coordinator-VWPH4XPX.js +2 -0
- package/dist/cli/chunks/{real-embeddings-5XL4LOG2.js → real-embeddings-W3GNAEJO.js} +2 -2
- package/dist/cli/chunks/{roocode-installer-LV3WONT5.js → roocode-installer-4FJNQ7PU.js} +2 -2
- package/dist/cli/chunks/router-OIB6ODHA.js +2 -0
- package/dist/cli/chunks/routing-feedback-EKYPCZYG.js +2 -0
- package/dist/cli/chunks/{routing-handler-WSMUILGD.js → routing-handler-GFS5FA4F.js} +2 -2
- package/dist/cli/chunks/{ruvector-commands-BCEIDTW3.js → ruvector-commands-GBMYNJKN.js} +2 -2
- package/dist/cli/chunks/{rvf-dual-writer-LRSPC6H3.js → rvf-dual-writer-STUAQT6U.js} +2 -2
- package/dist/cli/chunks/{rvf-migration-adapter-QHNX6353.js → rvf-migration-adapter-LO6DBNJH.js} +2 -2
- package/dist/cli/chunks/{rvf-migration-coordinator-SLNB3XPW.js → rvf-migration-coordinator-I5AD4VJ2.js} +2 -2
- package/dist/cli/chunks/rvf-native-adapter-7RXP2Q4Q.js +2 -0
- package/dist/cli/chunks/safe-db-MNKFEPBX.js +2 -0
- package/dist/cli/chunks/schedule-AJXABVXX.js +2 -0
- package/dist/cli/chunks/scheduler-LDWYHIAW.js +2 -0
- package/dist/cli/chunks/{security-CYY6TECQ.js → security-X3WCA5K5.js} +3 -3
- package/dist/cli/chunks/{shared-rvf-adapter-U6JE4O6A.js → shared-rvf-adapter-Z4FSPWNP.js} +2 -2
- package/dist/cli/chunks/{shared-rvf-dual-writer-PJBSNBRV.js → shared-rvf-dual-writer-QOPOIRIC.js} +2 -2
- package/dist/cli/chunks/sqlite-persistence-A6GKDMOJ.js +2 -0
- package/dist/cli/chunks/{status-handler-W723LXX5.js → status-handler-B2B5QBVK.js} +2 -2
- package/dist/cli/chunks/{structural-health-WZUPZBB5.js → structural-health-KT47LBVH.js} +2 -2
- package/dist/cli/chunks/{sync-ZLMF53TB.js → sync-CKID22IW.js} +2 -2
- package/dist/cli/chunks/{sync-UA22CKUS.js → sync-VWD6OOUR.js} +2 -2
- package/dist/cli/chunks/{task-handler-SENTEEXZ.js → task-handler-X5JT5YBF.js} +2 -2
- package/dist/cli/chunks/{task-handlers-FGVUZOCC.js → task-handlers-IW4GQDW4.js} +3 -3
- package/dist/cli/chunks/{test-Q37C3WI2.js → test-MBZSUASD.js} +4 -4
- package/dist/cli/chunks/{test-scheduling-E6SPIBTH.js → test-scheduling-E5KHKRZS.js} +3 -3
- package/dist/cli/chunks/{token-bootstrap-HQFFMZUF.js → token-bootstrap-TIDPJ5IG.js} +2 -2
- package/dist/cli/chunks/{token-usage-JHNWTZ7L.js → token-usage-ECJSPOQB.js} +2 -2
- package/dist/cli/chunks/{transformers-TEXDUVNI.js → transformers-UZJAQ7OZ.js} +2 -2
- package/dist/cli/chunks/{tree-sitter-wasm-parser-MWSS52H6.js → tree-sitter-wasm-parser-H6BU2E5R.js} +2 -2
- package/dist/cli/chunks/{types-YQRKHYH3.js → types-PM7NT3MH.js} +2 -2
- package/dist/cli/chunks/unified-memory-27QJHABO.js +2 -0
- package/dist/cli/chunks/unified-memory-hnsw-76VUXR4H.js +2 -0
- package/dist/cli/chunks/unified-persistence-QRCGDEXH.js +2 -0
- package/dist/cli/chunks/{upgrade-JKMEDURI.js → upgrade-FS2XYC2P.js} +2 -2
- package/dist/cli/chunks/{validate-URO7G6OE.js → validate-4Y2BNN3A.js} +3 -3
- package/dist/cli/chunks/{validate-swarm-VZVJ56Z5.js → validate-swarm-Z7QXZSUE.js} +4 -4
- package/dist/cli/chunks/{vibium-G5WZILL6.js → vibium-VZ6L3O2G.js} +2 -2
- package/dist/cli/chunks/visual-security-KB27O7BE.js +2 -0
- package/dist/cli/chunks/{web-tree-sitter-LECH5T6H.js → web-tree-sitter-H7P37W5U.js} +2 -2
- package/dist/cli/chunks/{windsurf-installer-2NPLC2YW.js → windsurf-installer-IB2VHSZS.js} +2 -2
- package/dist/cli/chunks/{witness-chain-X347C36A.js → witness-chain-C4DISYJN.js} +2 -2
- package/dist/cli/chunks/witness-chain-EYPXHRDV.js +2 -0
- package/dist/cli/chunks/{workflow-V4ALYZ73.js → workflow-IGM7KVIO.js} +4 -4
- package/dist/cli/chunks/workflow-orchestrator-6AQZ3USU.js +2 -0
- package/dist/cli/chunks/{wrappers-QXOPRPR4.js → wrappers-PQXC263L.js} +2 -2
- package/dist/cli/commands/arena.d.ts +10 -0
- package/dist/cli/commands/arena.js +129 -0
- package/dist/cli/commands/hooks-handlers/command-hooks.js +38 -2
- package/dist/cli/commands/hooks-handlers/hooks-dream-learning.d.ts +4 -0
- package/dist/cli/commands/hooks-handlers/hooks-dream-learning.js +66 -3
- package/dist/cli/commands/hooks-handlers/nesting-provenance.d.ts +27 -0
- package/dist/cli/commands/hooks-handlers/nesting-provenance.js +46 -0
- package/dist/cli/commands/hooks-handlers/task-hooks.js +22 -1
- package/dist/cli/commands/hooks-handlers/tool-loop-guardrail.d.ts +71 -0
- package/dist/cli/commands/hooks-handlers/tool-loop-guardrail.js +142 -0
- package/dist/cli/index.js +17 -0
- package/dist/contracts/verdicts.d.ts +297 -0
- package/dist/contracts/verdicts.js +178 -0
- package/dist/coordination/queen-types.d.ts +4 -0
- package/dist/integrations/agentic-flow/reasoning-bank/experience-replay.js +15 -6
- package/dist/integrations/agentic-flow/reasoning-bank/trajectory-tracker.js +12 -0
- package/dist/mcp/bundle.js +368 -368
- package/dist/mcp/handlers/core-handlers.d.ts +20 -0
- package/dist/mcp/handlers/core-handlers.js +28 -0
- package/dist/mcp/handlers/domain-handler-configs.d.ts +3 -0
- package/dist/mcp/handlers/domain-handler-configs.js +22 -10
- package/dist/shared/llm/cost-tracker.js +6 -2
- package/dist/shared/llm/interfaces.d.ts +4 -0
- package/dist/shared/llm/providers/claude.js +16 -2
- package/dist/shared/reasoning-scrub.d.ts +29 -0
- package/dist/shared/reasoning-scrub.js +75 -0
- package/package.json +1 -1
- package/dist/cli/chunks/adapter-A62ETL5C.js +0 -2
- package/dist/cli/chunks/aqe-learning-engine-MTCRAV6N.js +0 -2
- package/dist/cli/chunks/base-KKEBUHZC.js +0 -2
- package/dist/cli/chunks/browser-workflow-XHYAJUB6.js +0 -2
- package/dist/cli/chunks/chunk-HPYGMKZF.js +0 -2
- package/dist/cli/chunks/chunk-PZ4PRZXN.js +0 -699
- package/dist/cli/chunks/client-C6CJOCRN.js +0 -2
- package/dist/cli/chunks/cross-domain-router-I3GEA5G6.js +0 -2
- package/dist/cli/chunks/dream-JCQMG2RL.js +0 -2
- package/dist/cli/chunks/heartbeat-scheduler-FBHE4ZWH.js +0 -2
- package/dist/cli/chunks/hnsw-adapter-EOOA4WXD.js +0 -2
- package/dist/cli/chunks/hnsw-index-TD3KRPND.js +0 -2
- package/dist/cli/chunks/hooks-RUPQVIUM.js +0 -250
- package/dist/cli/chunks/hybrid-router-64O6PXZ2.js +0 -2
- package/dist/cli/chunks/impact-analyzer-ITQHXGTM.js +0 -2
- package/dist/cli/chunks/init-wizard-DZ4IKGQI.js +0 -2
- package/dist/cli/chunks/kernel-HSVY4ZYK.js +0 -2
- package/dist/cli/chunks/knowledge-graph-H32TXXX4.js +0 -2
- package/dist/cli/chunks/llm-router-service-3FKESBUX.js +0 -2
- package/dist/cli/chunks/load-test-LKHURZGZ.js +0 -2
- package/dist/cli/chunks/memory-backend-XRJRZ6CK.js +0 -2
- package/dist/cli/chunks/protocol-executor-KABPB6PQ.js +0 -2
- package/dist/cli/chunks/provider-manager-U7EBM3FA.js +0 -2
- package/dist/cli/chunks/qe-reasoning-bank-64O2OQIW.js +0 -2
- package/dist/cli/chunks/queen-coordinator-SV3COGIL.js +0 -2
- package/dist/cli/chunks/router-QARRPMED.js +0 -2
- package/dist/cli/chunks/routing-feedback-KD2JFTPK.js +0 -2
- package/dist/cli/chunks/rvf-native-adapter-4LLGF5AY.js +0 -2
- package/dist/cli/chunks/safe-db-RAX3H2P7.js +0 -2
- package/dist/cli/chunks/schedule-RQZGLLUY.js +0 -2
- package/dist/cli/chunks/scheduler-ACWTN4LN.js +0 -2
- package/dist/cli/chunks/sqlite-persistence-SWNBO257.js +0 -2
- package/dist/cli/chunks/unified-memory-QG3FDRKR.js +0 -2
- package/dist/cli/chunks/unified-memory-hnsw-KOR4EOIG.js +0 -2
- package/dist/cli/chunks/unified-persistence-J6NIRYKM.js +0 -2
- package/dist/cli/chunks/visual-security-RAWV6YLN.js +0 -2
- package/dist/cli/chunks/witness-chain-ZO7FIM35.js +0 -2
- package/dist/cli/chunks/workflow-orchestrator-7SKITNIJ.js +0 -2
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agentic QE v3 - Structured Verdict Contracts (ADR-103)
|
|
3
|
+
*
|
|
4
|
+
* Typed, versioned verdict envelopes for agent-to-agent and MCP-boundary
|
|
5
|
+
* handoffs: RiskDecision (quality gates), FindingVerdict (review findings
|
|
6
|
+
* with adversarial refutations), CoverageGap (risk-weighted gap reports).
|
|
7
|
+
*
|
|
8
|
+
* Validators are dependency-free and are the source of truth; the exported
|
|
9
|
+
* JSON Schemas (published to schemas/*.schema.json by
|
|
10
|
+
* scripts/generate-verdict-schemas.mjs) mirror them for external tooling
|
|
11
|
+
* (ajv, workflow agent() schema option). Envelopes are versioned and
|
|
12
|
+
* additive-only within a major version: consumers must tolerate unknown
|
|
13
|
+
* fields, so schemas keep `additionalProperties: true`.
|
|
14
|
+
*/
|
|
15
|
+
export const VERDICT_CONTRACT_VERSION = '1.0';
|
|
16
|
+
// ============================================================================
|
|
17
|
+
// Validators (dependency-free, boundary-grade)
|
|
18
|
+
// ============================================================================
|
|
19
|
+
function isRecord(v) {
|
|
20
|
+
return typeof v === 'object' && v !== null && !Array.isArray(v);
|
|
21
|
+
}
|
|
22
|
+
function isStringArray(v) {
|
|
23
|
+
return Array.isArray(v) && v.every((x) => typeof x === 'string');
|
|
24
|
+
}
|
|
25
|
+
function inUnitRange(v) {
|
|
26
|
+
return typeof v === 'number' && Number.isFinite(v) && v >= 0 && v <= 1;
|
|
27
|
+
}
|
|
28
|
+
export function validateRiskDecision(value) {
|
|
29
|
+
const errors = [];
|
|
30
|
+
if (!isRecord(value))
|
|
31
|
+
return { valid: false, errors: ['not an object'] };
|
|
32
|
+
if (value.contract !== 'risk-decision@1')
|
|
33
|
+
errors.push(`contract must be "risk-decision@1"`);
|
|
34
|
+
if (!['approve', 'block', 'escalate'].includes(value.decision)) {
|
|
35
|
+
errors.push('decision must be approve|block|escalate');
|
|
36
|
+
}
|
|
37
|
+
if (!isStringArray(value.riskFactors))
|
|
38
|
+
errors.push('riskFactors must be string[]');
|
|
39
|
+
if (!inUnitRange(value.confidence))
|
|
40
|
+
errors.push('confidence must be a number in [0,1]');
|
|
41
|
+
if (typeof value.rationale !== 'string' || value.rationale.length === 0) {
|
|
42
|
+
errors.push('rationale must be a non-empty string');
|
|
43
|
+
}
|
|
44
|
+
return { valid: errors.length === 0, errors };
|
|
45
|
+
}
|
|
46
|
+
export function validateFindingVerdict(value) {
|
|
47
|
+
const errors = [];
|
|
48
|
+
if (!isRecord(value))
|
|
49
|
+
return { valid: false, errors: ['not an object'] };
|
|
50
|
+
if (value.contract !== 'finding-verdict@1')
|
|
51
|
+
errors.push(`contract must be "finding-verdict@1"`);
|
|
52
|
+
if (typeof value.id !== 'string' || value.id.length === 0)
|
|
53
|
+
errors.push('id must be a non-empty string');
|
|
54
|
+
if (typeof value.title !== 'string' || value.title.length === 0)
|
|
55
|
+
errors.push('title must be a non-empty string');
|
|
56
|
+
if (value.file !== undefined && typeof value.file !== 'string')
|
|
57
|
+
errors.push('file must be a string when present');
|
|
58
|
+
if (!['critical', 'high', 'medium', 'low', 'info'].includes(value.severity)) {
|
|
59
|
+
errors.push('severity must be critical|high|medium|low|info');
|
|
60
|
+
}
|
|
61
|
+
if (!inUnitRange(value.confidence))
|
|
62
|
+
errors.push('confidence must be a number in [0,1]');
|
|
63
|
+
if (!isStringArray(value.evidence))
|
|
64
|
+
errors.push('evidence must be string[]');
|
|
65
|
+
if (!['upheld', 'refuted', 'uncertain'].includes(value.verdict)) {
|
|
66
|
+
errors.push('verdict must be upheld|refuted|uncertain');
|
|
67
|
+
}
|
|
68
|
+
if (!isStringArray(value.refutations))
|
|
69
|
+
errors.push('refutations must be string[]');
|
|
70
|
+
return { valid: errors.length === 0, errors };
|
|
71
|
+
}
|
|
72
|
+
export function validateCoverageGap(value) {
|
|
73
|
+
const errors = [];
|
|
74
|
+
if (!isRecord(value))
|
|
75
|
+
return { valid: false, errors: ['not an object'] };
|
|
76
|
+
if (value.contract !== 'coverage-gap@1')
|
|
77
|
+
errors.push(`contract must be "coverage-gap@1"`);
|
|
78
|
+
if (typeof value.file !== 'string' || value.file.length === 0)
|
|
79
|
+
errors.push('file must be a non-empty string');
|
|
80
|
+
for (const k of ['rangeStart', 'rangeEnd']) {
|
|
81
|
+
const v = value[k];
|
|
82
|
+
if (v !== undefined && (!Number.isInteger(v) || v < 1)) {
|
|
83
|
+
errors.push(`${k} must be a positive integer when present`);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
if (Number.isInteger(value.rangeStart) &&
|
|
87
|
+
Number.isInteger(value.rangeEnd) &&
|
|
88
|
+
value.rangeEnd < value.rangeStart) {
|
|
89
|
+
errors.push('rangeEnd must be >= rangeStart');
|
|
90
|
+
}
|
|
91
|
+
if (!inUnitRange(value.riskScore))
|
|
92
|
+
errors.push('riskScore must be a number in [0,1]');
|
|
93
|
+
if (!isStringArray(value.suggestedTests))
|
|
94
|
+
errors.push('suggestedTests must be string[]');
|
|
95
|
+
return { valid: errors.length === 0, errors };
|
|
96
|
+
}
|
|
97
|
+
// ============================================================================
|
|
98
|
+
// Builders — derive contract envelopes at MCP boundaries
|
|
99
|
+
// ============================================================================
|
|
100
|
+
/**
|
|
101
|
+
* Derive a RiskDecision from a quality-gate outcome (quality_assess boundary).
|
|
102
|
+
* Indeterminate gates (passed undefined) escalate rather than guess.
|
|
103
|
+
*/
|
|
104
|
+
export function buildRiskDecisionFromQualityGate(input) {
|
|
105
|
+
const { passed, qualityScore, recommendations = [] } = input;
|
|
106
|
+
const decision = passed === true ? 'approve' : passed === false ? 'block' : 'escalate';
|
|
107
|
+
return {
|
|
108
|
+
contract: 'risk-decision@1',
|
|
109
|
+
decision,
|
|
110
|
+
riskFactors: recommendations.slice(0, 10),
|
|
111
|
+
confidence: decision === 'escalate' ? 0.5 : 0.9,
|
|
112
|
+
rationale: decision === 'escalate'
|
|
113
|
+
? 'Quality gate outcome indeterminate — manual review required'
|
|
114
|
+
: `Quality gate ${passed ? 'passed' : 'failed'}${typeof qualityScore === 'number' ? ` with score ${qualityScore}` : ''}`,
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
// ============================================================================
|
|
118
|
+
// JSON Schemas (draft-07) — mirrors of the validators above, published to
|
|
119
|
+
// schemas/*.schema.json for ajv / workflow agent({schema}) consumers
|
|
120
|
+
// ============================================================================
|
|
121
|
+
const unit = { type: 'number', minimum: 0, maximum: 1 };
|
|
122
|
+
const stringArray = { type: 'array', items: { type: 'string' } };
|
|
123
|
+
export const RISK_DECISION_SCHEMA = {
|
|
124
|
+
$schema: 'http://json-schema.org/draft-07/schema#',
|
|
125
|
+
$id: 'https://agentic-qe.dev/schemas/risk-decision.schema.json',
|
|
126
|
+
title: 'RiskDecision',
|
|
127
|
+
type: 'object',
|
|
128
|
+
required: ['contract', 'decision', 'riskFactors', 'confidence', 'rationale'],
|
|
129
|
+
additionalProperties: true,
|
|
130
|
+
properties: {
|
|
131
|
+
contract: { const: 'risk-decision@1' },
|
|
132
|
+
decision: { enum: ['approve', 'block', 'escalate'] },
|
|
133
|
+
riskFactors: stringArray,
|
|
134
|
+
confidence: unit,
|
|
135
|
+
rationale: { type: 'string', minLength: 1 },
|
|
136
|
+
},
|
|
137
|
+
};
|
|
138
|
+
export const FINDING_VERDICT_SCHEMA = {
|
|
139
|
+
$schema: 'http://json-schema.org/draft-07/schema#',
|
|
140
|
+
$id: 'https://agentic-qe.dev/schemas/finding-verdict.schema.json',
|
|
141
|
+
title: 'FindingVerdict',
|
|
142
|
+
type: 'object',
|
|
143
|
+
required: ['contract', 'id', 'title', 'severity', 'confidence', 'evidence', 'verdict', 'refutations'],
|
|
144
|
+
additionalProperties: true,
|
|
145
|
+
properties: {
|
|
146
|
+
contract: { const: 'finding-verdict@1' },
|
|
147
|
+
id: { type: 'string', minLength: 1 },
|
|
148
|
+
title: { type: 'string', minLength: 1 },
|
|
149
|
+
file: { type: 'string' },
|
|
150
|
+
severity: { enum: ['critical', 'high', 'medium', 'low', 'info'] },
|
|
151
|
+
confidence: unit,
|
|
152
|
+
evidence: stringArray,
|
|
153
|
+
verdict: { enum: ['upheld', 'refuted', 'uncertain'] },
|
|
154
|
+
refutations: stringArray,
|
|
155
|
+
},
|
|
156
|
+
};
|
|
157
|
+
export const COVERAGE_GAP_SCHEMA = {
|
|
158
|
+
$schema: 'http://json-schema.org/draft-07/schema#',
|
|
159
|
+
$id: 'https://agentic-qe.dev/schemas/coverage-gap.schema.json',
|
|
160
|
+
title: 'CoverageGap',
|
|
161
|
+
type: 'object',
|
|
162
|
+
required: ['contract', 'file', 'riskScore', 'suggestedTests'],
|
|
163
|
+
additionalProperties: true,
|
|
164
|
+
properties: {
|
|
165
|
+
contract: { const: 'coverage-gap@1' },
|
|
166
|
+
file: { type: 'string', minLength: 1 },
|
|
167
|
+
rangeStart: { type: 'integer', minimum: 1 },
|
|
168
|
+
rangeEnd: { type: 'integer', minimum: 1 },
|
|
169
|
+
riskScore: unit,
|
|
170
|
+
suggestedTests: stringArray,
|
|
171
|
+
},
|
|
172
|
+
};
|
|
173
|
+
export const VERDICT_SCHEMAS = {
|
|
174
|
+
'risk-decision': RISK_DECISION_SCHEMA,
|
|
175
|
+
'finding-verdict': FINDING_VERDICT_SCHEMA,
|
|
176
|
+
'coverage-gap': COVERAGE_GAP_SCHEMA,
|
|
177
|
+
};
|
|
178
|
+
//# sourceMappingURL=verdicts.js.map
|
|
@@ -45,6 +45,10 @@ export interface TaskExecution {
|
|
|
45
45
|
readonly result?: unknown;
|
|
46
46
|
readonly error?: string;
|
|
47
47
|
readonly retryCount: number;
|
|
48
|
+
/** ADR-101: agent that spawned this task (nested-subagent provenance) */
|
|
49
|
+
readonly parentAgentId?: string;
|
|
50
|
+
/** ADR-101: nesting depth, 0 = top-level (Anthropic cap is 5; bound is 32) */
|
|
51
|
+
readonly depth?: number;
|
|
48
52
|
}
|
|
49
53
|
/**
|
|
50
54
|
* Domain group for coordination
|
|
@@ -18,6 +18,7 @@ import { computeRealEmbedding, } from '../../../learning/real-embeddings.js';
|
|
|
18
18
|
import { CircularBuffer } from '../../../shared/utils/circular-buffer.js';
|
|
19
19
|
import { HNSWEmbeddingIndex } from '../../embeddings/index/HNSWIndex.js';
|
|
20
20
|
import { safeJsonParse } from '../../../shared/safe-json.js';
|
|
21
|
+
import { scrubReasoningBlocks } from '../../../shared/reasoning-scrub.js';
|
|
21
22
|
import { ExperienceConsolidator } from '../../../learning/experience-consolidation.js';
|
|
22
23
|
import { getRuVectorFeatureFlags } from '../../ruvector/feature-flags.js';
|
|
23
24
|
import { ReservoirReplayBuffer } from '../../ruvector/reservoir-replay.js';
|
|
@@ -126,7 +127,8 @@ export class ExperienceReplay {
|
|
|
126
127
|
`);
|
|
127
128
|
let written = 0;
|
|
128
129
|
for (const row of ghosts) {
|
|
129
|
-
|
|
130
|
+
// ADR-099: legacy rows may predate ingestion-time scrubbing
|
|
131
|
+
const text = scrubReasoningBlocks(`${row.domain ?? ''}: ${row.task}`).slice(0, 512);
|
|
130
132
|
const embedding = await computeRealEmbedding(text);
|
|
131
133
|
const buf = Buffer.from(new Float32Array(embedding).buffer);
|
|
132
134
|
updateStmt.run(buf, embedding.length, row.id);
|
|
@@ -174,7 +176,8 @@ export class ExperienceReplay {
|
|
|
174
176
|
const updateStmt = this.db.prepare(`UPDATE qe_trajectories SET embedding = ? WHERE id = ?`);
|
|
175
177
|
let written = 0;
|
|
176
178
|
for (const row of rows) {
|
|
177
|
-
|
|
179
|
+
// ADR-099: legacy rows may predate ingestion-time scrubbing
|
|
180
|
+
const text = scrubReasoningBlocks(`${row.domain ?? ''}: ${row.task}`).slice(0, 512);
|
|
178
181
|
const embedding = await computeRealEmbedding(text);
|
|
179
182
|
updateStmt.run(Buffer.from(new Float32Array(embedding).buffer), row.id);
|
|
180
183
|
written++;
|
|
@@ -373,18 +376,22 @@ export class ExperienceReplay {
|
|
|
373
376
|
return null;
|
|
374
377
|
}
|
|
375
378
|
// Extract key actions
|
|
379
|
+
// ADR-099: scrub reasoning scratchpad blocks so neither the stored
|
|
380
|
+
// experience nor its embedding carries extended-thinking text
|
|
381
|
+
const task = scrubReasoningBlocks(trajectory.task);
|
|
382
|
+
strategy = scrubReasoningBlocks(strategy);
|
|
376
383
|
const keyActions = trajectory.steps
|
|
377
384
|
.filter(s => s.result.outcome === 'success')
|
|
378
|
-
.map(s => s.action);
|
|
385
|
+
.map(s => scrubReasoningBlocks(s.action));
|
|
379
386
|
// Generate embedding for similarity search
|
|
380
|
-
const embeddingText = `${
|
|
387
|
+
const embeddingText = `${task} ${strategy} ${keyActions.join(' ')}`;
|
|
381
388
|
const embedding = await computeRealEmbedding(embeddingText, this.config.embedding);
|
|
382
389
|
const id = uuidv4();
|
|
383
390
|
const domain = trajectory.domain || 'test-generation';
|
|
384
391
|
const experience = {
|
|
385
392
|
id,
|
|
386
393
|
trajectoryId: trajectory.id,
|
|
387
|
-
task
|
|
394
|
+
task,
|
|
388
395
|
domain,
|
|
389
396
|
strategy,
|
|
390
397
|
keyActions,
|
|
@@ -401,7 +408,7 @@ export class ExperienceReplay {
|
|
|
401
408
|
const insertStmt = this.prepared.get('insertExperience');
|
|
402
409
|
if (insertStmt) {
|
|
403
410
|
const embeddingBuffer = embedding ? this.floatArrayToBuffer(embedding) : null;
|
|
404
|
-
insertStmt.run(id,
|
|
411
|
+
insertStmt.run(id, task, strategy, // agent column stores strategy
|
|
405
412
|
domain, trajectory.metrics.efficiencyScore, JSON.stringify(keyActions), // steps_json stores key actions
|
|
406
413
|
JSON.stringify(trajectory.metrics), // routing_json stores original metrics
|
|
407
414
|
embeddingBuffer, embedding?.length ?? null, JSON.stringify(tags));
|
|
@@ -523,6 +530,8 @@ export class ExperienceReplay {
|
|
|
523
530
|
return [];
|
|
524
531
|
}
|
|
525
532
|
// Generate embedding for the task
|
|
533
|
+
// ADR-099: scrub so query embeddings match the scrubbed stored embeddings
|
|
534
|
+
task = scrubReasoningBlocks(task);
|
|
526
535
|
const taskEmbedding = await computeRealEmbedding(task, this.config.embedding);
|
|
527
536
|
// Create query embedding for HNSW search
|
|
528
537
|
const queryEmbedding = {
|
|
@@ -11,6 +11,7 @@ import { v4 as uuidv4 } from 'uuid';
|
|
|
11
11
|
import { getUnifiedMemory } from '../../../kernel/unified-memory.js';
|
|
12
12
|
import { CircularBuffer } from '../../../shared/utils/circular-buffer.js';
|
|
13
13
|
import { safeJsonParse } from '../../../shared/safe-json.js';
|
|
14
|
+
import { scrubReasoningBlocks, scrubReasoningDeep } from '../../../shared/reasoning-scrub.js';
|
|
14
15
|
const DEFAULT_CONFIG = {
|
|
15
16
|
maxStepsPerTrajectory: 100,
|
|
16
17
|
autoEndTimeoutMs: 30 * 60 * 1000, // 30 minutes
|
|
@@ -222,6 +223,9 @@ export class TrajectoryTracker {
|
|
|
222
223
|
*/
|
|
223
224
|
async startTrajectory(task, options = {}) {
|
|
224
225
|
this.ensureInitialized();
|
|
226
|
+
// ADR-099: strip reasoning scratchpad blocks before the task text enters
|
|
227
|
+
// persistence and (later) embedding generation
|
|
228
|
+
task = scrubReasoningBlocks(task);
|
|
225
229
|
const id = uuidv4();
|
|
226
230
|
const startedAt = new Date();
|
|
227
231
|
// Store in memory for active tracking
|
|
@@ -270,6 +274,14 @@ export class TrajectoryTracker {
|
|
|
270
274
|
}
|
|
271
275
|
const stepId = uuidv4();
|
|
272
276
|
const quality = options.quality ?? this.calculateStepQuality(result);
|
|
277
|
+
// ADR-099: scrub reasoning blocks from step content before it is held
|
|
278
|
+
// in memory (distilled into experiences at endTrajectory) and persisted
|
|
279
|
+
action = scrubReasoningBlocks(action);
|
|
280
|
+
result = {
|
|
281
|
+
...result,
|
|
282
|
+
data: result.data ? scrubReasoningDeep(result.data) : result.data,
|
|
283
|
+
error: result.error ? scrubReasoningBlocks(result.error) : result.error,
|
|
284
|
+
};
|
|
273
285
|
const step = {
|
|
274
286
|
id: stepId,
|
|
275
287
|
action,
|