onbuzz 3.7.1 → 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 +6 -0
- package/src/core/agentScheduler.js +16 -0
- 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-BvQP6tit.js +0 -1
- package/web-ui/build/static/abap-CBGXuAu8.js +0 -1
- package/web-ui/build/static/abnf-1UkoHMWF.js +0 -1
- package/web-ui/build/static/abnf-CQ-qs9SC.js +0 -1
- package/web-ui/build/static/accesslog-CLsck1tk.js +0 -1
- package/web-ui/build/static/actionscript-BmMrS3w5.js +0 -1
- package/web-ui/build/static/actionscript-CI5c8WNC.js +0 -1
- package/web-ui/build/static/ada-CRi96var.js +0 -1
- package/web-ui/build/static/ada-DcFm8e2f.js +0 -1
- package/web-ui/build/static/agda-f-um2AhY.js +0 -1
- package/web-ui/build/static/al-D84ITX3R.js +0 -1
- package/web-ui/build/static/angelscript-DyBqwI_J.js +0 -1
- package/web-ui/build/static/antlr4-BdAN4dwN.js +0 -1
- package/web-ui/build/static/apache-CLCWUMO1.js +0 -1
- package/web-ui/build/static/apacheconf-BU4Luno6.js +0 -1
- package/web-ui/build/static/apex-D18n7e5X.js +0 -1
- package/web-ui/build/static/apl-bBRu6uGn.js +0 -1
- package/web-ui/build/static/applescript-C0Wyk4RJ.js +0 -1
- package/web-ui/build/static/applescript-DvCIA60X.js +0 -1
- package/web-ui/build/static/aql-BdK-yfug.js +0 -1
- package/web-ui/build/static/arcade-DgYN3FpB.js +0 -1
- package/web-ui/build/static/arduino-02zY6DkA.js +0 -1
- package/web-ui/build/static/arduino-BCjv-TVb.js +0 -1
- package/web-ui/build/static/arff-B0zET-1U.js +0 -1
- package/web-ui/build/static/armasm-DEo0OaDp.js +0 -1
- package/web-ui/build/static/asciidoc-DjPR4d9U.js +0 -1
- package/web-ui/build/static/asciidoc-Dkzpf5Ug.js +0 -1
- package/web-ui/build/static/asm6502-BE0NRStf.js +0 -1
- package/web-ui/build/static/asmatmel-DNsgAeSs.js +0 -1
- package/web-ui/build/static/aspectj-C7LsbS_X.js +0 -1
- package/web-ui/build/static/aspnet-C-Pv2Vsy.js +0 -1
- package/web-ui/build/static/autohotkey-BKeAFYXM.js +0 -1
- package/web-ui/build/static/autohotkey-BPMdiv6b.js +0 -1
- package/web-ui/build/static/autoit-BaS2uHgt.js +0 -1
- package/web-ui/build/static/autoit-rI90Aidh.js +0 -1
- package/web-ui/build/static/avisynth-CAw8vH8h.js +0 -1
- package/web-ui/build/static/avrasm-xYjmc86q.js +0 -1
- package/web-ui/build/static/avro-idl-D4U--bZP.js +0 -1
- package/web-ui/build/static/awk-BvbDimae.js +0 -1
- package/web-ui/build/static/axapta-D99zP2ee.js +0 -1
- package/web-ui/build/static/bash-CDG976bG.js +0 -1
- package/web-ui/build/static/bash-T16fxSRn.js +0 -1
- package/web-ui/build/static/basic-BXxs1n3E.js +0 -1
- package/web-ui/build/static/basic-CBao4M9s.js +0 -1
- package/web-ui/build/static/batch-CsIfn0z_.js +0 -1
- package/web-ui/build/static/bbcode-BHCvmb7d.js +0 -1
- package/web-ui/build/static/bicep-B6jLtdUX.js +0 -1
- package/web-ui/build/static/birb-_6rus2Jq.js +0 -1
- package/web-ui/build/static/bison-Cf9k3OiL.js +0 -1
- package/web-ui/build/static/bnf-B5ia1hDk.js +0 -1
- package/web-ui/build/static/bnf-DVy-DEYH.js +0 -1
- package/web-ui/build/static/brainfuck-3sktcvyK.js +0 -1
- package/web-ui/build/static/brainfuck-BSQwhePZ.js +0 -1
- package/web-ui/build/static/brightscript-B2yu5VAa.js +0 -1
- package/web-ui/build/static/bro-CuvwcQz4.js +0 -1
- package/web-ui/build/static/bsl-B3k1XSIc.js +0 -1
- package/web-ui/build/static/c-CZkftNBD.js +0 -1
- package/web-ui/build/static/c-D90NjPHW.js +0 -1
- package/web-ui/build/static/c-like-DBGbcd7r.js +0 -1
- package/web-ui/build/static/cal-DOUwNXW9.js +0 -1
- package/web-ui/build/static/capnproto-B4IF4kgE.js +0 -1
- package/web-ui/build/static/ceylon-Euj-BzzX.js +0 -1
- package/web-ui/build/static/cfscript-Uc0ut-H8.js +0 -1
- package/web-ui/build/static/chaiscript-myZqNGA0.js +0 -1
- package/web-ui/build/static/cil-BrlRIfyY.js +0 -1
- package/web-ui/build/static/clean-CxcdJdPn.js +0 -1
- package/web-ui/build/static/clojure-BFoakyLp.js +0 -1
- package/web-ui/build/static/clojure-BQb2CXLJ.js +0 -1
- package/web-ui/build/static/clojure-repl-Cwj-gPVO.js +0 -1
- package/web-ui/build/static/cmake-Bb_18OuF.js +0 -1
- package/web-ui/build/static/cmake-BpOSK5UA.js +0 -1
- package/web-ui/build/static/cobol-BkjIzXNn.js +0 -1
- package/web-ui/build/static/coffeescript-Dc5dAHTu.js +0 -1
- package/web-ui/build/static/coffeescript-qX1FTabX.js +0 -1
- package/web-ui/build/static/concurnas-B_Sp5tG7.js +0 -1
- package/web-ui/build/static/coq-BTzlXTkY.js +0 -1
- package/web-ui/build/static/coq-CZkd7udr.js +0 -1
- package/web-ui/build/static/cos-Dtk-4cDZ.js +0 -1
- package/web-ui/build/static/cpp-BplhzSx_.js +0 -1
- package/web-ui/build/static/cpp-CpVmncKK.js +0 -1
- package/web-ui/build/static/crmsh-BI893dEs.js +0 -1
- package/web-ui/build/static/crystal-BKxkccmP.js +0 -1
- package/web-ui/build/static/crystal-mrGsRENj.js +0 -1
- package/web-ui/build/static/csharp-DLA5Qp39.js +0 -1
- package/web-ui/build/static/csharp-DoPhvPbf.js +0 -1
- package/web-ui/build/static/cshtml-C6tJPHW0.js +0 -1
- package/web-ui/build/static/csp-CPSrYj2d.js +0 -1
- package/web-ui/build/static/csp-j7UlanP8.js +0 -1
- package/web-ui/build/static/css-D8pS6JQQ.js +0 -1
- package/web-ui/build/static/css-extras-DddI11vT.js +0 -1
- package/web-ui/build/static/csv-DiHE6lo2.js +0 -1
- package/web-ui/build/static/cypher-COoWp4ya.js +0 -1
- package/web-ui/build/static/d-BWrBCCpO.js +0 -1
- package/web-ui/build/static/d-CLH7Iuz9.js +0 -1
- package/web-ui/build/static/dart-CZoNp2Ad.js +0 -1
- package/web-ui/build/static/dart-DipTt1Ry.js +0 -1
- package/web-ui/build/static/dataweave-BOsDKsnx.js +0 -1
- package/web-ui/build/static/dax-Dvoyws-_.js +0 -1
- package/web-ui/build/static/delphi-ltC50zma.js +0 -1
- package/web-ui/build/static/dhall-Dph02bpZ.js +0 -1
- package/web-ui/build/static/diff-BAQmYK7k.js +0 -1
- package/web-ui/build/static/diff-D6TeYOva.js +0 -1
- package/web-ui/build/static/django-B4JvUphT.js +0 -1
- package/web-ui/build/static/django-B8oJfAqO.js +0 -1
- package/web-ui/build/static/dns-Cguwqm77.js +0 -1
- package/web-ui/build/static/dns-zone-file-Bnxp0DdQ.js +0 -1
- package/web-ui/build/static/docker-BsKQISyk.js +0 -1
- package/web-ui/build/static/dockerfile-BArhvqpO.js +0 -1
- package/web-ui/build/static/dos-DKiRpqCm.js +0 -1
- package/web-ui/build/static/dot-C2Mjqqdc.js +0 -1
- package/web-ui/build/static/dsconfig--Q_zkeRJ.js +0 -1
- package/web-ui/build/static/dts-DuLM9Mtv.js +0 -1
- package/web-ui/build/static/dust-B2HNi2p1.js +0 -1
- package/web-ui/build/static/ebnf-B6n6tVKD.js +0 -1
- package/web-ui/build/static/ebnf-ByIi4hTP.js +0 -1
- package/web-ui/build/static/editorconfig-Cl5L844z.js +0 -1
- package/web-ui/build/static/eiffel-Dp-GGyCb.js +0 -1
- package/web-ui/build/static/ejs-DS7DqvRo.js +0 -1
- package/web-ui/build/static/elixir-BF8XO-Qw.js +0 -1
- package/web-ui/build/static/elixir-DWijnUgh.js +0 -1
- package/web-ui/build/static/elm-BvVC0Ihh.js +0 -1
- package/web-ui/build/static/elm-CAw1_c0s.js +0 -1
- package/web-ui/build/static/erb-BkyxkSNF.js +0 -1
- package/web-ui/build/static/erb-DekR4h1y.js +0 -1
- package/web-ui/build/static/erlang-DDbsnOBd.js +0 -1
- package/web-ui/build/static/erlang-raWR7opY.js +0 -1
- package/web-ui/build/static/erlang-repl-DI0fGnfK.js +0 -1
- package/web-ui/build/static/etlua-Cs_epD_6.js +0 -1
- package/web-ui/build/static/excel-DmMAq31p.js +0 -1
- package/web-ui/build/static/excel-formula-WyfEZz1D.js +0 -1
- package/web-ui/build/static/factor-BxxkExOX.js +0 -1
- package/web-ui/build/static/false-BUxxqLSk.js +0 -1
- package/web-ui/build/static/firestore-security-rules-CuUb7whq.js +0 -1
- package/web-ui/build/static/fix-BERIuQsi.js +0 -1
- package/web-ui/build/static/flix-D48i0h3B.js +0 -1
- package/web-ui/build/static/flow-lcmyFMPW.js +0 -1
- package/web-ui/build/static/fortran-BGpZ4F4n.js +0 -1
- package/web-ui/build/static/fortran-BbwxX6j1.js +0 -1
- package/web-ui/build/static/fsharp-DRHOrPVW.js +0 -1
- package/web-ui/build/static/fsharp-Wcmlw-1E.js +0 -1
- package/web-ui/build/static/ftl-DA4U9oLT.js +0 -1
- package/web-ui/build/static/gams-hw_b6QvW.js +0 -1
- package/web-ui/build/static/gap-BUPei8tk.js +0 -1
- package/web-ui/build/static/gauss-BL0-vBpu.js +0 -1
- package/web-ui/build/static/gcode-BuLfuU7c.js +0 -1
- package/web-ui/build/static/gcode-D8txcY5y.js +0 -1
- package/web-ui/build/static/gdscript-D2APWZbM.js +0 -1
- package/web-ui/build/static/gedcom-DBNV4Yfo.js +0 -1
- package/web-ui/build/static/gherkin-Bebgb73e.js +0 -1
- package/web-ui/build/static/gherkin-HqJT6bWg.js +0 -1
- package/web-ui/build/static/git-DK0jZ5E_.js +0 -1
- package/web-ui/build/static/glsl-B-q61PiB.js +0 -1
- package/web-ui/build/static/glsl-BJCTc_uH.js +0 -1
- package/web-ui/build/static/gml-BGDiQJTh.js +0 -1
- package/web-ui/build/static/gml-D7KkM2ni.js +0 -1
- package/web-ui/build/static/gn-BdU9rZYz.js +0 -1
- package/web-ui/build/static/go-B_ziBrei.js +0 -1
- package/web-ui/build/static/go-Ijzu8F6T.js +0 -1
- package/web-ui/build/static/go-module-DSUq4p2E.js +0 -1
- package/web-ui/build/static/golo-DqIWAjvP.js +0 -1
- package/web-ui/build/static/gradle-B7ZM61mq.js +0 -1
- package/web-ui/build/static/graphql-wC6fMnj4.js +0 -1
- package/web-ui/build/static/groovy-DZ5hzc-V.js +0 -1
- package/web-ui/build/static/groovy-WmrWMo4q.js +0 -1
- package/web-ui/build/static/haml-BxJJEd4v.js +0 -1
- package/web-ui/build/static/haml-Dn_bbzS1.js +0 -1
- package/web-ui/build/static/handlebars-CT-VtGMP.js +0 -1
- package/web-ui/build/static/handlebars-DY5VJNi-.js +0 -1
- package/web-ui/build/static/haskell-Bo-0s3-a.js +0 -1
- package/web-ui/build/static/haskell-CM03rlyg.js +0 -1
- package/web-ui/build/static/haxe-D34n-x3y.js +0 -1
- package/web-ui/build/static/haxe-LGeMgK7m.js +0 -1
- package/web-ui/build/static/hcl-D3p0B3pl.js +0 -1
- package/web-ui/build/static/hlsl-D6txtAQw.js +0 -1
- package/web-ui/build/static/hoon-Ba71rfsL.js +0 -1
- package/web-ui/build/static/hpkp-BNZOeeLk.js +0 -1
- package/web-ui/build/static/hsp-CqEQaBwI.js +0 -1
- package/web-ui/build/static/hsts-135eVtG4.js +0 -1
- package/web-ui/build/static/htmlbars-B8dOv8Kx.js +0 -1
- package/web-ui/build/static/http-CS1jBYmo.js +0 -1
- package/web-ui/build/static/http-CdY42VFX.js +0 -1
- package/web-ui/build/static/hy-B1YFE1ef.js +0 -1
- package/web-ui/build/static/ichigojam-BbNf1jEn.js +0 -1
- package/web-ui/build/static/icon-CEJtNUyu.js +0 -1
- package/web-ui/build/static/icu-message-format-D1pyu5nb.js +0 -1
- package/web-ui/build/static/idris-DlxMBZQK.js +0 -1
- package/web-ui/build/static/iecst-DOLBaiat.js +0 -1
- package/web-ui/build/static/ignore-DkpK0s7O.js +0 -1
- package/web-ui/build/static/index-BPWFYccV.js +0 -816
- package/web-ui/build/static/index-C4EI6D9D.js +0 -1
- package/web-ui/build/static/index-Cq_BrV5w.js +0 -13
- package/web-ui/build/static/index-DPFadqM6.css +0 -1
- package/web-ui/build/static/inform7-CgjoFKz3.js +0 -1
- package/web-ui/build/static/inform7-DVvVugiP.js +0 -1
- package/web-ui/build/static/ini-BJUY4fpX.js +0 -1
- package/web-ui/build/static/ini-BdBK3VwR.js +0 -1
- package/web-ui/build/static/io-CQ6MjhLL.js +0 -1
- package/web-ui/build/static/irpf90-BbtOPAww.js +0 -1
- package/web-ui/build/static/isbl-B0RRkr3V.js +0 -1
- package/web-ui/build/static/j-C1OQYZeH.js +0 -1
- package/web-ui/build/static/java-CGB1BWRH.js +0 -1
- package/web-ui/build/static/java-ChQglibU.js +0 -1
- package/web-ui/build/static/javadoc-BggcvnsV.js +0 -1
- package/web-ui/build/static/javadoclike-Bd5Qh2Hb.js +0 -1
- package/web-ui/build/static/javascript-CGgTql7x.js +0 -1
- package/web-ui/build/static/javastacktrace-DYABFlFu.js +0 -1
- package/web-ui/build/static/jboss-cli-BwEh-lwp.js +0 -1
- package/web-ui/build/static/jexl-BkSlG_kb.js +0 -1
- package/web-ui/build/static/jolie-BmJB4V8v.js +0 -1
- package/web-ui/build/static/jq-B-SsmDDk.js +0 -1
- package/web-ui/build/static/js-extras-BoevbnPJ.js +0 -1
- package/web-ui/build/static/js-templates-DHuTg-Ay.js +0 -1
- package/web-ui/build/static/jsdoc-CIBmrWH2.js +0 -1
- package/web-ui/build/static/json-BKj635_o.js +0 -1
- package/web-ui/build/static/json-CJKnOrLI.js +0 -1
- package/web-ui/build/static/json5-PfMzJB7y.js +0 -1
- package/web-ui/build/static/jsonp-CXTIFT1b.js +0 -1
- package/web-ui/build/static/jsstacktrace-DownPAn7.js +0 -1
- package/web-ui/build/static/jsx-BUDIikt-.js +0 -1
- package/web-ui/build/static/julia-AsdheIfB.js +0 -1
- package/web-ui/build/static/julia-DzP8X678.js +0 -1
- package/web-ui/build/static/julia-repl-BXI6aKys.js +0 -1
- package/web-ui/build/static/keepalived-DoCPnue1.js +0 -1
- package/web-ui/build/static/keyman-9H23LOap.js +0 -1
- package/web-ui/build/static/kotlin-DA_gpddk.js +0 -1
- package/web-ui/build/static/kotlin-Hd7AAUjI.js +0 -1
- package/web-ui/build/static/kumir-_X46sX4q.js +0 -1
- package/web-ui/build/static/kusto-D1zAQ8d4.js +0 -1
- package/web-ui/build/static/lasso-3O1F8JXq.js +0 -1
- package/web-ui/build/static/latex-D1lIfV7j.js +0 -1
- package/web-ui/build/static/latex-DeyY1nAb.js +0 -1
- package/web-ui/build/static/latte-CX527rFz.js +0 -1
- package/web-ui/build/static/ldif-B1M1kF8c.js +0 -1
- package/web-ui/build/static/leaf-CsoiJ7Ov.js +0 -1
- package/web-ui/build/static/less-DoJ1P5ux.js +0 -1
- package/web-ui/build/static/less-xKRlHPnV.js +0 -1
- package/web-ui/build/static/lilypond-CYlLp77e.js +0 -1
- package/web-ui/build/static/liquid-D8znKyfy.js +0 -1
- package/web-ui/build/static/lisp-BCo6gd6k.js +0 -1
- package/web-ui/build/static/lisp-Bb3rCxIw.js +0 -1
- package/web-ui/build/static/livecodeserver-DBAAOxSg.js +0 -1
- package/web-ui/build/static/livescript-BYGQp4kR.js +0 -1
- package/web-ui/build/static/livescript-DPtouT3Z.js +0 -1
- package/web-ui/build/static/llvm-D9fZ1I0h.js +0 -1
- package/web-ui/build/static/llvm-DYxbqMHA.js +0 -1
- package/web-ui/build/static/log-Bg7mOns0.js +0 -1
- package/web-ui/build/static/lolcode-LHm8cOV3.js +0 -1
- package/web-ui/build/static/lsl-BP_joNNv.js +0 -1
- package/web-ui/build/static/lua-BQFyp44d.js +0 -1
- package/web-ui/build/static/lua-CH7FE0lh.js +0 -1
- package/web-ui/build/static/magma-D5MI1OfT.js +0 -1
- package/web-ui/build/static/makefile-C6ydPEhw.js +0 -1
- package/web-ui/build/static/makefile-ntfN22fB.js +0 -1
- package/web-ui/build/static/markdown-DyHInK4o.js +0 -1
- package/web-ui/build/static/markdown-g17QyG0B.js +0 -1
- package/web-ui/build/static/markup-templating-B_dMditT.js +0 -1
- package/web-ui/build/static/mathematica-BQNq3yIm.js +0 -1
- package/web-ui/build/static/matlab-CFzqUsqr.js +0 -1
- package/web-ui/build/static/matlab-gFTS215H.js +0 -1
- package/web-ui/build/static/maxima-CDBIjqDz.js +0 -1
- package/web-ui/build/static/maxscript-D8-2TcxS.js +0 -1
- package/web-ui/build/static/mel-CLxL5-6c.js +0 -1
- package/web-ui/build/static/mel-DANhzCmt.js +0 -1
- package/web-ui/build/static/mercury-BX2sAg76.js +0 -1
- package/web-ui/build/static/mermaid-D4U5j_Xy.js +0 -1
- package/web-ui/build/static/mipsasm-jaTmy5cT.js +0 -1
- package/web-ui/build/static/mizar-BCbBfLyM.js +0 -1
- package/web-ui/build/static/mizar-DQQ-VwSh.js +0 -1
- package/web-ui/build/static/mojolicious-wR6EwckQ.js +0 -1
- package/web-ui/build/static/mongodb-CfHbd5GT.js +0 -1
- package/web-ui/build/static/monkey-00PXh3YV.js +0 -1
- package/web-ui/build/static/monkey-Cy85lSbX.js +0 -1
- package/web-ui/build/static/moonscript-BNR39c-_.js +0 -1
- package/web-ui/build/static/moonscript-C6h-cMvC.js +0 -1
- package/web-ui/build/static/n1ql-CCJ4i-Ms.js +0 -1
- package/web-ui/build/static/n1ql-MuGnmWmA.js +0 -1
- package/web-ui/build/static/n4js-Bhe0mLAY.js +0 -1
- package/web-ui/build/static/nand2tetris-hdl-BOVHEyHa.js +0 -1
- package/web-ui/build/static/naniscript-DzNMb3fu.js +0 -1
- package/web-ui/build/static/nasm-Ejmc1gd8.js +0 -1
- package/web-ui/build/static/neon-CCtwsYAF.js +0 -1
- package/web-ui/build/static/nevod-B3o6AWcd.js +0 -1
- package/web-ui/build/static/nginx-DrKFdXBW.js +0 -1
- package/web-ui/build/static/nginx-DwMkoVe1.js +0 -1
- package/web-ui/build/static/nim-B-22OwVC.js +0 -1
- package/web-ui/build/static/nim-ZjPPKugm.js +0 -1
- package/web-ui/build/static/nix-BQMQjAsl.js +0 -1
- package/web-ui/build/static/nix-C7a28vpe.js +0 -1
- package/web-ui/build/static/node-repl-CRPtL62k.js +0 -1
- package/web-ui/build/static/nsis-BODe6Xcw.js +0 -1
- package/web-ui/build/static/nsis-BeJcjSZt.js +0 -1
- package/web-ui/build/static/objectivec-CZ1yuh6z.js +0 -1
- package/web-ui/build/static/objectivec-Clfu2BNM.js +0 -1
- package/web-ui/build/static/ocaml-CzgyFb5G.js +0 -1
- package/web-ui/build/static/ocaml-DXl0dpsF.js +0 -1
- package/web-ui/build/static/opencl-BnxKg8-f.js +0 -1
- package/web-ui/build/static/openqasm-DNiURxKn.js +0 -1
- package/web-ui/build/static/openscad-DaUxKMuP.js +0 -1
- package/web-ui/build/static/oxygene-DToT8MZR.js +0 -1
- package/web-ui/build/static/oz-rk2z3dw9.js +0 -1
- package/web-ui/build/static/parigp-JVxpBNQL.js +0 -1
- package/web-ui/build/static/parser-BCr749Bx.js +0 -1
- package/web-ui/build/static/parser3-DD23j4-C.js +0 -1
- package/web-ui/build/static/pascal-o92_BnLQ.js +0 -1
- package/web-ui/build/static/pascaligo-C1NiAOY-.js +0 -1
- package/web-ui/build/static/pcaxis-Ct28ud-Z.js +0 -1
- package/web-ui/build/static/peoplecode-D0msqyIF.js +0 -1
- package/web-ui/build/static/perl-Ca3Lh7IC.js +0 -1
- package/web-ui/build/static/perl-DdfO0xnj.js +0 -1
- package/web-ui/build/static/pf-6ngkRCaQ.js +0 -1
- package/web-ui/build/static/pgsql-LnMUiMfo.js +0 -1
- package/web-ui/build/static/php-CRbqNLc3.js +0 -1
- package/web-ui/build/static/php-extras-CjxCwMrR.js +0 -1
- package/web-ui/build/static/php-template-BbUJ71E5.js +0 -1
- package/web-ui/build/static/php-vqCWLGEp.js +0 -1
- package/web-ui/build/static/phpdoc-BH3ycDdA.js +0 -1
- package/web-ui/build/static/plaintext-CFrVID5o.js +0 -1
- package/web-ui/build/static/plsql-BYqM4XXM.js +0 -1
- package/web-ui/build/static/pony-Cqct3CUz.js +0 -1
- package/web-ui/build/static/powerquery-BAWhP028.js +0 -1
- package/web-ui/build/static/powershell-CQL7GUfl.js +0 -1
- package/web-ui/build/static/powershell-DgdwI5Eh.js +0 -1
- package/web-ui/build/static/processing-BfBIMxtL.js +0 -1
- package/web-ui/build/static/processing-i59a_-ef.js +0 -1
- package/web-ui/build/static/profile-DkaNdviC.js +0 -1
- package/web-ui/build/static/prolog-B2qIThTJ.js +0 -1
- package/web-ui/build/static/prolog-BhyHZjOe.js +0 -1
- package/web-ui/build/static/promql-qEgmePIA.js +0 -1
- package/web-ui/build/static/properties-CyawWRw9.js +0 -1
- package/web-ui/build/static/properties-gOm9O5Sy.js +0 -1
- package/web-ui/build/static/protobuf-CloH91Iq.js +0 -1
- package/web-ui/build/static/protobuf-G4O4DUoo.js +0 -1
- package/web-ui/build/static/psl-Bgr9wiWi.js +0 -1
- package/web-ui/build/static/pug-BxLccAH6.js +0 -1
- package/web-ui/build/static/puppet-BfNch25g.js +0 -1
- package/web-ui/build/static/puppet-sUUSkNjn.js +0 -1
- package/web-ui/build/static/pure-D_3cOjjU.js +0 -1
- package/web-ui/build/static/purebasic-CglLPBBU.js +0 -1
- package/web-ui/build/static/purebasic-DVk-VIrz.js +0 -1
- package/web-ui/build/static/purescript-cC9geduB.js +0 -1
- package/web-ui/build/static/python-6oBctF_t.js +0 -1
- package/web-ui/build/static/python-CkeFCHQP.js +0 -1
- package/web-ui/build/static/python-repl-DA24S3zQ.js +0 -1
- package/web-ui/build/static/q-DAq1mvxr.js +0 -1
- package/web-ui/build/static/q-DO0WLR6_.js +0 -1
- package/web-ui/build/static/qml-CIcZeQuk.js +0 -1
- package/web-ui/build/static/qml-DOhAlSPk.js +0 -1
- package/web-ui/build/static/qore-DMXT-urE.js +0 -1
- package/web-ui/build/static/qsharp-DQSCFS4i.js +0 -1
- package/web-ui/build/static/r-BexjuX_J.js +0 -1
- package/web-ui/build/static/r-DQ70dpNZ.js +0 -1
- package/web-ui/build/static/racket-BN0_Mqyo.js +0 -1
- package/web-ui/build/static/reason-DWSbgvd5.js +0 -1
- package/web-ui/build/static/reasonml-B4vDb5Wy.js +0 -1
- package/web-ui/build/static/regex-Blyc3kiA.js +0 -1
- package/web-ui/build/static/rego-DeQ9hhU9.js +0 -1
- package/web-ui/build/static/renpy-X9jk43rk.js +0 -1
- package/web-ui/build/static/rest-C3lUc_4y.js +0 -1
- package/web-ui/build/static/rib-KmlQxPBA.js +0 -1
- package/web-ui/build/static/rip-Dd_hy2Zx.js +0 -1
- package/web-ui/build/static/roboconf-CAh7oVNW.js +0 -1
- package/web-ui/build/static/roboconf-vS_EfgBZ.js +0 -1
- package/web-ui/build/static/robotframework-D4p8tzHv.js +0 -1
- package/web-ui/build/static/routeros-qk4GV8KB.js +0 -1
- package/web-ui/build/static/rsl-B8Rcetgj.js +0 -1
- package/web-ui/build/static/ruby-CNs4GL5D.js +0 -1
- package/web-ui/build/static/ruby-Cmy0n2CS.js +0 -1
- package/web-ui/build/static/ruleslanguage-DSjkIE1G.js +0 -1
- package/web-ui/build/static/rust-3mT6Nlon.js +0 -1
- package/web-ui/build/static/rust-siFOJ9k9.js +0 -1
- package/web-ui/build/static/sas-BiIFTXUl.js +0 -1
- package/web-ui/build/static/sas-CFH6sinb.js +0 -1
- package/web-ui/build/static/sass-DLJxAkHT.js +0 -1
- package/web-ui/build/static/scala-Dan9dKMX.js +0 -1
- package/web-ui/build/static/scala-DhBV9i0_.js +0 -1
- package/web-ui/build/static/scheme-B-kFG3YE.js +0 -1
- package/web-ui/build/static/scheme-C82JxuTR.js +0 -1
- package/web-ui/build/static/scilab-BYXO8Tjb.js +0 -1
- package/web-ui/build/static/scss-C3fXpH6t.js +0 -1
- package/web-ui/build/static/scss-CYhub2iM.js +0 -1
- package/web-ui/build/static/shell-43RrssjM.js +0 -1
- package/web-ui/build/static/shell-session-BdMw_-Aq.js +0 -1
- package/web-ui/build/static/smali-DQKw2_YT.js +0 -1
- package/web-ui/build/static/smali-DgzB635b.js +0 -1
- package/web-ui/build/static/smalltalk-C5rBOjTB.js +0 -1
- package/web-ui/build/static/smalltalk-CYHhcmiV.js +0 -1
- package/web-ui/build/static/smarty-CID09f1Q.js +0 -1
- package/web-ui/build/static/sml-BL2fVky5.js +0 -1
- package/web-ui/build/static/sml-DaUiC-uU.js +0 -1
- package/web-ui/build/static/solidity-B79CxcUN.js +0 -1
- package/web-ui/build/static/solution-file-CsUb7U0w.js +0 -1
- package/web-ui/build/static/soy-CFvmM_vN.js +0 -1
- package/web-ui/build/static/sparql-27EYOOvP.js +0 -1
- package/web-ui/build/static/splunk-spl-CDCBtuCy.js +0 -1
- package/web-ui/build/static/sqf--mMF7IDD.js +0 -1
- package/web-ui/build/static/sqf-DycqQ0nl.js +0 -1
- package/web-ui/build/static/sql-D3gpI7bt.js +0 -1
- package/web-ui/build/static/sql-D_8mIIdo.js +0 -1
- package/web-ui/build/static/sql_more-DZnien0v.js +0 -1
- package/web-ui/build/static/squirrel-CyzC8bFO.js +0 -1
- package/web-ui/build/static/stan--8Ee57GP.js +0 -1
- package/web-ui/build/static/stan-Blk-8fQD.js +0 -1
- package/web-ui/build/static/stata-B43_f8Sg.js +0 -1
- package/web-ui/build/static/step21-cIrndd-a.js +0 -1
- package/web-ui/build/static/stylus-Bw-DLMjW.js +0 -1
- package/web-ui/build/static/stylus-Cvxg1e1F.js +0 -1
- package/web-ui/build/static/subunit-D8e4wXMb.js +0 -1
- package/web-ui/build/static/swift-QaHaYXf4.js +0 -1
- package/web-ui/build/static/swift-ZP1YdM86.js +0 -1
- package/web-ui/build/static/systemd-CgcrqApb.js +0 -1
- package/web-ui/build/static/t4-cs-CUdZPBnA.js +0 -1
- package/web-ui/build/static/t4-templating-_u5xDqh3.js +0 -1
- package/web-ui/build/static/t4-vb-3qjBkYS-.js +0 -1
- package/web-ui/build/static/taggerscript-D8YgaifY.js +0 -1
- package/web-ui/build/static/tap-BAYRIlR4.js +0 -1
- package/web-ui/build/static/tap-ChQUri2f.js +0 -1
- package/web-ui/build/static/tcl-C-qFMZF8.js +0 -1
- package/web-ui/build/static/tcl-Dq7cO6pT.js +0 -1
- package/web-ui/build/static/textile-BR7bDtBq.js +0 -1
- package/web-ui/build/static/thrift-DcItIR6k.js +0 -1
- package/web-ui/build/static/toml-CGmrNnja.js +0 -1
- package/web-ui/build/static/tp-IA3QzkJh.js +0 -1
- package/web-ui/build/static/tremor-Byh_aCT2.js +0 -1
- package/web-ui/build/static/tsx-DsGXO_Ut.js +0 -1
- package/web-ui/build/static/tt2-CkBPYU2O.js +0 -1
- package/web-ui/build/static/turtle-Uf7cFeyK.js +0 -1
- package/web-ui/build/static/twig-D6zS84Px.js +0 -1
- package/web-ui/build/static/twig-DfaWqA49.js +0 -1
- package/web-ui/build/static/typescript-BVP5Rkcq.js +0 -1
- package/web-ui/build/static/typescript-BkE8WUxS.js +0 -1
- package/web-ui/build/static/typoscript-DpY8KQ0A.js +0 -1
- package/web-ui/build/static/unrealscript-Bnp05FFR.js +0 -1
- package/web-ui/build/static/uorazor-B-AFreN7.js +0 -1
- package/web-ui/build/static/uri-DTmSIA3p.js +0 -1
- package/web-ui/build/static/v-D7ukc8ER.js +0 -1
- package/web-ui/build/static/vala-BKEZxvJv.js +0 -1
- package/web-ui/build/static/vala-D6gg83a_.js +0 -1
- package/web-ui/build/static/vbnet-BISeFuM9.js +0 -1
- package/web-ui/build/static/vbnet-D2du0hPo.js +0 -1
- package/web-ui/build/static/vbscript-html-DN8zPJTF.js +0 -1
- package/web-ui/build/static/vbscript-tkzqTL0C.js +0 -1
- package/web-ui/build/static/velocity-D7D_-SAZ.js +0 -1
- package/web-ui/build/static/verilog-D9SJlamQ.js +0 -1
- package/web-ui/build/static/verilog-b7Tj3APZ.js +0 -1
- package/web-ui/build/static/vhdl-DbVOi25M.js +0 -1
- package/web-ui/build/static/vhdl-xUdF-t0l.js +0 -1
- package/web-ui/build/static/vim-B2XFBXx9.js +0 -1
- package/web-ui/build/static/vim-DdQgvtGL.js +0 -1
- package/web-ui/build/static/visual-basic-DvBC9qhx.js +0 -1
- package/web-ui/build/static/warpscript-D3VcKbld.js +0 -1
- package/web-ui/build/static/wasm-D58v5WwG.js +0 -1
- package/web-ui/build/static/web-idl-DIPQ3Top.js +0 -1
- package/web-ui/build/static/wiki-BEjZzYVq.js +0 -1
- package/web-ui/build/static/wolfram-BPBF-xyT.js +0 -1
- package/web-ui/build/static/wren-eorvvPqg.js +0 -1
- package/web-ui/build/static/x86asm-CoA2j5cm.js +0 -1
- package/web-ui/build/static/xeora-CLwwBmY1.js +0 -1
- package/web-ui/build/static/xl-Dk3AxeFF.js +0 -1
- package/web-ui/build/static/xml-Co9DMAsK.js +0 -1
- package/web-ui/build/static/xml-doc-By7MC1uc.js +0 -1
- package/web-ui/build/static/xojo-BCxhTIyS.js +0 -1
- package/web-ui/build/static/xquery-BMGFXwE4.js +0 -1
- package/web-ui/build/static/xquery-CrrYDOVp.js +0 -1
- package/web-ui/build/static/yaml-8UJeGwzG.js +0 -1
- package/web-ui/build/static/yaml-D5WHAmZr.js +0 -1
- package/web-ui/build/static/yang-TjorshEe.js +0 -1
- package/web-ui/build/static/zephir-D-qqYhSq.js +0 -1
- package/web-ui/build/static/zig-DM44cVL8.js +0 -1
|
@@ -0,0 +1,559 @@
|
|
|
1
|
+
import { jest, describe, test, expect, beforeEach } from '@jest/globals';
|
|
2
|
+
import { createMockLogger } from '../../__test-utils__/mockFactories.js';
|
|
3
|
+
|
|
4
|
+
// Mock fs and userDataDir before importing service
|
|
5
|
+
jest.unstable_mockModule('fs', () => ({
|
|
6
|
+
promises: {
|
|
7
|
+
mkdir: jest.fn().mockResolvedValue(undefined),
|
|
8
|
+
readFile: jest.fn().mockRejectedValue(new Error('ENOENT')),
|
|
9
|
+
writeFile: jest.fn().mockResolvedValue(undefined)
|
|
10
|
+
}
|
|
11
|
+
}));
|
|
12
|
+
|
|
13
|
+
jest.unstable_mockModule('../../utilities/userDataDir.js', () => ({
|
|
14
|
+
getUserDataPaths: () => ({ base: '/mock/data' }),
|
|
15
|
+
ensureUserDataDirs: jest.fn().mockResolvedValue(undefined)
|
|
16
|
+
}));
|
|
17
|
+
|
|
18
|
+
const { DiscordService, DISCORD_STATUS } = await import('../discordService.js');
|
|
19
|
+
|
|
20
|
+
describe('DiscordService', () => {
|
|
21
|
+
let service;
|
|
22
|
+
let logger;
|
|
23
|
+
|
|
24
|
+
beforeEach(() => {
|
|
25
|
+
logger = createMockLogger();
|
|
26
|
+
service = new DiscordService(logger);
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
// --- Constructor & Status ---
|
|
30
|
+
|
|
31
|
+
test('constructor creates instance with correct defaults', () => {
|
|
32
|
+
expect(service).toBeInstanceOf(DiscordService);
|
|
33
|
+
expect(service.status).toBe(DISCORD_STATUS.DISCONNECTED);
|
|
34
|
+
expect(service.channelMappings).toEqual({});
|
|
35
|
+
expect(service.client).toBeNull();
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
test('getStatus returns disconnected state by default', () => {
|
|
39
|
+
const status = service.getStatus();
|
|
40
|
+
expect(status.status).toBe('disconnected');
|
|
41
|
+
expect(status.connected).toBe(false);
|
|
42
|
+
expect(status.botUsername).toBeNull();
|
|
43
|
+
expect(status.guildCount).toBe(0);
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
// --- Dependency Injection ---
|
|
47
|
+
|
|
48
|
+
test('setOrchestrator stores reference', () => {
|
|
49
|
+
const mockOrch = { processRequest: jest.fn() };
|
|
50
|
+
service.setOrchestrator(mockOrch);
|
|
51
|
+
expect(service.orchestrator).toBe(mockOrch);
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
test('setAgentPool stores reference', () => {
|
|
55
|
+
const mockPool = { getAgent: jest.fn() };
|
|
56
|
+
service.setAgentPool(mockPool);
|
|
57
|
+
expect(service.agentPool).toBe(mockPool);
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
test('setFlowExecutor stores reference', () => {
|
|
61
|
+
const mockFE = {};
|
|
62
|
+
service.setFlowExecutor(mockFE);
|
|
63
|
+
expect(service.flowExecutor).toBe(mockFE);
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
// --- Channel Mapping CRUD ---
|
|
67
|
+
|
|
68
|
+
test('assignAgentToChannel adds agent to empty channel', async () => {
|
|
69
|
+
await service.assignAgentToChannel('guild1:ch1', 'agent-1');
|
|
70
|
+
expect(service.channelMappings['guild1:ch1']).toEqual(['agent-1']);
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
test('assignAgentToChannel adds second agent to same channel', async () => {
|
|
74
|
+
await service.assignAgentToChannel('guild1:ch1', 'agent-1');
|
|
75
|
+
await service.assignAgentToChannel('guild1:ch1', 'agent-2');
|
|
76
|
+
expect(service.channelMappings['guild1:ch1']).toEqual(['agent-1', 'agent-2']);
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
test('assignAgentToChannel does not duplicate agent', async () => {
|
|
80
|
+
await service.assignAgentToChannel('guild1:ch1', 'agent-1');
|
|
81
|
+
await service.assignAgentToChannel('guild1:ch1', 'agent-1');
|
|
82
|
+
expect(service.channelMappings['guild1:ch1']).toEqual(['agent-1']);
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
test('removeAgentFromChannel removes agent', async () => {
|
|
86
|
+
await service.assignAgentToChannel('guild1:ch1', 'agent-1');
|
|
87
|
+
await service.assignAgentToChannel('guild1:ch1', 'agent-2');
|
|
88
|
+
await service.removeAgentFromChannel('guild1:ch1', 'agent-1');
|
|
89
|
+
expect(service.channelMappings['guild1:ch1']).toEqual(['agent-2']);
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
test('removeAgentFromChannel cleans up empty channel', async () => {
|
|
93
|
+
await service.assignAgentToChannel('guild1:ch1', 'agent-1');
|
|
94
|
+
await service.removeAgentFromChannel('guild1:ch1', 'agent-1');
|
|
95
|
+
expect(service.channelMappings['guild1:ch1']).toBeUndefined();
|
|
96
|
+
});
|
|
97
|
+
|
|
98
|
+
test('removeAgentFromChannel clears sticky agent if removed', async () => {
|
|
99
|
+
await service.assignAgentToChannel('guild1:ch1', 'agent-1');
|
|
100
|
+
service.stickyAgent.set('guild1:ch1', 'agent-1');
|
|
101
|
+
await service.removeAgentFromChannel('guild1:ch1', 'agent-1');
|
|
102
|
+
expect(service.stickyAgent.has('guild1:ch1')).toBe(false);
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
test('getChannelMappings returns full state', async () => {
|
|
106
|
+
await service.assignAgentToChannel('g1:c1', 'a1');
|
|
107
|
+
service.knownGuilds = { g1: { name: 'Test Server' } };
|
|
108
|
+
service.knownChannels = { 'g1:c1': { name: 'general', guildName: 'Test Server' } };
|
|
109
|
+
|
|
110
|
+
const result = service.getChannelMappings();
|
|
111
|
+
expect(result.mappings).toEqual({ 'g1:c1': ['a1'] });
|
|
112
|
+
expect(result.knownGuilds.g1.name).toBe('Test Server');
|
|
113
|
+
expect(result.knownChannels['g1:c1'].name).toBe('general');
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
// --- Message Splitting ---
|
|
117
|
+
|
|
118
|
+
test('_splitMessage returns single part for short messages', () => {
|
|
119
|
+
const parts = service._splitMessage('Hello world');
|
|
120
|
+
expect(parts).toEqual(['Hello world']);
|
|
121
|
+
});
|
|
122
|
+
|
|
123
|
+
test('_splitMessage splits long messages', () => {
|
|
124
|
+
const longText = 'A'.repeat(3000);
|
|
125
|
+
const parts = service._splitMessage(longText);
|
|
126
|
+
expect(parts.length).toBeGreaterThan(1);
|
|
127
|
+
expect(parts.join('').length).toBe(3000);
|
|
128
|
+
parts.forEach(p => expect(p.length).toBeLessThanOrEqual(1950));
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
test('_splitMessage prefers newline split points', () => {
|
|
132
|
+
const text = 'Line 1\n' + 'X'.repeat(1950) + '\nLine 3 with more content';
|
|
133
|
+
const parts = service._splitMessage(text);
|
|
134
|
+
expect(parts.length).toBeGreaterThanOrEqual(2);
|
|
135
|
+
expect(parts[0]).toContain('Line 1');
|
|
136
|
+
});
|
|
137
|
+
|
|
138
|
+
// --- Agent Mention Parsing ---
|
|
139
|
+
|
|
140
|
+
test('_stripAgentMention removes @name prefix', () => {
|
|
141
|
+
const result = service._stripAgentMention('@TestAgent do something', 'agent-1');
|
|
142
|
+
expect(result).toBe('do something');
|
|
143
|
+
});
|
|
144
|
+
|
|
145
|
+
test('_stripAgentMention returns original if no prefix', () => {
|
|
146
|
+
const result = service._stripAgentMention('just a message', 'agent-1');
|
|
147
|
+
expect(result).toBe('just a message');
|
|
148
|
+
});
|
|
149
|
+
|
|
150
|
+
// --- Broadcast Interception ---
|
|
151
|
+
|
|
152
|
+
test('_interceptBroadcasts chains onto existing wrapper', () => {
|
|
153
|
+
const originalFn = jest.fn();
|
|
154
|
+
const wsManager = { broadcastToSession: originalFn };
|
|
155
|
+
|
|
156
|
+
service._interceptBroadcasts(wsManager);
|
|
157
|
+
|
|
158
|
+
// Call the wrapped function
|
|
159
|
+
wsManager.broadcastToSession('session1', { type: 'test' });
|
|
160
|
+
|
|
161
|
+
// Original should still be called
|
|
162
|
+
expect(originalFn).toHaveBeenCalledWith('session1', { type: 'test' });
|
|
163
|
+
});
|
|
164
|
+
|
|
165
|
+
test('_interceptBroadcasts does not double-wrap', () => {
|
|
166
|
+
const originalFn = jest.fn();
|
|
167
|
+
const wsManager = { broadcastToSession: originalFn };
|
|
168
|
+
|
|
169
|
+
service._interceptBroadcasts(wsManager);
|
|
170
|
+
const firstWrapper = wsManager.broadcastToSession;
|
|
171
|
+
|
|
172
|
+
service._interceptBroadcasts(wsManager); // Second call
|
|
173
|
+
expect(wsManager.broadcastToSession).toBe(firstWrapper); // Should not change
|
|
174
|
+
});
|
|
175
|
+
|
|
176
|
+
// --- Disconnect ---
|
|
177
|
+
|
|
178
|
+
test('disconnect resets state', async () => {
|
|
179
|
+
service.status = DISCORD_STATUS.CONNECTED;
|
|
180
|
+
service.recentInteractions.set('test', { channelKey: 'g:c', timestamp: Date.now() });
|
|
181
|
+
service.stickyAgent.set('g:c', 'agent-1');
|
|
182
|
+
|
|
183
|
+
await service.disconnect();
|
|
184
|
+
|
|
185
|
+
expect(service.status).toBe(DISCORD_STATUS.DISCONNECTED);
|
|
186
|
+
expect(service.recentInteractions.size).toBe(0);
|
|
187
|
+
expect(service.stickyAgent.size).toBe(0);
|
|
188
|
+
expect(service.client).toBeNull();
|
|
189
|
+
});
|
|
190
|
+
|
|
191
|
+
// --- Available Channels (offline) ---
|
|
192
|
+
|
|
193
|
+
test('getAvailableChannels returns cached channels when disconnected', () => {
|
|
194
|
+
service.knownChannels = {
|
|
195
|
+
'g1:c1': { name: 'general', guildId: 'g1', guildName: 'Server' },
|
|
196
|
+
'g1:c2': { name: 'dev', guildId: 'g1', guildName: 'Server' }
|
|
197
|
+
};
|
|
198
|
+
|
|
199
|
+
const channels = service.getAvailableChannels();
|
|
200
|
+
expect(channels).toHaveLength(2);
|
|
201
|
+
expect(channels[0].name).toBe('general');
|
|
202
|
+
expect(channels[0].key).toBe('g1:c1');
|
|
203
|
+
expect(channels[1].name).toBe('dev');
|
|
204
|
+
});
|
|
205
|
+
|
|
206
|
+
// --- Message Routing (_handleMessage) ---
|
|
207
|
+
|
|
208
|
+
describe('_handleMessage', () => {
|
|
209
|
+
const makeMockMessage = (content, guildId = 'g1', channelId = 'c1', authorBot = false) => ({
|
|
210
|
+
content,
|
|
211
|
+
author: { bot: authorBot, id: 'user-123' },
|
|
212
|
+
guild: { id: guildId },
|
|
213
|
+
channel: { id: channelId, sendTyping: jest.fn().mockResolvedValue(undefined), send: jest.fn().mockResolvedValue(undefined) },
|
|
214
|
+
reply: jest.fn().mockResolvedValue(undefined)
|
|
215
|
+
});
|
|
216
|
+
|
|
217
|
+
beforeEach(() => {
|
|
218
|
+
service.orchestrator = { processRequest: jest.fn().mockResolvedValue({}) };
|
|
219
|
+
service.agentPool = {
|
|
220
|
+
getAgent: jest.fn().mockImplementation(id => {
|
|
221
|
+
const agents = {
|
|
222
|
+
'agent-1': { id: 'agent-1', name: 'Alpha' },
|
|
223
|
+
'agent-2': { id: 'agent-2', name: 'Beta' }
|
|
224
|
+
};
|
|
225
|
+
return Promise.resolve(agents[id] || null);
|
|
226
|
+
})
|
|
227
|
+
};
|
|
228
|
+
});
|
|
229
|
+
|
|
230
|
+
test('ignores bot messages', async () => {
|
|
231
|
+
const msg = makeMockMessage('hello', 'g1', 'c1', true);
|
|
232
|
+
service.channelMappings = { 'g1:c1': ['agent-1'] };
|
|
233
|
+
await service._handleMessage(msg);
|
|
234
|
+
expect(service.orchestrator.processRequest).not.toHaveBeenCalled();
|
|
235
|
+
});
|
|
236
|
+
|
|
237
|
+
test('ignores DMs (no guild)', async () => {
|
|
238
|
+
const msg = makeMockMessage('hello');
|
|
239
|
+
msg.guild = null;
|
|
240
|
+
service.channelMappings = { 'g1:c1': ['agent-1'] };
|
|
241
|
+
await service._handleMessage(msg);
|
|
242
|
+
expect(service.orchestrator.processRequest).not.toHaveBeenCalled();
|
|
243
|
+
});
|
|
244
|
+
|
|
245
|
+
test('ignores unmapped channels', async () => {
|
|
246
|
+
const msg = makeMockMessage('hello');
|
|
247
|
+
service.channelMappings = {}; // no mapping for g1:c1
|
|
248
|
+
await service._handleMessage(msg);
|
|
249
|
+
expect(service.orchestrator.processRequest).not.toHaveBeenCalled();
|
|
250
|
+
});
|
|
251
|
+
|
|
252
|
+
test('ignores empty messages', async () => {
|
|
253
|
+
const msg = makeMockMessage(' ');
|
|
254
|
+
service.channelMappings = { 'g1:c1': ['agent-1'] };
|
|
255
|
+
await service._handleMessage(msg);
|
|
256
|
+
expect(service.orchestrator.processRequest).not.toHaveBeenCalled();
|
|
257
|
+
});
|
|
258
|
+
|
|
259
|
+
test('routes directly when single agent mapped', async () => {
|
|
260
|
+
const msg = makeMockMessage('do the thing');
|
|
261
|
+
service.channelMappings = { 'g1:c1': ['agent-1'] };
|
|
262
|
+
|
|
263
|
+
await service._handleMessage(msg);
|
|
264
|
+
|
|
265
|
+
expect(service.orchestrator.processRequest).toHaveBeenCalledTimes(1);
|
|
266
|
+
const call = service.orchestrator.processRequest.mock.calls[0][0];
|
|
267
|
+
expect(call.payload.agentId).toBe('agent-1');
|
|
268
|
+
expect(call.payload.message).toBe('do the thing');
|
|
269
|
+
expect(call.interface).toBe('discord');
|
|
270
|
+
expect(call.sessionId).toBe('discord-g1-c1');
|
|
271
|
+
});
|
|
272
|
+
|
|
273
|
+
test('routes via @mention when multiple agents mapped', async () => {
|
|
274
|
+
const msg = makeMockMessage('@Alpha do something');
|
|
275
|
+
service.channelMappings = { 'g1:c1': ['agent-1', 'agent-2'] };
|
|
276
|
+
|
|
277
|
+
await service._handleMessage(msg);
|
|
278
|
+
|
|
279
|
+
expect(service.orchestrator.processRequest).toHaveBeenCalledTimes(1);
|
|
280
|
+
const call = service.orchestrator.processRequest.mock.calls[0][0];
|
|
281
|
+
expect(call.payload.agentId).toBe('agent-1');
|
|
282
|
+
expect(call.payload.message).toBe('do something'); // stripped @mention
|
|
283
|
+
});
|
|
284
|
+
|
|
285
|
+
test('uses sticky agent when no @mention and multi-agent', async () => {
|
|
286
|
+
const msg = makeMockMessage('follow up question');
|
|
287
|
+
service.channelMappings = { 'g1:c1': ['agent-1', 'agent-2'] };
|
|
288
|
+
service.stickyAgent.set('g1:c1', 'agent-2');
|
|
289
|
+
|
|
290
|
+
await service._handleMessage(msg);
|
|
291
|
+
|
|
292
|
+
const call = service.orchestrator.processRequest.mock.calls[0][0];
|
|
293
|
+
expect(call.payload.agentId).toBe('agent-2');
|
|
294
|
+
});
|
|
295
|
+
|
|
296
|
+
test('prompts user when multi-agent, no @mention, no sticky', async () => {
|
|
297
|
+
const msg = makeMockMessage('who am I talking to');
|
|
298
|
+
service.channelMappings = { 'g1:c1': ['agent-1', 'agent-2'] };
|
|
299
|
+
|
|
300
|
+
await service._handleMessage(msg);
|
|
301
|
+
|
|
302
|
+
expect(service.orchestrator.processRequest).not.toHaveBeenCalled();
|
|
303
|
+
expect(msg.reply).toHaveBeenCalledTimes(1);
|
|
304
|
+
const replyText = msg.reply.mock.calls[0][0];
|
|
305
|
+
expect(replyText).toContain('Multiple agents');
|
|
306
|
+
expect(replyText).toContain('@Alpha');
|
|
307
|
+
expect(replyText).toContain('@Beta');
|
|
308
|
+
});
|
|
309
|
+
|
|
310
|
+
test('updates sticky agent after routing', async () => {
|
|
311
|
+
const msg = makeMockMessage('hello');
|
|
312
|
+
service.channelMappings = { 'g1:c1': ['agent-1'] };
|
|
313
|
+
|
|
314
|
+
await service._handleMessage(msg);
|
|
315
|
+
|
|
316
|
+
expect(service.stickyAgent.get('g1:c1')).toBe('agent-1');
|
|
317
|
+
});
|
|
318
|
+
|
|
319
|
+
test('records recent interaction for response targeting', async () => {
|
|
320
|
+
const msg = makeMockMessage('hello');
|
|
321
|
+
service.channelMappings = { 'g1:c1': ['agent-1'] };
|
|
322
|
+
|
|
323
|
+
await service._handleMessage(msg);
|
|
324
|
+
|
|
325
|
+
const interaction = service.recentInteractions.get('agent-1:g1:c1');
|
|
326
|
+
expect(interaction).toBeDefined();
|
|
327
|
+
expect(interaction.channelKey).toBe('g1:c1');
|
|
328
|
+
expect(interaction.channelId).toBe('c1');
|
|
329
|
+
expect(interaction.timestamp).toBeGreaterThan(0);
|
|
330
|
+
});
|
|
331
|
+
});
|
|
332
|
+
|
|
333
|
+
// --- Agent Mention Resolution ---
|
|
334
|
+
|
|
335
|
+
describe('_resolveAgentFromMention', () => {
|
|
336
|
+
beforeEach(() => {
|
|
337
|
+
service.agentPool = {
|
|
338
|
+
getAgent: jest.fn().mockImplementation(id => {
|
|
339
|
+
const agents = {
|
|
340
|
+
'a1': { id: 'a1', name: 'CodeBot' },
|
|
341
|
+
'a2': { id: 'a2', name: 'Analyzer' }
|
|
342
|
+
};
|
|
343
|
+
return Promise.resolve(agents[id] || null);
|
|
344
|
+
})
|
|
345
|
+
};
|
|
346
|
+
});
|
|
347
|
+
|
|
348
|
+
test('resolves matching @mention to agent ID', async () => {
|
|
349
|
+
const result = await service._resolveAgentFromMention('@CodeBot fix bug', ['a1', 'a2']);
|
|
350
|
+
expect(result).toBe('a1');
|
|
351
|
+
});
|
|
352
|
+
|
|
353
|
+
test('resolves case-insensitively', async () => {
|
|
354
|
+
const result = await service._resolveAgentFromMention('@codebot fix bug', ['a1', 'a2']);
|
|
355
|
+
expect(result).toBe('a1');
|
|
356
|
+
});
|
|
357
|
+
|
|
358
|
+
test('returns null when no @mention', async () => {
|
|
359
|
+
const result = await service._resolveAgentFromMention('no mention here', ['a1', 'a2']);
|
|
360
|
+
expect(result).toBeNull();
|
|
361
|
+
});
|
|
362
|
+
|
|
363
|
+
test('returns null when @mention does not match any candidate', async () => {
|
|
364
|
+
const result = await service._resolveAgentFromMention('@Unknown do stuff', ['a1', 'a2']);
|
|
365
|
+
expect(result).toBeNull();
|
|
366
|
+
});
|
|
367
|
+
});
|
|
368
|
+
|
|
369
|
+
// --- Broadcast Relay (_relayAgentResponse) ---
|
|
370
|
+
|
|
371
|
+
describe('_relayAgentResponse', () => {
|
|
372
|
+
const mockChannel = { send: jest.fn().mockResolvedValue(undefined) };
|
|
373
|
+
|
|
374
|
+
beforeEach(() => {
|
|
375
|
+
service.status = DISCORD_STATUS.CONNECTED;
|
|
376
|
+
service.client = {
|
|
377
|
+
channels: { fetch: jest.fn().mockResolvedValue(mockChannel) }
|
|
378
|
+
};
|
|
379
|
+
service.agentPool = {
|
|
380
|
+
getAgent: jest.fn().mockResolvedValue({ id: 'a1', name: 'TestAgent' })
|
|
381
|
+
};
|
|
382
|
+
mockChannel.send.mockClear();
|
|
383
|
+
});
|
|
384
|
+
|
|
385
|
+
test('relays response to channel with recent interaction', async () => {
|
|
386
|
+
service.recentInteractions.set('a1:g1:c1', {
|
|
387
|
+
channelKey: 'g1:c1',
|
|
388
|
+
channelId: 'c1',
|
|
389
|
+
guildId: 'g1',
|
|
390
|
+
timestamp: Date.now()
|
|
391
|
+
});
|
|
392
|
+
|
|
393
|
+
await service._relayAgentResponse({
|
|
394
|
+
agentId: 'a1',
|
|
395
|
+
content: 'Here is my answer',
|
|
396
|
+
type: 'stream_complete'
|
|
397
|
+
});
|
|
398
|
+
|
|
399
|
+
expect(service.client.channels.fetch).toHaveBeenCalledWith('c1');
|
|
400
|
+
expect(mockChannel.send).toHaveBeenCalled();
|
|
401
|
+
const sentText = mockChannel.send.mock.calls[0][0];
|
|
402
|
+
expect(sentText).toContain('TestAgent');
|
|
403
|
+
expect(sentText).toContain('Here is my answer');
|
|
404
|
+
});
|
|
405
|
+
|
|
406
|
+
test('does NOT relay when no recent interaction for agent', async () => {
|
|
407
|
+
// No interactions recorded for a1
|
|
408
|
+
await service._relayAgentResponse({
|
|
409
|
+
agentId: 'a1',
|
|
410
|
+
content: 'Hello'
|
|
411
|
+
});
|
|
412
|
+
|
|
413
|
+
expect(mockChannel.send).not.toHaveBeenCalled();
|
|
414
|
+
});
|
|
415
|
+
|
|
416
|
+
test('does NOT relay expired interactions (TTL)', async () => {
|
|
417
|
+
service.recentInteractions.set('a1:g1:c1', {
|
|
418
|
+
channelKey: 'g1:c1',
|
|
419
|
+
channelId: 'c1',
|
|
420
|
+
guildId: 'g1',
|
|
421
|
+
timestamp: Date.now() - 31 * 60 * 1000 // 31 minutes ago — expired
|
|
422
|
+
});
|
|
423
|
+
|
|
424
|
+
await service._relayAgentResponse({
|
|
425
|
+
agentId: 'a1',
|
|
426
|
+
content: 'Hello'
|
|
427
|
+
});
|
|
428
|
+
|
|
429
|
+
expect(mockChannel.send).not.toHaveBeenCalled();
|
|
430
|
+
// Should also clean up expired entry
|
|
431
|
+
expect(service.recentInteractions.has('a1:g1:c1')).toBe(false);
|
|
432
|
+
});
|
|
433
|
+
|
|
434
|
+
test('relays only to the correct agent channels', async () => {
|
|
435
|
+
// agent-1 has interaction on c1, agent-2 has interaction on c2
|
|
436
|
+
service.recentInteractions.set('a1:g1:c1', {
|
|
437
|
+
channelKey: 'g1:c1', channelId: 'c1', guildId: 'g1', timestamp: Date.now()
|
|
438
|
+
});
|
|
439
|
+
service.recentInteractions.set('a2:g1:c2', {
|
|
440
|
+
channelKey: 'g1:c2', channelId: 'c2', guildId: 'g1', timestamp: Date.now()
|
|
441
|
+
});
|
|
442
|
+
|
|
443
|
+
await service._relayAgentResponse({ agentId: 'a1', content: 'Reply from a1' });
|
|
444
|
+
|
|
445
|
+
// Should only fetch c1, not c2
|
|
446
|
+
expect(service.client.channels.fetch).toHaveBeenCalledWith('c1');
|
|
447
|
+
expect(service.client.channels.fetch).not.toHaveBeenCalledWith('c2');
|
|
448
|
+
});
|
|
449
|
+
|
|
450
|
+
test('skips user-role messages', async () => {
|
|
451
|
+
service.recentInteractions.set('a1:g1:c1', {
|
|
452
|
+
channelKey: 'g1:c1', channelId: 'c1', guildId: 'g1', timestamp: Date.now()
|
|
453
|
+
});
|
|
454
|
+
|
|
455
|
+
await service._relayAgentResponse({ agentId: 'a1', content: 'user input', role: 'user' });
|
|
456
|
+
expect(mockChannel.send).not.toHaveBeenCalled();
|
|
457
|
+
});
|
|
458
|
+
|
|
459
|
+
test('skips tool-role messages', async () => {
|
|
460
|
+
service.recentInteractions.set('a1:g1:c1', {
|
|
461
|
+
channelKey: 'g1:c1', channelId: 'c1', guildId: 'g1', timestamp: Date.now()
|
|
462
|
+
});
|
|
463
|
+
|
|
464
|
+
await service._relayAgentResponse({ agentId: 'a1', content: 'tool output', role: 'tool' });
|
|
465
|
+
expect(mockChannel.send).not.toHaveBeenCalled();
|
|
466
|
+
});
|
|
467
|
+
|
|
468
|
+
test('skips messages with no content', async () => {
|
|
469
|
+
service.recentInteractions.set('a1:g1:c1', {
|
|
470
|
+
channelKey: 'g1:c1', channelId: 'c1', guildId: 'g1', timestamp: Date.now()
|
|
471
|
+
});
|
|
472
|
+
|
|
473
|
+
await service._relayAgentResponse({ agentId: 'a1' }); // no content
|
|
474
|
+
expect(mockChannel.send).not.toHaveBeenCalled();
|
|
475
|
+
});
|
|
476
|
+
});
|
|
477
|
+
|
|
478
|
+
// --- Broadcast Event Handling (_handleBroadcastEvent) ---
|
|
479
|
+
|
|
480
|
+
describe('_handleBroadcastEvent', () => {
|
|
481
|
+
beforeEach(() => {
|
|
482
|
+
service.status = DISCORD_STATUS.CONNECTED;
|
|
483
|
+
service.client = {
|
|
484
|
+
channels: { fetch: jest.fn().mockResolvedValue({ send: jest.fn().mockResolvedValue(undefined) }) }
|
|
485
|
+
};
|
|
486
|
+
service.agentPool = { getAgent: jest.fn().mockResolvedValue({ id: 'a1', name: 'Bot' }) };
|
|
487
|
+
});
|
|
488
|
+
|
|
489
|
+
test('ignores events when disconnected', async () => {
|
|
490
|
+
service.status = DISCORD_STATUS.DISCONNECTED;
|
|
491
|
+
const spy = jest.spyOn(service, '_relayAgentResponse');
|
|
492
|
+
await service._handleBroadcastEvent('s1', { type: 'stream_complete', agentId: 'a1', content: 'hi' });
|
|
493
|
+
expect(spy).not.toHaveBeenCalled();
|
|
494
|
+
});
|
|
495
|
+
|
|
496
|
+
test('ignores events with no type', async () => {
|
|
497
|
+
const spy = jest.spyOn(service, '_relayAgentResponse');
|
|
498
|
+
await service._handleBroadcastEvent('s1', {});
|
|
499
|
+
expect(spy).not.toHaveBeenCalled();
|
|
500
|
+
});
|
|
501
|
+
|
|
502
|
+
test('forwards stream_complete to _relayAgentResponse', async () => {
|
|
503
|
+
const spy = jest.spyOn(service, '_relayAgentResponse').mockResolvedValue(undefined);
|
|
504
|
+
const msg = { type: 'stream_complete', agentId: 'a1', content: 'result' };
|
|
505
|
+
await service._handleBroadcastEvent('s1', msg);
|
|
506
|
+
expect(spy).toHaveBeenCalledWith(msg);
|
|
507
|
+
});
|
|
508
|
+
|
|
509
|
+
test('forwards user_prompt_request to _relayPromptRequest', async () => {
|
|
510
|
+
const spy = jest.spyOn(service, '_relayPromptRequest').mockResolvedValue(undefined);
|
|
511
|
+
const msg = { type: 'user_prompt_request', data: { agentId: 'a1', prompt: 'Need input' } };
|
|
512
|
+
await service._handleBroadcastEvent('s1', msg);
|
|
513
|
+
expect(spy).toHaveBeenCalledWith(msg);
|
|
514
|
+
});
|
|
515
|
+
|
|
516
|
+
test('ignores other event types', async () => {
|
|
517
|
+
const relaySpy = jest.spyOn(service, '_relayAgentResponse');
|
|
518
|
+
const promptSpy = jest.spyOn(service, '_relayPromptRequest');
|
|
519
|
+
await service._handleBroadcastEvent('s1', { type: 'message_added', agentId: 'a1' });
|
|
520
|
+
expect(relaySpy).not.toHaveBeenCalled();
|
|
521
|
+
expect(promptSpy).not.toHaveBeenCalled();
|
|
522
|
+
});
|
|
523
|
+
});
|
|
524
|
+
|
|
525
|
+
// --- Config Persistence ---
|
|
526
|
+
|
|
527
|
+
describe('config persistence', () => {
|
|
528
|
+
test('_loadConfig handles missing file gracefully', async () => {
|
|
529
|
+
// fs.readFile is mocked to reject with ENOENT
|
|
530
|
+
await service._loadConfig();
|
|
531
|
+
expect(service.config).toEqual({});
|
|
532
|
+
expect(service.channelMappings).toEqual({});
|
|
533
|
+
});
|
|
534
|
+
|
|
535
|
+
test('_saveConfig persists current state', async () => {
|
|
536
|
+
const { promises: mockFs } = await import('fs');
|
|
537
|
+
service.channelMappings = { 'g1:c1': ['a1'] };
|
|
538
|
+
service.knownGuilds = { g1: { name: 'Server' } };
|
|
539
|
+
service.knownChannels = { 'g1:c1': { name: 'general' } };
|
|
540
|
+
|
|
541
|
+
await service._saveConfig();
|
|
542
|
+
|
|
543
|
+
expect(mockFs.writeFile).toHaveBeenCalled();
|
|
544
|
+
const writtenJson = JSON.parse(mockFs.writeFile.mock.calls[mockFs.writeFile.mock.calls.length - 1][1]);
|
|
545
|
+
expect(writtenJson.channelMappings).toEqual({ 'g1:c1': ['a1'] });
|
|
546
|
+
expect(writtenJson.knownGuilds.g1.name).toBe('Server');
|
|
547
|
+
expect(writtenJson.updatedAt).toBeDefined();
|
|
548
|
+
});
|
|
549
|
+
});
|
|
550
|
+
|
|
551
|
+
// --- Singleton ---
|
|
552
|
+
|
|
553
|
+
test('getDiscordService returns singleton', async () => {
|
|
554
|
+
const { getDiscordService } = await import('../discordService.js');
|
|
555
|
+
const s1 = getDiscordService(logger);
|
|
556
|
+
const s2 = getDiscordService(logger);
|
|
557
|
+
expect(s1).toBe(s2);
|
|
558
|
+
});
|
|
559
|
+
});
|