onbuzz 4.0.2 → 4.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/scripts/audit-report.js +164 -0
- package/src/core/__tests__/agentPoolToolConfig.test.js +191 -0
- package/src/core/__tests__/agentPoolWakeOnMessage.test.js +315 -0
- package/src/core/__tests__/agentScheduler.emptyResponseDiagnostics.test.js +191 -0
- package/src/core/__tests__/agentScheduler.modeTransitions.test.js +233 -0
- package/src/core/__tests__/agentScheduler.taskLifecycleInstruction.test.js +78 -0
- package/src/core/__tests__/agentScheduler.test.js +31 -13
- package/src/core/__tests__/messageProcessor.test.js +42 -0
- package/src/core/agentPool.js +127 -25
- package/src/core/agentScheduler.js +330 -151
- package/src/core/messageProcessor.js +19 -1
- package/src/interfaces/__tests__/galleryRoutes.test.js +311 -0
- package/src/interfaces/webServer.js +183 -2
- package/src/services/__tests__/agentActivityService.test.js +83 -0
- package/src/services/__tests__/aiService.reasoningTokens.test.js +66 -0
- package/src/services/__tests__/aiService.stream.test.js +301 -0
- package/src/services/__tests__/conversationQuery.reasoning.test.js +102 -0
- package/src/services/__tests__/conversationQuery.test.js +723 -0
- package/src/services/__tests__/toolCallBridgeContract.test.js +129 -0
- package/src/services/agentActivityService.js +25 -4
- package/src/services/aiService.js +180 -91
- package/src/services/conversationQuery.js +803 -0
- package/src/tools/__tests__/agentCommunicationTool.test.js +114 -0
- package/src/tools/__tests__/baseTool.getEffectiveConfig.test.js +77 -0
- package/src/tools/__tests__/baseTool.test.js +471 -420
- package/src/tools/__tests__/filesystemTool.test.js +98 -0
- package/src/tools/__tests__/memoryTool.reminisce.test.js +363 -0
- package/src/tools/__tests__/memoryTool.test.js +2 -2
- package/src/tools/__tests__/openaiFunctionSchemas.memoryReminisce.test.js +84 -0
- package/src/tools/__tests__/taskManagerTool.lifecycleGuidance.test.js +71 -0
- package/src/tools/__tests__/terminalTool.test.js +64 -0
- package/src/tools/__tests__/webTool.perAgentConfig.test.js +94 -0
- package/src/tools/agentCommunicationTool.js +33 -22
- package/src/tools/baseTool.js +980 -899
- package/src/tools/fileSystemTool.js +76 -2
- package/src/tools/memoryTool.js +270 -4
- package/src/tools/openaiFunctionSchemas.js +62 -7
- package/src/tools/taskManagerTool.js +21 -4
- package/src/tools/terminalTool.js +62 -2
- package/src/tools/webTool.js +65 -1
- package/src/utilities/__tests__/auditReport.test.js +328 -0
- package/src/utilities/__tests__/modeTransitionReasons.test.js +105 -0
- package/src/utilities/auditReport.js +331 -0
- package/src/utilities/modeTransitionReasons.js +101 -0
- package/web-ui/build/index.html +2 -2
- package/web-ui/build/static/1c-C_9olPfq.js +1 -0
- package/web-ui/build/static/abap--DeFI1OC.js +1 -0
- package/web-ui/build/static/abnf-5HzSmxRy.js +1 -0
- package/web-ui/build/static/abnf-IG-O3NHT.js +1 -0
- package/web-ui/build/static/accesslog-qO_3I5IJ.js +1 -0
- package/web-ui/build/static/actionscript-DbFc2Uxo.js +1 -0
- package/web-ui/build/static/actionscript-jU7xUh7w.js +1 -0
- package/web-ui/build/static/ada-DBOzyNDe.js +1 -0
- package/web-ui/build/static/ada-F0QwXh2e.js +1 -0
- package/web-ui/build/static/agda-Drhr_GYC.js +1 -0
- package/web-ui/build/static/al-bEatcrqU.js +1 -0
- package/web-ui/build/static/angelscript-Bp0mqasc.js +1 -0
- package/web-ui/build/static/antlr4-BCvixOqW.js +1 -0
- package/web-ui/build/static/apache-zSeWcGFf.js +1 -0
- package/web-ui/build/static/apacheconf-CEDX0qIZ.js +1 -0
- package/web-ui/build/static/apex-BHlvjPxZ.js +1 -0
- package/web-ui/build/static/apl-S86eLVnh.js +1 -0
- package/web-ui/build/static/applescript-D15JiHTt.js +1 -0
- package/web-ui/build/static/applescript-D6g2nIGs.js +1 -0
- package/web-ui/build/static/aql-C4SWmhk2.js +1 -0
- package/web-ui/build/static/arcade-DrwRCCCh.js +1 -0
- package/web-ui/build/static/arduino-Blsw4-hb.js +1 -0
- package/web-ui/build/static/arduino-s6CYn6L3.js +1 -0
- package/web-ui/build/static/arff-DnrfdsTx.js +1 -0
- package/web-ui/build/static/armasm-C2WK9q2y.js +1 -0
- package/web-ui/build/static/asciidoc-BiY2pDol.js +1 -0
- package/web-ui/build/static/asciidoc-DG128-Q1.js +1 -0
- package/web-ui/build/static/asm6502-BEAW0Cck.js +1 -0
- package/web-ui/build/static/asmatmel-C4v7boSu.js +1 -0
- package/web-ui/build/static/aspectj-Bfek529B.js +1 -0
- package/web-ui/build/static/aspnet-8K2PeLn2.js +1 -0
- package/web-ui/build/static/autohotkey-BHw78HYu.js +1 -0
- package/web-ui/build/static/autohotkey-C5DDQtDL.js +1 -0
- package/web-ui/build/static/autoit-CgsSmQkF.js +1 -0
- package/web-ui/build/static/autoit-DZ7IS_9i.js +1 -0
- package/web-ui/build/static/avisynth-B20WuEUg.js +1 -0
- package/web-ui/build/static/avrasm-C7TrcWBg.js +1 -0
- package/web-ui/build/static/avro-idl-CfDy8XWE.js +1 -0
- package/web-ui/build/static/awk-cjY-7p5o.js +1 -0
- package/web-ui/build/static/axapta-Bu9INQG2.js +1 -0
- package/web-ui/build/static/bash-B998wxy_.js +1 -0
- package/web-ui/build/static/bash-LE6roX2s.js +1 -0
- package/web-ui/build/static/basic-Cd6-vDdH.js +1 -0
- package/web-ui/build/static/basic-mfY-ovnp.js +1 -0
- package/web-ui/build/static/batch-DxVy2cwv.js +1 -0
- package/web-ui/build/static/bbcode-Ct3Yu8De.js +1 -0
- package/web-ui/build/static/bicep-CexPoMEW.js +1 -0
- package/web-ui/build/static/birb-CH1RMpPI.js +1 -0
- package/web-ui/build/static/bison-XQFuPB_Q.js +1 -0
- package/web-ui/build/static/bnf-CIDGmY3l.js +1 -0
- package/web-ui/build/static/bnf-DjN_FU2s.js +1 -0
- package/web-ui/build/static/brainfuck-Cu_hvayi.js +1 -0
- package/web-ui/build/static/brainfuck-eRbe4_qo.js +1 -0
- package/web-ui/build/static/brightscript-Cdq0ttTN.js +1 -0
- package/web-ui/build/static/bro-D3aio8LS.js +1 -0
- package/web-ui/build/static/bsl-DFEwVZ2J.js +1 -0
- package/web-ui/build/static/c-D6RK1vhn.js +1 -0
- package/web-ui/build/static/c-DUcBA02q.js +1 -0
- package/web-ui/build/static/c-like-BApJDFwD.js +1 -0
- package/web-ui/build/static/cal-Ckv8Qnpw.js +1 -0
- package/web-ui/build/static/capnproto-DCoblEyS.js +1 -0
- package/web-ui/build/static/ceylon-DM-zZDWY.js +1 -0
- package/web-ui/build/static/cfscript-CMoOAgUK.js +1 -0
- package/web-ui/build/static/chaiscript-B3Vl3wGb.js +1 -0
- package/web-ui/build/static/cil-ChEi_uFO.js +1 -0
- package/web-ui/build/static/clean-BtA08oDV.js +1 -0
- package/web-ui/build/static/clojure-CWMlf7lJ.js +1 -0
- package/web-ui/build/static/clojure-Vur8C4jr.js +1 -0
- package/web-ui/build/static/clojure-repl-BsfGHdYy.js +1 -0
- package/web-ui/build/static/cmake-Csgl_IVr.js +1 -0
- package/web-ui/build/static/cmake-DFMKvwxy.js +1 -0
- package/web-ui/build/static/cobol-XhlGrCrW.js +1 -0
- package/web-ui/build/static/coffeescript-DYldGW35.js +1 -0
- package/web-ui/build/static/coffeescript-DvbNKwrC.js +1 -0
- package/web-ui/build/static/concurnas-DjALqCYn.js +1 -0
- package/web-ui/build/static/coq-D9QGJI6g.js +1 -0
- package/web-ui/build/static/coq-fAZpoc7i.js +1 -0
- package/web-ui/build/static/cos-GgM7WWVZ.js +1 -0
- package/web-ui/build/static/cpp-Cgt5qqfd.js +1 -0
- package/web-ui/build/static/cpp-DxVcOuBe.js +1 -0
- package/web-ui/build/static/crmsh-BlZWnzbY.js +1 -0
- package/web-ui/build/static/crystal--H7HLAQf.js +1 -0
- package/web-ui/build/static/crystal-DWm0bbUT.js +1 -0
- package/web-ui/build/static/csharp-8dr-wktE.js +1 -0
- package/web-ui/build/static/csharp-DFuHLPFe.js +1 -0
- package/web-ui/build/static/cshtml-C-L4_dy2.js +1 -0
- package/web-ui/build/static/csp-CJ6qbecO.js +1 -0
- package/web-ui/build/static/csp-DswTy-5u.js +1 -0
- package/web-ui/build/static/css-DdRPdKXQ.js +1 -0
- package/web-ui/build/static/css-extras-DMwOZFrB.js +1 -0
- package/web-ui/build/static/csv-BiWlhIMC.js +1 -0
- package/web-ui/build/static/cypher-ByNaJKO8.js +1 -0
- package/web-ui/build/static/d-BR89VlK-.js +1 -0
- package/web-ui/build/static/d-KlWvBc4w.js +1 -0
- package/web-ui/build/static/dart-BIsk7m6o.js +1 -0
- package/web-ui/build/static/dart-BnyP1Rjp.js +1 -0
- package/web-ui/build/static/dataweave-CH_Q2gWX.js +1 -0
- package/web-ui/build/static/dax-wulX9uc-.js +1 -0
- package/web-ui/build/static/delphi-CFowdk_A.js +1 -0
- package/web-ui/build/static/dhall-BfCOemEp.js +1 -0
- package/web-ui/build/static/diff-DQD2zPaG.js +1 -0
- package/web-ui/build/static/diff-DZoEdrYM.js +1 -0
- package/web-ui/build/static/django-B0j973Kw.js +1 -0
- package/web-ui/build/static/django-CYScL320.js +1 -0
- package/web-ui/build/static/dns-DoECkAgz.js +1 -0
- package/web-ui/build/static/dns-zone-file-CuoIcXgj.js +1 -0
- package/web-ui/build/static/docker-C2nfXTBG.js +1 -0
- package/web-ui/build/static/dockerfile-DBalxIH7.js +1 -0
- package/web-ui/build/static/dos-GNL9IdmL.js +1 -0
- package/web-ui/build/static/dot-rKuRS-PS.js +1 -0
- package/web-ui/build/static/dsconfig-CKmenTFr.js +1 -0
- package/web-ui/build/static/dts-AxT2qjQU.js +1 -0
- package/web-ui/build/static/dust-DpqHWPC4.js +1 -0
- package/web-ui/build/static/ebnf-CONEMpLp.js +1 -0
- package/web-ui/build/static/ebnf-DRWcOs8R.js +1 -0
- package/web-ui/build/static/editorconfig-lmLHmECZ.js +1 -0
- package/web-ui/build/static/eiffel-B39e31fw.js +1 -0
- package/web-ui/build/static/ejs-DtJwpVdo.js +1 -0
- package/web-ui/build/static/elixir-BH4JTqa9.js +1 -0
- package/web-ui/build/static/elixir-aH1DLjYD.js +1 -0
- package/web-ui/build/static/elm-BcCGkSrW.js +1 -0
- package/web-ui/build/static/elm-CCrB1JbX.js +1 -0
- package/web-ui/build/static/erb-CcumI1K3.js +1 -0
- package/web-ui/build/static/erb-_HK77hx-.js +1 -0
- package/web-ui/build/static/erlang-B1qxMZZp.js +1 -0
- package/web-ui/build/static/erlang-CCM_ejO_.js +1 -0
- package/web-ui/build/static/erlang-repl-D1zC2Zf6.js +1 -0
- package/web-ui/build/static/etlua-HJMRx9x7.js +1 -0
- package/web-ui/build/static/excel-DqXCKUKa.js +1 -0
- package/web-ui/build/static/excel-formula-oNw1T5Gi.js +1 -0
- package/web-ui/build/static/factor-BrTp5FZH.js +1 -0
- package/web-ui/build/static/false-CAVqV3ok.js +1 -0
- package/web-ui/build/static/firestore-security-rules-CxTofGT0.js +1 -0
- package/web-ui/build/static/fix-BMooo7-3.js +1 -0
- package/web-ui/build/static/flix-DR5Pi_4n.js +1 -0
- package/web-ui/build/static/flow-BoCWpUCW.js +1 -0
- package/web-ui/build/static/fortran-B9JI5ahV.js +1 -0
- package/web-ui/build/static/fortran-LXg81aOn.js +1 -0
- package/web-ui/build/static/fsharp-BqcGG-SM.js +1 -0
- package/web-ui/build/static/fsharp-Dj5YVL_h.js +1 -0
- package/web-ui/build/static/ftl-kuY7uFR8.js +1 -0
- package/web-ui/build/static/gams-CzihHKqE.js +1 -0
- package/web-ui/build/static/gap-BbS0A-Wl.js +1 -0
- package/web-ui/build/static/gauss-BauwG_O4.js +1 -0
- package/web-ui/build/static/gcode-VY1OKBcC.js +1 -0
- package/web-ui/build/static/gcode-lapsLgV5.js +1 -0
- package/web-ui/build/static/gdscript-1UIYB8m0.js +1 -0
- package/web-ui/build/static/gedcom-Bhrxt1LM.js +1 -0
- package/web-ui/build/static/gherkin-BsUD3vJB.js +1 -0
- package/web-ui/build/static/gherkin-hj_asmFX.js +1 -0
- package/web-ui/build/static/git-DXIrRKzR.js +1 -0
- package/web-ui/build/static/glsl-Bww3i9-P.js +1 -0
- package/web-ui/build/static/glsl-tW4hvcaQ.js +1 -0
- package/web-ui/build/static/gml-BIqshajA.js +1 -0
- package/web-ui/build/static/gml-CQqc9F-B.js +1 -0
- package/web-ui/build/static/gn-CBgpy8B9.js +1 -0
- package/web-ui/build/static/go-CEUAUIgn.js +1 -0
- package/web-ui/build/static/go-DPEd33Yn.js +1 -0
- package/web-ui/build/static/go-module-BVPbZOg5.js +1 -0
- package/web-ui/build/static/golo-CqB3OATq.js +1 -0
- package/web-ui/build/static/gradle-Djj_6FTv.js +1 -0
- package/web-ui/build/static/graphql-ymSYYmmE.js +1 -0
- package/web-ui/build/static/groovy-BLoXi1Ew.js +1 -0
- package/web-ui/build/static/groovy-D8ua3DVO.js +1 -0
- package/web-ui/build/static/haml-DKlxHs26.js +1 -0
- package/web-ui/build/static/haml-S_iUNysn.js +1 -0
- package/web-ui/build/static/handlebars-B7tcAMGB.js +1 -0
- package/web-ui/build/static/handlebars-CV-zB05N.js +1 -0
- package/web-ui/build/static/haskell-CMxCwdZX.js +1 -0
- package/web-ui/build/static/haskell-Dis6rGJ5.js +1 -0
- package/web-ui/build/static/haxe-C76IK5YN.js +1 -0
- package/web-ui/build/static/haxe-hbmD2uei.js +1 -0
- package/web-ui/build/static/hcl-BPI_t80W.js +1 -0
- package/web-ui/build/static/hlsl-BmeH3MXM.js +1 -0
- package/web-ui/build/static/hoon-BYLX7KiR.js +1 -0
- package/web-ui/build/static/hpkp-CFV1lvIV.js +1 -0
- package/web-ui/build/static/hsp-_VXPtQPw.js +1 -0
- package/web-ui/build/static/hsts-DzmFog1b.js +1 -0
- package/web-ui/build/static/htmlbars-uX8JubPS.js +1 -0
- package/web-ui/build/static/http-BTDAHgkv.js +1 -0
- package/web-ui/build/static/http-Ba1gTHCW.js +1 -0
- package/web-ui/build/static/hy-G7MK4TLb.js +1 -0
- package/web-ui/build/static/ichigojam-BKKN56jZ.js +1 -0
- package/web-ui/build/static/icon-nrqdEYwB.js +1 -0
- package/web-ui/build/static/icu-message-format-Bjone7XH.js +1 -0
- package/web-ui/build/static/idris-CKkY_0op.js +1 -0
- package/web-ui/build/static/iecst-EV3ZvBDC.js +1 -0
- package/web-ui/build/static/ignore-LJIbInke.js +1 -0
- package/web-ui/build/static/index-C1x426Pt.js +734 -0
- package/web-ui/build/static/index-CTzeYMwr.js +13 -0
- package/web-ui/build/static/index-CUBjz1OL.css +1 -0
- package/web-ui/build/static/index-DnVIkRiR.js +1 -0
- package/web-ui/build/static/inform7-BiW6HbUl.js +1 -0
- package/web-ui/build/static/inform7-DT-x6SRD.js +1 -0
- package/web-ui/build/static/ini-BbnHjAtW.js +1 -0
- package/web-ui/build/static/ini-DuNY7Iqz.js +1 -0
- package/web-ui/build/static/io-BquAtlCB.js +1 -0
- package/web-ui/build/static/irpf90-CZELNeJl.js +1 -0
- package/web-ui/build/static/isbl-DhOgOzai.js +1 -0
- package/web-ui/build/static/j-r8D3BrBj.js +1 -0
- package/web-ui/build/static/java-MjQ5EBN5.js +1 -0
- package/web-ui/build/static/java-c3Jyc0B6.js +1 -0
- package/web-ui/build/static/javadoc-CfNFziRD.js +1 -0
- package/web-ui/build/static/javadoclike-BUcJZQAh.js +1 -0
- package/web-ui/build/static/javascript-CL_4g6j3.js +1 -0
- package/web-ui/build/static/javastacktrace-4P_J-58S.js +1 -0
- package/web-ui/build/static/jboss-cli-DUfK88hO.js +1 -0
- package/web-ui/build/static/jexl-DsSijmcs.js +1 -0
- package/web-ui/build/static/jolie-DjtNIZB4.js +1 -0
- package/web-ui/build/static/jq-BXdSm79y.js +1 -0
- package/web-ui/build/static/js-extras-B-C7ngCD.js +1 -0
- package/web-ui/build/static/js-templates-CmPAiwFC.js +1 -0
- package/web-ui/build/static/jsdoc-CkiXOOMV.js +1 -0
- package/web-ui/build/static/json-Bmvhezfj.js +1 -0
- package/web-ui/build/static/json-HPR8wBiw.js +1 -0
- package/web-ui/build/static/json5-Chcg9nnQ.js +1 -0
- package/web-ui/build/static/jsonp-C3KWcfzJ.js +1 -0
- package/web-ui/build/static/jsstacktrace-D1jRFy-S.js +1 -0
- package/web-ui/build/static/jsx-COtCqQ_9.js +1 -0
- package/web-ui/build/static/julia-BVvfw2TB.js +1 -0
- package/web-ui/build/static/julia-Ddalvdoa.js +1 -0
- package/web-ui/build/static/julia-repl-Bc-uwnIZ.js +1 -0
- package/web-ui/build/static/keepalived-CJ9ZYuQx.js +1 -0
- package/web-ui/build/static/keyman-BHea-dB6.js +1 -0
- package/web-ui/build/static/kotlin-DWOyCb_2.js +1 -0
- package/web-ui/build/static/kotlin-fvMiFIS3.js +1 -0
- package/web-ui/build/static/kumir-DaNls7gN.js +1 -0
- package/web-ui/build/static/kusto-DKweJuKl.js +1 -0
- package/web-ui/build/static/lasso-BB9dUrv_.js +1 -0
- package/web-ui/build/static/latex-C7U5RUQQ.js +1 -0
- package/web-ui/build/static/latex-CXM3EEy0.js +1 -0
- package/web-ui/build/static/latte-B4pEA635.js +1 -0
- package/web-ui/build/static/ldif-D3wYig10.js +1 -0
- package/web-ui/build/static/leaf-uFkjT9sR.js +1 -0
- package/web-ui/build/static/less-CbUH4jBX.js +1 -0
- package/web-ui/build/static/less-DEGyfeZn.js +1 -0
- package/web-ui/build/static/lilypond-UuoBjShK.js +1 -0
- package/web-ui/build/static/liquid-DB3a9n7S.js +1 -0
- package/web-ui/build/static/lisp-BDbj7Kd2.js +1 -0
- package/web-ui/build/static/lisp-D3T0YOb1.js +1 -0
- package/web-ui/build/static/livecodeserver-CkZMVLmr.js +1 -0
- package/web-ui/build/static/livescript-CJbtbTfA.js +1 -0
- package/web-ui/build/static/livescript-CdWg1xgf.js +1 -0
- package/web-ui/build/static/llvm-8hpjZ6qF.js +1 -0
- package/web-ui/build/static/llvm-DPpuma6i.js +1 -0
- package/web-ui/build/static/log-DwsLgecp.js +1 -0
- package/web-ui/build/static/lolcode-D3tkyiVB.js +1 -0
- package/web-ui/build/static/lsl-BBM4ZYza.js +1 -0
- package/web-ui/build/static/lua-DT0su8pZ.js +1 -0
- package/web-ui/build/static/lua-DqZXmUwn.js +1 -0
- package/web-ui/build/static/magma-DGW0-GCr.js +1 -0
- package/web-ui/build/static/makefile-C_K7AaVw.js +1 -0
- package/web-ui/build/static/makefile-CarddjPJ.js +1 -0
- package/web-ui/build/static/markdown-3dq-8I9T.js +1 -0
- package/web-ui/build/static/markdown-c4VYoNo2.js +1 -0
- package/web-ui/build/static/markup-templating-BBX0gWS5.js +1 -0
- package/web-ui/build/static/mathematica-n-aqoCbO.js +1 -0
- package/web-ui/build/static/matlab-B_kYC-A2.js +1 -0
- package/web-ui/build/static/matlab-CQP2D_0j.js +1 -0
- package/web-ui/build/static/maxima-piaAhCcP.js +1 -0
- package/web-ui/build/static/maxscript-CkxNZR1a.js +1 -0
- package/web-ui/build/static/mel-BXbrV0aU.js +1 -0
- package/web-ui/build/static/mel-CBSpVZcl.js +1 -0
- package/web-ui/build/static/mercury-CffeC87B.js +1 -0
- package/web-ui/build/static/mermaid-DAZcfksM.js +1 -0
- package/web-ui/build/static/mipsasm-DvOPoNgz.js +1 -0
- package/web-ui/build/static/mizar-C2ki99qc.js +1 -0
- package/web-ui/build/static/mizar-C5AXRrsD.js +1 -0
- package/web-ui/build/static/mojolicious-DklqV-uP.js +1 -0
- package/web-ui/build/static/mongodb-BbuSPlN0.js +1 -0
- package/web-ui/build/static/monkey-CJBb2-mV.js +1 -0
- package/web-ui/build/static/monkey-DgERCZQd.js +1 -0
- package/web-ui/build/static/moonscript-BovBU9jW.js +1 -0
- package/web-ui/build/static/moonscript-lPqbcjjy.js +1 -0
- package/web-ui/build/static/n1ql-CjVXW0Z0.js +1 -0
- package/web-ui/build/static/n1ql-DkfG2dTH.js +1 -0
- package/web-ui/build/static/n4js-6L9QW_kw.js +1 -0
- package/web-ui/build/static/nand2tetris-hdl-CqohGHfB.js +1 -0
- package/web-ui/build/static/naniscript-CIvQ6y1b.js +1 -0
- package/web-ui/build/static/nasm-CQbJbZZf.js +1 -0
- package/web-ui/build/static/neon-Cz41RJxQ.js +1 -0
- package/web-ui/build/static/nevod-WPRJ2Q9j.js +1 -0
- package/web-ui/build/static/nginx-BL2wPbD-.js +1 -0
- package/web-ui/build/static/nginx-DsqC_gQT.js +1 -0
- package/web-ui/build/static/nim-7qnwzYm_.js +1 -0
- package/web-ui/build/static/nim-D6iDo5H6.js +1 -0
- package/web-ui/build/static/nix-BQSsaH-G.js +1 -0
- package/web-ui/build/static/nix-DgwCtjpD.js +1 -0
- package/web-ui/build/static/node-repl-Cb4w8DbD.js +1 -0
- package/web-ui/build/static/nsis-CiXZWrqR.js +1 -0
- package/web-ui/build/static/nsis-CuwGI5px.js +1 -0
- package/web-ui/build/static/objectivec-DZXCqQ1J.js +1 -0
- package/web-ui/build/static/objectivec-GNGh-wiY.js +1 -0
- package/web-ui/build/static/ocaml-BPg_ANkr.js +1 -0
- package/web-ui/build/static/ocaml-DRUpaN8p.js +1 -0
- package/web-ui/build/static/opencl-CazTs_sf.js +1 -0
- package/web-ui/build/static/openqasm-DHuuXGjm.js +1 -0
- package/web-ui/build/static/openscad-YbvBFeLc.js +1 -0
- package/web-ui/build/static/oxygene-DDzgbCaQ.js +1 -0
- package/web-ui/build/static/oz-BRDBLIjx.js +1 -0
- package/web-ui/build/static/parigp-BbApdos7.js +1 -0
- package/web-ui/build/static/parser-CbVH4ySK.js +1 -0
- package/web-ui/build/static/parser3-BIkvuuuE.js +1 -0
- package/web-ui/build/static/pascal-oS7U_3sO.js +1 -0
- package/web-ui/build/static/pascaligo-57DdFj76.js +1 -0
- package/web-ui/build/static/pcaxis-V-Euf0DV.js +1 -0
- package/web-ui/build/static/peoplecode-DjyRW5V8.js +1 -0
- package/web-ui/build/static/perl-BEQWvjeP.js +1 -0
- package/web-ui/build/static/perl-CiDHRorC.js +1 -0
- package/web-ui/build/static/pf-S5x_U1LC.js +1 -0
- package/web-ui/build/static/pgsql-DwHZC-iy.js +1 -0
- package/web-ui/build/static/php-7enmlb-I.js +1 -0
- package/web-ui/build/static/php-extras-BhRDMlXE.js +1 -0
- package/web-ui/build/static/php-kIwfq-Jj.js +1 -0
- package/web-ui/build/static/php-template-M2RrZc1R.js +1 -0
- package/web-ui/build/static/phpdoc-HUeiWlkw.js +1 -0
- package/web-ui/build/static/plaintext-CPt25ow_.js +1 -0
- package/web-ui/build/static/plsql-BvoRAbdz.js +1 -0
- package/web-ui/build/static/pony-BVuhxk7D.js +1 -0
- package/web-ui/build/static/powerquery-rnRfiL3F.js +1 -0
- package/web-ui/build/static/powershell-BQR2-qjF.js +1 -0
- package/web-ui/build/static/powershell-S_XnLato.js +1 -0
- package/web-ui/build/static/processing-B-8pt1gx.js +1 -0
- package/web-ui/build/static/processing-ozS1KPr7.js +1 -0
- package/web-ui/build/static/profile-DOjTmxRs.js +1 -0
- package/web-ui/build/static/prolog-BaaxuI5L.js +1 -0
- package/web-ui/build/static/prolog-D90dFqfr.js +1 -0
- package/web-ui/build/static/promql-BuyoLqtl.js +1 -0
- package/web-ui/build/static/properties-C0pMastm.js +1 -0
- package/web-ui/build/static/properties-k7bXYQao.js +1 -0
- package/web-ui/build/static/protobuf-ChaO1q7B.js +1 -0
- package/web-ui/build/static/protobuf-DAGxv01T.js +1 -0
- package/web-ui/build/static/psl-BpYOLBqn.js +1 -0
- package/web-ui/build/static/pug-BUlJA4UD.js +1 -0
- package/web-ui/build/static/puppet-8l--PVpO.js +1 -0
- package/web-ui/build/static/puppet-BJDN84xr.js +1 -0
- package/web-ui/build/static/pure-DhqjQg1a.js +1 -0
- package/web-ui/build/static/purebasic-BHnSz9Yh.js +1 -0
- package/web-ui/build/static/purebasic-CeiLO2aV.js +1 -0
- package/web-ui/build/static/purescript-BaXXPnKS.js +1 -0
- package/web-ui/build/static/python-BXdJ4yqN.js +1 -0
- package/web-ui/build/static/python-Cef5Vfx2.js +1 -0
- package/web-ui/build/static/python-repl-CRpJP363.js +1 -0
- package/web-ui/build/static/q-C6Ov0g11.js +1 -0
- package/web-ui/build/static/q-D3tQMiHa.js +1 -0
- package/web-ui/build/static/qml-BYofTHXZ.js +1 -0
- package/web-ui/build/static/qml-DTxi8T37.js +1 -0
- package/web-ui/build/static/qore-Ny7MVtbP.js +1 -0
- package/web-ui/build/static/qsharp-Cy_rqHs2.js +1 -0
- package/web-ui/build/static/r-BtNaz7Jx.js +1 -0
- package/web-ui/build/static/r-DkF7wq0g.js +1 -0
- package/web-ui/build/static/racket-C5r8oFZa.js +1 -0
- package/web-ui/build/static/reason-BURRGL8T.js +1 -0
- package/web-ui/build/static/reasonml-ZPKVqo38.js +1 -0
- package/web-ui/build/static/regex-DgaaAttu.js +1 -0
- package/web-ui/build/static/rego-CtwYq-qp.js +1 -0
- package/web-ui/build/static/renpy-OueysuHf.js +1 -0
- package/web-ui/build/static/rest-Co13hzuk.js +1 -0
- package/web-ui/build/static/rib-CvGWooaO.js +1 -0
- package/web-ui/build/static/rip-5glwZfvx.js +1 -0
- package/web-ui/build/static/roboconf-B9R_ZXBj.js +1 -0
- package/web-ui/build/static/roboconf-Gf0nTNKt.js +1 -0
- package/web-ui/build/static/robotframework-C2axWAv1.js +1 -0
- package/web-ui/build/static/routeros-CE_Iedbm.js +1 -0
- package/web-ui/build/static/rsl-2QjczbcI.js +1 -0
- package/web-ui/build/static/ruby-5q7nApRB.js +1 -0
- package/web-ui/build/static/ruby-BUTeEeQo.js +1 -0
- package/web-ui/build/static/ruleslanguage-vxFl2T6e.js +1 -0
- package/web-ui/build/static/rust-BMuquF4q.js +1 -0
- package/web-ui/build/static/rust-CcZQo8qE.js +1 -0
- package/web-ui/build/static/sas-B3kZio_a.js +1 -0
- package/web-ui/build/static/sas-Bbv6Pcs_.js +1 -0
- package/web-ui/build/static/sass-C0q0q-U-.js +1 -0
- package/web-ui/build/static/scala-B5vW0oUX.js +1 -0
- package/web-ui/build/static/scala-CyVnVDED.js +1 -0
- package/web-ui/build/static/scheme-C9JOo4R_.js +1 -0
- package/web-ui/build/static/scheme-W2233tzx.js +1 -0
- package/web-ui/build/static/scilab-D2Bvw6Ov.js +1 -0
- package/web-ui/build/static/scss-CTlab4AI.js +1 -0
- package/web-ui/build/static/scss-DZ5g2Z9m.js +1 -0
- package/web-ui/build/static/shell-bYpiB--U.js +1 -0
- package/web-ui/build/static/shell-session-C4jzoNup.js +1 -0
- package/web-ui/build/static/smali-9ucoTzDl.js +1 -0
- package/web-ui/build/static/smali-BnluPxDD.js +1 -0
- package/web-ui/build/static/smalltalk-CAMGWItN.js +1 -0
- package/web-ui/build/static/smalltalk-DNxg0Og_.js +1 -0
- package/web-ui/build/static/smarty-YxNaCRZt.js +1 -0
- package/web-ui/build/static/sml-CZbvurr2.js +1 -0
- package/web-ui/build/static/sml-DGs_TRXx.js +1 -0
- package/web-ui/build/static/solidity-CEsviKxI.js +1 -0
- package/web-ui/build/static/solution-file-D0Yvaoet.js +1 -0
- package/web-ui/build/static/soy-BmVAPY7I.js +1 -0
- package/web-ui/build/static/sparql-D8d4i2J8.js +1 -0
- package/web-ui/build/static/splunk-spl-CcgWj5Im.js +1 -0
- package/web-ui/build/static/sqf-Cd4tBlXZ.js +1 -0
- package/web-ui/build/static/sqf-DC8e-wlP.js +1 -0
- package/web-ui/build/static/sql-D5KtfAwl.js +1 -0
- package/web-ui/build/static/sql-DX4iGc5J.js +1 -0
- package/web-ui/build/static/sql_more-9ztUFh5U.js +1 -0
- package/web-ui/build/static/squirrel-CiVV01fQ.js +1 -0
- package/web-ui/build/static/stan-DCrPYtdq.js +1 -0
- package/web-ui/build/static/stan-LL9ScTUT.js +1 -0
- package/web-ui/build/static/stata-n-r5-RvF.js +1 -0
- package/web-ui/build/static/step21-B2hxGG1E.js +1 -0
- package/web-ui/build/static/stylus-D-1wq2uN.js +1 -0
- package/web-ui/build/static/stylus-Dr-w1AjW.js +1 -0
- package/web-ui/build/static/subunit-DRCyiRHI.js +1 -0
- package/web-ui/build/static/swift-B2ZIuBjB.js +1 -0
- package/web-ui/build/static/swift-CnRpp8ao.js +1 -0
- package/web-ui/build/static/systemd-LPN-yj3b.js +1 -0
- package/web-ui/build/static/t4-cs-CXJSMlet.js +1 -0
- package/web-ui/build/static/t4-templating-Ciw3keAZ.js +1 -0
- package/web-ui/build/static/t4-vb-CXe99AWF.js +1 -0
- package/web-ui/build/static/taggerscript-Bm830ZwV.js +1 -0
- package/web-ui/build/static/tap-B0WwYGVt.js +1 -0
- package/web-ui/build/static/tap-Dw_cgj6K.js +1 -0
- package/web-ui/build/static/tcl-Di4JhH4s.js +1 -0
- package/web-ui/build/static/tcl-cIeBNf2V.js +1 -0
- package/web-ui/build/static/textile-DgMdCAz5.js +1 -0
- package/web-ui/build/static/thrift-zY2WxYMk.js +1 -0
- package/web-ui/build/static/toml-BtXdKizf.js +1 -0
- package/web-ui/build/static/tp-DxY0K8UF.js +1 -0
- package/web-ui/build/static/tremor-890wqxvH.js +1 -0
- package/web-ui/build/static/tsx-92ElsKxL.js +1 -0
- package/web-ui/build/static/tt2-DqcvjDKh.js +1 -0
- package/web-ui/build/static/turtle-BZikMsiD.js +1 -0
- package/web-ui/build/static/twig-BlxkEMdw.js +1 -0
- package/web-ui/build/static/twig-CfsoMGnv.js +1 -0
- package/web-ui/build/static/typescript-3xS8yDgH.js +1 -0
- package/web-ui/build/static/typescript-Dx0zHssr.js +1 -0
- package/web-ui/build/static/typoscript-BdFwMGCV.js +1 -0
- package/web-ui/build/static/unrealscript-DJzoqp3G.js +1 -0
- package/web-ui/build/static/uorazor-CQO8Ynpw.js +1 -0
- package/web-ui/build/static/uri-BUBBJdel.js +1 -0
- package/web-ui/build/static/v-XU798JEc.js +1 -0
- package/web-ui/build/static/vala-DsH-Nomr.js +1 -0
- package/web-ui/build/static/vala-gCVw4o0d.js +1 -0
- package/web-ui/build/static/vbnet-BHw8cZ4s.js +1 -0
- package/web-ui/build/static/vbnet-DPa2ddOk.js +1 -0
- package/web-ui/build/static/vbscript-html-CNADYJ1-.js +1 -0
- package/web-ui/build/static/vbscript-ztRmIppj.js +1 -0
- package/web-ui/build/static/velocity-DVfeN53w.js +1 -0
- package/web-ui/build/static/verilog-C9VDLRl9.js +1 -0
- package/web-ui/build/static/verilog-Dsmt_WJW.js +1 -0
- package/web-ui/build/static/vhdl-DbylNGny.js +1 -0
- package/web-ui/build/static/vhdl-wNJe3yKK.js +1 -0
- package/web-ui/build/static/vim-6PLlVaq_.js +1 -0
- package/web-ui/build/static/vim-BJpkTTe-.js +1 -0
- package/web-ui/build/static/visual-basic-GY3wXjJ3.js +1 -0
- package/web-ui/build/static/warpscript-DUb9z3yI.js +1 -0
- package/web-ui/build/static/wasm-Dey0RlHH.js +1 -0
- package/web-ui/build/static/web-idl-qAF1RqaI.js +1 -0
- package/web-ui/build/static/wiki-Dh3Vjtce.js +1 -0
- package/web-ui/build/static/wolfram-BrQcRMlt.js +1 -0
- package/web-ui/build/static/wren-Cu3Mzln6.js +1 -0
- package/web-ui/build/static/x86asm-DD5mhaEi.js +1 -0
- package/web-ui/build/static/xeora-DKRZ6hlr.js +1 -0
- package/web-ui/build/static/xl-BL8R8sAx.js +1 -0
- package/web-ui/build/static/xml-doc-BSpNJbEM.js +1 -0
- package/web-ui/build/static/xml-i5BJyEQ7.js +1 -0
- package/web-ui/build/static/xojo-r2ieNAyP.js +1 -0
- package/web-ui/build/static/xquery-BtAK8Dvl.js +1 -0
- package/web-ui/build/static/xquery-CM4Q_TX7.js +1 -0
- package/web-ui/build/static/yaml-Mm8ArZA3.js +1 -0
- package/web-ui/build/static/yaml-r-QeuY00.js +1 -0
- package/web-ui/build/static/yang-qcKR-Y23.js +1 -0
- package/web-ui/build/static/zephir-8ApHtH7c.js +1 -0
- package/web-ui/build/static/zig-BanqOd9_.js +1 -0
- package/web-ui/build/static/1c-alYWzgyM.js +0 -1
- package/web-ui/build/static/abap-MNX4MGQu.js +0 -1
- package/web-ui/build/static/abnf-PB6umZUe.js +0 -1
- package/web-ui/build/static/abnf-lLelqyRq.js +0 -1
- package/web-ui/build/static/accesslog-ECfnNf6M.js +0 -1
- package/web-ui/build/static/actionscript-48Mv-P2G.js +0 -1
- package/web-ui/build/static/actionscript-CmFMkWAF.js +0 -1
- package/web-ui/build/static/ada-D0nj2830.js +0 -1
- package/web-ui/build/static/ada-DC68kRrL.js +0 -1
- package/web-ui/build/static/agda-CjnuTEYG.js +0 -1
- package/web-ui/build/static/al-DICLGfy9.js +0 -1
- package/web-ui/build/static/angelscript-D7H0wknj.js +0 -1
- package/web-ui/build/static/antlr4-C_KsZIwI.js +0 -1
- package/web-ui/build/static/apache-Cfj2o0TW.js +0 -1
- package/web-ui/build/static/apacheconf-D5jQXqP_.js +0 -1
- package/web-ui/build/static/apex-G2rOb7vm.js +0 -1
- package/web-ui/build/static/apl-CE_aKOLQ.js +0 -1
- package/web-ui/build/static/applescript-BffXi9IZ.js +0 -1
- package/web-ui/build/static/applescript-CshVa-pZ.js +0 -1
- package/web-ui/build/static/aql-F9xr2xIN.js +0 -1
- package/web-ui/build/static/arcade-29Re4fPy.js +0 -1
- package/web-ui/build/static/arduino-BGsZiYrf.js +0 -1
- package/web-ui/build/static/arduino-HiqNS--s.js +0 -1
- package/web-ui/build/static/arff-jPcJv_eJ.js +0 -1
- package/web-ui/build/static/armasm-DDockn0p.js +0 -1
- package/web-ui/build/static/asciidoc-BW3nh79M.js +0 -1
- package/web-ui/build/static/asciidoc-Dxit6U7t.js +0 -1
- package/web-ui/build/static/asm6502-eTpxnsNy.js +0 -1
- package/web-ui/build/static/asmatmel-BHeErmNQ.js +0 -1
- package/web-ui/build/static/aspectj-CX6x53Aw.js +0 -1
- package/web-ui/build/static/aspnet-BFDGvlyU.js +0 -1
- package/web-ui/build/static/autohotkey-CRNZnW-g.js +0 -1
- package/web-ui/build/static/autohotkey-DhdXEUbC.js +0 -1
- package/web-ui/build/static/autoit-BrCU_LoC.js +0 -1
- package/web-ui/build/static/autoit-CNY5ZLoO.js +0 -1
- package/web-ui/build/static/avisynth-CvpX-vR-.js +0 -1
- package/web-ui/build/static/avrasm-Ch0VgbnW.js +0 -1
- package/web-ui/build/static/avro-idl-DVNgaXeA.js +0 -1
- package/web-ui/build/static/awk-DBbMErBm.js +0 -1
- package/web-ui/build/static/axapta-BZMCBJyd.js +0 -1
- package/web-ui/build/static/bash-B7W9_l_H.js +0 -1
- package/web-ui/build/static/bash-nUxPXV93.js +0 -1
- package/web-ui/build/static/basic-CncKWTdb.js +0 -1
- package/web-ui/build/static/basic-t050Yfrj.js +0 -1
- package/web-ui/build/static/batch-DzppEDD6.js +0 -1
- package/web-ui/build/static/bbcode-Cxa6xUCC.js +0 -1
- package/web-ui/build/static/bicep-CNfRbyLD.js +0 -1
- package/web-ui/build/static/birb-BQn3C4qH.js +0 -1
- package/web-ui/build/static/bison-CG1ITN82.js +0 -1
- package/web-ui/build/static/bnf-BH6EqVfg.js +0 -1
- package/web-ui/build/static/bnf-DOOI4ziA.js +0 -1
- package/web-ui/build/static/brainfuck-CuvanNT4.js +0 -1
- package/web-ui/build/static/brainfuck-DEN53aXA.js +0 -1
- package/web-ui/build/static/brightscript-C_qPLhPu.js +0 -1
- package/web-ui/build/static/bro-DE4fdxVn.js +0 -1
- package/web-ui/build/static/bsl-DhilRMN1.js +0 -1
- package/web-ui/build/static/c-DJMkv9RR.js +0 -1
- package/web-ui/build/static/c-HH0eyrSO.js +0 -1
- package/web-ui/build/static/c-like-CievvBLp.js +0 -1
- package/web-ui/build/static/cal-BBz3_HT0.js +0 -1
- package/web-ui/build/static/capnproto-BOgD9Wf3.js +0 -1
- package/web-ui/build/static/ceylon-MWYZBIMt.js +0 -1
- package/web-ui/build/static/cfscript-BiVuxt5i.js +0 -1
- package/web-ui/build/static/chaiscript-CPx7l6f-.js +0 -1
- package/web-ui/build/static/cil-3DGkdNym.js +0 -1
- package/web-ui/build/static/clean-Bxi-hwbJ.js +0 -1
- package/web-ui/build/static/clojure-BBMLjTS9.js +0 -1
- package/web-ui/build/static/clojure-RPrwnP3x.js +0 -1
- package/web-ui/build/static/clojure-repl-BE9VGIhP.js +0 -1
- package/web-ui/build/static/cmake-BMeSZbTq.js +0 -1
- package/web-ui/build/static/cmake-CLVNptnB.js +0 -1
- package/web-ui/build/static/cobol-f-w6Mj2H.js +0 -1
- package/web-ui/build/static/coffeescript-CESbl4tN.js +0 -1
- package/web-ui/build/static/coffeescript-DmOzsrDS.js +0 -1
- package/web-ui/build/static/concurnas-DxQ9U571.js +0 -1
- package/web-ui/build/static/coq-4Wu7fuDB.js +0 -1
- package/web-ui/build/static/coq-BERQ-1c4.js +0 -1
- package/web-ui/build/static/cos-SsvxAn6O.js +0 -1
- package/web-ui/build/static/cpp-BkY4KhJS.js +0 -1
- package/web-ui/build/static/cpp-CGkeKbAD.js +0 -1
- package/web-ui/build/static/crmsh-BL32bNK1.js +0 -1
- package/web-ui/build/static/crystal-C4e562-w.js +0 -1
- package/web-ui/build/static/crystal-Hu8WDm2E.js +0 -1
- package/web-ui/build/static/csharp-DvnJhHBw.js +0 -1
- package/web-ui/build/static/csharp-DxFH-E_J.js +0 -1
- package/web-ui/build/static/cshtml-BkimeLw1.js +0 -1
- package/web-ui/build/static/csp-CDNmbLWI.js +0 -1
- package/web-ui/build/static/csp-DXmobqdr.js +0 -1
- package/web-ui/build/static/css-VRUoX-cu.js +0 -1
- package/web-ui/build/static/css-extras-Dcz-5Gz_.js +0 -1
- package/web-ui/build/static/csv-Cy-vj0dX.js +0 -1
- package/web-ui/build/static/cypher-CyiGMZEd.js +0 -1
- package/web-ui/build/static/d-50yhKzqs.js +0 -1
- package/web-ui/build/static/d-CtQcHe9N.js +0 -1
- package/web-ui/build/static/dart-Dj05IVm2.js +0 -1
- package/web-ui/build/static/dart-kumEUEig.js +0 -1
- package/web-ui/build/static/dataweave-CyaTPvHl.js +0 -1
- package/web-ui/build/static/dax-BYZEUwTe.js +0 -1
- package/web-ui/build/static/delphi-Hrkf0_Zm.js +0 -1
- package/web-ui/build/static/dhall-ZfXZcVvQ.js +0 -1
- package/web-ui/build/static/diff-B681Qorw.js +0 -1
- package/web-ui/build/static/diff-C85U1vU3.js +0 -1
- package/web-ui/build/static/django-BbqkMAd3.js +0 -1
- package/web-ui/build/static/django-ebEm7IW1.js +0 -1
- package/web-ui/build/static/dns-CIKOn0cx.js +0 -1
- package/web-ui/build/static/dns-zone-file-Cgfj303q.js +0 -1
- package/web-ui/build/static/docker-DezZesK-.js +0 -1
- package/web-ui/build/static/dockerfile-HOIJDSPT.js +0 -1
- package/web-ui/build/static/dos-Bv0IPgh2.js +0 -1
- package/web-ui/build/static/dot-BiJIuPYL.js +0 -1
- package/web-ui/build/static/dsconfig-DCPRv9km.js +0 -1
- package/web-ui/build/static/dts-CXMbX7gl.js +0 -1
- package/web-ui/build/static/dust-Mjmn5ftw.js +0 -1
- package/web-ui/build/static/ebnf-469W3R_o.js +0 -1
- package/web-ui/build/static/ebnf-Bs6Ftm9u.js +0 -1
- package/web-ui/build/static/editorconfig-C4dD8cK_.js +0 -1
- package/web-ui/build/static/eiffel-D78uHdvn.js +0 -1
- package/web-ui/build/static/ejs-CUydrtqr.js +0 -1
- package/web-ui/build/static/elixir-BIxlPrSO.js +0 -1
- package/web-ui/build/static/elixir-CLS7rDXm.js +0 -1
- package/web-ui/build/static/elm-CdXXWPN7.js +0 -1
- package/web-ui/build/static/elm-DT7wSSPo.js +0 -1
- package/web-ui/build/static/erb-8Xeo3WFF.js +0 -1
- package/web-ui/build/static/erb-DROzrB_O.js +0 -1
- package/web-ui/build/static/erlang-DbMlkDTN.js +0 -1
- package/web-ui/build/static/erlang-DoF730hs.js +0 -1
- package/web-ui/build/static/erlang-repl-B7enXvga.js +0 -1
- package/web-ui/build/static/etlua-CehWhSD3.js +0 -1
- package/web-ui/build/static/excel-DHmOIegb.js +0 -1
- package/web-ui/build/static/excel-formula-DdeWF1_w.js +0 -1
- package/web-ui/build/static/factor-DBMZ3xT3.js +0 -1
- package/web-ui/build/static/false-AxZ_vqH0.js +0 -1
- package/web-ui/build/static/firestore-security-rules-BChGByFG.js +0 -1
- package/web-ui/build/static/fix-Cc-mOcI9.js +0 -1
- package/web-ui/build/static/flix-CBpO-hKP.js +0 -1
- package/web-ui/build/static/flow-FI5Ahl__.js +0 -1
- package/web-ui/build/static/fortran-C-jW3mxU.js +0 -1
- package/web-ui/build/static/fortran-zFBKdQax.js +0 -1
- package/web-ui/build/static/fsharp-Qu8P7ZfJ.js +0 -1
- package/web-ui/build/static/fsharp-gJT07_u6.js +0 -1
- package/web-ui/build/static/ftl-DcmD2jIl.js +0 -1
- package/web-ui/build/static/gams-BAhsVwik.js +0 -1
- package/web-ui/build/static/gap-DtjJMac5.js +0 -1
- package/web-ui/build/static/gauss-DLNJrvWH.js +0 -1
- package/web-ui/build/static/gcode-CbChIRHG.js +0 -1
- package/web-ui/build/static/gcode-lgPukEuS.js +0 -1
- package/web-ui/build/static/gdscript-ChdqKkXx.js +0 -1
- package/web-ui/build/static/gedcom-B3RAxWnR.js +0 -1
- package/web-ui/build/static/gherkin-BwKe4UMd.js +0 -1
- package/web-ui/build/static/gherkin-D1Q4xoY6.js +0 -1
- package/web-ui/build/static/git-CwA8K3Cg.js +0 -1
- package/web-ui/build/static/glsl-B_AtY5k6.js +0 -1
- package/web-ui/build/static/glsl-BgXyZa9x.js +0 -1
- package/web-ui/build/static/gml-O2ebFipB.js +0 -1
- package/web-ui/build/static/gml-xLusiP_j.js +0 -1
- package/web-ui/build/static/gn-T-uGKQLr.js +0 -1
- package/web-ui/build/static/go-B9spniuU.js +0 -1
- package/web-ui/build/static/go-DTwlbvuB.js +0 -1
- package/web-ui/build/static/go-module-DWCbGNjZ.js +0 -1
- package/web-ui/build/static/golo-Dp3ZC9Ry.js +0 -1
- package/web-ui/build/static/gradle-DxnYLs2J.js +0 -1
- package/web-ui/build/static/graphql-8stFQb3o.js +0 -1
- package/web-ui/build/static/groovy-Dbpy85Rs.js +0 -1
- package/web-ui/build/static/groovy-zimUQS73.js +0 -1
- package/web-ui/build/static/haml-B5gJAH_w.js +0 -1
- package/web-ui/build/static/haml-CXW3L0QY.js +0 -1
- package/web-ui/build/static/handlebars-BW92WxdN.js +0 -1
- package/web-ui/build/static/handlebars-DNysemQE.js +0 -1
- package/web-ui/build/static/haskell-BCP5M1h6.js +0 -1
- package/web-ui/build/static/haskell-BvSwVdJS.js +0 -1
- package/web-ui/build/static/haxe-BBVHLa1y.js +0 -1
- package/web-ui/build/static/haxe-DHK7XQB_.js +0 -1
- package/web-ui/build/static/hcl-CW0_ZJVS.js +0 -1
- package/web-ui/build/static/hlsl-DAH7B5KM.js +0 -1
- package/web-ui/build/static/hoon-CXY0i4p4.js +0 -1
- package/web-ui/build/static/hpkp-RL8DG2Fy.js +0 -1
- package/web-ui/build/static/hsp-DMAT8yb3.js +0 -1
- package/web-ui/build/static/hsts-SOCNnT21.js +0 -1
- package/web-ui/build/static/htmlbars-Bsrm5Qs8.js +0 -1
- package/web-ui/build/static/http-CYjIQwPj.js +0 -1
- package/web-ui/build/static/http-Hu8W9pON.js +0 -1
- package/web-ui/build/static/hy-CDbyyAxf.js +0 -1
- package/web-ui/build/static/ichigojam-CpPBjr7T.js +0 -1
- package/web-ui/build/static/icon-UI22EXz2.js +0 -1
- package/web-ui/build/static/icu-message-format-DAU066Wq.js +0 -1
- package/web-ui/build/static/idris-BuMEL37s.js +0 -1
- package/web-ui/build/static/iecst-CEqwKb_G.js +0 -1
- package/web-ui/build/static/ignore-CcCxTW7I.js +0 -1
- package/web-ui/build/static/index-C9Fa_kgD.css +0 -1
- package/web-ui/build/static/index-DexoK8pu.js +0 -834
- package/web-ui/build/static/index-DgeaGxMy.js +0 -13
- package/web-ui/build/static/index-RM91zq9j.js +0 -1
- package/web-ui/build/static/inform7-BdnukB1N.js +0 -1
- package/web-ui/build/static/inform7-Chkw-Df3.js +0 -1
- package/web-ui/build/static/ini--KUo0NJD.js +0 -1
- package/web-ui/build/static/ini-eo_rWFNv.js +0 -1
- package/web-ui/build/static/io-CWDVYxeI.js +0 -1
- package/web-ui/build/static/irpf90-CWFfmPjK.js +0 -1
- package/web-ui/build/static/isbl-BNkdk_dr.js +0 -1
- package/web-ui/build/static/j-Bg02P4UL.js +0 -1
- package/web-ui/build/static/java-BIDWcDHj.js +0 -1
- package/web-ui/build/static/java-D4bhM1sC.js +0 -1
- package/web-ui/build/static/javadoc-DxxfkSj4.js +0 -1
- package/web-ui/build/static/javadoclike-C3v2LXMS.js +0 -1
- package/web-ui/build/static/javascript-CSu6Pvd7.js +0 -1
- package/web-ui/build/static/javastacktrace-C50AqeNg.js +0 -1
- package/web-ui/build/static/jboss-cli-D4aAEeAL.js +0 -1
- package/web-ui/build/static/jexl-F8wyoUqO.js +0 -1
- package/web-ui/build/static/jolie-CdEDMXNQ.js +0 -1
- package/web-ui/build/static/jq-D95l3yQ0.js +0 -1
- package/web-ui/build/static/js-extras-55OlT8yf.js +0 -1
- package/web-ui/build/static/js-templates-4m7AkoaU.js +0 -1
- package/web-ui/build/static/jsdoc-BC6Ab1D0.js +0 -1
- package/web-ui/build/static/json-BHS2wD8g.js +0 -1
- package/web-ui/build/static/json-CPEJ9diH.js +0 -1
- package/web-ui/build/static/json5-EDQFzkuf.js +0 -1
- package/web-ui/build/static/jsonp-Cn_lpjaf.js +0 -1
- package/web-ui/build/static/jsstacktrace-pqdhqbKV.js +0 -1
- package/web-ui/build/static/jsx-Cop--oM_.js +0 -1
- package/web-ui/build/static/julia-B728rR99.js +0 -1
- package/web-ui/build/static/julia-Cq6vOawm.js +0 -1
- package/web-ui/build/static/julia-repl-BfOfjY_7.js +0 -1
- package/web-ui/build/static/keepalived-6ZwoBjFL.js +0 -1
- package/web-ui/build/static/keyman-DmOLCkH_.js +0 -1
- package/web-ui/build/static/kotlin-Bt385M6s.js +0 -1
- package/web-ui/build/static/kotlin-DsTE9me6.js +0 -1
- package/web-ui/build/static/kumir-DGpgb_2O.js +0 -1
- package/web-ui/build/static/kusto-Bb1U0J5m.js +0 -1
- package/web-ui/build/static/lasso-B4Rh4fa1.js +0 -1
- package/web-ui/build/static/latex-BlKwUVQO.js +0 -1
- package/web-ui/build/static/latex-D4EkT2Sx.js +0 -1
- package/web-ui/build/static/latte-8APUTRqH.js +0 -1
- package/web-ui/build/static/ldif-C1AH3r9Q.js +0 -1
- package/web-ui/build/static/leaf-DgHqqnCU.js +0 -1
- package/web-ui/build/static/less-BmLC9UX9.js +0 -1
- package/web-ui/build/static/less-D7wanA1u.js +0 -1
- package/web-ui/build/static/lilypond-CPpwdP3M.js +0 -1
- package/web-ui/build/static/liquid-C9g89s0-.js +0 -1
- package/web-ui/build/static/lisp-Ck1UA6zq.js +0 -1
- package/web-ui/build/static/lisp-tlR-SVFU.js +0 -1
- package/web-ui/build/static/livecodeserver-CfcVUDKK.js +0 -1
- package/web-ui/build/static/livescript-BPfp_PIe.js +0 -1
- package/web-ui/build/static/livescript-BVClM17E.js +0 -1
- package/web-ui/build/static/llvm-1CmNV1WZ.js +0 -1
- package/web-ui/build/static/llvm-DzaT3xf4.js +0 -1
- package/web-ui/build/static/log-x35sd55_.js +0 -1
- package/web-ui/build/static/lolcode-DfGz4a2C.js +0 -1
- package/web-ui/build/static/lsl-BJ13xzsn.js +0 -1
- package/web-ui/build/static/lua-DHTiU4iK.js +0 -1
- package/web-ui/build/static/lua-DttbbyOa.js +0 -1
- package/web-ui/build/static/magma-CM6u6Urv.js +0 -1
- package/web-ui/build/static/makefile--_TmwP5m.js +0 -1
- package/web-ui/build/static/makefile-DoB_xjMl.js +0 -1
- package/web-ui/build/static/markdown-BnyhT66e.js +0 -1
- package/web-ui/build/static/markdown-DvTREwgd.js +0 -1
- package/web-ui/build/static/markup-templating-yOvzgP3Z.js +0 -1
- package/web-ui/build/static/mathematica-BtY5tmVE.js +0 -1
- package/web-ui/build/static/matlab-DK98sDbn.js +0 -1
- package/web-ui/build/static/matlab-sBcSHRlC.js +0 -1
- package/web-ui/build/static/maxima-DMUOymL4.js +0 -1
- package/web-ui/build/static/maxscript-DaIC7eX6.js +0 -1
- package/web-ui/build/static/mel-BuONpgVc.js +0 -1
- package/web-ui/build/static/mel-Ckh0frDB.js +0 -1
- package/web-ui/build/static/mercury-CDFt4KAe.js +0 -1
- package/web-ui/build/static/mermaid-BqSA7Pr5.js +0 -1
- package/web-ui/build/static/mipsasm-Dj6mne2g.js +0 -1
- package/web-ui/build/static/mizar-CIQIQU-V.js +0 -1
- package/web-ui/build/static/mizar-CLTLHCGu.js +0 -1
- package/web-ui/build/static/mojolicious-DxjS7wDV.js +0 -1
- package/web-ui/build/static/mongodb-BAEipI91.js +0 -1
- package/web-ui/build/static/monkey-BBGnwc6s.js +0 -1
- package/web-ui/build/static/monkey-CvxTCuiS.js +0 -1
- package/web-ui/build/static/moonscript-CqDVk1K9.js +0 -1
- package/web-ui/build/static/moonscript-DJyxvZQc.js +0 -1
- package/web-ui/build/static/n1ql-AFWwB4Xn.js +0 -1
- package/web-ui/build/static/n1ql-VuVk9_MG.js +0 -1
- package/web-ui/build/static/n4js-BH6hpdgG.js +0 -1
- package/web-ui/build/static/nand2tetris-hdl-kVewh9V1.js +0 -1
- package/web-ui/build/static/naniscript-B_oQ4TiW.js +0 -1
- package/web-ui/build/static/nasm-B1_bJvcz.js +0 -1
- package/web-ui/build/static/neon-CbXfhQIm.js +0 -1
- package/web-ui/build/static/nevod-5Fv5cPWk.js +0 -1
- package/web-ui/build/static/nginx-BfifkBy-.js +0 -1
- package/web-ui/build/static/nginx-D9toNO0V.js +0 -1
- package/web-ui/build/static/nim-BFN2inD1.js +0 -1
- package/web-ui/build/static/nim-do_UhCvy.js +0 -1
- package/web-ui/build/static/nix-D6RLwwOZ.js +0 -1
- package/web-ui/build/static/nix-djoKaPeE.js +0 -1
- package/web-ui/build/static/node-repl-DDbffQSR.js +0 -1
- package/web-ui/build/static/nsis-BiO6b68i.js +0 -1
- package/web-ui/build/static/nsis-CHzeu7js.js +0 -1
- package/web-ui/build/static/objectivec-B7vXzYuT.js +0 -1
- package/web-ui/build/static/objectivec-BLn212SY.js +0 -1
- package/web-ui/build/static/ocaml-BvpR0Yig.js +0 -1
- package/web-ui/build/static/ocaml-DWZF00Ti.js +0 -1
- package/web-ui/build/static/opencl-C2K2Ctu5.js +0 -1
- package/web-ui/build/static/openqasm-Cbtnnn3m.js +0 -1
- package/web-ui/build/static/openscad-CEPC0-yW.js +0 -1
- package/web-ui/build/static/oxygene-KfcdTXi0.js +0 -1
- package/web-ui/build/static/oz-B-azwNjQ.js +0 -1
- package/web-ui/build/static/parigp-IWtYGphS.js +0 -1
- package/web-ui/build/static/parser-CUCdnJ6l.js +0 -1
- package/web-ui/build/static/parser3--a7jm4Uq.js +0 -1
- package/web-ui/build/static/pascal-BbezKExl.js +0 -1
- package/web-ui/build/static/pascaligo-Bd8IN8hq.js +0 -1
- package/web-ui/build/static/pcaxis-CfT0dd7B.js +0 -1
- package/web-ui/build/static/peoplecode-Dq29i2LW.js +0 -1
- package/web-ui/build/static/perl-BZLc5sMP.js +0 -1
- package/web-ui/build/static/perl-JJmLLJne.js +0 -1
- package/web-ui/build/static/pf-seOENy0q.js +0 -1
- package/web-ui/build/static/pgsql-BtkzXwKY.js +0 -1
- package/web-ui/build/static/php-8b9a1w98.js +0 -1
- package/web-ui/build/static/php-extras-5D00a1Fm.js +0 -1
- package/web-ui/build/static/php-imFv4WXA.js +0 -1
- package/web-ui/build/static/php-template-CI-0RdMu.js +0 -1
- package/web-ui/build/static/phpdoc-DdcPBfc-.js +0 -1
- package/web-ui/build/static/plaintext-Ca1WAvT6.js +0 -1
- package/web-ui/build/static/plsql-CZV7QAnN.js +0 -1
- package/web-ui/build/static/pony-DiomUkGt.js +0 -1
- package/web-ui/build/static/powerquery-CKXX2_O_.js +0 -1
- package/web-ui/build/static/powershell-2Ctsosr0.js +0 -1
- package/web-ui/build/static/powershell-DVPkgaB6.js +0 -1
- package/web-ui/build/static/processing-BAuxATGX.js +0 -1
- package/web-ui/build/static/processing-DBzyjRsf.js +0 -1
- package/web-ui/build/static/profile-Cq2gkRUb.js +0 -1
- package/web-ui/build/static/prolog-ByKO_5p_.js +0 -1
- package/web-ui/build/static/prolog-CDCLze6j.js +0 -1
- package/web-ui/build/static/promql-BYOPu10L.js +0 -1
- package/web-ui/build/static/properties-kP8T8mqV.js +0 -1
- package/web-ui/build/static/properties-zdANIr61.js +0 -1
- package/web-ui/build/static/protobuf-DhAYlNOg.js +0 -1
- package/web-ui/build/static/protobuf-a1lLQN1f.js +0 -1
- package/web-ui/build/static/psl-DpP1u6wu.js +0 -1
- package/web-ui/build/static/pug-BobY0hsa.js +0 -1
- package/web-ui/build/static/puppet-CDimLnep.js +0 -1
- package/web-ui/build/static/puppet-D7DLS3gG.js +0 -1
- package/web-ui/build/static/pure-4QGsilHw.js +0 -1
- package/web-ui/build/static/purebasic-D0wI4z6w.js +0 -1
- package/web-ui/build/static/purebasic-Du_RxI7h.js +0 -1
- package/web-ui/build/static/purescript-CM92Fn9c.js +0 -1
- package/web-ui/build/static/python-Bvcn81x2.js +0 -1
- package/web-ui/build/static/python-CkfwrdRF.js +0 -1
- package/web-ui/build/static/python-repl-C48-EfyF.js +0 -1
- package/web-ui/build/static/q-B2-zP3za.js +0 -1
- package/web-ui/build/static/q-KuKa9s_e.js +0 -1
- package/web-ui/build/static/qml-D8j38-Sx.js +0 -1
- package/web-ui/build/static/qml-DTP6fbZN.js +0 -1
- package/web-ui/build/static/qore-DY-n97IK.js +0 -1
- package/web-ui/build/static/qsharp-Mn8hUKww.js +0 -1
- package/web-ui/build/static/r-BBPYkuMA.js +0 -1
- package/web-ui/build/static/r-CheuVCRq.js +0 -1
- package/web-ui/build/static/racket-2UxWXIqI.js +0 -1
- package/web-ui/build/static/reason-CudKWaht.js +0 -1
- package/web-ui/build/static/reasonml-BDZgwPxq.js +0 -1
- package/web-ui/build/static/regex-DpKrn61Z.js +0 -1
- package/web-ui/build/static/rego-CS2iMzor.js +0 -1
- package/web-ui/build/static/renpy-0CbyBFae.js +0 -1
- package/web-ui/build/static/rest-Ckpz2bGS.js +0 -1
- package/web-ui/build/static/rib-g77eioCq.js +0 -1
- package/web-ui/build/static/rip-L-KlpyJn.js +0 -1
- package/web-ui/build/static/roboconf-BkNeb0Yn.js +0 -1
- package/web-ui/build/static/roboconf-CE-yfGxs.js +0 -1
- package/web-ui/build/static/robotframework-ZhLv32cH.js +0 -1
- package/web-ui/build/static/routeros-C_1I4hFK.js +0 -1
- package/web-ui/build/static/rsl-CxEYmrJa.js +0 -1
- package/web-ui/build/static/ruby-Cgxmv3hM.js +0 -1
- package/web-ui/build/static/ruby-Cs4qnUzE.js +0 -1
- package/web-ui/build/static/ruleslanguage-DPK5B1Dg.js +0 -1
- package/web-ui/build/static/rust-BbVN6hMu.js +0 -1
- package/web-ui/build/static/rust-C6MrX2UK.js +0 -1
- package/web-ui/build/static/sas-CGov9per.js +0 -1
- package/web-ui/build/static/sas-Cp88q4DD.js +0 -1
- package/web-ui/build/static/sass-COOJqQer.js +0 -1
- package/web-ui/build/static/scala-BvOmMtdv.js +0 -1
- package/web-ui/build/static/scala-D5gnz3xs.js +0 -1
- package/web-ui/build/static/scheme-CNBfxsvv.js +0 -1
- package/web-ui/build/static/scheme-DiKuURfA.js +0 -1
- package/web-ui/build/static/scilab-vGKouaTh.js +0 -1
- package/web-ui/build/static/scss-B4PKgroe.js +0 -1
- package/web-ui/build/static/scss-BvRxfJ1U.js +0 -1
- package/web-ui/build/static/shell-B5TooOs0.js +0 -1
- package/web-ui/build/static/shell-session-TNT_ahRW.js +0 -1
- package/web-ui/build/static/smali-CiIXEKzG.js +0 -1
- package/web-ui/build/static/smali-EGdSXgM9.js +0 -1
- package/web-ui/build/static/smalltalk-DVAXFBVS.js +0 -1
- package/web-ui/build/static/smalltalk-Dfy8hlRv.js +0 -1
- package/web-ui/build/static/smarty-Rc2y-rm6.js +0 -1
- package/web-ui/build/static/sml-BoYe_d8x.js +0 -1
- package/web-ui/build/static/sml-CaIv1GsI.js +0 -1
- package/web-ui/build/static/solidity-Dem-6tsD.js +0 -1
- package/web-ui/build/static/solution-file-DfDjJASp.js +0 -1
- package/web-ui/build/static/soy-CkrJH5eW.js +0 -1
- package/web-ui/build/static/sparql-Dvg1P5oN.js +0 -1
- package/web-ui/build/static/splunk-spl-rB2pJQdl.js +0 -1
- package/web-ui/build/static/sqf-Cj_KV-kC.js +0 -1
- package/web-ui/build/static/sqf-DA_tj5Fb.js +0 -1
- package/web-ui/build/static/sql-CYDE0gzH.js +0 -1
- package/web-ui/build/static/sql-D8byAq-B.js +0 -1
- package/web-ui/build/static/sql_more-bMORpicj.js +0 -1
- package/web-ui/build/static/squirrel-rgwbGN0q.js +0 -1
- package/web-ui/build/static/stan-C-OYiHTu.js +0 -1
- package/web-ui/build/static/stan-CT8cMsn7.js +0 -1
- package/web-ui/build/static/stata-BJwZeN-z.js +0 -1
- package/web-ui/build/static/step21-WP26kxkW.js +0 -1
- package/web-ui/build/static/stylus-Cw9up-Iv.js +0 -1
- package/web-ui/build/static/stylus-CyFEQpH2.js +0 -1
- package/web-ui/build/static/subunit-B2XhtaLx.js +0 -1
- package/web-ui/build/static/swift-Bpyyuvtg.js +0 -1
- package/web-ui/build/static/swift-D-jiKNlA.js +0 -1
- package/web-ui/build/static/systemd-DE3AeWrd.js +0 -1
- package/web-ui/build/static/t4-cs-BSG7rkB_.js +0 -1
- package/web-ui/build/static/t4-templating-Cy7LuqAv.js +0 -1
- package/web-ui/build/static/t4-vb-ZLfMjXrh.js +0 -1
- package/web-ui/build/static/taggerscript-q2zFfkel.js +0 -1
- package/web-ui/build/static/tap-CzjhWyhf.js +0 -1
- package/web-ui/build/static/tap-ttXfPums.js +0 -1
- package/web-ui/build/static/tcl-6ta1XDva.js +0 -1
- package/web-ui/build/static/tcl-Cvx4AN_Q.js +0 -1
- package/web-ui/build/static/textile-zWm4gRbJ.js +0 -1
- package/web-ui/build/static/thrift-Crj4hRsm.js +0 -1
- package/web-ui/build/static/toml-hVfLOJr-.js +0 -1
- package/web-ui/build/static/tp-D5aJh4yF.js +0 -1
- package/web-ui/build/static/tremor-B9gWC4v1.js +0 -1
- package/web-ui/build/static/tsx-DtNWBAJO.js +0 -1
- package/web-ui/build/static/tt2-eH1L7Bpm.js +0 -1
- package/web-ui/build/static/turtle-BYCk4r6f.js +0 -1
- package/web-ui/build/static/twig-BQ-dq4no.js +0 -1
- package/web-ui/build/static/twig-n3AiXKyV.js +0 -1
- package/web-ui/build/static/typescript-CPQ0vD90.js +0 -1
- package/web-ui/build/static/typescript-juxiNWRf.js +0 -1
- package/web-ui/build/static/typoscript-C5h9SqFN.js +0 -1
- package/web-ui/build/static/unrealscript-9ht7jiai.js +0 -1
- package/web-ui/build/static/uorazor-36B6okgA.js +0 -1
- package/web-ui/build/static/uri-DEwrtmz_.js +0 -1
- package/web-ui/build/static/v-CvhXAFWo.js +0 -1
- package/web-ui/build/static/vala-CU_jVQ3c.js +0 -1
- package/web-ui/build/static/vala-H_yoFBZf.js +0 -1
- package/web-ui/build/static/vbnet-BNI0Gy5q.js +0 -1
- package/web-ui/build/static/vbnet-D-4O1Hpc.js +0 -1
- package/web-ui/build/static/vbscript-1zyalaSG.js +0 -1
- package/web-ui/build/static/vbscript-html-ea5_TYi7.js +0 -1
- package/web-ui/build/static/velocity-BlEdS1Un.js +0 -1
- package/web-ui/build/static/verilog-BGSIJuDJ.js +0 -1
- package/web-ui/build/static/verilog-C1vff5Z3.js +0 -1
- package/web-ui/build/static/vhdl-5H4C8O-_.js +0 -1
- package/web-ui/build/static/vhdl-DHiBEhsE.js +0 -1
- package/web-ui/build/static/vim-Bd1MNlxj.js +0 -1
- package/web-ui/build/static/vim-DBP2ZsgQ.js +0 -1
- package/web-ui/build/static/visual-basic-DI34-9vJ.js +0 -1
- package/web-ui/build/static/warpscript-DBQ-KbS6.js +0 -1
- package/web-ui/build/static/wasm-CY5W57_Y.js +0 -1
- package/web-ui/build/static/web-idl-CF9xaLpZ.js +0 -1
- package/web-ui/build/static/wiki-xfSWwdeC.js +0 -1
- package/web-ui/build/static/wolfram-DZ6ghwRH.js +0 -1
- package/web-ui/build/static/wren-qULNE4ZV.js +0 -1
- package/web-ui/build/static/x86asm-DD2-d5-3.js +0 -1
- package/web-ui/build/static/xeora-CMja58lL.js +0 -1
- package/web-ui/build/static/xl-DKZpXGv8.js +0 -1
- package/web-ui/build/static/xml-Xf5ErmV_.js +0 -1
- package/web-ui/build/static/xml-doc-Bl_99SZE.js +0 -1
- package/web-ui/build/static/xojo-PwcPgmIF.js +0 -1
- package/web-ui/build/static/xquery-BshbqrZe.js +0 -1
- package/web-ui/build/static/xquery-DY2-GgvB.js +0 -1
- package/web-ui/build/static/yaml-9mp-mYjQ.js +0 -1
- package/web-ui/build/static/yaml-BnH4Y8-L.js +0 -1
- package/web-ui/build/static/yang-CRK7RS7V.js +0 -1
- package/web-ui/build/static/zephir-B560hCdS.js +0 -1
- package/web-ui/build/static/zig-CBG6H3iO.js +0 -1
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tests for empty-response diagnostic capture.
|
|
3
|
+
*
|
|
4
|
+
* When an AI response lands and our accumulator classifies it as "empty"
|
|
5
|
+
* (no content and no tool calls), the scheduler records a SHAPE SNAPSHOT
|
|
6
|
+
* of that response onto `_emptyResponseTracker[agentId].samples`. The
|
|
7
|
+
* /scheduler visualizer surfaces the last snapshot's `hint` as a subline
|
|
8
|
+
* under the Empties chip so an operator can tell WHY it was empty:
|
|
9
|
+
* tool-call-only turn (bridge bug), reasoning-only turn (streaming never
|
|
10
|
+
* reached text), content-filter, length, etc.
|
|
11
|
+
*
|
|
12
|
+
* These tests cover the classifier's hint logic and the per-agent
|
|
13
|
+
* ring-buffer (cap 3 samples) behavior. They do not exercise the full
|
|
14
|
+
* stall path — agentScheduler.test.js handles that.
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
import { jest, describe, test, expect, beforeEach } from '@jest/globals';
|
|
18
|
+
import { createMockLogger } from '../../__test-utils__/mockFactories.js';
|
|
19
|
+
|
|
20
|
+
// Silence activity service
|
|
21
|
+
const mockShouldAgentBeActive = jest.fn(() => ({ active: false, reason: 'idle' }));
|
|
22
|
+
const mockGetActiveAgents = jest.fn(() => []);
|
|
23
|
+
const mockShouldSkipIteration = jest.fn(() => false);
|
|
24
|
+
jest.unstable_mockModule('../../services/agentActivityService.js', () => ({
|
|
25
|
+
shouldAgentBeActive: mockShouldAgentBeActive,
|
|
26
|
+
getActiveAgents: mockGetActiveAgents,
|
|
27
|
+
shouldSkipIteration: mockShouldSkipIteration,
|
|
28
|
+
}));
|
|
29
|
+
|
|
30
|
+
const { default: AgentScheduler } = await import('../agentScheduler.js');
|
|
31
|
+
|
|
32
|
+
function makeScheduler() {
|
|
33
|
+
const logger = createMockLogger();
|
|
34
|
+
const agentPool = {
|
|
35
|
+
getAgent: jest.fn().mockResolvedValue(null),
|
|
36
|
+
getAllAgents: jest.fn().mockResolvedValue([]),
|
|
37
|
+
persistAgentState: jest.fn().mockResolvedValue(undefined),
|
|
38
|
+
getCompactionMetadata: jest.fn().mockResolvedValue(null),
|
|
39
|
+
getMessagesForAI: jest.fn().mockResolvedValue([]),
|
|
40
|
+
};
|
|
41
|
+
const messageProcessor = {};
|
|
42
|
+
const aiService = { abortRequest: jest.fn().mockReturnValue(false), getActiveRequest: () => null };
|
|
43
|
+
const scheduler = new AgentScheduler(agentPool, messageProcessor, aiService, logger);
|
|
44
|
+
return { scheduler, agentPool };
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
describe('_snapshotResponseShape', () => {
|
|
48
|
+
let scheduler;
|
|
49
|
+
beforeEach(() => {
|
|
50
|
+
jest.clearAllMocks();
|
|
51
|
+
({ scheduler } = makeScheduler());
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
test('null / undefined response produces a null-content snapshot with a clear hint', () => {
|
|
55
|
+
const s = scheduler._snapshotResponseShape(null);
|
|
56
|
+
expect(s.contentType).toBe('null');
|
|
57
|
+
expect(s.contentLength).toBe(0);
|
|
58
|
+
expect(s.hint).toMatch(/null\/undefined/);
|
|
59
|
+
});
|
|
60
|
+
|
|
61
|
+
test('string content measures length correctly', () => {
|
|
62
|
+
const s = scheduler._snapshotResponseShape({ content: 'hello world' });
|
|
63
|
+
expect(s.contentType).toBe('string');
|
|
64
|
+
expect(s.contentLength).toBe(11);
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
test('array content (Responses API shape) sums text-part lengths', () => {
|
|
68
|
+
const s = scheduler._snapshotResponseShape({
|
|
69
|
+
content: [{ type: 'text', text: 'hi ' }, { type: 'text', text: 'there' }],
|
|
70
|
+
});
|
|
71
|
+
expect(s.contentType).toBe('array');
|
|
72
|
+
expect(s.contentLength).toBe(8);
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
test('tool-call-only turn (content null + toolCalls present) → bridge-gap hint', () => {
|
|
76
|
+
const s = scheduler._snapshotResponseShape({
|
|
77
|
+
content: null,
|
|
78
|
+
toolCalls: [{ id: 'call_1', function: { name: 'x', arguments: '{}' } }],
|
|
79
|
+
});
|
|
80
|
+
expect(s.hasToolCalls).toBe(true);
|
|
81
|
+
expect(s.toolCallCount).toBe(1);
|
|
82
|
+
expect(s.hint).toMatch(/Tool-call-only turn/);
|
|
83
|
+
expect(s.hint).toMatch(/Chat Completions bridge gap/);
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
test('snake_case tool_calls also detected (OpenAI raw shape)', () => {
|
|
87
|
+
const s = scheduler._snapshotResponseShape({
|
|
88
|
+
content: '',
|
|
89
|
+
tool_calls: [{ id: 'a' }, { id: 'b' }],
|
|
90
|
+
});
|
|
91
|
+
expect(s.hasToolCalls).toBe(true);
|
|
92
|
+
expect(s.toolCallCount).toBe(2);
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
test('reasoning-only turn (empty content + reasoning field) → reasoning-only hint', () => {
|
|
96
|
+
const s = scheduler._snapshotResponseShape({
|
|
97
|
+
content: '',
|
|
98
|
+
reasoning: 'long chain of thought...',
|
|
99
|
+
});
|
|
100
|
+
expect(s.hasReasoning).toBe(true);
|
|
101
|
+
expect(s.hint).toMatch(/Reasoning-only turn/);
|
|
102
|
+
expect(s.hint).toMatch(/output_text/);
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
test('reasoning detected when content is an array with a reasoning part', () => {
|
|
106
|
+
const s = scheduler._snapshotResponseShape({
|
|
107
|
+
content: [{ type: 'reasoning', text: '…' }],
|
|
108
|
+
});
|
|
109
|
+
expect(s.hasReasoning).toBe(true);
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
test('finish_reason content_filter → safety-filter hint', () => {
|
|
113
|
+
const s = scheduler._snapshotResponseShape({
|
|
114
|
+
content: '',
|
|
115
|
+
finish_reason: 'content_filter',
|
|
116
|
+
});
|
|
117
|
+
expect(s.hint).toMatch(/content filter/i);
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
test('finish_reason length → max_tokens hint', () => {
|
|
121
|
+
const s = scheduler._snapshotResponseShape({
|
|
122
|
+
content: '',
|
|
123
|
+
finishReason: 'length',
|
|
124
|
+
});
|
|
125
|
+
expect(s.hint).toMatch(/max_tokens/);
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
test('clean stop with empty content → silent-rejection hint', () => {
|
|
129
|
+
const s = scheduler._snapshotResponseShape({
|
|
130
|
+
content: '',
|
|
131
|
+
finishReason: 'stop',
|
|
132
|
+
});
|
|
133
|
+
expect(s.hint).toMatch(/silent prompt-rejection|context-limit|upstream timeout/);
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
test('unknown-shape fallback hint is present', () => {
|
|
137
|
+
const s = scheduler._snapshotResponseShape({ content: '' });
|
|
138
|
+
expect(s.hint).toMatch(/unclear|inspect raw/);
|
|
139
|
+
});
|
|
140
|
+
|
|
141
|
+
test('does not leak content body — only metadata', () => {
|
|
142
|
+
const s = scheduler._snapshotResponseShape({
|
|
143
|
+
content: 'a very secret payload that must not appear in /scheduler or logs',
|
|
144
|
+
});
|
|
145
|
+
expect(JSON.stringify(s)).not.toContain('secret payload');
|
|
146
|
+
});
|
|
147
|
+
});
|
|
148
|
+
|
|
149
|
+
describe('_trackEmptyResponse + samples ring buffer', () => {
|
|
150
|
+
let scheduler, agentPool;
|
|
151
|
+
beforeEach(() => {
|
|
152
|
+
jest.clearAllMocks();
|
|
153
|
+
({ scheduler, agentPool } = makeScheduler());
|
|
154
|
+
const agent = { id: 'a1', name: 'A', mode: 'agent', conversations: { full: { messages: [] } } };
|
|
155
|
+
agentPool.getAgent.mockResolvedValue(agent);
|
|
156
|
+
});
|
|
157
|
+
|
|
158
|
+
test('records a sample snapshot on each empty-response cycle', async () => {
|
|
159
|
+
await scheduler._trackEmptyResponse('a1', { content: '' });
|
|
160
|
+
const entry = scheduler._emptyResponseTracker.get('a1');
|
|
161
|
+
expect(entry.samples).toHaveLength(1);
|
|
162
|
+
expect(entry.samples[0].contentType).toBe('string');
|
|
163
|
+
expect(entry.samples[0].hint).toBeDefined();
|
|
164
|
+
});
|
|
165
|
+
|
|
166
|
+
test('samples ring buffer caps at 3 entries', async () => {
|
|
167
|
+
for (let i = 0; i < 5; i++) {
|
|
168
|
+
await scheduler._trackEmptyResponse('a1', { content: `sample-${i}` });
|
|
169
|
+
}
|
|
170
|
+
const entry = scheduler._emptyResponseTracker.get('a1');
|
|
171
|
+
// Note: threshold may have fired and cleared the tracker — we only get
|
|
172
|
+
// here if the tracker survives. Either way, the ring buffer's cap is
|
|
173
|
+
// the contract we want to lock.
|
|
174
|
+
if (entry) expect(entry.samples.length).toBeLessThanOrEqual(3);
|
|
175
|
+
});
|
|
176
|
+
|
|
177
|
+
test('missing aiResponse is tolerated (null-safe snapshot)', async () => {
|
|
178
|
+
await scheduler._trackEmptyResponse('a1', null);
|
|
179
|
+
const entry = scheduler._emptyResponseTracker.get('a1');
|
|
180
|
+
expect(entry.samples[0].contentType).toBe('null');
|
|
181
|
+
});
|
|
182
|
+
|
|
183
|
+
test('samples carry over from previous cycles on same agent', async () => {
|
|
184
|
+
await scheduler._trackEmptyResponse('a1', { content: '' });
|
|
185
|
+
await scheduler._trackEmptyResponse('a1', { content: null, toolCalls: [{ id: 'x' }] });
|
|
186
|
+
const entry = scheduler._emptyResponseTracker.get('a1');
|
|
187
|
+
expect(entry.count).toBe(2);
|
|
188
|
+
expect(entry.samples).toHaveLength(2);
|
|
189
|
+
expect(entry.samples[1].hasToolCalls).toBe(true);
|
|
190
|
+
});
|
|
191
|
+
});
|
|
@@ -0,0 +1,233 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tests for the mode-transition history surface on AgentScheduler.
|
|
3
|
+
*
|
|
4
|
+
* The scheduler owns the ring buffer (`_modeTransitionHistory`) and exposes
|
|
5
|
+
* two entry points:
|
|
6
|
+
*
|
|
7
|
+
* - `recordModeTransition(agentId, from, to, reasonCode, detail)`
|
|
8
|
+
* Bookkeeping only — no mutation, no persist, no broadcast. Called by
|
|
9
|
+
* agentPool.updateAgent when an external flip happens (UI toggle, etc.).
|
|
10
|
+
*
|
|
11
|
+
* - `_transitionMode(agentId, to, reasonCode, detail)`
|
|
12
|
+
* End-to-end — mutates agent.mode, pushes transcript message (if any),
|
|
13
|
+
* persists via agentPool, broadcasts two events. Used by the scheduler's
|
|
14
|
+
* own protective flips (user stop, AI timeout, empty stall, loop).
|
|
15
|
+
*
|
|
16
|
+
* Tests exercise both without a real agent pool — a minimal mock pool is
|
|
17
|
+
* plenty to lock the contract. The point here is "bookkeeping correctness
|
|
18
|
+
* and broadcast shape", not agent lifecycle.
|
|
19
|
+
*/
|
|
20
|
+
|
|
21
|
+
import { jest, describe, test, expect, beforeEach } from '@jest/globals';
|
|
22
|
+
import { createMockLogger } from '../../__test-utils__/mockFactories.js';
|
|
23
|
+
import AgentScheduler from '../agentScheduler.js';
|
|
24
|
+
import { AGENT_MODES } from '../../utilities/constants.js';
|
|
25
|
+
|
|
26
|
+
function makeScheduler(opts = {}) {
|
|
27
|
+
const broadcastToSession = jest.fn();
|
|
28
|
+
const webSocketManager = { broadcastToSession };
|
|
29
|
+
const persistAgentState = jest.fn().mockResolvedValue(undefined);
|
|
30
|
+
const broadcastAgentStateUpdate = jest.fn().mockResolvedValue(undefined);
|
|
31
|
+
const agent = opts.agent || {
|
|
32
|
+
id: 'a1', name: 'A', mode: AGENT_MODES.AGENT,
|
|
33
|
+
sessionId: 's1', conversations: { full: { messages: [] } },
|
|
34
|
+
};
|
|
35
|
+
const agentPool = {
|
|
36
|
+
getAgent: jest.fn().mockImplementation(id => Promise.resolve(id === agent.id ? agent : null)),
|
|
37
|
+
getAllAgents: jest.fn().mockResolvedValue([agent]),
|
|
38
|
+
persistAgentState,
|
|
39
|
+
getCompactionMetadata: jest.fn().mockResolvedValue(null),
|
|
40
|
+
getMessagesForAI: jest.fn().mockResolvedValue([]),
|
|
41
|
+
};
|
|
42
|
+
const messageProcessor = {
|
|
43
|
+
extractAndExecuteTools: jest.fn().mockResolvedValue([]),
|
|
44
|
+
extractToolCommands: jest.fn().mockResolvedValue([]),
|
|
45
|
+
};
|
|
46
|
+
const aiService = {
|
|
47
|
+
sendMessage: jest.fn().mockResolvedValue({ content: 'x', tokenUsage: {} }),
|
|
48
|
+
abortRequest: jest.fn().mockReturnValue(false),
|
|
49
|
+
getActiveRequest: jest.fn().mockReturnValue(null),
|
|
50
|
+
};
|
|
51
|
+
// Actual constructor signature: (agentPool, messageProcessor, aiService, logger, webSocketManager, ...)
|
|
52
|
+
const scheduler = new AgentScheduler(agentPool, messageProcessor, aiService,
|
|
53
|
+
createMockLogger(), webSocketManager);
|
|
54
|
+
// broadcastAgentStateUpdate is a real method on the scheduler that does UI
|
|
55
|
+
// broadcasts — stub it so tests can focus on the agent_mode_changed event
|
|
56
|
+
// shape without caring about the canonical-state event's wiring.
|
|
57
|
+
scheduler.broadcastAgentStateUpdate = broadcastAgentStateUpdate;
|
|
58
|
+
// Pretend we have a session map so the broadcast finds a target.
|
|
59
|
+
scheduler.registerAgentSession(agent.id, agent.sessionId);
|
|
60
|
+
return { scheduler, agent, agentPool, webSocketManager, broadcastToSession,
|
|
61
|
+
persistAgentState, broadcastAgentStateUpdate };
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
describe('AgentScheduler.recordModeTransition', () => {
|
|
65
|
+
test('appends an entry with timestamp + human reason', () => {
|
|
66
|
+
const { scheduler } = makeScheduler();
|
|
67
|
+
scheduler.recordModeTransition('a1', 'agent', 'chat', 'user-stop');
|
|
68
|
+
|
|
69
|
+
const history = scheduler._modeTransitionHistory.get('a1');
|
|
70
|
+
expect(history).toHaveLength(1);
|
|
71
|
+
expect(history[0]).toMatchObject({
|
|
72
|
+
from: 'agent',
|
|
73
|
+
to: 'chat',
|
|
74
|
+
reasonCode: 'user-stop',
|
|
75
|
+
humanReason: 'Stopped by user.',
|
|
76
|
+
});
|
|
77
|
+
expect(new Date(history[0].at).getTime()).not.toBeNaN();
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
test('interpolates detail into the human reason', () => {
|
|
81
|
+
const { scheduler } = makeScheduler();
|
|
82
|
+
scheduler.recordModeTransition('a1', 'agent', 'chat', 'empty-response-stall',
|
|
83
|
+
{ count: 5, elapsedSec: 57 });
|
|
84
|
+
|
|
85
|
+
const entry = scheduler._modeTransitionHistory.get('a1')[0];
|
|
86
|
+
expect(entry.humanReason).toBe(
|
|
87
|
+
'The model returned 5 empty responses in a row over 57s — likely rate-limited, misconfigured, or rejecting the conversation. Switched to Guided Chat.'
|
|
88
|
+
);
|
|
89
|
+
expect(entry.detail).toEqual({ count: 5, elapsedSec: 57 });
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
test('no-op when from === to (prevents phantom same-mode entries)', () => {
|
|
93
|
+
const { scheduler } = makeScheduler();
|
|
94
|
+
scheduler.recordModeTransition('a1', 'chat', 'chat', 'user-toggle');
|
|
95
|
+
expect(scheduler._modeTransitionHistory.get('a1')).toBeUndefined();
|
|
96
|
+
});
|
|
97
|
+
|
|
98
|
+
test('no-op when agentId is missing', () => {
|
|
99
|
+
const { scheduler } = makeScheduler();
|
|
100
|
+
scheduler.recordModeTransition('', 'agent', 'chat', 'user-stop');
|
|
101
|
+
scheduler.recordModeTransition(null, 'agent', 'chat', 'user-stop');
|
|
102
|
+
expect(scheduler._modeTransitionHistory.size).toBe(0);
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
test('ring buffer trims to MAX_PER_AGENT', () => {
|
|
106
|
+
const { scheduler } = makeScheduler();
|
|
107
|
+
const MAX = scheduler._MODE_TRANSITION_HISTORY_MAX_PER_AGENT;
|
|
108
|
+
for (let i = 0; i < MAX + 10; i++) {
|
|
109
|
+
// Alternate direction so from !== to every time.
|
|
110
|
+
scheduler.recordModeTransition('a1',
|
|
111
|
+
i % 2 === 0 ? 'agent' : 'chat',
|
|
112
|
+
i % 2 === 0 ? 'chat' : 'agent',
|
|
113
|
+
'user-toggle');
|
|
114
|
+
}
|
|
115
|
+
expect(scheduler._modeTransitionHistory.get('a1')).toHaveLength(MAX);
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
test('stores null detail when none provided (avoids empty-object noise)', () => {
|
|
119
|
+
const { scheduler } = makeScheduler();
|
|
120
|
+
scheduler.recordModeTransition('a1', 'agent', 'chat', 'user-stop');
|
|
121
|
+
expect(scheduler._modeTransitionHistory.get('a1')[0].detail).toBeNull();
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
test('unknown reason codes still produce a readable humanReason (no bare symbol)', () => {
|
|
125
|
+
const { scheduler } = makeScheduler();
|
|
126
|
+
scheduler.recordModeTransition('a1', 'agent', 'chat', 'some-future-code');
|
|
127
|
+
const entry = scheduler._modeTransitionHistory.get('a1')[0];
|
|
128
|
+
expect(entry.humanReason).toBe('Mode change (some future code).');
|
|
129
|
+
});
|
|
130
|
+
});
|
|
131
|
+
|
|
132
|
+
describe('AgentScheduler._transitionMode', () => {
|
|
133
|
+
test('mutates agent.mode, records transition, persists, and broadcasts', async () => {
|
|
134
|
+
const { scheduler, agent, persistAgentState, broadcastToSession,
|
|
135
|
+
broadcastAgentStateUpdate } = makeScheduler();
|
|
136
|
+
|
|
137
|
+
const changed = await scheduler._transitionMode('a1', AGENT_MODES.CHAT, 'user-stop');
|
|
138
|
+
|
|
139
|
+
expect(changed).toBe(true);
|
|
140
|
+
expect(agent.mode).toBe(AGENT_MODES.CHAT);
|
|
141
|
+
expect(persistAgentState).toHaveBeenCalledWith('a1');
|
|
142
|
+
expect(broadcastAgentStateUpdate).toHaveBeenCalledWith('a1', 'user-stop');
|
|
143
|
+
|
|
144
|
+
// Find the agent_mode_changed broadcast
|
|
145
|
+
const modeEvent = broadcastToSession.mock.calls
|
|
146
|
+
.find(c => c[1].type === 'agent_mode_changed');
|
|
147
|
+
expect(modeEvent).toBeDefined();
|
|
148
|
+
expect(modeEvent[1].data).toMatchObject({
|
|
149
|
+
agentId: 'a1',
|
|
150
|
+
mode: AGENT_MODES.CHAT,
|
|
151
|
+
reason: 'user-stop', // back-compat symbolic
|
|
152
|
+
humanReason: 'Stopped by user.', // new natural-language field
|
|
153
|
+
});
|
|
154
|
+
|
|
155
|
+
// Ring buffer records the flip
|
|
156
|
+
expect(scheduler._modeTransitionHistory.get('a1')).toHaveLength(1);
|
|
157
|
+
});
|
|
158
|
+
|
|
159
|
+
test('transcriptMessage is pushed into conversations.full and broadcast as message_added', async () => {
|
|
160
|
+
const { scheduler, agent, broadcastToSession } = makeScheduler();
|
|
161
|
+
|
|
162
|
+
const msg = {
|
|
163
|
+
id: 'm-1', role: 'assistant', content: 'Stalled.',
|
|
164
|
+
timestamp: new Date().toISOString(),
|
|
165
|
+
};
|
|
166
|
+
await scheduler._transitionMode('a1', AGENT_MODES.CHAT, 'empty-response-stall',
|
|
167
|
+
{ count: 5, elapsedSec: 57, transcriptMessage: msg });
|
|
168
|
+
|
|
169
|
+
// Conversation got the bubble
|
|
170
|
+
expect(agent.conversations.full.messages).toHaveLength(1);
|
|
171
|
+
expect(agent.conversations.full.messages[0].id).toBe('m-1');
|
|
172
|
+
|
|
173
|
+
// transcriptMessage was excluded from the saved detail
|
|
174
|
+
const entry = scheduler._modeTransitionHistory.get('a1')[0];
|
|
175
|
+
expect(entry.detail).toEqual({ count: 5, elapsedSec: 57 });
|
|
176
|
+
expect(entry.detail.transcriptMessage).toBeUndefined();
|
|
177
|
+
|
|
178
|
+
// message_added broadcast fired
|
|
179
|
+
const msgEvent = broadcastToSession.mock.calls
|
|
180
|
+
.find(c => c[1].type === 'message_added');
|
|
181
|
+
expect(msgEvent).toBeDefined();
|
|
182
|
+
expect(msgEvent[1].data.message.id).toBe('m-1');
|
|
183
|
+
expect(msgEvent[1].data.type).toBe('empty-response-stall');
|
|
184
|
+
});
|
|
185
|
+
|
|
186
|
+
test('no-op (returns false) when agent is already in the target mode', async () => {
|
|
187
|
+
const { scheduler, persistAgentState } = makeScheduler();
|
|
188
|
+
const changed = await scheduler._transitionMode('a1', AGENT_MODES.AGENT, 'user-toggle');
|
|
189
|
+
expect(changed).toBe(false);
|
|
190
|
+
expect(persistAgentState).not.toHaveBeenCalled();
|
|
191
|
+
expect(scheduler._modeTransitionHistory.size).toBe(0);
|
|
192
|
+
});
|
|
193
|
+
|
|
194
|
+
test('returns false when agent does not exist', async () => {
|
|
195
|
+
const { scheduler, persistAgentState } = makeScheduler();
|
|
196
|
+
const changed = await scheduler._transitionMode('nonexistent', AGENT_MODES.CHAT, 'user-stop');
|
|
197
|
+
expect(changed).toBe(false);
|
|
198
|
+
expect(persistAgentState).not.toHaveBeenCalled();
|
|
199
|
+
});
|
|
200
|
+
|
|
201
|
+
test('persistence failure does NOT crash the flip (mode still mutated)', async () => {
|
|
202
|
+
const { scheduler, agent, persistAgentState } = makeScheduler();
|
|
203
|
+
persistAgentState.mockRejectedValueOnce(new Error('disk full'));
|
|
204
|
+
|
|
205
|
+
const changed = await scheduler._transitionMode('a1', AGENT_MODES.CHAT, 'user-stop');
|
|
206
|
+
expect(changed).toBe(true);
|
|
207
|
+
expect(agent.mode).toBe(AGENT_MODES.CHAT);
|
|
208
|
+
expect(scheduler._modeTransitionHistory.get('a1')).toHaveLength(1);
|
|
209
|
+
});
|
|
210
|
+
});
|
|
211
|
+
|
|
212
|
+
describe('AgentScheduler.getState — surfaces modeTransitions per agent', () => {
|
|
213
|
+
test('agent row includes the last N transitions', async () => {
|
|
214
|
+
const { scheduler } = makeScheduler();
|
|
215
|
+
scheduler.recordModeTransition('a1', 'agent', 'chat', 'empty-response-stall',
|
|
216
|
+
{ count: 5, elapsedSec: 57 });
|
|
217
|
+
scheduler.recordModeTransition('a1', 'chat', 'agent', 'user-toggle');
|
|
218
|
+
|
|
219
|
+
const state = await scheduler.getState();
|
|
220
|
+
expect(state.agents).toHaveLength(1);
|
|
221
|
+
expect(state.agents[0].modeTransitions).toHaveLength(2);
|
|
222
|
+
expect(state.agents[0].modeTransitions[0].reasonCode).toBe('empty-response-stall');
|
|
223
|
+
expect(state.agents[0].modeTransitions[1].reasonCode).toBe('user-toggle');
|
|
224
|
+
// humanReason is already interpolated — the frontend can render verbatim
|
|
225
|
+
expect(state.agents[0].modeTransitions[0].humanReason).toContain('5 empty responses');
|
|
226
|
+
});
|
|
227
|
+
|
|
228
|
+
test('agent with no transitions reports an empty array (not undefined)', async () => {
|
|
229
|
+
const { scheduler } = makeScheduler();
|
|
230
|
+
const state = await scheduler.getState();
|
|
231
|
+
expect(state.agents[0].modeTransitions).toEqual([]);
|
|
232
|
+
});
|
|
233
|
+
});
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Contract test for the AGENT-mode TaskManager instruction that
|
|
3
|
+
* agentScheduler injects into every system prompt on an agent-mode turn.
|
|
4
|
+
*
|
|
5
|
+
* The instruction and the tool's getDescription() (see
|
|
6
|
+
* tools/__tests__/taskManagerTool.lifecycleGuidance.test.js) must agree
|
|
7
|
+
* on the lifecycle — if they drift, the agent gets conflicting guidance
|
|
8
|
+
* and reverts to whichever one the model's attention happens to anchor
|
|
9
|
+
* on, which in practice is the older, shorter one. Both tripwires
|
|
10
|
+
* together lock the contract end-to-end.
|
|
11
|
+
*
|
|
12
|
+
* The assertions are keyword-level and case-insensitive so wording can
|
|
13
|
+
* evolve without breaking the test — but the underlying concepts
|
|
14
|
+
* (sync-first, in_progress → completed, jobdone at the end) must stay
|
|
15
|
+
* named.
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
import { jest, describe, test, expect } from '@jest/globals';
|
|
19
|
+
|
|
20
|
+
// Read the scheduler source file directly and grep for the instruction
|
|
21
|
+
// string. Importing the class would drag the whole compaction / AI /
|
|
22
|
+
// websocket stack along for a plain-text check, which is wasteful.
|
|
23
|
+
import { readFileSync } from 'fs';
|
|
24
|
+
import { fileURLToPath } from 'url';
|
|
25
|
+
import { dirname, join } from 'path';
|
|
26
|
+
|
|
27
|
+
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
28
|
+
const SCHEDULER_SRC = readFileSync(
|
|
29
|
+
join(__dirname, '../agentScheduler.js'),
|
|
30
|
+
'utf-8'
|
|
31
|
+
);
|
|
32
|
+
|
|
33
|
+
describe('agentScheduler AGENT-mode TaskManager instruction — lifecycle contract', () => {
|
|
34
|
+
// Locate the instruction literal. It starts with "IMPORTANT: You are in
|
|
35
|
+
// AGENT mode" and is followed by the lifecycle guidance block.
|
|
36
|
+
const startIdx = SCHEDULER_SRC.indexOf('IMPORTANT: You are in AGENT mode');
|
|
37
|
+
const endIdx = SCHEDULER_SRC.indexOf('enhancedSystemPrompt = (agent.systemPrompt',
|
|
38
|
+
startIdx + 1);
|
|
39
|
+
const instruction = SCHEDULER_SRC.slice(startIdx, endIdx);
|
|
40
|
+
|
|
41
|
+
const has = (needle) => expect(instruction).toMatch(new RegExp(needle, 'i'));
|
|
42
|
+
|
|
43
|
+
test('the instruction block was located in the source', () => {
|
|
44
|
+
expect(startIdx).toBeGreaterThan(-1);
|
|
45
|
+
expect(instruction.length).toBeGreaterThan(100);
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
test('names TASK LIFECYCLE up front', () => {
|
|
49
|
+
has('TASK LIFECYCLE');
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
test('first call must be sync, not per-task create', () => {
|
|
53
|
+
has('FIRST TaskManager call must be');
|
|
54
|
+
has('sync');
|
|
55
|
+
has("Don't `create` tasks one at a time");
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
test('per-step pattern: in_progress → do work → completed', () => {
|
|
59
|
+
has('in_progress');
|
|
60
|
+
has('completed');
|
|
61
|
+
has('one at a time');
|
|
62
|
+
});
|
|
63
|
+
|
|
64
|
+
test('mid-flight refinement allowed via create or sync', () => {
|
|
65
|
+
has('`create`');
|
|
66
|
+
has('`sync`');
|
|
67
|
+
has("Don't `sync` every turn");
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
test('jobdone is the terminal action', () => {
|
|
71
|
+
has('jobdone');
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
test('preserves the agent-mode behavioral constraints (no thank-yous, etc.)', () => {
|
|
75
|
+
has("no thank-you");
|
|
76
|
+
has('no self-commentary');
|
|
77
|
+
});
|
|
78
|
+
});
|
|
@@ -256,19 +256,27 @@ describe('AgentScheduler', () => {
|
|
|
256
256
|
|
|
257
257
|
// ─── handleRepetitiveLoop ──────────────────────────────────────────────
|
|
258
258
|
describe('handleRepetitiveLoop', () => {
|
|
259
|
-
test('switches agent to chat mode
|
|
260
|
-
|
|
259
|
+
test('switches agent to chat mode without polluting the chat transcript', async () => {
|
|
260
|
+
// Loop detection is a system event, not conversation content. The mode
|
|
261
|
+
// flip is the action; the humanReason is surfaced via the
|
|
262
|
+
// `agent_mode_changed` broadcast so the UI can render a toast /
|
|
263
|
+
// notification-center entry. NO transcript bubble is added (previous
|
|
264
|
+
// behavior tripled-posted the same "I notice I've been producing
|
|
265
|
+
// similar responses..." text every time the loop tripped).
|
|
266
|
+
const agent = makeAgent({ id: 'agent-loop', mode: 'agent' });
|
|
261
267
|
agentPool.getAgent.mockResolvedValue(agent);
|
|
262
268
|
|
|
263
269
|
await scheduler.handleRepetitiveLoop('agent-loop', { occurrences: 5, windowSize: 20 });
|
|
264
270
|
|
|
265
271
|
expect(agent.mode).toBe('chat');
|
|
266
|
-
expect(agent.conversations.full.messages.length).toBe(
|
|
267
|
-
const msg = agent.conversations.full.messages[0];
|
|
268
|
-
expect(msg.role).toBe('assistant');
|
|
269
|
-
expect(msg.content).toContain('similar responses repeatedly');
|
|
270
|
-
expect(msg.loopDetection.occurrences).toBe(5);
|
|
272
|
+
expect(agent.conversations.full.messages.length).toBe(0); // no chat bubble
|
|
271
273
|
expect(agentPool.persistAgentState).toHaveBeenCalledWith('agent-loop');
|
|
274
|
+
|
|
275
|
+
// Mode transition was recorded with a human-readable reason.
|
|
276
|
+
const history = scheduler._modeTransitionHistory.get('agent-loop');
|
|
277
|
+
expect(history).toHaveLength(1);
|
|
278
|
+
expect(history[0].reasonCode).toBe('loop-detected');
|
|
279
|
+
expect(history[0].humanReason).toMatch(/repeated 5 times in a 20-step window/);
|
|
272
280
|
});
|
|
273
281
|
|
|
274
282
|
test('clears hash history after handling', async () => {
|
|
@@ -288,7 +296,8 @@ describe('AgentScheduler', () => {
|
|
|
288
296
|
});
|
|
289
297
|
|
|
290
298
|
test('broadcasts to websocket if available', async () => {
|
|
291
|
-
|
|
299
|
+
// See sibling test — needs mode:'agent' so the flip is a real transition.
|
|
300
|
+
const agent = makeAgent({ id: 'agent-loop', mode: 'agent', sessionId: 'sess-abc' });
|
|
292
301
|
agentPool.getAgent.mockResolvedValue(agent);
|
|
293
302
|
const ws = { broadcastToSession: jest.fn() };
|
|
294
303
|
scheduler.webSocketManager = ws;
|
|
@@ -403,11 +412,20 @@ describe('AgentScheduler', () => {
|
|
|
403
412
|
|
|
404
413
|
expect(agent.mode).toBe('chat');
|
|
405
414
|
expect(scheduler._emptyResponseTracker.has('agent-empty')).toBe(false);
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
415
|
+
|
|
416
|
+
// NO chat-transcript bubble — the stall is surfaced via the
|
|
417
|
+
// `agent_mode_changed` broadcast's `humanReason`, not a fake
|
|
418
|
+
// assistant message in the conversation. Previously every stall
|
|
419
|
+
// posted the same "I've switched to chat mode" paragraph into the
|
|
420
|
+
// feed, which operators (reasonably) complained about.
|
|
421
|
+
expect(agent.conversations.full.messages.length).toBe(0);
|
|
422
|
+
|
|
423
|
+
// The transition, however, is recorded with count + elapsedSec
|
|
424
|
+
// interpolated into the human reason.
|
|
425
|
+
const history = scheduler._modeTransitionHistory.get('agent-empty');
|
|
426
|
+
expect(history).toHaveLength(1);
|
|
427
|
+
expect(history[0].reasonCode).toBe('empty-response-stall');
|
|
428
|
+
expect(history[0].humanReason).toMatch(/5 empty responses/);
|
|
411
429
|
});
|
|
412
430
|
|
|
413
431
|
test('stall handler is crash-safe when persist throws', async () => {
|
|
@@ -454,6 +454,48 @@ describe('MessageProcessor', () => {
|
|
|
454
454
|
const toolContext = mockTool.execute.mock.calls[0][1];
|
|
455
455
|
expect(toolContext.projectDir).toBe('/custom/dir');
|
|
456
456
|
});
|
|
457
|
+
|
|
458
|
+
// Per-agent tool config passthrough — see agentPool `toolConfig`
|
|
459
|
+
// schema and BaseTool#getEffectiveConfig. These tests lock the
|
|
460
|
+
// message-processor side of the plumbing: the correct slice of
|
|
461
|
+
// agent.toolConfig must land on the tool execution context.
|
|
462
|
+
test('passes agent.toolConfig[toolId] to the tool as context.toolConfig', async () => {
|
|
463
|
+
const mockTool = { execute: jest.fn().mockResolvedValue({ ok: true }) };
|
|
464
|
+
toolsRegistry.getTool.mockReturnValue(mockTool);
|
|
465
|
+
const commands = [{ toolId: 'terminal', parameters: {}, isAsync: false }];
|
|
466
|
+
const context = {
|
|
467
|
+
agentId: 'a1',
|
|
468
|
+
agentToolConfig: {
|
|
469
|
+
terminal: { allowedCommands: ['git', 'npm'] },
|
|
470
|
+
filesystem: { maxFileSize: 500 },
|
|
471
|
+
},
|
|
472
|
+
};
|
|
473
|
+
await mp.executeTools(commands, context);
|
|
474
|
+
const toolContext = mockTool.execute.mock.calls[0][1];
|
|
475
|
+
expect(toolContext.toolConfig).toEqual({ allowedCommands: ['git', 'npm'] });
|
|
476
|
+
});
|
|
477
|
+
|
|
478
|
+
test('context.toolConfig is null when agent has no config for this tool', async () => {
|
|
479
|
+
const mockTool = { execute: jest.fn().mockResolvedValue({ ok: true }) };
|
|
480
|
+
toolsRegistry.getTool.mockReturnValue(mockTool);
|
|
481
|
+
const commands = [{ toolId: 'vision', parameters: {}, isAsync: false }];
|
|
482
|
+
const context = {
|
|
483
|
+
agentId: 'a1',
|
|
484
|
+
agentToolConfig: { terminal: { allowedCommands: ['git'] } },
|
|
485
|
+
};
|
|
486
|
+
await mp.executeTools(commands, context);
|
|
487
|
+
const toolContext = mockTool.execute.mock.calls[0][1];
|
|
488
|
+
expect(toolContext.toolConfig).toBeNull();
|
|
489
|
+
});
|
|
490
|
+
|
|
491
|
+
test('context.toolConfig is null when agent has no toolConfig at all', async () => {
|
|
492
|
+
const mockTool = { execute: jest.fn().mockResolvedValue({ ok: true }) };
|
|
493
|
+
toolsRegistry.getTool.mockReturnValue(mockTool);
|
|
494
|
+
const commands = [{ toolId: 'terminal', parameters: {}, isAsync: false }];
|
|
495
|
+
await mp.executeTools(commands, { agentId: 'a1' });
|
|
496
|
+
const toolContext = mockTool.execute.mock.calls[0][1];
|
|
497
|
+
expect(toolContext.toolConfig).toBeNull();
|
|
498
|
+
});
|
|
457
499
|
});
|
|
458
500
|
|
|
459
501
|
// ─── executeAsyncTool ─────────────────────────────────────────────────
|