onbuzz 3.7.1 → 3.8.1
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/controller.js +57 -0
- package/src/modules/fileExplorer/routes.js +129 -0
- package/src/services/__tests__/compactionRetry.test.js +272 -0
- package/src/services/__tests__/discordService.integration.test.js +639 -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 +700 -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-kdS9Tc53.js +1 -0
- package/web-ui/build/static/abap-0h239kg3.js +1 -0
- package/web-ui/build/static/abnf-AOCuIGYA.js +1 -0
- package/web-ui/build/static/abnf-Dv7TjVc_.js +1 -0
- package/web-ui/build/static/accesslog-CI30X7m_.js +1 -0
- package/web-ui/build/static/actionscript-BTc-LfxH.js +1 -0
- package/web-ui/build/static/actionscript-CPjI4ETO.js +1 -0
- package/web-ui/build/static/ada-BwsQ_Rlq.js +1 -0
- package/web-ui/build/static/ada-iW6x_8HP.js +1 -0
- package/web-ui/build/static/agda-CTc5ug8C.js +1 -0
- package/web-ui/build/static/al-BvWQ4YKg.js +1 -0
- package/web-ui/build/static/angelscript-ptY5eVOo.js +1 -0
- package/web-ui/build/static/antlr4-B65HvZ_b.js +1 -0
- package/web-ui/build/static/apache-D9qH06tM.js +1 -0
- package/web-ui/build/static/apacheconf-D-i8BqtK.js +1 -0
- package/web-ui/build/static/apex-E5-brxaK.js +1 -0
- package/web-ui/build/static/apl-CeHIJ9LA.js +1 -0
- package/web-ui/build/static/applescript-BkvcGu0c.js +1 -0
- package/web-ui/build/static/applescript-CUXciVPd.js +1 -0
- package/web-ui/build/static/aql-DJb6VgYH.js +1 -0
- package/web-ui/build/static/arcade-CXtn3mt1.js +1 -0
- package/web-ui/build/static/arduino-Cr5DT-5_.js +1 -0
- package/web-ui/build/static/arduino-Dr0MG6LL.js +1 -0
- package/web-ui/build/static/arff-C27OQZpo.js +1 -0
- package/web-ui/build/static/armasm-D0ptjIAm.js +1 -0
- package/web-ui/build/static/asciidoc-BgUng529.js +1 -0
- package/web-ui/build/static/asciidoc-DhUQ37T9.js +1 -0
- package/web-ui/build/static/asm6502-ldPVFRMY.js +1 -0
- package/web-ui/build/static/asmatmel-CXTC5caR.js +1 -0
- package/web-ui/build/static/aspectj-D15tZGSM.js +1 -0
- package/web-ui/build/static/aspnet-i-xfvr5h.js +1 -0
- package/web-ui/build/static/autohotkey-Dn6fESO3.js +1 -0
- package/web-ui/build/static/autohotkey-Dni08gre.js +1 -0
- package/web-ui/build/static/autoit-BIWWs9LU.js +1 -0
- package/web-ui/build/static/autoit-BztmfF41.js +1 -0
- package/web-ui/build/static/avisynth-CpqxPwSK.js +1 -0
- package/web-ui/build/static/avrasm-DuxrVPCJ.js +1 -0
- package/web-ui/build/static/avro-idl-vZX4XpfO.js +1 -0
- package/web-ui/build/static/awk-C6xhwDfg.js +1 -0
- package/web-ui/build/static/axapta-DQ4Vdy3u.js +1 -0
- package/web-ui/build/static/bash-D9QEww8y.js +1 -0
- package/web-ui/build/static/bash-DtdlGrGu.js +1 -0
- package/web-ui/build/static/basic-BC3aWGyQ.js +1 -0
- package/web-ui/build/static/basic-CbGviA1N.js +1 -0
- package/web-ui/build/static/batch-DEPoXp8r.js +1 -0
- package/web-ui/build/static/bbcode-COingAHU.js +1 -0
- package/web-ui/build/static/bicep-BB7sjMaE.js +1 -0
- package/web-ui/build/static/birb-DFPuJfqF.js +1 -0
- package/web-ui/build/static/bison-BXV84blr.js +1 -0
- package/web-ui/build/static/bnf-jND_RkKc.js +1 -0
- package/web-ui/build/static/bnf-qhF_iG4n.js +1 -0
- package/web-ui/build/static/brainfuck-CKXZTVX5.js +1 -0
- package/web-ui/build/static/brainfuck-DHefdgJw.js +1 -0
- package/web-ui/build/static/brightscript-DrenUX5n.js +1 -0
- package/web-ui/build/static/bro-Ba6qViYi.js +1 -0
- package/web-ui/build/static/bsl-CojgWkzr.js +1 -0
- package/web-ui/build/static/c-CCPZIv43.js +1 -0
- package/web-ui/build/static/c-RKFUJXwH.js +1 -0
- package/web-ui/build/static/c-like-C60JW-xx.js +1 -0
- package/web-ui/build/static/cal-Df2y_cE6.js +1 -0
- package/web-ui/build/static/capnproto-t_Oadw3n.js +1 -0
- package/web-ui/build/static/ceylon-Thw4r_-K.js +1 -0
- package/web-ui/build/static/cfscript-dqymuq6t.js +1 -0
- package/web-ui/build/static/chaiscript-DAJelTnj.js +1 -0
- package/web-ui/build/static/cil-DNvYrYfm.js +1 -0
- package/web-ui/build/static/clean-DLHONqB2.js +1 -0
- package/web-ui/build/static/clojure-BLvtPMso.js +1 -0
- package/web-ui/build/static/clojure-DGJ7bhx6.js +1 -0
- package/web-ui/build/static/clojure-repl-BOWFtWxG.js +1 -0
- package/web-ui/build/static/cmake-BTf4X-_f.js +1 -0
- package/web-ui/build/static/cmake-Hq2PBUsB.js +1 -0
- package/web-ui/build/static/cobol-Dd1PmczQ.js +1 -0
- package/web-ui/build/static/coffeescript-BXT_oj6S.js +1 -0
- package/web-ui/build/static/coffeescript-COtRCBlY.js +1 -0
- package/web-ui/build/static/concurnas-CmXAvGRd.js +1 -0
- package/web-ui/build/static/coq-BDrd_p3n.js +1 -0
- package/web-ui/build/static/coq-cEMj6nWn.js +1 -0
- package/web-ui/build/static/cos-rR0w9aDG.js +1 -0
- package/web-ui/build/static/cpp-BxgRm2TZ.js +1 -0
- package/web-ui/build/static/cpp-Cb97V0y9.js +1 -0
- package/web-ui/build/static/crmsh-C0Z0ZnaX.js +1 -0
- package/web-ui/build/static/crystal-CCcOY5Da.js +1 -0
- package/web-ui/build/static/crystal-e24LtQ8D.js +1 -0
- package/web-ui/build/static/csharp-DBex-vMg.js +1 -0
- package/web-ui/build/static/csharp-DxHm88Zl.js +1 -0
- package/web-ui/build/static/cshtml-B33qvc-S.js +1 -0
- package/web-ui/build/static/csp-CiC-gxVo.js +1 -0
- package/web-ui/build/static/csp-EQuD3502.js +1 -0
- package/web-ui/build/static/css-extras-Dt7ftI3c.js +1 -0
- package/web-ui/build/static/css-tV-OMrg3.js +1 -0
- package/web-ui/build/static/csv-DkH0VyE4.js +1 -0
- package/web-ui/build/static/cypher-CqRmFhs3.js +1 -0
- package/web-ui/build/static/d-D8fJAH1c.js +1 -0
- package/web-ui/build/static/d-HcefIEWU.js +1 -0
- package/web-ui/build/static/dart-BDaE5P8h.js +1 -0
- package/web-ui/build/static/dart-UepkXmVV.js +1 -0
- package/web-ui/build/static/dataweave-DLxLyuMW.js +1 -0
- package/web-ui/build/static/dax-D02omR9M.js +1 -0
- package/web-ui/build/static/delphi-BmJHcrv1.js +1 -0
- package/web-ui/build/static/dhall-Ds5JsMUO.js +1 -0
- package/web-ui/build/static/diff-BmRoN-45.js +1 -0
- package/web-ui/build/static/diff-CW6K03Wp.js +1 -0
- package/web-ui/build/static/django-Cvuh94fb.js +1 -0
- package/web-ui/build/static/django-DdLkFBj4.js +1 -0
- package/web-ui/build/static/dns-B2DxSbd-.js +1 -0
- package/web-ui/build/static/dns-zone-file-BeM6CQ_o.js +1 -0
- package/web-ui/build/static/docker-7w2Aw3rk.js +1 -0
- package/web-ui/build/static/dockerfile-BSTcBagG.js +1 -0
- package/web-ui/build/static/dos-CJKicq3Q.js +1 -0
- package/web-ui/build/static/dot-B_A9ZQ-w.js +1 -0
- package/web-ui/build/static/dsconfig-C7lfFXpw.js +1 -0
- package/web-ui/build/static/dts-Bj6VHLb-.js +1 -0
- package/web-ui/build/static/dust-Bx0gsN4l.js +1 -0
- package/web-ui/build/static/ebnf-BxkAfaLZ.js +1 -0
- package/web-ui/build/static/ebnf-C7hLULzs.js +1 -0
- package/web-ui/build/static/editorconfig-BYLnviVc.js +1 -0
- package/web-ui/build/static/eiffel-BO5SQCB4.js +1 -0
- package/web-ui/build/static/ejs-C1pAQ69V.js +1 -0
- package/web-ui/build/static/elixir-CYqw1kMy.js +1 -0
- package/web-ui/build/static/elixir-DEfU3dBG.js +1 -0
- package/web-ui/build/static/elm-C49c2uYA.js +1 -0
- package/web-ui/build/static/elm-CkTL_OTL.js +1 -0
- package/web-ui/build/static/erb-Ddkj3ZW4.js +1 -0
- package/web-ui/build/static/erb-NRNGb6x_.js +1 -0
- package/web-ui/build/static/erlang-Cj_X5TSn.js +1 -0
- package/web-ui/build/static/erlang-D1Fudf5R.js +1 -0
- package/web-ui/build/static/erlang-repl-BYQZ3z3O.js +1 -0
- package/web-ui/build/static/etlua-Dv1Hjk6O.js +1 -0
- package/web-ui/build/static/excel-ByIvzD6w.js +1 -0
- package/web-ui/build/static/excel-formula-Cmwn22ae.js +1 -0
- package/web-ui/build/static/factor-DrEE6ylY.js +1 -0
- package/web-ui/build/static/false-BqLn4ol0.js +1 -0
- package/web-ui/build/static/firestore-security-rules-oXUzwumD.js +1 -0
- package/web-ui/build/static/fix-D0va0gNJ.js +1 -0
- package/web-ui/build/static/flix--0eRNVM8.js +1 -0
- package/web-ui/build/static/flow-DmD4pZDw.js +1 -0
- package/web-ui/build/static/fortran-DQgZF3so.js +1 -0
- package/web-ui/build/static/fortran-DTJRkgm0.js +1 -0
- package/web-ui/build/static/fsharp-CtTNujbv.js +1 -0
- package/web-ui/build/static/fsharp-iEoOUmEL.js +1 -0
- package/web-ui/build/static/ftl-Dx6nEkbB.js +1 -0
- package/web-ui/build/static/gams-De1TKEpt.js +1 -0
- package/web-ui/build/static/gap-CvvEgyX-.js +1 -0
- package/web-ui/build/static/gauss-jf-wjAg6.js +1 -0
- package/web-ui/build/static/gcode-8X5Biuc2.js +1 -0
- package/web-ui/build/static/gcode-MwRZ8tc2.js +1 -0
- package/web-ui/build/static/gdscript-Bm1ge_D5.js +1 -0
- package/web-ui/build/static/gedcom-FtUGQ7t5.js +1 -0
- package/web-ui/build/static/gherkin-DoA7JTWi.js +1 -0
- package/web-ui/build/static/gherkin-Fi4nogIx.js +1 -0
- package/web-ui/build/static/git-1o8MAL9P.js +1 -0
- package/web-ui/build/static/glsl-C8tOkxx3.js +1 -0
- package/web-ui/build/static/glsl-nE78aBK6.js +1 -0
- package/web-ui/build/static/gml-8yXvaUPU.js +1 -0
- package/web-ui/build/static/gml-BJkQljI7.js +1 -0
- package/web-ui/build/static/gn-CTf8vcwV.js +1 -0
- package/web-ui/build/static/go-BVLWj6TK.js +1 -0
- package/web-ui/build/static/go-D1TZAvjQ.js +1 -0
- package/web-ui/build/static/go-module-Cy3W-T5R.js +1 -0
- package/web-ui/build/static/golo-CRIP6Kfa.js +1 -0
- package/web-ui/build/static/gradle-CvkTBmDH.js +1 -0
- package/web-ui/build/static/graphql-CattLgtQ.js +1 -0
- package/web-ui/build/static/groovy-CnO06VMw.js +1 -0
- package/web-ui/build/static/groovy-D4UzsWuO.js +1 -0
- package/web-ui/build/static/haml-BahkK20F.js +1 -0
- package/web-ui/build/static/haml-Dx96108W.js +1 -0
- package/web-ui/build/static/handlebars-CkQbGaco.js +1 -0
- package/web-ui/build/static/handlebars-DTCynsRr.js +1 -0
- package/web-ui/build/static/haskell-4gqXKpug.js +1 -0
- package/web-ui/build/static/haskell-BhTd-8b1.js +1 -0
- package/web-ui/build/static/haxe-B9cZRIDM.js +1 -0
- package/web-ui/build/static/haxe-CPtE95-J.js +1 -0
- package/web-ui/build/static/hcl-BrYl947E.js +1 -0
- package/web-ui/build/static/hlsl-CGVnV9pW.js +1 -0
- package/web-ui/build/static/hoon-DBKdDZ5s.js +1 -0
- package/web-ui/build/static/hpkp-BfzidT0I.js +1 -0
- package/web-ui/build/static/hsp-Dp3V6kiq.js +1 -0
- package/web-ui/build/static/hsts-pm65qL5J.js +1 -0
- package/web-ui/build/static/htmlbars-CdUDFATp.js +1 -0
- package/web-ui/build/static/http-BdiYsRQV.js +1 -0
- package/web-ui/build/static/http-C0XI1ZmI.js +1 -0
- package/web-ui/build/static/hy-CWGebQLd.js +1 -0
- package/web-ui/build/static/ichigojam-CDSJM1IC.js +1 -0
- package/web-ui/build/static/icon-CTk0djd_.js +1 -0
- package/web-ui/build/static/icu-message-format-BD_wM1-v.js +1 -0
- package/web-ui/build/static/idris-DKXq2kwP.js +1 -0
- package/web-ui/build/static/iecst-BDNbkupX.js +1 -0
- package/web-ui/build/static/ignore-BWQqZxhS.js +1 -0
- package/web-ui/build/static/index-BAdiKqoV.css +1 -0
- package/web-ui/build/static/index-BP21MuR_.js +819 -0
- package/web-ui/build/static/index-BsD9WUaZ.js +1 -0
- package/web-ui/build/static/index-N0XS6Dah.js +13 -0
- package/web-ui/build/static/inform7-BjhxELDv.js +1 -0
- package/web-ui/build/static/inform7-Di9x78qY.js +1 -0
- package/web-ui/build/static/ini-Ci12a7mM.js +1 -0
- package/web-ui/build/static/ini-Dn4T2Web.js +1 -0
- package/web-ui/build/static/io-VwjWm6AV.js +1 -0
- package/web-ui/build/static/irpf90-7DLbiPTY.js +1 -0
- package/web-ui/build/static/isbl-N5jG8gdE.js +1 -0
- package/web-ui/build/static/j-Dv_J2HSG.js +1 -0
- package/web-ui/build/static/java-Cx72cYmO.js +1 -0
- package/web-ui/build/static/java-DQjJu2--.js +1 -0
- package/web-ui/build/static/javadoc-CGIjUxzI.js +1 -0
- package/web-ui/build/static/javadoclike-_PWzeFO2.js +1 -0
- package/web-ui/build/static/javascript-Zz-FCMjX.js +1 -0
- package/web-ui/build/static/javastacktrace-DpTpKKmQ.js +1 -0
- package/web-ui/build/static/jboss-cli-tx9An2n3.js +1 -0
- package/web-ui/build/static/jexl-B1wdJSX5.js +1 -0
- package/web-ui/build/static/jolie-DUn1tQOT.js +1 -0
- package/web-ui/build/static/jq-uw2SuH18.js +1 -0
- package/web-ui/build/static/js-extras-GTWZTeMk.js +1 -0
- package/web-ui/build/static/js-templates-DCaOSDRZ.js +1 -0
- package/web-ui/build/static/jsdoc-BkSQV9yg.js +1 -0
- package/web-ui/build/static/json-BeevXT6_.js +1 -0
- package/web-ui/build/static/json-CzyCLbDJ.js +1 -0
- package/web-ui/build/static/json5-BDkHQUth.js +1 -0
- package/web-ui/build/static/jsonp-CuUf5Oqw.js +1 -0
- package/web-ui/build/static/jsstacktrace-BPHi3Dtx.js +1 -0
- package/web-ui/build/static/jsx-BUbsN7gk.js +1 -0
- package/web-ui/build/static/julia-B54k2vAV.js +1 -0
- package/web-ui/build/static/julia-Cdih4cBZ.js +1 -0
- package/web-ui/build/static/julia-repl-CGa9k5Qt.js +1 -0
- package/web-ui/build/static/keepalived-CYTMkhaY.js +1 -0
- package/web-ui/build/static/keyman-DeSrlXgI.js +1 -0
- package/web-ui/build/static/kotlin-DRKZGIfv.js +1 -0
- package/web-ui/build/static/kotlin-J9lewlfL.js +1 -0
- package/web-ui/build/static/kumir-DsMaXbgn.js +1 -0
- package/web-ui/build/static/kusto-_zqpYifP.js +1 -0
- package/web-ui/build/static/lasso-BTHvYnA7.js +1 -0
- package/web-ui/build/static/latex-JBjfZx0W.js +1 -0
- package/web-ui/build/static/latex-b4jarEZC.js +1 -0
- package/web-ui/build/static/latte-DnHUO78u.js +1 -0
- package/web-ui/build/static/ldif-Cmjbqpqc.js +1 -0
- package/web-ui/build/static/leaf-CmDS5fV2.js +1 -0
- package/web-ui/build/static/less--kHhZXAX.js +1 -0
- package/web-ui/build/static/less-XBP-sPJ3.js +1 -0
- package/web-ui/build/static/lilypond-o_otew5V.js +1 -0
- package/web-ui/build/static/liquid-CrYvHLwx.js +1 -0
- package/web-ui/build/static/lisp-D3tm58fK.js +1 -0
- package/web-ui/build/static/lisp-D4Z5kO82.js +1 -0
- package/web-ui/build/static/livecodeserver-B-0n6FCx.js +1 -0
- package/web-ui/build/static/livescript-0KPwoTjZ.js +1 -0
- package/web-ui/build/static/livescript-DKfwfWPL.js +1 -0
- package/web-ui/build/static/llvm-CkfY4J3C.js +1 -0
- package/web-ui/build/static/llvm-pqFX0uyb.js +1 -0
- package/web-ui/build/static/log-DVSShcXU.js +1 -0
- package/web-ui/build/static/lolcode-4FllK7ZA.js +1 -0
- package/web-ui/build/static/lsl-BrNkHkAW.js +1 -0
- package/web-ui/build/static/lua-dypHBlta.js +1 -0
- package/web-ui/build/static/lua-h1vX8uRg.js +1 -0
- package/web-ui/build/static/magma-CkeqNKpI.js +1 -0
- package/web-ui/build/static/makefile-1to1VmXP.js +1 -0
- package/web-ui/build/static/makefile-DWgMI3zN.js +1 -0
- package/web-ui/build/static/markdown-BmlYl1Dg.js +1 -0
- package/web-ui/build/static/markdown-CRIkOS-6.js +1 -0
- package/web-ui/build/static/markup-templating-BNjcK72d.js +1 -0
- package/web-ui/build/static/mathematica-B7CQ5yI0.js +1 -0
- package/web-ui/build/static/matlab-D9TyDFKk.js +1 -0
- package/web-ui/build/static/matlab-DKLzFQH3.js +1 -0
- package/web-ui/build/static/maxima-e6X_zn0F.js +1 -0
- package/web-ui/build/static/maxscript-ByU_6cgp.js +1 -0
- package/web-ui/build/static/mel-BCDwIpJN.js +1 -0
- package/web-ui/build/static/mel-CqTugUm1.js +1 -0
- package/web-ui/build/static/mercury-CH53gHW8.js +1 -0
- package/web-ui/build/static/mermaid-DJSvQkhT.js +1 -0
- package/web-ui/build/static/mipsasm-DhWWP7g6.js +1 -0
- package/web-ui/build/static/mizar-B00_mNTM.js +1 -0
- package/web-ui/build/static/mizar-CnS9eIFJ.js +1 -0
- package/web-ui/build/static/mojolicious-CrX4mgHX.js +1 -0
- package/web-ui/build/static/mongodb-KGaDXSBz.js +1 -0
- package/web-ui/build/static/monkey-Bha1q1Xx.js +1 -0
- package/web-ui/build/static/monkey-Cm1tlX46.js +1 -0
- package/web-ui/build/static/moonscript-B3kxcIeX.js +1 -0
- package/web-ui/build/static/moonscript-D2QDx4Ct.js +1 -0
- package/web-ui/build/static/n1ql-B2rUg_yi.js +1 -0
- package/web-ui/build/static/n1ql-B3pR-3JV.js +1 -0
- package/web-ui/build/static/n4js-CEbbxPRp.js +1 -0
- package/web-ui/build/static/nand2tetris-hdl-DHgmoSW3.js +1 -0
- package/web-ui/build/static/naniscript-BZIop3Q5.js +1 -0
- package/web-ui/build/static/nasm-inVcIMbd.js +1 -0
- package/web-ui/build/static/neon-BYJ-lMP6.js +1 -0
- package/web-ui/build/static/nevod-sMrXfe3F.js +1 -0
- package/web-ui/build/static/nginx-BgPHR6bS.js +1 -0
- package/web-ui/build/static/nginx-DqpyN2v8.js +1 -0
- package/web-ui/build/static/nim-Bqw-roeF.js +1 -0
- package/web-ui/build/static/nim-RMRPniGW.js +1 -0
- package/web-ui/build/static/nix-Bxlxz-QE.js +1 -0
- package/web-ui/build/static/nix-C11igat6.js +1 -0
- package/web-ui/build/static/node-repl-Di1-dSCZ.js +1 -0
- package/web-ui/build/static/nsis-D70-TluF.js +1 -0
- package/web-ui/build/static/nsis-DEqbopCo.js +1 -0
- package/web-ui/build/static/objectivec-B_tLdw2I.js +1 -0
- package/web-ui/build/static/objectivec-DqCHTYmh.js +1 -0
- package/web-ui/build/static/ocaml-BqBvMYIo.js +1 -0
- package/web-ui/build/static/ocaml-DQaBMY5E.js +1 -0
- package/web-ui/build/static/opencl-B7RBp80H.js +1 -0
- package/web-ui/build/static/openqasm-hn5g2tAw.js +1 -0
- package/web-ui/build/static/openscad-CyEhZLgT.js +1 -0
- package/web-ui/build/static/oxygene-C51OhK8-.js +1 -0
- package/web-ui/build/static/oz-C00UByv4.js +1 -0
- package/web-ui/build/static/parigp-DEwbj6Fl.js +1 -0
- package/web-ui/build/static/parser-BvBBLDKY.js +1 -0
- package/web-ui/build/static/parser3-D3mbAuOt.js +1 -0
- package/web-ui/build/static/pascal-UkDjVSPr.js +1 -0
- package/web-ui/build/static/pascaligo-CkVZWARU.js +1 -0
- package/web-ui/build/static/pcaxis-CI7A9k5B.js +1 -0
- package/web-ui/build/static/peoplecode-DK-QZT1D.js +1 -0
- package/web-ui/build/static/perl-0G-5NnXj.js +1 -0
- package/web-ui/build/static/perl-Ct4ij6Ni.js +1 -0
- package/web-ui/build/static/pf-BKeJo2XD.js +1 -0
- package/web-ui/build/static/pgsql-BcJSuBW7.js +1 -0
- package/web-ui/build/static/php-CYsEiKIv.js +1 -0
- package/web-ui/build/static/php-ec_OoKAd.js +1 -0
- package/web-ui/build/static/php-extras-BWAIvmKu.js +1 -0
- package/web-ui/build/static/php-template-DCxDXo86.js +1 -0
- package/web-ui/build/static/phpdoc-BYf4cQai.js +1 -0
- package/web-ui/build/static/plaintext-CtUex0sE.js +1 -0
- package/web-ui/build/static/plsql-Sqw2ttrI.js +1 -0
- package/web-ui/build/static/pony-JGIj1EnN.js +1 -0
- package/web-ui/build/static/powerquery-CdWEkmau.js +1 -0
- package/web-ui/build/static/powershell-5xMVTYxm.js +1 -0
- package/web-ui/build/static/powershell-DqXYtn4z.js +1 -0
- package/web-ui/build/static/processing-C9Oshb5c.js +1 -0
- package/web-ui/build/static/processing-Dk9D9Oda.js +1 -0
- package/web-ui/build/static/profile-OeCpZjWR.js +1 -0
- package/web-ui/build/static/prolog-BEHfToXJ.js +1 -0
- package/web-ui/build/static/prolog-BEvr04SD.js +1 -0
- package/web-ui/build/static/promql-6rIpz1uQ.js +1 -0
- package/web-ui/build/static/properties-CBHQAddQ.js +1 -0
- package/web-ui/build/static/properties-CfRK6wBJ.js +1 -0
- package/web-ui/build/static/protobuf-BKk-NDnX.js +1 -0
- package/web-ui/build/static/protobuf-DQ1ntiS5.js +1 -0
- package/web-ui/build/static/psl-Dlx8n01w.js +1 -0
- package/web-ui/build/static/pug-Cv7seLJZ.js +1 -0
- package/web-ui/build/static/puppet-BsCKG45y.js +1 -0
- package/web-ui/build/static/puppet-D13pQ6ux.js +1 -0
- package/web-ui/build/static/pure-BiGiaM4N.js +1 -0
- package/web-ui/build/static/purebasic-2GNfc9PP.js +1 -0
- package/web-ui/build/static/purebasic-B0uRdSs4.js +1 -0
- package/web-ui/build/static/purescript-D2_nPyDl.js +1 -0
- package/web-ui/build/static/python-BX3DMke9.js +1 -0
- package/web-ui/build/static/python-BbgHU6gG.js +1 -0
- package/web-ui/build/static/python-repl-BBR7u1v9.js +1 -0
- package/web-ui/build/static/q-Ce8HZO1v.js +1 -0
- package/web-ui/build/static/q-DZB4YM1k.js +1 -0
- package/web-ui/build/static/qml-5FeVfNgq.js +1 -0
- package/web-ui/build/static/qml-BGH8flkv.js +1 -0
- package/web-ui/build/static/qore-DzWQ-MX8.js +1 -0
- package/web-ui/build/static/qsharp-C13wIooV.js +1 -0
- package/web-ui/build/static/r-Cwa9CnoU.js +1 -0
- package/web-ui/build/static/r-D_WwfaBh.js +1 -0
- package/web-ui/build/static/racket-BVzUaE4S.js +1 -0
- package/web-ui/build/static/reason-BV65ZBhV.js +1 -0
- package/web-ui/build/static/reasonml-BAmrK2aA.js +1 -0
- package/web-ui/build/static/regex-DiBkKKf2.js +1 -0
- package/web-ui/build/static/rego-qmeEDKBa.js +1 -0
- package/web-ui/build/static/renpy-rS89YdO3.js +1 -0
- package/web-ui/build/static/rest-DIHoQfMF.js +1 -0
- package/web-ui/build/static/rib-tRH9hnpJ.js +1 -0
- package/web-ui/build/static/rip-BAkRVCRN.js +1 -0
- package/web-ui/build/static/roboconf-BPlSNGkx.js +1 -0
- package/web-ui/build/static/roboconf-DtYDmord.js +1 -0
- package/web-ui/build/static/robotframework-CGp33lel.js +1 -0
- package/web-ui/build/static/routeros-CPsgrpcd.js +1 -0
- package/web-ui/build/static/rsl-DJkGu6Wt.js +1 -0
- package/web-ui/build/static/ruby-CUyfjDZ-.js +1 -0
- package/web-ui/build/static/ruby-D9BNocuK.js +1 -0
- package/web-ui/build/static/ruleslanguage-DEv0-HgA.js +1 -0
- package/web-ui/build/static/rust-DZF14o2c.js +1 -0
- package/web-ui/build/static/rust-D_zBtJXD.js +1 -0
- package/web-ui/build/static/sas-C9p0sDvC.js +1 -0
- package/web-ui/build/static/sas-CjepM0yu.js +1 -0
- package/web-ui/build/static/sass-Dw7_4klj.js +1 -0
- package/web-ui/build/static/scala-DyyB1-lO.js +1 -0
- package/web-ui/build/static/scala-gtqVrKcV.js +1 -0
- package/web-ui/build/static/scheme-BoF2OcfB.js +1 -0
- package/web-ui/build/static/scheme-D71DI2MX.js +1 -0
- package/web-ui/build/static/scilab-BBMH_xAV.js +1 -0
- package/web-ui/build/static/scss-CZuHDUbd.js +1 -0
- package/web-ui/build/static/scss-V-h-z4wf.js +1 -0
- package/web-ui/build/static/shell-DTxbAwnO.js +1 -0
- package/web-ui/build/static/shell-session-7KexPNJ5.js +1 -0
- package/web-ui/build/static/smali-4ygYaBhS.js +1 -0
- package/web-ui/build/static/smali-D80rMXb_.js +1 -0
- package/web-ui/build/static/smalltalk-DXD_lPsj.js +1 -0
- package/web-ui/build/static/smalltalk-c2nyWSNA.js +1 -0
- package/web-ui/build/static/smarty-CiplbPqH.js +1 -0
- package/web-ui/build/static/sml-BF1uC_B1.js +1 -0
- package/web-ui/build/static/sml-DC6Hv4Cs.js +1 -0
- package/web-ui/build/static/solidity-Bacf15ZH.js +1 -0
- package/web-ui/build/static/solution-file-CYMQND5e.js +1 -0
- package/web-ui/build/static/soy-BeR2KcUQ.js +1 -0
- package/web-ui/build/static/sparql-DIJfQCH2.js +1 -0
- package/web-ui/build/static/splunk-spl-DuiC9kKA.js +1 -0
- package/web-ui/build/static/sqf-AsZI23Fg.js +1 -0
- package/web-ui/build/static/sqf-DuLGXB7I.js +1 -0
- package/web-ui/build/static/sql-BOpQE2BL.js +1 -0
- package/web-ui/build/static/sql-CBw_H4bM.js +1 -0
- package/web-ui/build/static/sql_more-BzdScnMn.js +1 -0
- package/web-ui/build/static/squirrel-CBgIes0g.js +1 -0
- package/web-ui/build/static/stan-Bzx1mMjj.js +1 -0
- package/web-ui/build/static/stan-CUdhaH4k.js +1 -0
- package/web-ui/build/static/stata-DP9d39xz.js +1 -0
- package/web-ui/build/static/step21-qvCBiZr4.js +1 -0
- package/web-ui/build/static/stylus-B1auflmR.js +1 -0
- package/web-ui/build/static/stylus-CHGDQHZi.js +1 -0
- package/web-ui/build/static/subunit-BEqUDJAk.js +1 -0
- package/web-ui/build/static/swift-B-zsUijG.js +1 -0
- package/web-ui/build/static/swift-CIApcDEy.js +1 -0
- package/web-ui/build/static/systemd-DKZD-7DT.js +1 -0
- package/web-ui/build/static/t4-cs-sNGFeLwf.js +1 -0
- package/web-ui/build/static/t4-templating-BcTML3He.js +1 -0
- package/web-ui/build/static/t4-vb-DFKxMzp3.js +1 -0
- package/web-ui/build/static/taggerscript-B2F3dePS.js +1 -0
- package/web-ui/build/static/tap-6VEaDPY1.js +1 -0
- package/web-ui/build/static/tap-C3WPiU6D.js +1 -0
- package/web-ui/build/static/tcl-D3nufc31.js +1 -0
- package/web-ui/build/static/tcl-JAFgp27j.js +1 -0
- package/web-ui/build/static/textile-BICOKz3C.js +1 -0
- package/web-ui/build/static/thrift-vlMRUCHp.js +1 -0
- package/web-ui/build/static/toml-lbaFfUDa.js +1 -0
- package/web-ui/build/static/tp-C0DryNKq.js +1 -0
- package/web-ui/build/static/tremor-KV0uKKzP.js +1 -0
- package/web-ui/build/static/tsx-BbXA-WZO.js +1 -0
- package/web-ui/build/static/tt2-CBBLol2A.js +1 -0
- package/web-ui/build/static/turtle-BXnWySj2.js +1 -0
- package/web-ui/build/static/twig-DRCdONqg.js +1 -0
- package/web-ui/build/static/twig-DvopFSwI.js +1 -0
- package/web-ui/build/static/typescript-B04Ldc-G.js +1 -0
- package/web-ui/build/static/typescript-BDyQiGV-.js +1 -0
- package/web-ui/build/static/typoscript-DSTWJd5j.js +1 -0
- package/web-ui/build/static/unrealscript-CAQqr4L3.js +1 -0
- package/web-ui/build/static/uorazor-BVrkqw05.js +1 -0
- package/web-ui/build/static/uri-B8pFZmb9.js +1 -0
- package/web-ui/build/static/v-NCU31506.js +1 -0
- package/web-ui/build/static/vala-CVnv4d8J.js +1 -0
- package/web-ui/build/static/vala-CdWE1scN.js +1 -0
- package/web-ui/build/static/vbnet-BiBScEXy.js +1 -0
- package/web-ui/build/static/vbnet-DIgU2O1_.js +1 -0
- package/web-ui/build/static/vbscript-DIK8CtvZ.js +1 -0
- package/web-ui/build/static/vbscript-html-DlxeEFRH.js +1 -0
- package/web-ui/build/static/velocity-CflO9yO8.js +1 -0
- package/web-ui/build/static/verilog-B85b7wIr.js +1 -0
- package/web-ui/build/static/verilog-RN98vB_a.js +1 -0
- package/web-ui/build/static/vhdl-BXVcr_LB.js +1 -0
- package/web-ui/build/static/vhdl-BXbY0rlw.js +1 -0
- package/web-ui/build/static/vim-awBx1FO0.js +1 -0
- package/web-ui/build/static/vim-fODNLmpH.js +1 -0
- package/web-ui/build/static/visual-basic-D2KGI8Ia.js +1 -0
- package/web-ui/build/static/warpscript-F0xOt1_S.js +1 -0
- package/web-ui/build/static/wasm-B7m5T3sw.js +1 -0
- package/web-ui/build/static/web-idl-C2O3TyAx.js +1 -0
- package/web-ui/build/static/wiki-s41mX--U.js +1 -0
- package/web-ui/build/static/wolfram-DMSzq9xC.js +1 -0
- package/web-ui/build/static/wren-Beb7Kmvd.js +1 -0
- package/web-ui/build/static/x86asm-DcE8O4ah.js +1 -0
- package/web-ui/build/static/xeora-DoxuBh5U.js +1 -0
- package/web-ui/build/static/xl-DA_7OwbE.js +1 -0
- package/web-ui/build/static/xml-BCIuAfRx.js +1 -0
- package/web-ui/build/static/xml-doc-2kkUZTB_.js +1 -0
- package/web-ui/build/static/xojo-OyjSaR_W.js +1 -0
- package/web-ui/build/static/xquery-Cy4tEat7.js +1 -0
- package/web-ui/build/static/xquery-D6Lgg9Sc.js +1 -0
- package/web-ui/build/static/yaml-Bg34jnh4.js +1 -0
- package/web-ui/build/static/yaml-D8uKqyyA.js +1 -0
- package/web-ui/build/static/yang-F-YGZhRB.js +1 -0
- package/web-ui/build/static/zephir-FaymYhAB.js +1 -0
- package/web-ui/build/static/zig-YtKTd6AY.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
|
+
});
|