onbuzz 3.7.0 → 3.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/core/__tests__/agentPoolAutoResume.test.js +209 -0
- package/src/core/agentPool.js +17 -1
- package/src/core/agentScheduler.js +36 -4
- package/src/index.js +23 -0
- package/src/interfaces/webServer.js +132 -0
- package/src/modules/fileExplorer/__tests__/zipDownload.test.js +237 -0
- package/src/modules/fileExplorer/routes.js +102 -0
- package/src/services/__tests__/compactionRetry.test.js +272 -0
- package/src/services/__tests__/discordService.integration.test.js +505 -0
- package/src/services/__tests__/discordService.test.js +559 -0
- package/src/services/__tests__/promptServiceTimer.test.js +251 -0
- package/src/services/aiService.js +16 -0
- package/src/services/conversationCompactionService.js +83 -3
- package/src/services/discordService.js +647 -0
- package/src/services/promptService.js +46 -0
- package/src/tools/__tests__/filesystemTool.test.js +717 -0
- package/src/tools/fileSystemTool.js +1 -1
- package/src/tools/taskManagerTool.js +111 -13
- package/src/tools/visualEditorTool.js +25 -6
- package/src/utilities/constants.js +9 -7
- package/web-ui/build/index.html +2 -2
- package/web-ui/build/static/1c-DQZhJixd.js +1 -0
- package/web-ui/build/static/abap-jcbS-qYi.js +1 -0
- package/web-ui/build/static/abnf-C8BFyWHh.js +1 -0
- package/web-ui/build/static/abnf-DCfylG1r.js +1 -0
- package/web-ui/build/static/accesslog-B74nH2MW.js +1 -0
- package/web-ui/build/static/actionscript-CF3CElpZ.js +1 -0
- package/web-ui/build/static/actionscript-DYqJgZzV.js +1 -0
- package/web-ui/build/static/ada-BNH7OKDz.js +1 -0
- package/web-ui/build/static/ada-DlQgwseY.js +1 -0
- package/web-ui/build/static/agda-IylpxncM.js +1 -0
- package/web-ui/build/static/al-KjXYleZ9.js +1 -0
- package/web-ui/build/static/angelscript-COWzPiMv.js +1 -0
- package/web-ui/build/static/antlr4-CN-CUGqr.js +1 -0
- package/web-ui/build/static/apache-DguwgwuK.js +1 -0
- package/web-ui/build/static/apacheconf-eWcHsYF1.js +1 -0
- package/web-ui/build/static/apex-CCKpZDvd.js +1 -0
- package/web-ui/build/static/apl-Cdb0gHC1.js +1 -0
- package/web-ui/build/static/applescript-8K2JC3yp.js +1 -0
- package/web-ui/build/static/applescript-D0gZ0NPm.js +1 -0
- package/web-ui/build/static/aql-MbnZvyuX.js +1 -0
- package/web-ui/build/static/arcade-I6Lqht83.js +1 -0
- package/web-ui/build/static/arduino-CXkDHd_n.js +1 -0
- package/web-ui/build/static/arduino-Ccu8UQ9T.js +1 -0
- package/web-ui/build/static/arff-Ci3DLKL2.js +1 -0
- package/web-ui/build/static/armasm-DimsTcQx.js +1 -0
- package/web-ui/build/static/asciidoc-BQJJ4zZ1.js +1 -0
- package/web-ui/build/static/asciidoc-BQTVMcl8.js +1 -0
- package/web-ui/build/static/asm6502-BMIyLsLp.js +1 -0
- package/web-ui/build/static/asmatmel-BhgjQCVD.js +1 -0
- package/web-ui/build/static/aspectj-CLuxZycF.js +1 -0
- package/web-ui/build/static/aspnet-BqHMc19r.js +1 -0
- package/web-ui/build/static/autohotkey-C4YesMHy.js +1 -0
- package/web-ui/build/static/autohotkey-DNjoyChQ.js +1 -0
- package/web-ui/build/static/autoit-CHk1P_cF.js +1 -0
- package/web-ui/build/static/autoit-DS9A-G03.js +1 -0
- package/web-ui/build/static/avisynth-DICgtbTg.js +1 -0
- package/web-ui/build/static/avrasm-DjMF_WAr.js +1 -0
- package/web-ui/build/static/avro-idl-Cdc1XxcN.js +1 -0
- package/web-ui/build/static/awk-BdsPwgrU.js +1 -0
- package/web-ui/build/static/axapta-CPbDamY8.js +1 -0
- package/web-ui/build/static/bash-BOPrFz4C.js +1 -0
- package/web-ui/build/static/bash-JX5bBY92.js +1 -0
- package/web-ui/build/static/basic-Bu-vrocM.js +1 -0
- package/web-ui/build/static/basic-CIBQzPd2.js +1 -0
- package/web-ui/build/static/batch-Bbl0bA3Q.js +1 -0
- package/web-ui/build/static/bbcode-Fbj0Kri-.js +1 -0
- package/web-ui/build/static/bicep-Bf4-yQnl.js +1 -0
- package/web-ui/build/static/birb-DcpbRHXB.js +1 -0
- package/web-ui/build/static/bison-CDLJmWhw.js +1 -0
- package/web-ui/build/static/bnf-BeC5PC-s.js +1 -0
- package/web-ui/build/static/bnf-Bkjm5CHH.js +1 -0
- package/web-ui/build/static/brainfuck-Bq7Anw5S.js +1 -0
- package/web-ui/build/static/brainfuck-DZas4utH.js +1 -0
- package/web-ui/build/static/brightscript-Tba37hpM.js +1 -0
- package/web-ui/build/static/bro-DsE2bSOa.js +1 -0
- package/web-ui/build/static/bsl-4RZTBbEq.js +1 -0
- package/web-ui/build/static/c-DEk3ebj-.js +1 -0
- package/web-ui/build/static/c-like-CAEXbwuR.js +1 -0
- package/web-ui/build/static/c-xh_v0-z_.js +1 -0
- package/web-ui/build/static/cal-CSCTkeJY.js +1 -0
- package/web-ui/build/static/capnproto-Dv3brkDW.js +1 -0
- package/web-ui/build/static/ceylon-gikahgkK.js +1 -0
- package/web-ui/build/static/cfscript-VSs1e42R.js +1 -0
- package/web-ui/build/static/chaiscript-CbYMStW5.js +1 -0
- package/web-ui/build/static/cil-DT1wxWmp.js +1 -0
- package/web-ui/build/static/clean-Df_mH1zx.js +1 -0
- package/web-ui/build/static/clojure-B-9ioj1j.js +1 -0
- package/web-ui/build/static/clojure-DyV4dzij.js +1 -0
- package/web-ui/build/static/clojure-repl-CMQD4k0J.js +1 -0
- package/web-ui/build/static/cmake-CjQfG8ud.js +1 -0
- package/web-ui/build/static/cmake-ZA7YCB6y.js +1 -0
- package/web-ui/build/static/cobol-B60Z_qsn.js +1 -0
- package/web-ui/build/static/coffeescript-AiK_tFQr.js +1 -0
- package/web-ui/build/static/coffeescript-CCii4uxx.js +1 -0
- package/web-ui/build/static/concurnas-DdMVfQVm.js +1 -0
- package/web-ui/build/static/coq-DbrJpXIJ.js +1 -0
- package/web-ui/build/static/coq-DfQ0ztBe.js +1 -0
- package/web-ui/build/static/cos-C5wWuNOO.js +1 -0
- package/web-ui/build/static/cpp-BKaTciIR.js +1 -0
- package/web-ui/build/static/cpp-VoKD2fj1.js +1 -0
- package/web-ui/build/static/crmsh-piEaCtL6.js +1 -0
- package/web-ui/build/static/crystal-DXpDi2j6.js +1 -0
- package/web-ui/build/static/crystal-h3mPHkX7.js +1 -0
- package/web-ui/build/static/csharp-DEy5un5Z.js +1 -0
- package/web-ui/build/static/csharp-Di_Q9ozw.js +1 -0
- package/web-ui/build/static/cshtml-0u5MXiVi.js +1 -0
- package/web-ui/build/static/csp-B3m9yNAM.js +1 -0
- package/web-ui/build/static/csp-CqjT6U07.js +1 -0
- package/web-ui/build/static/css-BE3xVICv.js +1 -0
- package/web-ui/build/static/css-extras-CySgcz3e.js +1 -0
- package/web-ui/build/static/csv-KGPO_dk8.js +1 -0
- package/web-ui/build/static/cypher-Bo1_PY1N.js +1 -0
- package/web-ui/build/static/d-BC8RqAm_.js +1 -0
- package/web-ui/build/static/d-BLve56aI.js +1 -0
- package/web-ui/build/static/dart-B35PTaCm.js +1 -0
- package/web-ui/build/static/dart-C2YlroXm.js +1 -0
- package/web-ui/build/static/dataweave-CN50nAVf.js +1 -0
- package/web-ui/build/static/dax-CHSYrVod.js +1 -0
- package/web-ui/build/static/delphi-BgHX2xzz.js +1 -0
- package/web-ui/build/static/dhall-BGz4-nAc.js +1 -0
- package/web-ui/build/static/diff-DMY5y_DI.js +1 -0
- package/web-ui/build/static/diff-Dv4PtPUH.js +1 -0
- package/web-ui/build/static/django-Bb1vBtjE.js +1 -0
- package/web-ui/build/static/django-C2xF86EI.js +1 -0
- package/web-ui/build/static/dns-CnOxPa_z.js +1 -0
- package/web-ui/build/static/dns-zone-file-Bafr1g3z.js +1 -0
- package/web-ui/build/static/docker-B313CWFC.js +1 -0
- package/web-ui/build/static/dockerfile-OdWiLWEc.js +1 -0
- package/web-ui/build/static/dos-DxNcIdFI.js +1 -0
- package/web-ui/build/static/dot-VeVPbNzZ.js +1 -0
- package/web-ui/build/static/dsconfig-0y2xEGf-.js +1 -0
- package/web-ui/build/static/dts-DREi0l4a.js +1 -0
- package/web-ui/build/static/dust-DfvNpqfV.js +1 -0
- package/web-ui/build/static/ebnf-DcUtfew2.js +1 -0
- package/web-ui/build/static/ebnf-DvlPqoB4.js +1 -0
- package/web-ui/build/static/editorconfig-DHYUeApo.js +1 -0
- package/web-ui/build/static/eiffel-CfwmVSqQ.js +1 -0
- package/web-ui/build/static/ejs-DMz6aWQ3.js +1 -0
- package/web-ui/build/static/elixir-B4XJmrzm.js +1 -0
- package/web-ui/build/static/elixir-DvcMz9bd.js +1 -0
- package/web-ui/build/static/elm-BuGca3iI.js +1 -0
- package/web-ui/build/static/elm-DZ9WksKB.js +1 -0
- package/web-ui/build/static/erb-DBgOfar0.js +1 -0
- package/web-ui/build/static/erb-Dxfq3wNo.js +1 -0
- package/web-ui/build/static/erlang-D-YmsYiY.js +1 -0
- package/web-ui/build/static/erlang-repl-CNRRa3UJ.js +1 -0
- package/web-ui/build/static/erlang-rwow-cE9.js +1 -0
- package/web-ui/build/static/etlua-5An7iV5p.js +1 -0
- package/web-ui/build/static/excel-f9bR2bC7.js +1 -0
- package/web-ui/build/static/excel-formula-BaoCOHYh.js +1 -0
- package/web-ui/build/static/factor-BLb83S9U.js +1 -0
- package/web-ui/build/static/false-CmpOvE2a.js +1 -0
- package/web-ui/build/static/firestore-security-rules-BVI59GZZ.js +1 -0
- package/web-ui/build/static/fix-BF79j4bk.js +1 -0
- package/web-ui/build/static/flix-Dzm5-Ymh.js +1 -0
- package/web-ui/build/static/flow-B45H1tBM.js +1 -0
- package/web-ui/build/static/fortran-5QD_WC6L.js +1 -0
- package/web-ui/build/static/fortran-CpXSOOV5.js +1 -0
- package/web-ui/build/static/fsharp-C3lc5coB.js +1 -0
- package/web-ui/build/static/fsharp-LB12BbE7.js +1 -0
- package/web-ui/build/static/ftl-8sYtTFc-.js +1 -0
- package/web-ui/build/static/gams-Ce5pMTNL.js +1 -0
- package/web-ui/build/static/gap-oVO1SpQ_.js +1 -0
- package/web-ui/build/static/gauss-zX0vtXs8.js +1 -0
- package/web-ui/build/static/gcode-DLwc2lay.js +1 -0
- package/web-ui/build/static/gcode-T2ml-YpM.js +1 -0
- package/web-ui/build/static/gdscript-C6KcX_JD.js +1 -0
- package/web-ui/build/static/gedcom-DeIYfk9F.js +1 -0
- package/web-ui/build/static/gherkin-CkdPaT55.js +1 -0
- package/web-ui/build/static/gherkin-XM3laxUq.js +1 -0
- package/web-ui/build/static/git-Br9iczHm.js +1 -0
- package/web-ui/build/static/glsl-CBzg2o55.js +1 -0
- package/web-ui/build/static/glsl-DriXJFnb.js +1 -0
- package/web-ui/build/static/gml-B-agwJv1.js +1 -0
- package/web-ui/build/static/gml-BDfG2eFC.js +1 -0
- package/web-ui/build/static/gn-D61Xuc6h.js +1 -0
- package/web-ui/build/static/go-CU_iSpxK.js +1 -0
- package/web-ui/build/static/go-DDLqpPAZ.js +1 -0
- package/web-ui/build/static/go-module-BDA0BkLV.js +1 -0
- package/web-ui/build/static/golo-Cv3GIUiS.js +1 -0
- package/web-ui/build/static/gradle-i5NhoSFx.js +1 -0
- package/web-ui/build/static/graphql-B2lk0sWL.js +1 -0
- package/web-ui/build/static/groovy-DBVkacP2.js +1 -0
- package/web-ui/build/static/groovy-o_wtm9j3.js +1 -0
- package/web-ui/build/static/haml-EHdA878O.js +1 -0
- package/web-ui/build/static/haml-dAHqwBkg.js +1 -0
- package/web-ui/build/static/handlebars-C5Tozmxc.js +1 -0
- package/web-ui/build/static/handlebars-Dyyc-fIz.js +1 -0
- package/web-ui/build/static/haskell-BobFtAX9.js +1 -0
- package/web-ui/build/static/haskell-Dwp-x9aV.js +1 -0
- package/web-ui/build/static/haxe-3AwSUM3s.js +1 -0
- package/web-ui/build/static/haxe-DSXgLcSz.js +1 -0
- package/web-ui/build/static/hcl-G4adEKaz.js +1 -0
- package/web-ui/build/static/hlsl-YFPdD2DF.js +1 -0
- package/web-ui/build/static/hoon-DwPpTugn.js +1 -0
- package/web-ui/build/static/hpkp-CKf-BifN.js +1 -0
- package/web-ui/build/static/hsp-ClZnSAIQ.js +1 -0
- package/web-ui/build/static/hsts-2Fcq0sWo.js +1 -0
- package/web-ui/build/static/htmlbars-BlVRg-Xj.js +1 -0
- package/web-ui/build/static/http-C0R1csZD.js +1 -0
- package/web-ui/build/static/http-fefdUXGG.js +1 -0
- package/web-ui/build/static/hy-DYDgrI8_.js +1 -0
- package/web-ui/build/static/ichigojam-BM1MGPOe.js +1 -0
- package/web-ui/build/static/icon-BZ1Cb6KH.js +1 -0
- package/web-ui/build/static/icu-message-format-B1qWjTGj.js +1 -0
- package/web-ui/build/static/idris-gmTNNmvX.js +1 -0
- package/web-ui/build/static/iecst-DdiQIvdF.js +1 -0
- package/web-ui/build/static/ignore-tFQ9l2Rn.js +1 -0
- package/web-ui/build/static/index-B3LQ5vNm.js +13 -0
- package/web-ui/build/static/index-BNTBWfAV.js +1 -0
- package/web-ui/build/static/index-BydTFOJo.js +819 -0
- package/web-ui/build/static/index-CgjhwrCA.css +1 -0
- package/web-ui/build/static/inform7-SSco8KBJ.js +1 -0
- package/web-ui/build/static/inform7-yEMWJcEu.js +1 -0
- package/web-ui/build/static/ini-C4fcFIKV.js +1 -0
- package/web-ui/build/static/ini-YVuIbcnM.js +1 -0
- package/web-ui/build/static/io-DPQWeD7I.js +1 -0
- package/web-ui/build/static/irpf90-B87ZLBag.js +1 -0
- package/web-ui/build/static/isbl-BO4fL12g.js +1 -0
- package/web-ui/build/static/j-BypfBpFH.js +1 -0
- package/web-ui/build/static/java-4hDAuTKm.js +1 -0
- package/web-ui/build/static/java-CybBd6Ck.js +1 -0
- package/web-ui/build/static/javadoc-m2xud0X-.js +1 -0
- package/web-ui/build/static/javadoclike-DTr7-Hyr.js +1 -0
- package/web-ui/build/static/javascript-BQLVmcyb.js +1 -0
- package/web-ui/build/static/javastacktrace-7Nb8W9B2.js +1 -0
- package/web-ui/build/static/jboss-cli-ClEuFXCv.js +1 -0
- package/web-ui/build/static/jexl-CWhULFjx.js +1 -0
- package/web-ui/build/static/jolie-CX4jhDy8.js +1 -0
- package/web-ui/build/static/jq-DQYCqPgM.js +1 -0
- package/web-ui/build/static/js-extras-CmuMG4V-.js +1 -0
- package/web-ui/build/static/js-templates-psX-_yXa.js +1 -0
- package/web-ui/build/static/jsdoc-Bec0-Tg-.js +1 -0
- package/web-ui/build/static/json-BMsRcKQy.js +1 -0
- package/web-ui/build/static/json-D6lyXyX8.js +1 -0
- package/web-ui/build/static/json5-mOKVxAwC.js +1 -0
- package/web-ui/build/static/jsonp-BrjXvkW5.js +1 -0
- package/web-ui/build/static/jsstacktrace-CNTpQPR9.js +1 -0
- package/web-ui/build/static/jsx-vbszxbSu.js +1 -0
- package/web-ui/build/static/julia-DbT1TAHl.js +1 -0
- package/web-ui/build/static/julia-DwlTZxPf.js +1 -0
- package/web-ui/build/static/julia-repl-B0601McL.js +1 -0
- package/web-ui/build/static/keepalived-BkPa4Dqn.js +1 -0
- package/web-ui/build/static/keyman-nCt8r9rk.js +1 -0
- package/web-ui/build/static/kotlin-CdsyHGtn.js +1 -0
- package/web-ui/build/static/kotlin-DgyAL0Vc.js +1 -0
- package/web-ui/build/static/kumir-CEkP8N7P.js +1 -0
- package/web-ui/build/static/kusto-6TxHf-jz.js +1 -0
- package/web-ui/build/static/lasso-CQ8OsHiQ.js +1 -0
- package/web-ui/build/static/latex-1QQnNLTt.js +1 -0
- package/web-ui/build/static/latex-BwuPJ3BU.js +1 -0
- package/web-ui/build/static/latte-tMu4iXLd.js +1 -0
- package/web-ui/build/static/ldif-CI0Mtnwp.js +1 -0
- package/web-ui/build/static/leaf-Gqdr9gvs.js +1 -0
- package/web-ui/build/static/less-CZ6ZJX6l.js +1 -0
- package/web-ui/build/static/less-KlFg2xhz.js +1 -0
- package/web-ui/build/static/lilypond-CTbR74Hw.js +1 -0
- package/web-ui/build/static/liquid-Bm-iMRfD.js +1 -0
- package/web-ui/build/static/lisp-B9EeIebh.js +1 -0
- package/web-ui/build/static/lisp-n5BSmbHN.js +1 -0
- package/web-ui/build/static/livecodeserver-DUutdIm_.js +1 -0
- package/web-ui/build/static/livescript-B8EKROWL.js +1 -0
- package/web-ui/build/static/livescript-DBwrrseu.js +1 -0
- package/web-ui/build/static/llvm-CGIN5zDj.js +1 -0
- package/web-ui/build/static/llvm-ipRtBY9v.js +1 -0
- package/web-ui/build/static/log-Bx1i-I-U.js +1 -0
- package/web-ui/build/static/lolcode-D37Mj6bT.js +1 -0
- package/web-ui/build/static/lsl-BLIuFvgZ.js +1 -0
- package/web-ui/build/static/lua-3OFwCNzr.js +1 -0
- package/web-ui/build/static/lua-QA9Qsv8O.js +1 -0
- package/web-ui/build/static/magma-BZ1hY7k1.js +1 -0
- package/web-ui/build/static/makefile-CheEZ39i.js +1 -0
- package/web-ui/build/static/makefile-Do-FV7sA.js +1 -0
- package/web-ui/build/static/markdown-C9x5qaS2.js +1 -0
- package/web-ui/build/static/markdown-DeoqJuS-.js +1 -0
- package/web-ui/build/static/markup-templating-k597cuoU.js +1 -0
- package/web-ui/build/static/mathematica-D7X22VPf.js +1 -0
- package/web-ui/build/static/matlab-BTZVvA1V.js +1 -0
- package/web-ui/build/static/matlab-CAaNOORF.js +1 -0
- package/web-ui/build/static/maxima-DQ5hExkg.js +1 -0
- package/web-ui/build/static/maxscript-P166IuIA.js +1 -0
- package/web-ui/build/static/mel-Dea_UDQn.js +1 -0
- package/web-ui/build/static/mel-SWS8MbL4.js +1 -0
- package/web-ui/build/static/mercury-B15taW16.js +1 -0
- package/web-ui/build/static/mermaid-D9uycv0U.js +1 -0
- package/web-ui/build/static/mipsasm-DWLSI8yY.js +1 -0
- package/web-ui/build/static/mizar-DZfOAx1W.js +1 -0
- package/web-ui/build/static/mizar-wP7qld9h.js +1 -0
- package/web-ui/build/static/mojolicious-OhN1hKXJ.js +1 -0
- package/web-ui/build/static/mongodb-CfTJAVbl.js +1 -0
- package/web-ui/build/static/monkey-DH8dtKmh.js +1 -0
- package/web-ui/build/static/monkey-zSRbKN7Z.js +1 -0
- package/web-ui/build/static/moonscript-B8jjrc-e.js +1 -0
- package/web-ui/build/static/moonscript-DQPTKOKN.js +1 -0
- package/web-ui/build/static/n1ql-CD9IiqlN.js +1 -0
- package/web-ui/build/static/n1ql-sTdqCmt9.js +1 -0
- package/web-ui/build/static/n4js-CS8ZuFHv.js +1 -0
- package/web-ui/build/static/nand2tetris-hdl-2gmAgTTc.js +1 -0
- package/web-ui/build/static/naniscript-C1awJ6HX.js +1 -0
- package/web-ui/build/static/nasm-tZxTecp8.js +1 -0
- package/web-ui/build/static/neon-BiPM6i5R.js +1 -0
- package/web-ui/build/static/nevod-ouMmEjzd.js +1 -0
- package/web-ui/build/static/nginx-C6hKsxV1.js +1 -0
- package/web-ui/build/static/nginx-CuNu7OOU.js +1 -0
- package/web-ui/build/static/nim-BOMQEpXl.js +1 -0
- package/web-ui/build/static/nim-BWRQ178A.js +1 -0
- package/web-ui/build/static/nix-BtBupNzF.js +1 -0
- package/web-ui/build/static/nix-hXlrnIP1.js +1 -0
- package/web-ui/build/static/node-repl-0Z-b1jsu.js +1 -0
- package/web-ui/build/static/nsis-DvyxUYoE.js +1 -0
- package/web-ui/build/static/nsis-dSmierty.js +1 -0
- package/web-ui/build/static/objectivec-C-Pf0sDM.js +1 -0
- package/web-ui/build/static/objectivec-D84mTJ5F.js +1 -0
- package/web-ui/build/static/ocaml-0eGuEirH.js +1 -0
- package/web-ui/build/static/ocaml-DGF3MJcj.js +1 -0
- package/web-ui/build/static/opencl-CV2zqHFD.js +1 -0
- package/web-ui/build/static/openqasm-BMU26Vhz.js +1 -0
- package/web-ui/build/static/openscad-CtmyK1r-.js +1 -0
- package/web-ui/build/static/oxygene-CctiOBRE.js +1 -0
- package/web-ui/build/static/oz-BnClHcIU.js +1 -0
- package/web-ui/build/static/parigp-DM1yhSck.js +1 -0
- package/web-ui/build/static/parser-CD57pwRj.js +1 -0
- package/web-ui/build/static/parser3-B36qohVL.js +1 -0
- package/web-ui/build/static/pascal-CHiGN25z.js +1 -0
- package/web-ui/build/static/pascaligo-Cm3W5RZ2.js +1 -0
- package/web-ui/build/static/pcaxis-B2Lxy_S3.js +1 -0
- package/web-ui/build/static/peoplecode-1lpcxUWV.js +1 -0
- package/web-ui/build/static/perl-BQtKW1zd.js +1 -0
- package/web-ui/build/static/perl-F4BSKDUu.js +1 -0
- package/web-ui/build/static/pf-B6nZ1tB1.js +1 -0
- package/web-ui/build/static/pgsql-BKr70t8w.js +1 -0
- package/web-ui/build/static/php-BP7uFrTU.js +1 -0
- package/web-ui/build/static/php-CDUYY_2M.js +1 -0
- package/web-ui/build/static/php-extras-CTvR9ZFI.js +1 -0
- package/web-ui/build/static/php-template-Dq9meGro.js +1 -0
- package/web-ui/build/static/phpdoc-DSr-kVLU.js +1 -0
- package/web-ui/build/static/plaintext-DZnAC4aX.js +1 -0
- package/web-ui/build/static/plsql-Buq_GU6U.js +1 -0
- package/web-ui/build/static/pony-JzUyTPyR.js +1 -0
- package/web-ui/build/static/powerquery-CzCeJ7RE.js +1 -0
- package/web-ui/build/static/powershell-7JFf14So.js +1 -0
- package/web-ui/build/static/powershell-Cep8HTlS.js +1 -0
- package/web-ui/build/static/processing--HVNHaGl.js +1 -0
- package/web-ui/build/static/processing-BfgK_eM-.js +1 -0
- package/web-ui/build/static/profile-P-a8dWVd.js +1 -0
- package/web-ui/build/static/prolog-CjwjuXPC.js +1 -0
- package/web-ui/build/static/prolog-DSZIgF50.js +1 -0
- package/web-ui/build/static/promql-BAkGfj5s.js +1 -0
- package/web-ui/build/static/properties-dUkcvmd6.js +1 -0
- package/web-ui/build/static/properties-x-wnweER.js +1 -0
- package/web-ui/build/static/protobuf-DWLUJD3_.js +1 -0
- package/web-ui/build/static/protobuf-G2h4_GQ6.js +1 -0
- package/web-ui/build/static/psl-BAvYGQm1.js +1 -0
- package/web-ui/build/static/pug-BmEIyWnb.js +1 -0
- package/web-ui/build/static/puppet-DK6yX9Kb.js +1 -0
- package/web-ui/build/static/puppet-OyU62P-J.js +1 -0
- package/web-ui/build/static/pure-DYbufb4b.js +1 -0
- package/web-ui/build/static/purebasic-BpNxGYhX.js +1 -0
- package/web-ui/build/static/purebasic-DHPw9Taz.js +1 -0
- package/web-ui/build/static/purescript-D-wYAmFw.js +1 -0
- package/web-ui/build/static/python-BZ9aYTNK.js +1 -0
- package/web-ui/build/static/python-DYkVdyEn.js +1 -0
- package/web-ui/build/static/python-repl-BllOn4wD.js +1 -0
- package/web-ui/build/static/q-BCSd4pFN.js +1 -0
- package/web-ui/build/static/q-DvBdv0dn.js +1 -0
- package/web-ui/build/static/qml-BilPoUNq.js +1 -0
- package/web-ui/build/static/qml-DBy9k93V.js +1 -0
- package/web-ui/build/static/qore-DdKIDU5q.js +1 -0
- package/web-ui/build/static/qsharp-dYwM1ZdA.js +1 -0
- package/web-ui/build/static/r-D-ZmoQlZ.js +1 -0
- package/web-ui/build/static/r-Jz8JUNIn.js +1 -0
- package/web-ui/build/static/racket-eaDXGE9n.js +1 -0
- package/web-ui/build/static/reason-B0k-k2bb.js +1 -0
- package/web-ui/build/static/reasonml-yQ_uJZv3.js +1 -0
- package/web-ui/build/static/regex-38B1u1Ig.js +1 -0
- package/web-ui/build/static/rego-CGJeWnlJ.js +1 -0
- package/web-ui/build/static/renpy-ChuBxeI8.js +1 -0
- package/web-ui/build/static/rest-bUTWZx08.js +1 -0
- package/web-ui/build/static/rib-BcERfc_O.js +1 -0
- package/web-ui/build/static/rip-DYPRA5Vl.js +1 -0
- package/web-ui/build/static/roboconf-DRhQco59.js +1 -0
- package/web-ui/build/static/roboconf-DSogU9t9.js +1 -0
- package/web-ui/build/static/robotframework-50KhPl7Z.js +1 -0
- package/web-ui/build/static/routeros-BNZHZi1f.js +1 -0
- package/web-ui/build/static/rsl-DOqfw7z7.js +1 -0
- package/web-ui/build/static/ruby-BZ7pZFBr.js +1 -0
- package/web-ui/build/static/ruby-DdqIuM3h.js +1 -0
- package/web-ui/build/static/ruleslanguage-DRWDHp0i.js +1 -0
- package/web-ui/build/static/rust-DGO2kGWZ.js +1 -0
- package/web-ui/build/static/rust-fE54r8Sa.js +1 -0
- package/web-ui/build/static/sas-BvynLpPR.js +1 -0
- package/web-ui/build/static/sas-Ch5kYxfO.js +1 -0
- package/web-ui/build/static/sass-CmIhqaoF.js +1 -0
- package/web-ui/build/static/scala-Dm8HU6AF.js +1 -0
- package/web-ui/build/static/scala-d2rS5ahM.js +1 -0
- package/web-ui/build/static/scheme-BeOBERfO.js +1 -0
- package/web-ui/build/static/scheme-Bu438SBC.js +1 -0
- package/web-ui/build/static/scilab-BNTTBE7k.js +1 -0
- package/web-ui/build/static/scss-CqXMiECw.js +1 -0
- package/web-ui/build/static/scss-rCvANcI5.js +1 -0
- package/web-ui/build/static/shell-CcE9Emp_.js +1 -0
- package/web-ui/build/static/shell-session-BSsPBY87.js +1 -0
- package/web-ui/build/static/smali-BA5qcrek.js +1 -0
- package/web-ui/build/static/smali-CYRcyTSG.js +1 -0
- package/web-ui/build/static/smalltalk-B4b0saS1.js +1 -0
- package/web-ui/build/static/smalltalk-DRi4mC5P.js +1 -0
- package/web-ui/build/static/smarty-jVnj0bqK.js +1 -0
- package/web-ui/build/static/sml-Cxj3GJIV.js +1 -0
- package/web-ui/build/static/sml-XyPrN6KF.js +1 -0
- package/web-ui/build/static/solidity-0qOWAJpD.js +1 -0
- package/web-ui/build/static/solution-file-CuyBr6ep.js +1 -0
- package/web-ui/build/static/soy-Bk_b1jHj.js +1 -0
- package/web-ui/build/static/sparql-DzrwPsKF.js +1 -0
- package/web-ui/build/static/splunk-spl-BaPMuXa4.js +1 -0
- package/web-ui/build/static/sqf-B_oF1tVo.js +1 -0
- package/web-ui/build/static/sqf-C6A9wolp.js +1 -0
- package/web-ui/build/static/sql-B6NQlhRZ.js +1 -0
- package/web-ui/build/static/sql-BzgEpszE.js +1 -0
- package/web-ui/build/static/sql_more-BXaAmV-S.js +1 -0
- package/web-ui/build/static/squirrel-CGwNppBF.js +1 -0
- package/web-ui/build/static/stan-C5jS2VgU.js +1 -0
- package/web-ui/build/static/stan-LaITyIDc.js +1 -0
- package/web-ui/build/static/stata-npwfM7zE.js +1 -0
- package/web-ui/build/static/step21-CUX9ve4Y.js +1 -0
- package/web-ui/build/static/stylus-DpnL9zpo.js +1 -0
- package/web-ui/build/static/stylus-h3eZL3e_.js +1 -0
- package/web-ui/build/static/subunit-DzlxDWRl.js +1 -0
- package/web-ui/build/static/swift-B_dEx54z.js +1 -0
- package/web-ui/build/static/swift-C1kgSgEu.js +1 -0
- package/web-ui/build/static/systemd-6LGnwh0Q.js +1 -0
- package/web-ui/build/static/t4-cs-CuJ8R4Ej.js +1 -0
- package/web-ui/build/static/t4-templating-B73Z4jdy.js +1 -0
- package/web-ui/build/static/t4-vb-19b5EuoQ.js +1 -0
- package/web-ui/build/static/taggerscript-BQKNCrFp.js +1 -0
- package/web-ui/build/static/tap-BkD7e5f9.js +1 -0
- package/web-ui/build/static/tap-jeXr4g4R.js +1 -0
- package/web-ui/build/static/tcl-BP2rNXH-.js +1 -0
- package/web-ui/build/static/tcl-PFm8u7O1.js +1 -0
- package/web-ui/build/static/textile-BS9I4q8g.js +1 -0
- package/web-ui/build/static/thrift-BcfcGZ7Z.js +1 -0
- package/web-ui/build/static/toml-58rz0fiz.js +1 -0
- package/web-ui/build/static/tp-BbCj038Z.js +1 -0
- package/web-ui/build/static/tremor-D4m_vL82.js +1 -0
- package/web-ui/build/static/tsx-HncuqJGW.js +1 -0
- package/web-ui/build/static/tt2-oUUPgLZ_.js +1 -0
- package/web-ui/build/static/turtle-DUBHo4bj.js +1 -0
- package/web-ui/build/static/twig-Cq3htTRx.js +1 -0
- package/web-ui/build/static/twig-trYoIRRL.js +1 -0
- package/web-ui/build/static/typescript-B3Kdakxu.js +1 -0
- package/web-ui/build/static/typescript-BCX_4UZl.js +1 -0
- package/web-ui/build/static/typoscript-BSBtU4jq.js +1 -0
- package/web-ui/build/static/unrealscript-BMFqdJqx.js +1 -0
- package/web-ui/build/static/uorazor-QaTALCl5.js +1 -0
- package/web-ui/build/static/uri-BT5WB8Zp.js +1 -0
- package/web-ui/build/static/v-B8iw7r8j.js +1 -0
- package/web-ui/build/static/vala-DAeusypP.js +1 -0
- package/web-ui/build/static/vala-shoILkhJ.js +1 -0
- package/web-ui/build/static/vbnet-Bg4xq7Z0.js +1 -0
- package/web-ui/build/static/vbnet-CAdVR0Rf.js +1 -0
- package/web-ui/build/static/vbscript-CgdaY0nC.js +1 -0
- package/web-ui/build/static/vbscript-html-BtY9Hf15.js +1 -0
- package/web-ui/build/static/velocity-CzZx5-jh.js +1 -0
- package/web-ui/build/static/verilog-B6gjurlt.js +1 -0
- package/web-ui/build/static/verilog-CtF4gLu6.js +1 -0
- package/web-ui/build/static/vhdl-7_r1L5WG.js +1 -0
- package/web-ui/build/static/vhdl-CyQjSL-n.js +1 -0
- package/web-ui/build/static/vim-Bw4ePWG5.js +1 -0
- package/web-ui/build/static/vim-DGXJoziv.js +1 -0
- package/web-ui/build/static/visual-basic-Z0cpzfUI.js +1 -0
- package/web-ui/build/static/warpscript-DR5ykbRR.js +1 -0
- package/web-ui/build/static/wasm-CzKwkMwK.js +1 -0
- package/web-ui/build/static/web-idl-CBpaqpbk.js +1 -0
- package/web-ui/build/static/wiki-DAlEPjkp.js +1 -0
- package/web-ui/build/static/wolfram-BjGOb_ug.js +1 -0
- package/web-ui/build/static/wren-DgTT6pzB.js +1 -0
- package/web-ui/build/static/x86asm-DF9sTmvg.js +1 -0
- package/web-ui/build/static/xeora-D3OpIJ1y.js +1 -0
- package/web-ui/build/static/xl-CZ8lHBjF.js +1 -0
- package/web-ui/build/static/xml-Cz2nv6eo.js +1 -0
- package/web-ui/build/static/xml-doc-BXA2vzES.js +1 -0
- package/web-ui/build/static/xojo-iTRoQfSv.js +1 -0
- package/web-ui/build/static/xquery-Fq1Vzr9v.js +1 -0
- package/web-ui/build/static/xquery-YTPBil5C.js +1 -0
- package/web-ui/build/static/yaml-BO9w92gu.js +1 -0
- package/web-ui/build/static/yaml-BZNZjH6O.js +1 -0
- package/web-ui/build/static/yang-B0KXJeNg.js +1 -0
- package/web-ui/build/static/zephir-DTiqvpWn.js +1 -0
- package/web-ui/build/static/zig-CVZVSNfd.js +1 -0
- package/src/tools/__tests__/fileSystemTool.test.js +0 -717
- package/web-ui/build/static/1c-BlrHh78j.js +0 -1
- package/web-ui/build/static/abap-_FM2fO0A.js +0 -1
- package/web-ui/build/static/abnf-BCg5l0uq.js +0 -1
- package/web-ui/build/static/abnf-bjp9lfvU.js +0 -1
- package/web-ui/build/static/accesslog-oWIbABC7.js +0 -1
- package/web-ui/build/static/actionscript-BL-UEd19.js +0 -1
- package/web-ui/build/static/actionscript-BdgU11VW.js +0 -1
- package/web-ui/build/static/ada-2jo1mg6S.js +0 -1
- package/web-ui/build/static/ada-BJKXcDpH.js +0 -1
- package/web-ui/build/static/agda-BI2k58w0.js +0 -1
- package/web-ui/build/static/al-9pQmDGIl.js +0 -1
- package/web-ui/build/static/angelscript-XIBdMnfJ.js +0 -1
- package/web-ui/build/static/antlr4-D-ZDWzMb.js +0 -1
- package/web-ui/build/static/apache-DMhil-MY.js +0 -1
- package/web-ui/build/static/apacheconf-DGcKDVce.js +0 -1
- package/web-ui/build/static/apex-DZOd60Pp.js +0 -1
- package/web-ui/build/static/apl-In7HeqFP.js +0 -1
- package/web-ui/build/static/applescript-CV7_S_Z9.js +0 -1
- package/web-ui/build/static/applescript-h0wfiWYj.js +0 -1
- package/web-ui/build/static/aql-BJEqUjR-.js +0 -1
- package/web-ui/build/static/arcade-7mSfmbHh.js +0 -1
- package/web-ui/build/static/arduino-CLTxDDKW.js +0 -1
- package/web-ui/build/static/arduino-DzOv2F37.js +0 -1
- package/web-ui/build/static/arff-DKkV2tlj.js +0 -1
- package/web-ui/build/static/armasm-DQgXdSck.js +0 -1
- package/web-ui/build/static/asciidoc-BjoDOhtL.js +0 -1
- package/web-ui/build/static/asciidoc-C5Ldz-2k.js +0 -1
- package/web-ui/build/static/asm6502-Bx3mopF9.js +0 -1
- package/web-ui/build/static/asmatmel-CtJb8Bm-.js +0 -1
- package/web-ui/build/static/aspectj-BQjRLKNR.js +0 -1
- package/web-ui/build/static/aspnet-DWBLFotO.js +0 -1
- package/web-ui/build/static/autohotkey-C-YN-KsQ.js +0 -1
- package/web-ui/build/static/autohotkey-mz5BB0In.js +0 -1
- package/web-ui/build/static/autoit-CDRJDCnX.js +0 -1
- package/web-ui/build/static/autoit-CXm-b_sO.js +0 -1
- package/web-ui/build/static/avisynth-Bi0_P3BV.js +0 -1
- package/web-ui/build/static/avrasm-D9WGD48m.js +0 -1
- package/web-ui/build/static/avro-idl-TDOgmXVo.js +0 -1
- package/web-ui/build/static/awk-D29cheDd.js +0 -1
- package/web-ui/build/static/axapta-BzO9TZ9g.js +0 -1
- package/web-ui/build/static/bash-BIV-IMgg.js +0 -1
- package/web-ui/build/static/bash-ViWzMYxC.js +0 -1
- package/web-ui/build/static/basic-CNzSY9iY.js +0 -1
- package/web-ui/build/static/basic-L71-Ju4M.js +0 -1
- package/web-ui/build/static/batch-DoOCpY4Z.js +0 -1
- package/web-ui/build/static/bbcode-cfGINYKl.js +0 -1
- package/web-ui/build/static/bicep-BHdKpDQS.js +0 -1
- package/web-ui/build/static/birb-iu1uBV-C.js +0 -1
- package/web-ui/build/static/bison-CreP8C4K.js +0 -1
- package/web-ui/build/static/bnf-Cf4Kjht-.js +0 -1
- package/web-ui/build/static/bnf-DB0Gt2Zo.js +0 -1
- package/web-ui/build/static/brainfuck-CBICa1Wj.js +0 -1
- package/web-ui/build/static/brainfuck-D_g682MY.js +0 -1
- package/web-ui/build/static/brightscript-CiohIbpi.js +0 -1
- package/web-ui/build/static/bro-CauioUkg.js +0 -1
- package/web-ui/build/static/bsl-BOoTmdZX.js +0 -1
- package/web-ui/build/static/c-C3O_kFMi.js +0 -1
- package/web-ui/build/static/c-IJZdX1u8.js +0 -1
- package/web-ui/build/static/c-like-BBpyChEP.js +0 -1
- package/web-ui/build/static/cal-BdOa1Gwi.js +0 -1
- package/web-ui/build/static/capnproto-COPvly3A.js +0 -1
- package/web-ui/build/static/ceylon-s1BnkZSe.js +0 -1
- package/web-ui/build/static/cfscript-DwVXJuCm.js +0 -1
- package/web-ui/build/static/chaiscript-CSscijqP.js +0 -1
- package/web-ui/build/static/cil-dyrlrBb8.js +0 -1
- package/web-ui/build/static/clean-CH4fJMuF.js +0 -1
- package/web-ui/build/static/clojure-BNopSp7o.js +0 -1
- package/web-ui/build/static/clojure-CRkwHz6e.js +0 -1
- package/web-ui/build/static/clojure-repl-CWdDQ2vE.js +0 -1
- package/web-ui/build/static/cmake-CvggjX5p.js +0 -1
- package/web-ui/build/static/cmake-IXMKfUfx.js +0 -1
- package/web-ui/build/static/cobol-BltwikzZ.js +0 -1
- package/web-ui/build/static/coffeescript-55G2HARA.js +0 -1
- package/web-ui/build/static/coffeescript-sQHJBCLd.js +0 -1
- package/web-ui/build/static/concurnas-dNhU2fMP.js +0 -1
- package/web-ui/build/static/coq-D7oTdG55.js +0 -1
- package/web-ui/build/static/coq-cXhRp1dp.js +0 -1
- package/web-ui/build/static/cos-C7i2Layt.js +0 -1
- package/web-ui/build/static/cpp-DIjjs9Bt.js +0 -1
- package/web-ui/build/static/cpp-DZ3X8oTi.js +0 -1
- package/web-ui/build/static/crmsh-DRccV68B.js +0 -1
- package/web-ui/build/static/crystal-BV1cPIXz.js +0 -1
- package/web-ui/build/static/crystal-D8c9sfap.js +0 -1
- package/web-ui/build/static/csharp-CS7M_as7.js +0 -1
- package/web-ui/build/static/csharp-Dd_Z53o8.js +0 -1
- package/web-ui/build/static/cshtml-D8UwS_BJ.js +0 -1
- package/web-ui/build/static/csp-B4HBhuTQ.js +0 -1
- package/web-ui/build/static/csp-KT5I_MQ2.js +0 -1
- package/web-ui/build/static/css-B92Qcnd4.js +0 -1
- package/web-ui/build/static/css-extras-DxSH3TUW.js +0 -1
- package/web-ui/build/static/csv-BKj8Pv2U.js +0 -1
- package/web-ui/build/static/cypher-BY2uT6yz.js +0 -1
- package/web-ui/build/static/d-Bcrym4RM.js +0 -1
- package/web-ui/build/static/d-CzfsDfQy.js +0 -1
- package/web-ui/build/static/dart-Bn_3WEIT.js +0 -1
- package/web-ui/build/static/dart-MeNj_4h6.js +0 -1
- package/web-ui/build/static/dataweave-CaivFI6P.js +0 -1
- package/web-ui/build/static/dax-tp2nPqsr.js +0 -1
- package/web-ui/build/static/delphi-DTDoPYA_.js +0 -1
- package/web-ui/build/static/dhall-BjmZTfmQ.js +0 -1
- package/web-ui/build/static/diff-CKU-PMTL.js +0 -1
- package/web-ui/build/static/diff-F3eRT0vN.js +0 -1
- package/web-ui/build/static/django-ItwycP6m.js +0 -1
- package/web-ui/build/static/django-TePC2Pg1.js +0 -1
- package/web-ui/build/static/dns-BLSPC2tJ.js +0 -1
- package/web-ui/build/static/dns-zone-file-CAWkDknQ.js +0 -1
- package/web-ui/build/static/docker-BChc1Hzt.js +0 -1
- package/web-ui/build/static/dockerfile-CNlAzsMo.js +0 -1
- package/web-ui/build/static/dos-DWVZ-srC.js +0 -1
- package/web-ui/build/static/dot-BvdcslVQ.js +0 -1
- package/web-ui/build/static/dsconfig-DJ-96CUp.js +0 -1
- package/web-ui/build/static/dts-YE7T6H_5.js +0 -1
- package/web-ui/build/static/dust-h6_7tOBV.js +0 -1
- package/web-ui/build/static/ebnf-Dnv5WsY4.js +0 -1
- package/web-ui/build/static/ebnf-TlcsFH2w.js +0 -1
- package/web-ui/build/static/editorconfig-BwVXrhO9.js +0 -1
- package/web-ui/build/static/eiffel-BuaKIwFF.js +0 -1
- package/web-ui/build/static/ejs-DxAWCeU5.js +0 -1
- package/web-ui/build/static/elixir-C1r2eUrS.js +0 -1
- package/web-ui/build/static/elixir-Cc6Uv5mK.js +0 -1
- package/web-ui/build/static/elm-CxYyIzU5.js +0 -1
- package/web-ui/build/static/elm-DbOvvckA.js +0 -1
- package/web-ui/build/static/erb-CipwjrNI.js +0 -1
- package/web-ui/build/static/erb-DG49Y25z.js +0 -1
- package/web-ui/build/static/erlang-BVxLSAbG.js +0 -1
- package/web-ui/build/static/erlang-DOQ8pTIn.js +0 -1
- package/web-ui/build/static/erlang-repl-CjtN5aLk.js +0 -1
- package/web-ui/build/static/etlua-T-MIPc56.js +0 -1
- package/web-ui/build/static/excel-CovJQExC.js +0 -1
- package/web-ui/build/static/excel-formula-Dl1dBnPV.js +0 -1
- package/web-ui/build/static/factor-BwKMEj6C.js +0 -1
- package/web-ui/build/static/false-BhHjZIB8.js +0 -1
- package/web-ui/build/static/firestore-security-rules-B28qcbbn.js +0 -1
- package/web-ui/build/static/fix-nu-sRNKo.js +0 -1
- package/web-ui/build/static/flix-2x0_B7om.js +0 -1
- package/web-ui/build/static/flow-BXxbKI2P.js +0 -1
- package/web-ui/build/static/fortran-B1dPvyp7.js +0 -1
- package/web-ui/build/static/fortran-Dy3SKNj1.js +0 -1
- package/web-ui/build/static/fsharp-BvUCQMwU.js +0 -1
- package/web-ui/build/static/fsharp-QamXHMM-.js +0 -1
- package/web-ui/build/static/ftl-LoFW5mH6.js +0 -1
- package/web-ui/build/static/gams-C065UISp.js +0 -1
- package/web-ui/build/static/gap-C9KLK5fX.js +0 -1
- package/web-ui/build/static/gauss-xcDG6Tuu.js +0 -1
- package/web-ui/build/static/gcode-BuLEK5Xs.js +0 -1
- package/web-ui/build/static/gcode-D3XAgRhF.js +0 -1
- package/web-ui/build/static/gdscript-_w5Q3570.js +0 -1
- package/web-ui/build/static/gedcom-BOHICUnT.js +0 -1
- package/web-ui/build/static/gherkin-BQmMAkDw.js +0 -1
- package/web-ui/build/static/gherkin-pqQyur-X.js +0 -1
- package/web-ui/build/static/git-CI2AADA-.js +0 -1
- package/web-ui/build/static/glsl-Bh8zh8mj.js +0 -1
- package/web-ui/build/static/glsl-C3FqJJMe.js +0 -1
- package/web-ui/build/static/gml-BycSQm7B.js +0 -1
- package/web-ui/build/static/gml-DnmTBUms.js +0 -1
- package/web-ui/build/static/gn-CZCJwrA8.js +0 -1
- package/web-ui/build/static/go-B-eVlnsj.js +0 -1
- package/web-ui/build/static/go-BbxMWSfm.js +0 -1
- package/web-ui/build/static/go-module-Bv-o10ZZ.js +0 -1
- package/web-ui/build/static/golo-BexGZreJ.js +0 -1
- package/web-ui/build/static/gradle-CN3mbg6r.js +0 -1
- package/web-ui/build/static/graphql-BZkUs1N9.js +0 -1
- package/web-ui/build/static/groovy-FO3EIHpG.js +0 -1
- package/web-ui/build/static/groovy-h5dGV7lF.js +0 -1
- package/web-ui/build/static/haml--biotPuc.js +0 -1
- package/web-ui/build/static/haml-Ks_81seg.js +0 -1
- package/web-ui/build/static/handlebars-BVfACCgi.js +0 -1
- package/web-ui/build/static/handlebars-DyafjZYu.js +0 -1
- package/web-ui/build/static/haskell-DC-EMXpY.js +0 -1
- package/web-ui/build/static/haskell-DFyu5bk6.js +0 -1
- package/web-ui/build/static/haxe-CJS2BrQd.js +0 -1
- package/web-ui/build/static/haxe-DmoNEqjU.js +0 -1
- package/web-ui/build/static/hcl-DEnv6zfu.js +0 -1
- package/web-ui/build/static/hlsl-BNT9UaoE.js +0 -1
- package/web-ui/build/static/hoon-ClPTUKZr.js +0 -1
- package/web-ui/build/static/hpkp-D_sOtiuH.js +0 -1
- package/web-ui/build/static/hsp-Doi3mr8d.js +0 -1
- package/web-ui/build/static/hsts-BOhib0IZ.js +0 -1
- package/web-ui/build/static/htmlbars-CwsQg6HI.js +0 -1
- package/web-ui/build/static/http-CqL1l0zD.js +0 -1
- package/web-ui/build/static/http-Cv64IO9P.js +0 -1
- package/web-ui/build/static/hy-91xuPraT.js +0 -1
- package/web-ui/build/static/ichigojam-tPibVBsf.js +0 -1
- package/web-ui/build/static/icon-BdpU5ujH.js +0 -1
- package/web-ui/build/static/icu-message-format-BCRjCx0V.js +0 -1
- package/web-ui/build/static/idris-DfTBbO-F.js +0 -1
- package/web-ui/build/static/iecst-Dl-4-4V9.js +0 -1
- package/web-ui/build/static/ignore-DPGnJ7dK.js +0 -1
- package/web-ui/build/static/index-BHFx5gqZ.js +0 -1
- package/web-ui/build/static/index-CniI5veb.js +0 -816
- package/web-ui/build/static/index-DPFadqM6.css +0 -1
- package/web-ui/build/static/index-Dk5AiDjB.js +0 -13
- package/web-ui/build/static/inform7-DKDA94H1.js +0 -1
- package/web-ui/build/static/inform7-iHglhSrw.js +0 -1
- package/web-ui/build/static/ini-BJrGoNqI.js +0 -1
- package/web-ui/build/static/ini-DCD8m5HG.js +0 -1
- package/web-ui/build/static/io-CSM_nGtS.js +0 -1
- package/web-ui/build/static/irpf90-ClLilwKb.js +0 -1
- package/web-ui/build/static/isbl-eFR7NRHn.js +0 -1
- package/web-ui/build/static/j-gsN31nPq.js +0 -1
- package/web-ui/build/static/java-EG70g_LQ.js +0 -1
- package/web-ui/build/static/java-blpgpVJ2.js +0 -1
- package/web-ui/build/static/javadoc-CQRYAMoH.js +0 -1
- package/web-ui/build/static/javadoclike-CtntEcxp.js +0 -1
- package/web-ui/build/static/javascript-wVlUOB0t.js +0 -1
- package/web-ui/build/static/javastacktrace-CV-3Txhr.js +0 -1
- package/web-ui/build/static/jboss-cli-De7Nuw78.js +0 -1
- package/web-ui/build/static/jexl-DeQWTWa9.js +0 -1
- package/web-ui/build/static/jolie-m4gKZWw6.js +0 -1
- package/web-ui/build/static/jq-Ck_ck9Yr.js +0 -1
- package/web-ui/build/static/js-extras-CRDSBe8l.js +0 -1
- package/web-ui/build/static/js-templates-C4T7ZxFp.js +0 -1
- package/web-ui/build/static/jsdoc-Dcxfssc6.js +0 -1
- package/web-ui/build/static/json-Cubgga7t.js +0 -1
- package/web-ui/build/static/json-D_Um5YKp.js +0 -1
- package/web-ui/build/static/json5-BcTtn_qy.js +0 -1
- package/web-ui/build/static/jsonp-DB5UQQBQ.js +0 -1
- package/web-ui/build/static/jsstacktrace-BEmh2JUu.js +0 -1
- package/web-ui/build/static/jsx-C44cEZ6P.js +0 -1
- package/web-ui/build/static/julia-CqYzy3SO.js +0 -1
- package/web-ui/build/static/julia-DBdUPK-5.js +0 -1
- package/web-ui/build/static/julia-repl-Kil57S7q.js +0 -1
- package/web-ui/build/static/keepalived-BR8Hz7wW.js +0 -1
- package/web-ui/build/static/keyman-C4aibtgp.js +0 -1
- package/web-ui/build/static/kotlin-D4baaoJz.js +0 -1
- package/web-ui/build/static/kotlin-DQ_6kGUI.js +0 -1
- package/web-ui/build/static/kumir-Dp2oRWNT.js +0 -1
- package/web-ui/build/static/kusto-DsFORaZv.js +0 -1
- package/web-ui/build/static/lasso-C2W0rk4U.js +0 -1
- package/web-ui/build/static/latex-BsfVgWP-.js +0 -1
- package/web-ui/build/static/latex-DpZCEa5A.js +0 -1
- package/web-ui/build/static/latte-DASikqZh.js +0 -1
- package/web-ui/build/static/ldif-DrW53I82.js +0 -1
- package/web-ui/build/static/leaf-wYG-mkOs.js +0 -1
- package/web-ui/build/static/less-4gWxeWxX.js +0 -1
- package/web-ui/build/static/less-jSdnB7MJ.js +0 -1
- package/web-ui/build/static/lilypond-DCqi1TqY.js +0 -1
- package/web-ui/build/static/liquid-DtLp3ZvK.js +0 -1
- package/web-ui/build/static/lisp-BpPJTlyh.js +0 -1
- package/web-ui/build/static/lisp-Cxv53m14.js +0 -1
- package/web-ui/build/static/livecodeserver-Dzf3gr-3.js +0 -1
- package/web-ui/build/static/livescript-AlJ3qFZK.js +0 -1
- package/web-ui/build/static/livescript-O29gv6rf.js +0 -1
- package/web-ui/build/static/llvm-CfAnjwpz.js +0 -1
- package/web-ui/build/static/llvm-DdnSDCwZ.js +0 -1
- package/web-ui/build/static/log-bDm8ND3_.js +0 -1
- package/web-ui/build/static/lolcode-sgfxVMFb.js +0 -1
- package/web-ui/build/static/lsl-szeadEr9.js +0 -1
- package/web-ui/build/static/lua-CY5AVgA0.js +0 -1
- package/web-ui/build/static/lua-DLJFMT9b.js +0 -1
- package/web-ui/build/static/magma-DbcuJbkz.js +0 -1
- package/web-ui/build/static/makefile-CEo7Nrg9.js +0 -1
- package/web-ui/build/static/makefile-SeiicPQK.js +0 -1
- package/web-ui/build/static/markdown-BRDGZsy7.js +0 -1
- package/web-ui/build/static/markdown-OzKszMEj.js +0 -1
- package/web-ui/build/static/markup-templating-C2p1cjKn.js +0 -1
- package/web-ui/build/static/mathematica-DGHXEpfY.js +0 -1
- package/web-ui/build/static/matlab-CciIBZPN.js +0 -1
- package/web-ui/build/static/matlab-DuhvPde0.js +0 -1
- package/web-ui/build/static/maxima-DW4VnNIU.js +0 -1
- package/web-ui/build/static/maxscript-Hj4rM016.js +0 -1
- package/web-ui/build/static/mel-CBnXhWOy.js +0 -1
- package/web-ui/build/static/mel-CjtpIzp_.js +0 -1
- package/web-ui/build/static/mercury-BkFc4ZpL.js +0 -1
- package/web-ui/build/static/mermaid-Ee8PxF5r.js +0 -1
- package/web-ui/build/static/mipsasm-QJjlp0ez.js +0 -1
- package/web-ui/build/static/mizar-AJIAYqZz.js +0 -1
- package/web-ui/build/static/mizar-J3pHvI5_.js +0 -1
- package/web-ui/build/static/mojolicious-DXqu9uix.js +0 -1
- package/web-ui/build/static/mongodb-8t6aGfIL.js +0 -1
- package/web-ui/build/static/monkey-Bq7XAxxX.js +0 -1
- package/web-ui/build/static/monkey-DZRPsZlz.js +0 -1
- package/web-ui/build/static/moonscript-BMyoWudl.js +0 -1
- package/web-ui/build/static/moonscript-DdxCgtZd.js +0 -1
- package/web-ui/build/static/n1ql-CQQEfFqp.js +0 -1
- package/web-ui/build/static/n1ql-M35VaQPs.js +0 -1
- package/web-ui/build/static/n4js-Nn3F8iYd.js +0 -1
- package/web-ui/build/static/nand2tetris-hdl-CY0Mydq-.js +0 -1
- package/web-ui/build/static/naniscript-Bf5FUeKE.js +0 -1
- package/web-ui/build/static/nasm-oE_Ev8Tl.js +0 -1
- package/web-ui/build/static/neon-BW1074YC.js +0 -1
- package/web-ui/build/static/nevod-DJtC733W.js +0 -1
- package/web-ui/build/static/nginx-B_WXvUom.js +0 -1
- package/web-ui/build/static/nginx-D3OVAhg6.js +0 -1
- package/web-ui/build/static/nim-BqRhQ5Ag.js +0 -1
- package/web-ui/build/static/nim-DuX0Fjdw.js +0 -1
- package/web-ui/build/static/nix-BIBF2qLF.js +0 -1
- package/web-ui/build/static/nix-DBUOjNC5.js +0 -1
- package/web-ui/build/static/node-repl-CkfIQQw6.js +0 -1
- package/web-ui/build/static/nsis-CcaUTCJR.js +0 -1
- package/web-ui/build/static/nsis-DAFOyySm.js +0 -1
- package/web-ui/build/static/objectivec-C2RgUPHf.js +0 -1
- package/web-ui/build/static/objectivec-DfLpZaoG.js +0 -1
- package/web-ui/build/static/ocaml-D7WlxCwk.js +0 -1
- package/web-ui/build/static/ocaml-DfPqJu9M.js +0 -1
- package/web-ui/build/static/opencl-CYqIs6u6.js +0 -1
- package/web-ui/build/static/openqasm-DLX_72b7.js +0 -1
- package/web-ui/build/static/openscad-GMIf4cc5.js +0 -1
- package/web-ui/build/static/oxygene-CNswvvUF.js +0 -1
- package/web-ui/build/static/oz-JFPs4bgR.js +0 -1
- package/web-ui/build/static/parigp-BSSSGRJA.js +0 -1
- package/web-ui/build/static/parser-DCqP-nIT.js +0 -1
- package/web-ui/build/static/parser3-DofTJ497.js +0 -1
- package/web-ui/build/static/pascal-sG1DCn8R.js +0 -1
- package/web-ui/build/static/pascaligo-cf6T97z0.js +0 -1
- package/web-ui/build/static/pcaxis-dyCMpcef.js +0 -1
- package/web-ui/build/static/peoplecode-C70rykMW.js +0 -1
- package/web-ui/build/static/perl-BeeWO9vp.js +0 -1
- package/web-ui/build/static/perl-P3vFKJ8a.js +0 -1
- package/web-ui/build/static/pf-CEKDR2LS.js +0 -1
- package/web-ui/build/static/pgsql-BfDaRjai.js +0 -1
- package/web-ui/build/static/php-CjE1PpxQ.js +0 -1
- package/web-ui/build/static/php-U-t65-Me.js +0 -1
- package/web-ui/build/static/php-extras-DkIpQpJC.js +0 -1
- package/web-ui/build/static/php-template-C_rq-1y-.js +0 -1
- package/web-ui/build/static/phpdoc-BPjFV-08.js +0 -1
- package/web-ui/build/static/plaintext-Bi35zOIR.js +0 -1
- package/web-ui/build/static/plsql-Bmeh6R8z.js +0 -1
- package/web-ui/build/static/pony-Ca1cGVk1.js +0 -1
- package/web-ui/build/static/powerquery-BEjnDYhm.js +0 -1
- package/web-ui/build/static/powershell-BSZfIEEW.js +0 -1
- package/web-ui/build/static/powershell-CzAuSE69.js +0 -1
- package/web-ui/build/static/processing-6jK7zPrr.js +0 -1
- package/web-ui/build/static/processing-C94fonUc.js +0 -1
- package/web-ui/build/static/profile-DyAUroFp.js +0 -1
- package/web-ui/build/static/prolog-DUVOta7P.js +0 -1
- package/web-ui/build/static/prolog-W9tPXtWW.js +0 -1
- package/web-ui/build/static/promql-DR8137yx.js +0 -1
- package/web-ui/build/static/properties--ca7dnFz.js +0 -1
- package/web-ui/build/static/properties-Sos46c1M.js +0 -1
- package/web-ui/build/static/protobuf-BF_35Z6Q.js +0 -1
- package/web-ui/build/static/protobuf-D9XtpA7u.js +0 -1
- package/web-ui/build/static/psl-BK1k9K-L.js +0 -1
- package/web-ui/build/static/pug-B9rWB8cB.js +0 -1
- package/web-ui/build/static/puppet-BUdnP_xy.js +0 -1
- package/web-ui/build/static/puppet-H2FLeckN.js +0 -1
- package/web-ui/build/static/pure-B801YQaj.js +0 -1
- package/web-ui/build/static/purebasic-Crezxyps.js +0 -1
- package/web-ui/build/static/purebasic-DXZfkZ-V.js +0 -1
- package/web-ui/build/static/purescript-BLM3Pc1X.js +0 -1
- package/web-ui/build/static/python-3I9bWKiI.js +0 -1
- package/web-ui/build/static/python-DTdH_5_D.js +0 -1
- package/web-ui/build/static/python-repl-BeURYy_8.js +0 -1
- package/web-ui/build/static/q-C61HVOUt.js +0 -1
- package/web-ui/build/static/q-DURNNyeE.js +0 -1
- package/web-ui/build/static/qml-CKanVt6U.js +0 -1
- package/web-ui/build/static/qml-gPQSMOdX.js +0 -1
- package/web-ui/build/static/qore-BUFhnjzS.js +0 -1
- package/web-ui/build/static/qsharp-C923dDYX.js +0 -1
- package/web-ui/build/static/r-A92xuI2g.js +0 -1
- package/web-ui/build/static/r-Dt0nCttC.js +0 -1
- package/web-ui/build/static/racket-BYZde8iG.js +0 -1
- package/web-ui/build/static/reason-0dUluItR.js +0 -1
- package/web-ui/build/static/reasonml-npg8nG4N.js +0 -1
- package/web-ui/build/static/regex-jVmSitjz.js +0 -1
- package/web-ui/build/static/rego-DfvPUx8N.js +0 -1
- package/web-ui/build/static/renpy-DE2svz6U.js +0 -1
- package/web-ui/build/static/rest-BcMBEAjJ.js +0 -1
- package/web-ui/build/static/rib-Dl26FqEH.js +0 -1
- package/web-ui/build/static/rip-Bz84xYrp.js +0 -1
- package/web-ui/build/static/roboconf-Dj89PcRA.js +0 -1
- package/web-ui/build/static/roboconf-vtg7vCOk.js +0 -1
- package/web-ui/build/static/robotframework-Bldi1oWh.js +0 -1
- package/web-ui/build/static/routeros-DKoSqqzC.js +0 -1
- package/web-ui/build/static/rsl-BFhqGeyO.js +0 -1
- package/web-ui/build/static/ruby-BM90rOrD.js +0 -1
- package/web-ui/build/static/ruby-CfPgimVP.js +0 -1
- package/web-ui/build/static/ruleslanguage-CGpDPEya.js +0 -1
- package/web-ui/build/static/rust-BnWVmE8f.js +0 -1
- package/web-ui/build/static/rust-C5xnSUBf.js +0 -1
- package/web-ui/build/static/sas-D201Exyi.js +0 -1
- package/web-ui/build/static/sas-DcncDygD.js +0 -1
- package/web-ui/build/static/sass-BdqMitdY.js +0 -1
- package/web-ui/build/static/scala-DNNT4nLs.js +0 -1
- package/web-ui/build/static/scala-kEmw5Quy.js +0 -1
- package/web-ui/build/static/scheme-BZuurIoy.js +0 -1
- package/web-ui/build/static/scheme-Et3A8oH2.js +0 -1
- package/web-ui/build/static/scilab-DBdlHTPM.js +0 -1
- package/web-ui/build/static/scss-BBhzMDCD.js +0 -1
- package/web-ui/build/static/scss-Dg3Nir_b.js +0 -1
- package/web-ui/build/static/shell-BUuThspA.js +0 -1
- package/web-ui/build/static/shell-session-B7bvuyPf.js +0 -1
- package/web-ui/build/static/smali-BELiKY3k.js +0 -1
- package/web-ui/build/static/smali-BxjuNefK.js +0 -1
- package/web-ui/build/static/smalltalk-B4EsZ2EJ.js +0 -1
- package/web-ui/build/static/smalltalk-lTwcoGYD.js +0 -1
- package/web-ui/build/static/smarty-DIPVvzKE.js +0 -1
- package/web-ui/build/static/sml-CfaXHqx0.js +0 -1
- package/web-ui/build/static/sml-CvFsXYHC.js +0 -1
- package/web-ui/build/static/solidity-BDj3y-05.js +0 -1
- package/web-ui/build/static/solution-file-DFLmzmGp.js +0 -1
- package/web-ui/build/static/soy-CHOnVWTz.js +0 -1
- package/web-ui/build/static/sparql-Hcjtig-Y.js +0 -1
- package/web-ui/build/static/splunk-spl-CrltuYBp.js +0 -1
- package/web-ui/build/static/sqf-BC1V0tcX.js +0 -1
- package/web-ui/build/static/sqf-DIwz7oZ1.js +0 -1
- package/web-ui/build/static/sql-C7YCUUIj.js +0 -1
- package/web-ui/build/static/sql-Cq3_lvQI.js +0 -1
- package/web-ui/build/static/sql_more-D4tCPipO.js +0 -1
- package/web-ui/build/static/squirrel-BdibIHgM.js +0 -1
- package/web-ui/build/static/stan-CaxJGJrt.js +0 -1
- package/web-ui/build/static/stan-CiELmaSj.js +0 -1
- package/web-ui/build/static/stata-DlcJ2LFr.js +0 -1
- package/web-ui/build/static/step21-DhrgKSOW.js +0 -1
- package/web-ui/build/static/stylus-CZjt3SJI.js +0 -1
- package/web-ui/build/static/stylus-C_Hh8X-x.js +0 -1
- package/web-ui/build/static/subunit-BkiDvJmr.js +0 -1
- package/web-ui/build/static/swift-Cit9Wp6e.js +0 -1
- package/web-ui/build/static/swift-CoVj9bgZ.js +0 -1
- package/web-ui/build/static/systemd-B8kNk_Tb.js +0 -1
- package/web-ui/build/static/t4-cs-DVvQFuLK.js +0 -1
- package/web-ui/build/static/t4-templating-ikCj1p8X.js +0 -1
- package/web-ui/build/static/t4-vb-1VgvkiTv.js +0 -1
- package/web-ui/build/static/taggerscript-Zu1G-l4N.js +0 -1
- package/web-ui/build/static/tap-cdYqjnm1.js +0 -1
- package/web-ui/build/static/tap-rRBspZts.js +0 -1
- package/web-ui/build/static/tcl-CJyyMjlH.js +0 -1
- package/web-ui/build/static/tcl-vW9riGb8.js +0 -1
- package/web-ui/build/static/textile-B2GDAAnW.js +0 -1
- package/web-ui/build/static/thrift-B4BE_hRc.js +0 -1
- package/web-ui/build/static/toml-C9yQDJ2s.js +0 -1
- package/web-ui/build/static/tp-C7nFKHNE.js +0 -1
- package/web-ui/build/static/tremor-C_HsoZlg.js +0 -1
- package/web-ui/build/static/tsx-Dc6knZPL.js +0 -1
- package/web-ui/build/static/tt2-IN2xqYKH.js +0 -1
- package/web-ui/build/static/turtle-DVsyoksr.js +0 -1
- package/web-ui/build/static/twig-Cl6cQ494.js +0 -1
- package/web-ui/build/static/twig-DbH0_SH8.js +0 -1
- package/web-ui/build/static/typescript-Bbgu_HG4.js +0 -1
- package/web-ui/build/static/typescript-Byl2fDGm.js +0 -1
- package/web-ui/build/static/typoscript-8_1tCA9q.js +0 -1
- package/web-ui/build/static/unrealscript-Bnk2Fv5r.js +0 -1
- package/web-ui/build/static/uorazor-CQSna7SS.js +0 -1
- package/web-ui/build/static/uri-CdTVADHh.js +0 -1
- package/web-ui/build/static/v-65XnRvBX.js +0 -1
- package/web-ui/build/static/vala-D4N8h-VC.js +0 -1
- package/web-ui/build/static/vala-hJIni_Vg.js +0 -1
- package/web-ui/build/static/vbnet-DEJ3ht5y.js +0 -1
- package/web-ui/build/static/vbnet-DcrQ8ARb.js +0 -1
- package/web-ui/build/static/vbscript-CMriusPn.js +0 -1
- package/web-ui/build/static/vbscript-html-DUdOc5iD.js +0 -1
- package/web-ui/build/static/velocity-BOEqpiHv.js +0 -1
- package/web-ui/build/static/verilog-CysEPERq.js +0 -1
- package/web-ui/build/static/verilog-k_ck79hD.js +0 -1
- package/web-ui/build/static/vhdl-IGdX3X1H.js +0 -1
- package/web-ui/build/static/vhdl-z4hbi7Us.js +0 -1
- package/web-ui/build/static/vim-B-0oRv6O.js +0 -1
- package/web-ui/build/static/vim-BQvI1efu.js +0 -1
- package/web-ui/build/static/visual-basic-DjRvuKpY.js +0 -1
- package/web-ui/build/static/warpscript-Bd2WOwl9.js +0 -1
- package/web-ui/build/static/wasm-DjaLmjiy.js +0 -1
- package/web-ui/build/static/web-idl-Btlt2Db6.js +0 -1
- package/web-ui/build/static/wiki-DGS1Kp3y.js +0 -1
- package/web-ui/build/static/wolfram-BL83yE3I.js +0 -1
- package/web-ui/build/static/wren-lxZgzgDT.js +0 -1
- package/web-ui/build/static/x86asm-g0rDhQNk.js +0 -1
- package/web-ui/build/static/xeora-C2_qV-JU.js +0 -1
- package/web-ui/build/static/xl-ZZEMAC0q.js +0 -1
- package/web-ui/build/static/xml-CHEyAvJF.js +0 -1
- package/web-ui/build/static/xml-doc-CoZ-ivqh.js +0 -1
- package/web-ui/build/static/xojo-Dpw9Hj_e.js +0 -1
- package/web-ui/build/static/xquery-2b32xTbX.js +0 -1
- package/web-ui/build/static/xquery-BxHxuvCl.js +0 -1
- package/web-ui/build/static/yaml-BcPNkuyp.js +0 -1
- package/web-ui/build/static/yaml-CpG5lHLV.js +0 -1
- package/web-ui/build/static/yang-DmJsiRFL.js +0 -1
- package/web-ui/build/static/zephir-CmmEV7bN.js +0 -1
- package/web-ui/build/static/zig-CL38WbGp.js +0 -1
|
@@ -0,0 +1,505 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Discord Service — Integration / Flow Tests
|
|
3
|
+
*
|
|
4
|
+
* Tests complete flows across components rather than isolated units:
|
|
5
|
+
* - Full message round-trip (Discord msg → agent → response back to channel)
|
|
6
|
+
* - API route integration (HTTP → service → response)
|
|
7
|
+
* - Broadcast chain integrity (multiple services wrapping broadcastToSession)
|
|
8
|
+
* - Config persistence round-trip (save → reload → verify state)
|
|
9
|
+
* - Multi-channel isolation (agent responses only go to originating channel)
|
|
10
|
+
* - Agent lifecycle (deletion cleans up stale mappings)
|
|
11
|
+
*/
|
|
12
|
+
|
|
13
|
+
import { jest, describe, test, expect, beforeEach, afterEach } from '@jest/globals';
|
|
14
|
+
import { createMockLogger } from '../../__test-utils__/mockFactories.js';
|
|
15
|
+
|
|
16
|
+
// Mock fs for config persistence
|
|
17
|
+
const mockFs = {
|
|
18
|
+
mkdir: jest.fn().mockResolvedValue(undefined),
|
|
19
|
+
readFile: jest.fn().mockRejectedValue(new Error('ENOENT')),
|
|
20
|
+
writeFile: jest.fn().mockResolvedValue(undefined)
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
jest.unstable_mockModule('fs', () => ({
|
|
24
|
+
promises: mockFs
|
|
25
|
+
}));
|
|
26
|
+
|
|
27
|
+
jest.unstable_mockModule('../../utilities/userDataDir.js', () => ({
|
|
28
|
+
getUserDataPaths: () => ({ base: '/mock/data' }),
|
|
29
|
+
ensureUserDataDirs: jest.fn().mockResolvedValue(undefined)
|
|
30
|
+
}));
|
|
31
|
+
|
|
32
|
+
const { DiscordService, DISCORD_STATUS } = await import('../discordService.js');
|
|
33
|
+
|
|
34
|
+
// --- Helpers ---
|
|
35
|
+
|
|
36
|
+
function createService() {
|
|
37
|
+
const logger = createMockLogger();
|
|
38
|
+
const service = new DiscordService(logger);
|
|
39
|
+
return service;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
function createMockOrchestrator() {
|
|
43
|
+
return {
|
|
44
|
+
processRequest: jest.fn().mockResolvedValue({ success: true })
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
function createMockAgentPool(agents = {}) {
|
|
49
|
+
return {
|
|
50
|
+
getAgent: jest.fn().mockImplementation(id => Promise.resolve(agents[id] || null)),
|
|
51
|
+
getAllAgents: jest.fn().mockReturnValue(Object.values(agents))
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
function createMockChannel(id = 'c1') {
|
|
56
|
+
return {
|
|
57
|
+
id,
|
|
58
|
+
send: jest.fn().mockResolvedValue({}),
|
|
59
|
+
sendTyping: jest.fn().mockResolvedValue(undefined)
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
function createDiscordMessage(content, opts = {}) {
|
|
64
|
+
const guildId = opts.guildId || 'guild-1';
|
|
65
|
+
const channelId = opts.channelId || 'ch-1';
|
|
66
|
+
return {
|
|
67
|
+
content,
|
|
68
|
+
author: { bot: opts.bot || false, id: opts.userId || 'user-42' },
|
|
69
|
+
guild: opts.noDM ? null : { id: guildId },
|
|
70
|
+
channel: {
|
|
71
|
+
id: channelId,
|
|
72
|
+
send: jest.fn().mockResolvedValue({}),
|
|
73
|
+
sendTyping: jest.fn().mockResolvedValue(undefined)
|
|
74
|
+
},
|
|
75
|
+
reply: jest.fn().mockResolvedValue({})
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
// ========================================================================
|
|
80
|
+
// FLOW 1: Full message round-trip
|
|
81
|
+
// Discord message → _handleMessage → orchestrator → broadcast → channel.send
|
|
82
|
+
// ========================================================================
|
|
83
|
+
|
|
84
|
+
describe('Flow: Full message round-trip', () => {
|
|
85
|
+
let service, orchestrator, agentPool, mockChannel;
|
|
86
|
+
|
|
87
|
+
beforeEach(() => {
|
|
88
|
+
service = createService();
|
|
89
|
+
orchestrator = createMockOrchestrator();
|
|
90
|
+
agentPool = createMockAgentPool({
|
|
91
|
+
'agent-alpha': { id: 'agent-alpha', name: 'Alpha' }
|
|
92
|
+
});
|
|
93
|
+
mockChannel = createMockChannel('ch-1');
|
|
94
|
+
|
|
95
|
+
service.setOrchestrator(orchestrator);
|
|
96
|
+
service.setAgentPool(agentPool);
|
|
97
|
+
service.status = DISCORD_STATUS.CONNECTED;
|
|
98
|
+
service.client = {
|
|
99
|
+
channels: { fetch: jest.fn().mockResolvedValue(mockChannel) }
|
|
100
|
+
};
|
|
101
|
+
|
|
102
|
+
// Map agent to channel
|
|
103
|
+
service.channelMappings = { 'guild-1:ch-1': ['agent-alpha'] };
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
test('user sends message → agent processes → response appears in same channel', async () => {
|
|
107
|
+
// Step 1: Incoming Discord message
|
|
108
|
+
const msg = createDiscordMessage('explain recursion');
|
|
109
|
+
await service._handleMessage(msg);
|
|
110
|
+
|
|
111
|
+
// Step 2: Verify orchestrator received the request
|
|
112
|
+
expect(orchestrator.processRequest).toHaveBeenCalledTimes(1);
|
|
113
|
+
const request = orchestrator.processRequest.mock.calls[0][0];
|
|
114
|
+
expect(request.interface).toBe('discord');
|
|
115
|
+
expect(request.sessionId).toBe('discord-guild-1-ch-1');
|
|
116
|
+
expect(request.payload.agentId).toBe('agent-alpha');
|
|
117
|
+
expect(request.payload.message).toBe('explain recursion');
|
|
118
|
+
|
|
119
|
+
// Step 3: Simulate broadcast from agentScheduler (what happens after AI responds)
|
|
120
|
+
await service._handleBroadcastEvent('discord-guild-1-ch-1', {
|
|
121
|
+
type: 'stream_complete',
|
|
122
|
+
agentId: 'agent-alpha',
|
|
123
|
+
content: 'Recursion is when a function calls itself.'
|
|
124
|
+
});
|
|
125
|
+
|
|
126
|
+
// Step 4: Verify response was sent to the correct channel
|
|
127
|
+
expect(service.client.channels.fetch).toHaveBeenCalledWith('ch-1');
|
|
128
|
+
expect(mockChannel.send).toHaveBeenCalledTimes(1);
|
|
129
|
+
const sent = mockChannel.send.mock.calls[0][0];
|
|
130
|
+
expect(sent).toContain('Alpha');
|
|
131
|
+
expect(sent).toContain('Recursion is when a function calls itself.');
|
|
132
|
+
});
|
|
133
|
+
|
|
134
|
+
test('full round-trip with long response triggers message splitting', async () => {
|
|
135
|
+
const msg = createDiscordMessage('write a long essay');
|
|
136
|
+
await service._handleMessage(msg);
|
|
137
|
+
|
|
138
|
+
// Simulate a response longer than Discord's limit
|
|
139
|
+
const longContent = 'A'.repeat(3500);
|
|
140
|
+
await service._handleBroadcastEvent('discord-guild-1-ch-1', {
|
|
141
|
+
type: 'stream_complete',
|
|
142
|
+
agentId: 'agent-alpha',
|
|
143
|
+
content: longContent
|
|
144
|
+
});
|
|
145
|
+
|
|
146
|
+
// Should have split into multiple messages
|
|
147
|
+
expect(mockChannel.send).toHaveBeenCalled();
|
|
148
|
+
const totalSent = mockChannel.send.mock.calls.map(c => c[0]).join('');
|
|
149
|
+
expect(totalSent).toContain('Alpha');
|
|
150
|
+
expect(totalSent.length).toBeGreaterThanOrEqual(3500);
|
|
151
|
+
});
|
|
152
|
+
});
|
|
153
|
+
|
|
154
|
+
// ========================================================================
|
|
155
|
+
// FLOW 2: Multi-agent channel routing
|
|
156
|
+
// ========================================================================
|
|
157
|
+
|
|
158
|
+
describe('Flow: Multi-agent channel routing', () => {
|
|
159
|
+
let service, orchestrator, agentPool;
|
|
160
|
+
|
|
161
|
+
beforeEach(() => {
|
|
162
|
+
service = createService();
|
|
163
|
+
orchestrator = createMockOrchestrator();
|
|
164
|
+
agentPool = createMockAgentPool({
|
|
165
|
+
'a1': { id: 'a1', name: 'Coder' },
|
|
166
|
+
'a2': { id: 'a2', name: 'Reviewer' }
|
|
167
|
+
});
|
|
168
|
+
|
|
169
|
+
service.setOrchestrator(orchestrator);
|
|
170
|
+
service.setAgentPool(agentPool);
|
|
171
|
+
service.status = DISCORD_STATUS.CONNECTED;
|
|
172
|
+
service.channelMappings = { 'g1:c1': ['a1', 'a2'] };
|
|
173
|
+
});
|
|
174
|
+
|
|
175
|
+
test('@mention routes to correct agent, then follow-up uses sticky', async () => {
|
|
176
|
+
// First message: explicit @mention
|
|
177
|
+
const msg1 = createDiscordMessage('@Coder fix the login bug', { guildId: 'g1', channelId: 'c1' });
|
|
178
|
+
await service._handleMessage(msg1);
|
|
179
|
+
|
|
180
|
+
expect(orchestrator.processRequest).toHaveBeenCalledTimes(1);
|
|
181
|
+
expect(orchestrator.processRequest.mock.calls[0][0].payload.agentId).toBe('a1');
|
|
182
|
+
expect(orchestrator.processRequest.mock.calls[0][0].payload.message).toBe('fix the login bug');
|
|
183
|
+
|
|
184
|
+
// Second message: no mention — should use sticky (last addressed agent)
|
|
185
|
+
const msg2 = createDiscordMessage('also add error handling', { guildId: 'g1', channelId: 'c1' });
|
|
186
|
+
await service._handleMessage(msg2);
|
|
187
|
+
|
|
188
|
+
expect(orchestrator.processRequest).toHaveBeenCalledTimes(2);
|
|
189
|
+
expect(orchestrator.processRequest.mock.calls[1][0].payload.agentId).toBe('a1'); // sticky to Coder
|
|
190
|
+
|
|
191
|
+
// Third message: switch to different agent via @mention
|
|
192
|
+
const msg3 = createDiscordMessage('@Reviewer review the PR', { guildId: 'g1', channelId: 'c1' });
|
|
193
|
+
await service._handleMessage(msg3);
|
|
194
|
+
|
|
195
|
+
expect(orchestrator.processRequest).toHaveBeenCalledTimes(3);
|
|
196
|
+
expect(orchestrator.processRequest.mock.calls[2][0].payload.agentId).toBe('a2'); // switched to Reviewer
|
|
197
|
+
|
|
198
|
+
// Fourth message: no mention — sticky should now be Reviewer
|
|
199
|
+
const msg4 = createDiscordMessage('any concerns?', { guildId: 'g1', channelId: 'c1' });
|
|
200
|
+
await service._handleMessage(msg4);
|
|
201
|
+
|
|
202
|
+
expect(orchestrator.processRequest.mock.calls[3][0].payload.agentId).toBe('a2');
|
|
203
|
+
});
|
|
204
|
+
|
|
205
|
+
test('invalid @mention with no sticky prompts user to choose', async () => {
|
|
206
|
+
const msg = createDiscordMessage('@UnknownBot do something', { guildId: 'g1', channelId: 'c1' });
|
|
207
|
+
await service._handleMessage(msg);
|
|
208
|
+
|
|
209
|
+
// Should not route
|
|
210
|
+
expect(orchestrator.processRequest).not.toHaveBeenCalled();
|
|
211
|
+
// Should prompt user
|
|
212
|
+
expect(msg.reply).toHaveBeenCalledTimes(1);
|
|
213
|
+
expect(msg.reply.mock.calls[0][0]).toContain('@Coder');
|
|
214
|
+
expect(msg.reply.mock.calls[0][0]).toContain('@Reviewer');
|
|
215
|
+
});
|
|
216
|
+
});
|
|
217
|
+
|
|
218
|
+
// ========================================================================
|
|
219
|
+
// FLOW 3: Multi-channel isolation
|
|
220
|
+
// Agent responds to channel A only — not channel B even if mapped to both
|
|
221
|
+
// ========================================================================
|
|
222
|
+
|
|
223
|
+
describe('Flow: Multi-channel response isolation', () => {
|
|
224
|
+
let service, agentPool;
|
|
225
|
+
const channelA = createMockChannel('chA');
|
|
226
|
+
const channelB = createMockChannel('chB');
|
|
227
|
+
|
|
228
|
+
beforeEach(() => {
|
|
229
|
+
service = createService();
|
|
230
|
+
agentPool = createMockAgentPool({
|
|
231
|
+
'agent-1': { id: 'agent-1', name: 'SharedBot' }
|
|
232
|
+
});
|
|
233
|
+
service.setAgentPool(agentPool);
|
|
234
|
+
service.setOrchestrator(createMockOrchestrator());
|
|
235
|
+
service.status = DISCORD_STATUS.CONNECTED;
|
|
236
|
+
service.client = {
|
|
237
|
+
channels: {
|
|
238
|
+
fetch: jest.fn().mockImplementation(id => {
|
|
239
|
+
if (id === 'chA') return Promise.resolve(channelA);
|
|
240
|
+
if (id === 'chB') return Promise.resolve(channelB);
|
|
241
|
+
return Promise.resolve(null);
|
|
242
|
+
})
|
|
243
|
+
}
|
|
244
|
+
};
|
|
245
|
+
|
|
246
|
+
// Same agent mapped to TWO channels
|
|
247
|
+
service.channelMappings = {
|
|
248
|
+
'g1:chA': ['agent-1'],
|
|
249
|
+
'g1:chB': ['agent-1']
|
|
250
|
+
};
|
|
251
|
+
|
|
252
|
+
channelA.send.mockClear();
|
|
253
|
+
channelB.send.mockClear();
|
|
254
|
+
});
|
|
255
|
+
|
|
256
|
+
test('response only goes to channel where user initiated', async () => {
|
|
257
|
+
// User sends message in channel A
|
|
258
|
+
const msg = createDiscordMessage('hello', { guildId: 'g1', channelId: 'chA' });
|
|
259
|
+
await service._handleMessage(msg);
|
|
260
|
+
|
|
261
|
+
// Agent responds via broadcast
|
|
262
|
+
await service._handleBroadcastEvent('discord-g1-chA', {
|
|
263
|
+
type: 'stream_complete',
|
|
264
|
+
agentId: 'agent-1',
|
|
265
|
+
content: 'Hi there!'
|
|
266
|
+
});
|
|
267
|
+
|
|
268
|
+
// Channel A should get the response
|
|
269
|
+
expect(channelA.send).toHaveBeenCalled();
|
|
270
|
+
// Channel B should NOT
|
|
271
|
+
expect(channelB.send).not.toHaveBeenCalled();
|
|
272
|
+
});
|
|
273
|
+
|
|
274
|
+
test('separate conversations in separate channels stay isolated', async () => {
|
|
275
|
+
// User sends in channel A
|
|
276
|
+
const msgA = createDiscordMessage('question A', { guildId: 'g1', channelId: 'chA' });
|
|
277
|
+
await service._handleMessage(msgA);
|
|
278
|
+
|
|
279
|
+
// Different user sends in channel B
|
|
280
|
+
const msgB = createDiscordMessage('question B', { guildId: 'g1', channelId: 'chB' });
|
|
281
|
+
await service._handleMessage(msgB);
|
|
282
|
+
|
|
283
|
+
// Agent responds (to question A)
|
|
284
|
+
await service._relayAgentResponse({
|
|
285
|
+
agentId: 'agent-1',
|
|
286
|
+
content: 'Answer A'
|
|
287
|
+
});
|
|
288
|
+
|
|
289
|
+
// Both channels should get the response (both have recent interaction)
|
|
290
|
+
expect(channelA.send).toHaveBeenCalled();
|
|
291
|
+
expect(channelB.send).toHaveBeenCalled();
|
|
292
|
+
|
|
293
|
+
// But if we clear channel A's interaction (expired)
|
|
294
|
+
channelA.send.mockClear();
|
|
295
|
+
channelB.send.mockClear();
|
|
296
|
+
const keyA = 'agent-1:g1:chA';
|
|
297
|
+
const interactionA = service.recentInteractions.get(keyA);
|
|
298
|
+
if (interactionA) interactionA.timestamp = Date.now() - 31 * 60 * 1000; // expire it
|
|
299
|
+
|
|
300
|
+
await service._relayAgentResponse({
|
|
301
|
+
agentId: 'agent-1',
|
|
302
|
+
content: 'Answer B'
|
|
303
|
+
});
|
|
304
|
+
|
|
305
|
+
// Only channel B should get it now
|
|
306
|
+
expect(channelA.send).not.toHaveBeenCalled();
|
|
307
|
+
expect(channelB.send).toHaveBeenCalled();
|
|
308
|
+
});
|
|
309
|
+
});
|
|
310
|
+
|
|
311
|
+
// ========================================================================
|
|
312
|
+
// FLOW 4: Broadcast chain integrity (multiple services wrapping)
|
|
313
|
+
// ========================================================================
|
|
314
|
+
|
|
315
|
+
describe('Flow: Broadcast chain integrity', () => {
|
|
316
|
+
test('Discord and Telegram can both wrap broadcastToSession without breaking each other', () => {
|
|
317
|
+
const originalCalls = [];
|
|
318
|
+
const telegramCalls = [];
|
|
319
|
+
const discordCalls = [];
|
|
320
|
+
|
|
321
|
+
const wsManager = {
|
|
322
|
+
broadcastToSession: jest.fn((sid, msg) => originalCalls.push({ sid, msg }))
|
|
323
|
+
};
|
|
324
|
+
|
|
325
|
+
// Simulate Telegram wrapping first (like real init order)
|
|
326
|
+
const telegramOriginal = wsManager.broadcastToSession.bind(wsManager);
|
|
327
|
+
wsManager.broadcastToSession = (sid, msg) => {
|
|
328
|
+
telegramOriginal(sid, msg);
|
|
329
|
+
telegramCalls.push({ sid, msg });
|
|
330
|
+
};
|
|
331
|
+
|
|
332
|
+
// Now Discord wraps on top
|
|
333
|
+
const service = createService();
|
|
334
|
+
service._interceptBroadcasts(wsManager);
|
|
335
|
+
|
|
336
|
+
// Fire a broadcast
|
|
337
|
+
wsManager.broadcastToSession('s1', { type: 'stream_complete', agentId: 'a1', content: 'hello' });
|
|
338
|
+
|
|
339
|
+
// Original should be called (through the chain)
|
|
340
|
+
expect(originalCalls).toHaveLength(1);
|
|
341
|
+
// Telegram should see it
|
|
342
|
+
expect(telegramCalls).toHaveLength(1);
|
|
343
|
+
// Discord's _handleBroadcastEvent should also have been called
|
|
344
|
+
// (verified by the fact that the chain didn't throw)
|
|
345
|
+
|
|
346
|
+
// Fire another — all three layers still work
|
|
347
|
+
wsManager.broadcastToSession('s2', { type: 'message_added' });
|
|
348
|
+
expect(originalCalls).toHaveLength(2);
|
|
349
|
+
expect(telegramCalls).toHaveLength(2);
|
|
350
|
+
});
|
|
351
|
+
});
|
|
352
|
+
|
|
353
|
+
// ========================================================================
|
|
354
|
+
// FLOW 5: Config persistence round-trip
|
|
355
|
+
// ========================================================================
|
|
356
|
+
|
|
357
|
+
describe('Flow: Config persistence round-trip', () => {
|
|
358
|
+
test('assign agents → save → reload → mappings restored → routing works', async () => {
|
|
359
|
+
const service1 = createService();
|
|
360
|
+
service1.setOrchestrator(createMockOrchestrator());
|
|
361
|
+
service1.setAgentPool(createMockAgentPool({
|
|
362
|
+
'a1': { id: 'a1', name: 'Bot1' }
|
|
363
|
+
}));
|
|
364
|
+
|
|
365
|
+
// Step 1: Assign agents to channels
|
|
366
|
+
await service1.assignAgentToChannel('g1:c1', 'a1');
|
|
367
|
+
await service1.assignAgentToChannel('g1:c2', 'a1');
|
|
368
|
+
service1.knownGuilds = { g1: { name: 'TestServer' } };
|
|
369
|
+
service1.knownChannels = {
|
|
370
|
+
'g1:c1': { name: 'general', guildName: 'TestServer' },
|
|
371
|
+
'g1:c2': { name: 'dev', guildName: 'TestServer' }
|
|
372
|
+
};
|
|
373
|
+
await service1._saveConfig();
|
|
374
|
+
|
|
375
|
+
// Step 2: Capture what was written to disk
|
|
376
|
+
const lastWriteCall = mockFs.writeFile.mock.calls[mockFs.writeFile.mock.calls.length - 1];
|
|
377
|
+
const savedJson = lastWriteCall[1];
|
|
378
|
+
|
|
379
|
+
// Step 3: Create new service instance and load the saved config
|
|
380
|
+
mockFs.readFile.mockResolvedValueOnce(savedJson);
|
|
381
|
+
const service2 = createService();
|
|
382
|
+
await service2._loadConfig();
|
|
383
|
+
|
|
384
|
+
// Step 4: Verify mappings are restored
|
|
385
|
+
expect(service2.channelMappings).toEqual({
|
|
386
|
+
'g1:c1': ['a1'],
|
|
387
|
+
'g1:c2': ['a1']
|
|
388
|
+
});
|
|
389
|
+
expect(service2.knownGuilds.g1.name).toBe('TestServer');
|
|
390
|
+
expect(service2.knownChannels['g1:c1'].name).toBe('general');
|
|
391
|
+
|
|
392
|
+
// Step 5: Verify routing works with restored mappings
|
|
393
|
+
service2.setOrchestrator(createMockOrchestrator());
|
|
394
|
+
service2.setAgentPool(createMockAgentPool({
|
|
395
|
+
'a1': { id: 'a1', name: 'Bot1' }
|
|
396
|
+
}));
|
|
397
|
+
service2.status = DISCORD_STATUS.CONNECTED;
|
|
398
|
+
|
|
399
|
+
const msg = createDiscordMessage('hello', { guildId: 'g1', channelId: 'c1' });
|
|
400
|
+
await service2._handleMessage(msg);
|
|
401
|
+
|
|
402
|
+
expect(service2.orchestrator.processRequest).toHaveBeenCalledTimes(1);
|
|
403
|
+
expect(service2.orchestrator.processRequest.mock.calls[0][0].payload.agentId).toBe('a1');
|
|
404
|
+
});
|
|
405
|
+
});
|
|
406
|
+
|
|
407
|
+
// ========================================================================
|
|
408
|
+
// FLOW 6: Agent deletion / stale mapping handling
|
|
409
|
+
// ========================================================================
|
|
410
|
+
|
|
411
|
+
describe('Flow: Agent lifecycle and stale mappings', () => {
|
|
412
|
+
test('agent deleted from pool — routed message fails gracefully', async () => {
|
|
413
|
+
const service = createService();
|
|
414
|
+
const orchestrator = createMockOrchestrator();
|
|
415
|
+
orchestrator.processRequest.mockRejectedValueOnce(new Error('Agent not found'));
|
|
416
|
+
|
|
417
|
+
service.setOrchestrator(orchestrator);
|
|
418
|
+
service.setAgentPool(createMockAgentPool({})); // empty — agent gone
|
|
419
|
+
service.status = DISCORD_STATUS.CONNECTED;
|
|
420
|
+
service.channelMappings = { 'g1:c1': ['deleted-agent'] };
|
|
421
|
+
|
|
422
|
+
const msg = createDiscordMessage('hello', { guildId: 'g1', channelId: 'c1' });
|
|
423
|
+
await service._handleMessage(msg);
|
|
424
|
+
|
|
425
|
+
// Should attempt to route but handle error gracefully
|
|
426
|
+
expect(orchestrator.processRequest).toHaveBeenCalled();
|
|
427
|
+
// Should reply with error
|
|
428
|
+
expect(msg.reply).toHaveBeenCalledTimes(1);
|
|
429
|
+
expect(msg.reply.mock.calls[0][0]).toContain('Failed');
|
|
430
|
+
});
|
|
431
|
+
|
|
432
|
+
test('guild removal cleans up all mappings for that guild', async () => {
|
|
433
|
+
const service = createService();
|
|
434
|
+
service.channelMappings = {
|
|
435
|
+
'guild-A:c1': ['a1'],
|
|
436
|
+
'guild-A:c2': ['a2'],
|
|
437
|
+
'guild-B:c3': ['a3']
|
|
438
|
+
};
|
|
439
|
+
service.knownGuilds = {
|
|
440
|
+
'guild-A': { name: 'ServerA' },
|
|
441
|
+
'guild-B': { name: 'ServerB' }
|
|
442
|
+
};
|
|
443
|
+
service.knownChannels = {
|
|
444
|
+
'guild-A:c1': { name: 'gen' },
|
|
445
|
+
'guild-A:c2': { name: 'dev' },
|
|
446
|
+
'guild-B:c3': { name: 'main' }
|
|
447
|
+
};
|
|
448
|
+
|
|
449
|
+
// Simulate guildDelete event handler logic
|
|
450
|
+
const guildId = 'guild-A';
|
|
451
|
+
delete service.knownGuilds[guildId];
|
|
452
|
+
for (const key of Object.keys(service.channelMappings)) {
|
|
453
|
+
if (key.startsWith(`${guildId}:`)) {
|
|
454
|
+
delete service.channelMappings[key];
|
|
455
|
+
delete service.knownChannels[key];
|
|
456
|
+
}
|
|
457
|
+
}
|
|
458
|
+
|
|
459
|
+
// guild-A channels should be gone
|
|
460
|
+
expect(service.channelMappings['guild-A:c1']).toBeUndefined();
|
|
461
|
+
expect(service.channelMappings['guild-A:c2']).toBeUndefined();
|
|
462
|
+
expect(service.knownChannels['guild-A:c1']).toBeUndefined();
|
|
463
|
+
|
|
464
|
+
// guild-B should be untouched
|
|
465
|
+
expect(service.channelMappings['guild-B:c3']).toEqual(['a3']);
|
|
466
|
+
expect(service.knownGuilds['guild-B'].name).toBe('ServerB');
|
|
467
|
+
});
|
|
468
|
+
});
|
|
469
|
+
|
|
470
|
+
// ========================================================================
|
|
471
|
+
// FLOW 7: Prompt relay flow
|
|
472
|
+
// ========================================================================
|
|
473
|
+
|
|
474
|
+
describe('Flow: User prompt relay', () => {
|
|
475
|
+
test('user_prompt_request broadcast → relayed to channel with recent interaction', async () => {
|
|
476
|
+
const service = createService();
|
|
477
|
+
const mockCh = createMockChannel('ch-1');
|
|
478
|
+
service.status = DISCORD_STATUS.CONNECTED;
|
|
479
|
+
service.client = {
|
|
480
|
+
channels: { fetch: jest.fn().mockResolvedValue(mockCh) }
|
|
481
|
+
};
|
|
482
|
+
service.agentPool = createMockAgentPool({
|
|
483
|
+
'a1': { id: 'a1', name: 'Worker' }
|
|
484
|
+
});
|
|
485
|
+
|
|
486
|
+
// Record a recent interaction
|
|
487
|
+
service.recentInteractions.set('a1:g1:ch-1', {
|
|
488
|
+
channelKey: 'g1:ch-1',
|
|
489
|
+
channelId: 'ch-1',
|
|
490
|
+
guildId: 'g1',
|
|
491
|
+
timestamp: Date.now()
|
|
492
|
+
});
|
|
493
|
+
|
|
494
|
+
// Simulate prompt request broadcast
|
|
495
|
+
await service._handleBroadcastEvent('session', {
|
|
496
|
+
type: 'user_prompt_request',
|
|
497
|
+
data: { agentId: 'a1', prompt: 'Please provide the API key' }
|
|
498
|
+
});
|
|
499
|
+
|
|
500
|
+
expect(mockCh.send).toHaveBeenCalledTimes(1);
|
|
501
|
+
const sent = mockCh.send.mock.calls[0][0];
|
|
502
|
+
expect(sent).toContain('Input needed');
|
|
503
|
+
expect(sent).toContain('API key');
|
|
504
|
+
});
|
|
505
|
+
});
|