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,639 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Discord Service — Integration / Flow Tests
|
|
3
|
+
*
|
|
4
|
+
* Tests complete flows across components rather than isolated units:
|
|
5
|
+
* - Full message round-trip (Discord msg → agent → response back to channel)
|
|
6
|
+
* - API route integration (HTTP → service → response)
|
|
7
|
+
* - Broadcast chain integrity (multiple services wrapping broadcastToSession)
|
|
8
|
+
* - Config persistence round-trip (save → reload → verify state)
|
|
9
|
+
* - Multi-channel isolation (agent responses only go to originating channel)
|
|
10
|
+
* - Agent lifecycle (deletion cleans up stale mappings)
|
|
11
|
+
*/
|
|
12
|
+
|
|
13
|
+
import { jest, describe, test, expect, beforeEach, afterEach } from '@jest/globals';
|
|
14
|
+
import { createMockLogger } from '../../__test-utils__/mockFactories.js';
|
|
15
|
+
|
|
16
|
+
// Mock fs for config persistence
|
|
17
|
+
const mockFs = {
|
|
18
|
+
mkdir: jest.fn().mockResolvedValue(undefined),
|
|
19
|
+
readFile: jest.fn().mockRejectedValue(new Error('ENOENT')),
|
|
20
|
+
writeFile: jest.fn().mockResolvedValue(undefined)
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
jest.unstable_mockModule('fs', () => ({
|
|
24
|
+
promises: mockFs
|
|
25
|
+
}));
|
|
26
|
+
|
|
27
|
+
jest.unstable_mockModule('../../utilities/userDataDir.js', () => ({
|
|
28
|
+
getUserDataPaths: () => ({ base: '/mock/data' }),
|
|
29
|
+
ensureUserDataDirs: jest.fn().mockResolvedValue(undefined)
|
|
30
|
+
}));
|
|
31
|
+
|
|
32
|
+
const { DiscordService, DISCORD_STATUS } = await import('../discordService.js');
|
|
33
|
+
|
|
34
|
+
// --- Helpers ---
|
|
35
|
+
|
|
36
|
+
function createService() {
|
|
37
|
+
const logger = createMockLogger();
|
|
38
|
+
const service = new DiscordService(logger);
|
|
39
|
+
return service;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
function createMockOrchestrator() {
|
|
43
|
+
return {
|
|
44
|
+
processRequest: jest.fn().mockResolvedValue({ success: true })
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
function createMockAgentPool(agents = {}) {
|
|
49
|
+
return {
|
|
50
|
+
getAgent: jest.fn().mockImplementation(id => Promise.resolve(agents[id] || null)),
|
|
51
|
+
getAllAgents: jest.fn().mockReturnValue(Object.values(agents))
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
function createMockChannel(id = 'c1') {
|
|
56
|
+
return {
|
|
57
|
+
id,
|
|
58
|
+
send: jest.fn().mockResolvedValue({}),
|
|
59
|
+
sendTyping: jest.fn().mockResolvedValue(undefined)
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
function createDiscordMessage(content, opts = {}) {
|
|
64
|
+
const guildId = opts.guildId || 'guild-1';
|
|
65
|
+
const channelId = opts.channelId || 'ch-1';
|
|
66
|
+
return {
|
|
67
|
+
content,
|
|
68
|
+
author: { bot: opts.bot || false, id: opts.userId || 'user-42' },
|
|
69
|
+
guild: opts.noDM ? null : { id: guildId },
|
|
70
|
+
channel: {
|
|
71
|
+
id: channelId,
|
|
72
|
+
parentId: opts.parentId || null, // thread parent channel ID
|
|
73
|
+
send: jest.fn().mockResolvedValue({}),
|
|
74
|
+
sendTyping: jest.fn().mockResolvedValue(undefined)
|
|
75
|
+
},
|
|
76
|
+
reply: jest.fn().mockResolvedValue({})
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
// ========================================================================
|
|
81
|
+
// FLOW 1: Full message round-trip
|
|
82
|
+
// Discord message → _handleMessage → orchestrator → broadcast → channel.send
|
|
83
|
+
// ========================================================================
|
|
84
|
+
|
|
85
|
+
describe('Flow: Full message round-trip', () => {
|
|
86
|
+
let service, orchestrator, agentPool, mockChannel;
|
|
87
|
+
|
|
88
|
+
beforeEach(() => {
|
|
89
|
+
service = createService();
|
|
90
|
+
orchestrator = createMockOrchestrator();
|
|
91
|
+
agentPool = createMockAgentPool({
|
|
92
|
+
'agent-alpha': { id: 'agent-alpha', name: 'Alpha' }
|
|
93
|
+
});
|
|
94
|
+
mockChannel = createMockChannel('ch-1');
|
|
95
|
+
|
|
96
|
+
service.setOrchestrator(orchestrator);
|
|
97
|
+
service.setAgentPool(agentPool);
|
|
98
|
+
service.status = DISCORD_STATUS.CONNECTED;
|
|
99
|
+
service.client = {
|
|
100
|
+
channels: { fetch: jest.fn().mockResolvedValue(mockChannel) }
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
// Map agent to channel
|
|
104
|
+
service.channelMappings = { 'guild-1:ch-1': ['agent-alpha'] };
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
test('user sends message → agent processes → response appears in same channel', async () => {
|
|
108
|
+
// Step 1: Incoming Discord message
|
|
109
|
+
const msg = createDiscordMessage('explain recursion');
|
|
110
|
+
await service._handleMessage(msg);
|
|
111
|
+
|
|
112
|
+
// Step 2: Verify orchestrator received the request
|
|
113
|
+
expect(orchestrator.processRequest).toHaveBeenCalledTimes(1);
|
|
114
|
+
const request = orchestrator.processRequest.mock.calls[0][0];
|
|
115
|
+
expect(request.interface).toBe('discord');
|
|
116
|
+
expect(request.sessionId).toBe('discord-guild-1-ch-1');
|
|
117
|
+
expect(request.payload.agentId).toBe('agent-alpha');
|
|
118
|
+
expect(request.payload.message).toBe('explain recursion');
|
|
119
|
+
|
|
120
|
+
// Step 3: Simulate broadcast from agentScheduler (what happens after AI responds)
|
|
121
|
+
await service._handleBroadcastEvent('discord-guild-1-ch-1', {
|
|
122
|
+
type: 'stream_complete',
|
|
123
|
+
agentId: 'agent-alpha',
|
|
124
|
+
content: 'Recursion is when a function calls itself.'
|
|
125
|
+
});
|
|
126
|
+
|
|
127
|
+
// Step 4: Verify response was sent to the correct channel
|
|
128
|
+
expect(service.client.channels.fetch).toHaveBeenCalledWith('ch-1');
|
|
129
|
+
expect(mockChannel.send).toHaveBeenCalledTimes(1);
|
|
130
|
+
const sent = mockChannel.send.mock.calls[0][0];
|
|
131
|
+
expect(sent).toContain('Alpha');
|
|
132
|
+
expect(sent).toContain('Recursion is when a function calls itself.');
|
|
133
|
+
});
|
|
134
|
+
|
|
135
|
+
test('full round-trip with long response triggers message splitting', async () => {
|
|
136
|
+
const msg = createDiscordMessage('write a long essay');
|
|
137
|
+
await service._handleMessage(msg);
|
|
138
|
+
|
|
139
|
+
// Simulate a response longer than Discord's limit
|
|
140
|
+
const longContent = 'A'.repeat(3500);
|
|
141
|
+
await service._handleBroadcastEvent('discord-guild-1-ch-1', {
|
|
142
|
+
type: 'stream_complete',
|
|
143
|
+
agentId: 'agent-alpha',
|
|
144
|
+
content: longContent
|
|
145
|
+
});
|
|
146
|
+
|
|
147
|
+
// Should have split into multiple messages
|
|
148
|
+
expect(mockChannel.send).toHaveBeenCalled();
|
|
149
|
+
const totalSent = mockChannel.send.mock.calls.map(c => c[0]).join('');
|
|
150
|
+
expect(totalSent).toContain('Alpha');
|
|
151
|
+
expect(totalSent.length).toBeGreaterThanOrEqual(3500);
|
|
152
|
+
});
|
|
153
|
+
});
|
|
154
|
+
|
|
155
|
+
// ========================================================================
|
|
156
|
+
// FLOW 2: Multi-agent channel routing
|
|
157
|
+
// ========================================================================
|
|
158
|
+
|
|
159
|
+
describe('Flow: Multi-agent channel routing', () => {
|
|
160
|
+
let service, orchestrator, agentPool;
|
|
161
|
+
|
|
162
|
+
beforeEach(() => {
|
|
163
|
+
service = createService();
|
|
164
|
+
orchestrator = createMockOrchestrator();
|
|
165
|
+
agentPool = createMockAgentPool({
|
|
166
|
+
'a1': { id: 'a1', name: 'Coder' },
|
|
167
|
+
'a2': { id: 'a2', name: 'Reviewer' }
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
service.setOrchestrator(orchestrator);
|
|
171
|
+
service.setAgentPool(agentPool);
|
|
172
|
+
service.status = DISCORD_STATUS.CONNECTED;
|
|
173
|
+
service.channelMappings = { 'g1:c1': ['a1', 'a2'] };
|
|
174
|
+
});
|
|
175
|
+
|
|
176
|
+
test('@mention routes to correct agent, then follow-up uses sticky', async () => {
|
|
177
|
+
// First message: explicit @mention
|
|
178
|
+
const msg1 = createDiscordMessage('@Coder fix the login bug', { guildId: 'g1', channelId: 'c1' });
|
|
179
|
+
await service._handleMessage(msg1);
|
|
180
|
+
|
|
181
|
+
expect(orchestrator.processRequest).toHaveBeenCalledTimes(1);
|
|
182
|
+
expect(orchestrator.processRequest.mock.calls[0][0].payload.agentId).toBe('a1');
|
|
183
|
+
expect(orchestrator.processRequest.mock.calls[0][0].payload.message).toBe('fix the login bug');
|
|
184
|
+
|
|
185
|
+
// Second message: no mention — should use sticky (last addressed agent)
|
|
186
|
+
const msg2 = createDiscordMessage('also add error handling', { guildId: 'g1', channelId: 'c1' });
|
|
187
|
+
await service._handleMessage(msg2);
|
|
188
|
+
|
|
189
|
+
expect(orchestrator.processRequest).toHaveBeenCalledTimes(2);
|
|
190
|
+
expect(orchestrator.processRequest.mock.calls[1][0].payload.agentId).toBe('a1'); // sticky to Coder
|
|
191
|
+
|
|
192
|
+
// Third message: switch to different agent via @mention
|
|
193
|
+
const msg3 = createDiscordMessage('@Reviewer review the PR', { guildId: 'g1', channelId: 'c1' });
|
|
194
|
+
await service._handleMessage(msg3);
|
|
195
|
+
|
|
196
|
+
expect(orchestrator.processRequest).toHaveBeenCalledTimes(3);
|
|
197
|
+
expect(orchestrator.processRequest.mock.calls[2][0].payload.agentId).toBe('a2'); // switched to Reviewer
|
|
198
|
+
|
|
199
|
+
// Fourth message: no mention — sticky should now be Reviewer
|
|
200
|
+
const msg4 = createDiscordMessage('any concerns?', { guildId: 'g1', channelId: 'c1' });
|
|
201
|
+
await service._handleMessage(msg4);
|
|
202
|
+
|
|
203
|
+
expect(orchestrator.processRequest.mock.calls[3][0].payload.agentId).toBe('a2');
|
|
204
|
+
});
|
|
205
|
+
|
|
206
|
+
test('invalid @mention with no sticky prompts user to choose', async () => {
|
|
207
|
+
const msg = createDiscordMessage('@UnknownBot do something', { guildId: 'g1', channelId: 'c1' });
|
|
208
|
+
await service._handleMessage(msg);
|
|
209
|
+
|
|
210
|
+
// Should not route
|
|
211
|
+
expect(orchestrator.processRequest).not.toHaveBeenCalled();
|
|
212
|
+
// Should prompt user
|
|
213
|
+
expect(msg.reply).toHaveBeenCalledTimes(1);
|
|
214
|
+
expect(msg.reply.mock.calls[0][0]).toContain('@Coder');
|
|
215
|
+
expect(msg.reply.mock.calls[0][0]).toContain('@Reviewer');
|
|
216
|
+
});
|
|
217
|
+
});
|
|
218
|
+
|
|
219
|
+
// ========================================================================
|
|
220
|
+
// FLOW 3: Multi-channel isolation
|
|
221
|
+
// Agent responds to channel A only — not channel B even if mapped to both
|
|
222
|
+
// ========================================================================
|
|
223
|
+
|
|
224
|
+
describe('Flow: Multi-channel response isolation', () => {
|
|
225
|
+
let service, agentPool;
|
|
226
|
+
const channelA = createMockChannel('chA');
|
|
227
|
+
const channelB = createMockChannel('chB');
|
|
228
|
+
|
|
229
|
+
beforeEach(() => {
|
|
230
|
+
service = createService();
|
|
231
|
+
agentPool = createMockAgentPool({
|
|
232
|
+
'agent-1': { id: 'agent-1', name: 'SharedBot' }
|
|
233
|
+
});
|
|
234
|
+
service.setAgentPool(agentPool);
|
|
235
|
+
service.setOrchestrator(createMockOrchestrator());
|
|
236
|
+
service.status = DISCORD_STATUS.CONNECTED;
|
|
237
|
+
service.client = {
|
|
238
|
+
channels: {
|
|
239
|
+
fetch: jest.fn().mockImplementation(id => {
|
|
240
|
+
if (id === 'chA') return Promise.resolve(channelA);
|
|
241
|
+
if (id === 'chB') return Promise.resolve(channelB);
|
|
242
|
+
return Promise.resolve(null);
|
|
243
|
+
})
|
|
244
|
+
}
|
|
245
|
+
};
|
|
246
|
+
|
|
247
|
+
// Same agent mapped to TWO channels
|
|
248
|
+
service.channelMappings = {
|
|
249
|
+
'g1:chA': ['agent-1'],
|
|
250
|
+
'g1:chB': ['agent-1']
|
|
251
|
+
};
|
|
252
|
+
|
|
253
|
+
channelA.send.mockClear();
|
|
254
|
+
channelB.send.mockClear();
|
|
255
|
+
});
|
|
256
|
+
|
|
257
|
+
test('response only goes to channel where user initiated', async () => {
|
|
258
|
+
// User sends message in channel A
|
|
259
|
+
const msg = createDiscordMessage('hello', { guildId: 'g1', channelId: 'chA' });
|
|
260
|
+
await service._handleMessage(msg);
|
|
261
|
+
|
|
262
|
+
// Agent responds via broadcast
|
|
263
|
+
await service._handleBroadcastEvent('discord-g1-chA', {
|
|
264
|
+
type: 'stream_complete',
|
|
265
|
+
agentId: 'agent-1',
|
|
266
|
+
content: 'Hi there!'
|
|
267
|
+
});
|
|
268
|
+
|
|
269
|
+
// Channel A should get the response
|
|
270
|
+
expect(channelA.send).toHaveBeenCalled();
|
|
271
|
+
// Channel B should NOT
|
|
272
|
+
expect(channelB.send).not.toHaveBeenCalled();
|
|
273
|
+
});
|
|
274
|
+
|
|
275
|
+
test('separate conversations in separate channels stay isolated', async () => {
|
|
276
|
+
// User sends in channel A
|
|
277
|
+
const msgA = createDiscordMessage('question A', { guildId: 'g1', channelId: 'chA' });
|
|
278
|
+
await service._handleMessage(msgA);
|
|
279
|
+
|
|
280
|
+
// Different user sends in channel B
|
|
281
|
+
const msgB = createDiscordMessage('question B', { guildId: 'g1', channelId: 'chB' });
|
|
282
|
+
await service._handleMessage(msgB);
|
|
283
|
+
|
|
284
|
+
// Agent responds (to question A)
|
|
285
|
+
await service._relayAgentResponse({
|
|
286
|
+
agentId: 'agent-1',
|
|
287
|
+
content: 'Answer A'
|
|
288
|
+
});
|
|
289
|
+
|
|
290
|
+
// Both channels should get the response (both have recent interaction)
|
|
291
|
+
expect(channelA.send).toHaveBeenCalled();
|
|
292
|
+
expect(channelB.send).toHaveBeenCalled();
|
|
293
|
+
|
|
294
|
+
// But if we clear channel A's interaction (expired)
|
|
295
|
+
channelA.send.mockClear();
|
|
296
|
+
channelB.send.mockClear();
|
|
297
|
+
const keyA = 'agent-1:g1:chA';
|
|
298
|
+
const interactionA = service.recentInteractions.get(keyA);
|
|
299
|
+
if (interactionA) interactionA.timestamp = Date.now() - 31 * 60 * 1000; // expire it
|
|
300
|
+
|
|
301
|
+
await service._relayAgentResponse({
|
|
302
|
+
agentId: 'agent-1',
|
|
303
|
+
content: 'Answer B'
|
|
304
|
+
});
|
|
305
|
+
|
|
306
|
+
// Only channel B should get it now
|
|
307
|
+
expect(channelA.send).not.toHaveBeenCalled();
|
|
308
|
+
expect(channelB.send).toHaveBeenCalled();
|
|
309
|
+
});
|
|
310
|
+
});
|
|
311
|
+
|
|
312
|
+
// ========================================================================
|
|
313
|
+
// FLOW 4: Broadcast chain integrity (multiple services wrapping)
|
|
314
|
+
// ========================================================================
|
|
315
|
+
|
|
316
|
+
describe('Flow: Broadcast chain integrity', () => {
|
|
317
|
+
test('Discord and Telegram can both wrap broadcastToSession without breaking each other', () => {
|
|
318
|
+
const originalCalls = [];
|
|
319
|
+
const telegramCalls = [];
|
|
320
|
+
const discordCalls = [];
|
|
321
|
+
|
|
322
|
+
const wsManager = {
|
|
323
|
+
broadcastToSession: jest.fn((sid, msg) => originalCalls.push({ sid, msg }))
|
|
324
|
+
};
|
|
325
|
+
|
|
326
|
+
// Simulate Telegram wrapping first (like real init order)
|
|
327
|
+
const telegramOriginal = wsManager.broadcastToSession.bind(wsManager);
|
|
328
|
+
wsManager.broadcastToSession = (sid, msg) => {
|
|
329
|
+
telegramOriginal(sid, msg);
|
|
330
|
+
telegramCalls.push({ sid, msg });
|
|
331
|
+
};
|
|
332
|
+
|
|
333
|
+
// Now Discord wraps on top
|
|
334
|
+
const service = createService();
|
|
335
|
+
service._interceptBroadcasts(wsManager);
|
|
336
|
+
|
|
337
|
+
// Fire a broadcast
|
|
338
|
+
wsManager.broadcastToSession('s1', { type: 'stream_complete', agentId: 'a1', content: 'hello' });
|
|
339
|
+
|
|
340
|
+
// Original should be called (through the chain)
|
|
341
|
+
expect(originalCalls).toHaveLength(1);
|
|
342
|
+
// Telegram should see it
|
|
343
|
+
expect(telegramCalls).toHaveLength(1);
|
|
344
|
+
// Discord's _handleBroadcastEvent should also have been called
|
|
345
|
+
// (verified by the fact that the chain didn't throw)
|
|
346
|
+
|
|
347
|
+
// Fire another — all three layers still work
|
|
348
|
+
wsManager.broadcastToSession('s2', { type: 'message_added' });
|
|
349
|
+
expect(originalCalls).toHaveLength(2);
|
|
350
|
+
expect(telegramCalls).toHaveLength(2);
|
|
351
|
+
});
|
|
352
|
+
});
|
|
353
|
+
|
|
354
|
+
// ========================================================================
|
|
355
|
+
// FLOW 5: Config persistence round-trip
|
|
356
|
+
// ========================================================================
|
|
357
|
+
|
|
358
|
+
describe('Flow: Config persistence round-trip', () => {
|
|
359
|
+
test('assign agents → save → reload → mappings restored → routing works', async () => {
|
|
360
|
+
const service1 = createService();
|
|
361
|
+
service1.setOrchestrator(createMockOrchestrator());
|
|
362
|
+
service1.setAgentPool(createMockAgentPool({
|
|
363
|
+
'a1': { id: 'a1', name: 'Bot1' }
|
|
364
|
+
}));
|
|
365
|
+
|
|
366
|
+
// Step 1: Assign agents to channels
|
|
367
|
+
await service1.assignAgentToChannel('g1:c1', 'a1');
|
|
368
|
+
await service1.assignAgentToChannel('g1:c2', 'a1');
|
|
369
|
+
service1.knownGuilds = { g1: { name: 'TestServer' } };
|
|
370
|
+
service1.knownChannels = {
|
|
371
|
+
'g1:c1': { name: 'general', guildName: 'TestServer' },
|
|
372
|
+
'g1:c2': { name: 'dev', guildName: 'TestServer' }
|
|
373
|
+
};
|
|
374
|
+
await service1._saveConfig();
|
|
375
|
+
|
|
376
|
+
// Step 2: Capture what was written to disk
|
|
377
|
+
const lastWriteCall = mockFs.writeFile.mock.calls[mockFs.writeFile.mock.calls.length - 1];
|
|
378
|
+
const savedJson = lastWriteCall[1];
|
|
379
|
+
|
|
380
|
+
// Step 3: Create new service instance and load the saved config
|
|
381
|
+
mockFs.readFile.mockResolvedValueOnce(savedJson);
|
|
382
|
+
const service2 = createService();
|
|
383
|
+
await service2._loadConfig();
|
|
384
|
+
|
|
385
|
+
// Step 4: Verify mappings are restored
|
|
386
|
+
expect(service2.channelMappings).toEqual({
|
|
387
|
+
'g1:c1': ['a1'],
|
|
388
|
+
'g1:c2': ['a1']
|
|
389
|
+
});
|
|
390
|
+
expect(service2.knownGuilds.g1.name).toBe('TestServer');
|
|
391
|
+
expect(service2.knownChannels['g1:c1'].name).toBe('general');
|
|
392
|
+
|
|
393
|
+
// Step 5: Verify routing works with restored mappings
|
|
394
|
+
service2.setOrchestrator(createMockOrchestrator());
|
|
395
|
+
service2.setAgentPool(createMockAgentPool({
|
|
396
|
+
'a1': { id: 'a1', name: 'Bot1' }
|
|
397
|
+
}));
|
|
398
|
+
service2.status = DISCORD_STATUS.CONNECTED;
|
|
399
|
+
|
|
400
|
+
const msg = createDiscordMessage('hello', { guildId: 'g1', channelId: 'c1' });
|
|
401
|
+
await service2._handleMessage(msg);
|
|
402
|
+
|
|
403
|
+
expect(service2.orchestrator.processRequest).toHaveBeenCalledTimes(1);
|
|
404
|
+
expect(service2.orchestrator.processRequest.mock.calls[0][0].payload.agentId).toBe('a1');
|
|
405
|
+
});
|
|
406
|
+
});
|
|
407
|
+
|
|
408
|
+
// ========================================================================
|
|
409
|
+
// FLOW 6: Agent deletion / stale mapping handling
|
|
410
|
+
// ========================================================================
|
|
411
|
+
|
|
412
|
+
describe('Flow: Agent lifecycle and stale mappings', () => {
|
|
413
|
+
test('agent deleted from pool — routed message fails gracefully', async () => {
|
|
414
|
+
const service = createService();
|
|
415
|
+
const orchestrator = createMockOrchestrator();
|
|
416
|
+
orchestrator.processRequest.mockRejectedValueOnce(new Error('Agent not found'));
|
|
417
|
+
|
|
418
|
+
service.setOrchestrator(orchestrator);
|
|
419
|
+
service.setAgentPool(createMockAgentPool({})); // empty — agent gone
|
|
420
|
+
service.status = DISCORD_STATUS.CONNECTED;
|
|
421
|
+
service.channelMappings = { 'g1:c1': ['deleted-agent'] };
|
|
422
|
+
|
|
423
|
+
const msg = createDiscordMessage('hello', { guildId: 'g1', channelId: 'c1' });
|
|
424
|
+
await service._handleMessage(msg);
|
|
425
|
+
|
|
426
|
+
// Should attempt to route but handle error gracefully
|
|
427
|
+
expect(orchestrator.processRequest).toHaveBeenCalled();
|
|
428
|
+
// Should reply with error
|
|
429
|
+
expect(msg.reply).toHaveBeenCalledTimes(1);
|
|
430
|
+
expect(msg.reply.mock.calls[0][0]).toContain('Failed');
|
|
431
|
+
});
|
|
432
|
+
|
|
433
|
+
test('guild removal cleans up all mappings for that guild', async () => {
|
|
434
|
+
const service = createService();
|
|
435
|
+
service.channelMappings = {
|
|
436
|
+
'guild-A:c1': ['a1'],
|
|
437
|
+
'guild-A:c2': ['a2'],
|
|
438
|
+
'guild-B:c3': ['a3']
|
|
439
|
+
};
|
|
440
|
+
service.knownGuilds = {
|
|
441
|
+
'guild-A': { name: 'ServerA' },
|
|
442
|
+
'guild-B': { name: 'ServerB' }
|
|
443
|
+
};
|
|
444
|
+
service.knownChannels = {
|
|
445
|
+
'guild-A:c1': { name: 'gen' },
|
|
446
|
+
'guild-A:c2': { name: 'dev' },
|
|
447
|
+
'guild-B:c3': { name: 'main' }
|
|
448
|
+
};
|
|
449
|
+
|
|
450
|
+
// Simulate guildDelete event handler logic
|
|
451
|
+
const guildId = 'guild-A';
|
|
452
|
+
delete service.knownGuilds[guildId];
|
|
453
|
+
for (const key of Object.keys(service.channelMappings)) {
|
|
454
|
+
if (key.startsWith(`${guildId}:`)) {
|
|
455
|
+
delete service.channelMappings[key];
|
|
456
|
+
delete service.knownChannels[key];
|
|
457
|
+
}
|
|
458
|
+
}
|
|
459
|
+
|
|
460
|
+
// guild-A channels should be gone
|
|
461
|
+
expect(service.channelMappings['guild-A:c1']).toBeUndefined();
|
|
462
|
+
expect(service.channelMappings['guild-A:c2']).toBeUndefined();
|
|
463
|
+
expect(service.knownChannels['guild-A:c1']).toBeUndefined();
|
|
464
|
+
|
|
465
|
+
// guild-B should be untouched
|
|
466
|
+
expect(service.channelMappings['guild-B:c3']).toEqual(['a3']);
|
|
467
|
+
expect(service.knownGuilds['guild-B'].name).toBe('ServerB');
|
|
468
|
+
});
|
|
469
|
+
});
|
|
470
|
+
|
|
471
|
+
// ========================================================================
|
|
472
|
+
// FLOW 7: Prompt relay flow
|
|
473
|
+
// ========================================================================
|
|
474
|
+
|
|
475
|
+
describe('Flow: User prompt relay', () => {
|
|
476
|
+
test('user_prompt_request broadcast → relayed to channel with recent interaction', async () => {
|
|
477
|
+
const service = createService();
|
|
478
|
+
const mockCh = createMockChannel('ch-1');
|
|
479
|
+
service.status = DISCORD_STATUS.CONNECTED;
|
|
480
|
+
service.client = {
|
|
481
|
+
channels: { fetch: jest.fn().mockResolvedValue(mockCh) }
|
|
482
|
+
};
|
|
483
|
+
service.agentPool = createMockAgentPool({
|
|
484
|
+
'a1': { id: 'a1', name: 'Worker' }
|
|
485
|
+
});
|
|
486
|
+
|
|
487
|
+
// Record a recent interaction
|
|
488
|
+
service.recentInteractions.set('a1:g1:ch-1', {
|
|
489
|
+
channelKey: 'g1:ch-1',
|
|
490
|
+
channelId: 'ch-1',
|
|
491
|
+
guildId: 'g1',
|
|
492
|
+
timestamp: Date.now()
|
|
493
|
+
});
|
|
494
|
+
|
|
495
|
+
// Simulate prompt request broadcast
|
|
496
|
+
await service._handleBroadcastEvent('session', {
|
|
497
|
+
type: 'user_prompt_request',
|
|
498
|
+
data: { agentId: 'a1', prompt: 'Please provide the API key' }
|
|
499
|
+
});
|
|
500
|
+
|
|
501
|
+
expect(mockCh.send).toHaveBeenCalledTimes(1);
|
|
502
|
+
const sent = mockCh.send.mock.calls[0][0];
|
|
503
|
+
expect(sent).toContain('Input needed');
|
|
504
|
+
expect(sent).toContain('API key');
|
|
505
|
+
});
|
|
506
|
+
});
|
|
507
|
+
|
|
508
|
+
// ========================================================================
|
|
509
|
+
// FLOW 8: Thread-level routing
|
|
510
|
+
// ========================================================================
|
|
511
|
+
|
|
512
|
+
describe('Flow: Thread-level routing', () => {
|
|
513
|
+
let service, orchestrator;
|
|
514
|
+
|
|
515
|
+
beforeEach(() => {
|
|
516
|
+
service = createService();
|
|
517
|
+
orchestrator = createMockOrchestrator();
|
|
518
|
+
service.setOrchestrator(orchestrator);
|
|
519
|
+
service.setAgentPool(createMockAgentPool({
|
|
520
|
+
'a1': { id: 'a1', name: 'Alpha' },
|
|
521
|
+
'a2': { id: 'a2', name: 'Beta' }
|
|
522
|
+
}));
|
|
523
|
+
service.status = DISCORD_STATUS.CONNECTED;
|
|
524
|
+
});
|
|
525
|
+
|
|
526
|
+
test('thread with its own mapping uses thread-specific agents', async () => {
|
|
527
|
+
// Channel has agent Alpha, but thread has agent Beta
|
|
528
|
+
service.channelMappings = {
|
|
529
|
+
'g1:parent-ch': ['a1'],
|
|
530
|
+
'g1:thread-1': ['a2']
|
|
531
|
+
};
|
|
532
|
+
|
|
533
|
+
// Message in the thread
|
|
534
|
+
const msg = createDiscordMessage('hello from thread', {
|
|
535
|
+
guildId: 'g1',
|
|
536
|
+
channelId: 'thread-1',
|
|
537
|
+
parentId: 'parent-ch'
|
|
538
|
+
});
|
|
539
|
+
await service._handleMessage(msg);
|
|
540
|
+
|
|
541
|
+
// Should route to Beta (thread-specific), NOT Alpha (parent)
|
|
542
|
+
expect(orchestrator.processRequest).toHaveBeenCalledTimes(1);
|
|
543
|
+
expect(orchestrator.processRequest.mock.calls[0][0].payload.agentId).toBe('a2');
|
|
544
|
+
});
|
|
545
|
+
|
|
546
|
+
test('thread without its own mapping falls back to parent channel mapping', async () => {
|
|
547
|
+
// Only the parent channel has an agent assigned
|
|
548
|
+
service.channelMappings = {
|
|
549
|
+
'g1:parent-ch': ['a1']
|
|
550
|
+
};
|
|
551
|
+
|
|
552
|
+
// Message in a thread under that channel
|
|
553
|
+
const msg = createDiscordMessage('hello from thread', {
|
|
554
|
+
guildId: 'g1',
|
|
555
|
+
channelId: 'thread-2',
|
|
556
|
+
parentId: 'parent-ch'
|
|
557
|
+
});
|
|
558
|
+
await service._handleMessage(msg);
|
|
559
|
+
|
|
560
|
+
// Should fall back to Alpha (parent channel agent)
|
|
561
|
+
expect(orchestrator.processRequest).toHaveBeenCalledTimes(1);
|
|
562
|
+
expect(orchestrator.processRequest.mock.calls[0][0].payload.agentId).toBe('a1');
|
|
563
|
+
});
|
|
564
|
+
|
|
565
|
+
test('thread with no mapping and unmapped parent is ignored', async () => {
|
|
566
|
+
service.channelMappings = {}; // nothing mapped
|
|
567
|
+
|
|
568
|
+
const msg = createDiscordMessage('hello', {
|
|
569
|
+
guildId: 'g1',
|
|
570
|
+
channelId: 'thread-3',
|
|
571
|
+
parentId: 'unmapped-ch'
|
|
572
|
+
});
|
|
573
|
+
await service._handleMessage(msg);
|
|
574
|
+
|
|
575
|
+
expect(orchestrator.processRequest).not.toHaveBeenCalled();
|
|
576
|
+
});
|
|
577
|
+
|
|
578
|
+
test('response to thread stays in thread, not parent channel', async () => {
|
|
579
|
+
const threadChannel = createMockChannel('thread-1');
|
|
580
|
+
const parentChannel = createMockChannel('parent-ch');
|
|
581
|
+
|
|
582
|
+
service.client = {
|
|
583
|
+
channels: {
|
|
584
|
+
fetch: jest.fn().mockImplementation(id => {
|
|
585
|
+
if (id === 'thread-1') return Promise.resolve(threadChannel);
|
|
586
|
+
if (id === 'parent-ch') return Promise.resolve(parentChannel);
|
|
587
|
+
return Promise.resolve(null);
|
|
588
|
+
})
|
|
589
|
+
}
|
|
590
|
+
};
|
|
591
|
+
service.channelMappings = { 'g1:parent-ch': ['a1'] };
|
|
592
|
+
|
|
593
|
+
// User messages in thread (falls back to parent mapping)
|
|
594
|
+
const msg = createDiscordMessage('question', {
|
|
595
|
+
guildId: 'g1',
|
|
596
|
+
channelId: 'thread-1',
|
|
597
|
+
parentId: 'parent-ch'
|
|
598
|
+
});
|
|
599
|
+
await service._handleMessage(msg);
|
|
600
|
+
|
|
601
|
+
// Agent responds
|
|
602
|
+
await service._handleBroadcastEvent('session', {
|
|
603
|
+
type: 'stream_complete',
|
|
604
|
+
agentId: 'a1',
|
|
605
|
+
content: 'answer'
|
|
606
|
+
});
|
|
607
|
+
|
|
608
|
+
// Response should go to the thread, not the parent
|
|
609
|
+
expect(threadChannel.send).toHaveBeenCalled();
|
|
610
|
+
expect(parentChannel.send).not.toHaveBeenCalled();
|
|
611
|
+
});
|
|
612
|
+
|
|
613
|
+
test('sticky agent is per-thread, not shared with parent channel', async () => {
|
|
614
|
+
service.channelMappings = {
|
|
615
|
+
'g1:parent-ch': ['a1', 'a2'],
|
|
616
|
+
'g1:thread-1': ['a1', 'a2']
|
|
617
|
+
};
|
|
618
|
+
|
|
619
|
+
// In parent channel: address Alpha
|
|
620
|
+
const msg1 = createDiscordMessage('@Alpha do X', { guildId: 'g1', channelId: 'parent-ch' });
|
|
621
|
+
await service._handleMessage(msg1);
|
|
622
|
+
expect(orchestrator.processRequest.mock.calls[0][0].payload.agentId).toBe('a1');
|
|
623
|
+
|
|
624
|
+
// In thread: address Beta
|
|
625
|
+
const msg2 = createDiscordMessage('@Beta do Y', { guildId: 'g1', channelId: 'thread-1', parentId: 'parent-ch' });
|
|
626
|
+
await service._handleMessage(msg2);
|
|
627
|
+
expect(orchestrator.processRequest.mock.calls[1][0].payload.agentId).toBe('a2');
|
|
628
|
+
|
|
629
|
+
// Follow-up in parent (no mention) → sticky should be Alpha
|
|
630
|
+
const msg3 = createDiscordMessage('follow up', { guildId: 'g1', channelId: 'parent-ch' });
|
|
631
|
+
await service._handleMessage(msg3);
|
|
632
|
+
expect(orchestrator.processRequest.mock.calls[2][0].payload.agentId).toBe('a1');
|
|
633
|
+
|
|
634
|
+
// Follow-up in thread (no mention) → sticky should be Beta
|
|
635
|
+
const msg4 = createDiscordMessage('thread follow up', { guildId: 'g1', channelId: 'thread-1', parentId: 'parent-ch' });
|
|
636
|
+
await service._handleMessage(msg4);
|
|
637
|
+
expect(orchestrator.processRequest.mock.calls[3][0].payload.agentId).toBe('a2');
|
|
638
|
+
});
|
|
639
|
+
});
|