onbuzz 4.8.3 → 4.9.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/bin/cli.js +27 -1
- package/bin/composio-cli.js +431 -0
- package/package.json +1 -1
- package/scripts/build-onboarding-doc.cjs +805 -0
- package/scripts/composio-bench/README.md +151 -0
- package/scripts/memory-bench/bench.mjs +576 -0
- package/scripts/memory-bench/live-after-2026-05-21T16-20-52-767Z.json +150 -0
- package/scripts/memory-bench/live-after-2026-05-21T16-37-17-147Z.json +795 -0
- package/scripts/memory-bench/live-after-final-2026-05-21T17-16-02-947Z.json +766 -0
- package/scripts/memory-bench/live-after-v2-2026-05-21T16-52-26-833Z.json +890 -0
- package/scripts/memory-bench/live-after-v3-2026-05-21T17-05-40-622Z.json +955 -0
- package/scripts/memory-bench/live-probe-v2.mjs +412 -0
- package/scripts/memory-bench/live-probe.mjs +387 -0
- package/scripts/memory-bench/live-smoke-2026-05-21T16-22-35-945Z.json +36 -0
- package/scripts/memory-bench/live-smoke2-2026-05-21T16-24-14-095Z.json +36 -0
- package/scripts/memory-bench/live-smoke3-2026-05-21T16-26-54-093Z.json +123 -0
- package/scripts/memory-bench/live-v2-baseline-2026-05-23T22-43-20-757Z.json +628 -0
- package/scripts/memory-bench/live-v2-directive-2026-05-23T21-32-41-369Z.json +628 -0
- package/scripts/memory-bench/live-v2-smoke-2026-05-23T20-06-37-325Z.json +34 -0
- package/scripts/memory-bench/live-v2-smoke-2026-05-23T20-12-48-199Z.json +38 -0
- package/scripts/memory-bench/results-baseline-2026-05-19T11-23-12-245Z.json +39 -0
- package/scripts/memory-bench/results-baseline-2026-05-19T11-30-28-763Z.json +1024 -0
- package/scripts/memory-bench/results-baseline-2026-05-19T11-34-19-299Z.json +1007 -0
- package/scripts/memory-bench/results-baseline-2026-05-19T11-44-18-054Z.json +1432 -0
- package/scripts/memory-bench/results-nudge-combined-2026-05-19T12-00-37-465Z.json +1413 -0
- package/scripts/memory-bench/results-nudge-directive-2026-05-19T11-36-52-963Z.json +210 -0
- package/scripts/memory-bench/results-nudge-directive-2026-05-19T11-49-55-790Z.json +1464 -0
- package/scripts/memory-bench/results-nudge-echo-catalog-2026-05-19T11-39-01-829Z.json +232 -0
- package/scripts/memory-bench/results-nudge-echo-catalog-2026-05-19T11-55-12-705Z.json +1397 -0
- package/scripts/memory-bench/scenarios-v2.mjs +123 -0
- package/scripts/memory-bench/scenarios.mjs +178 -0
- package/scripts/office-bench/generate-samples.mjs +180 -0
- package/scripts/op-posture-bench/bench.mjs +397 -0
- package/scripts/op-posture-bench/probe.mjs +87 -0
- package/scripts/op-posture-bench/results-2026-05-18T20-29-13-941Z.json +57 -0
- package/scripts/op-posture-bench/results-2026-05-18T20-38-36-400Z.json +3071 -0
- package/scripts/op-posture-bench/scenarios.mjs +60 -0
- package/scripts/op-posture-bench/variants.mjs +68 -0
- package/scripts/stub-bench/bench.mjs +439 -0
- package/scripts/stub-bench/fixture/auth.js +41 -0
- package/scripts/stub-bench/results-2026-05-19T10-33-27-045Z.json +99 -0
- package/scripts/stub-bench/results-2026-05-19T10-35-08-240Z.json +920 -0
- package/scripts/stub-bench/results-2026-05-19T10-40-12-166Z.json +463 -0
- package/scripts/verify/azure-custom-embeddings.mjs +152 -0
- package/scripts/verify/azure-embeddings.mjs +146 -0
- package/scripts/verify/composio-toolkits.mjs +453 -0
- package/scripts/verify/local-embeddings.mjs +171 -0
- package/scripts/verify/openai-embeddings.mjs +140 -0
- package/src/__tests__/composioCliFlags.test.js +239 -0
- package/src/core/__tests__/agentScheduler.autoRecall.test.js +215 -0
- package/src/core/__tests__/agentScheduler.codebaseKnowledge.test.js +65 -0
- package/src/core/__tests__/agentScheduler.errorCategorisation.test.js +169 -0
- package/src/core/__tests__/agentScheduler.memoryInjection.test.js +78 -0
- package/src/core/agentPool.js +10 -0
- package/src/core/agentScheduler.js +273 -36
- package/src/index.js +82 -4
- package/src/interfaces/__tests__/bulkAgentRoute.test.js +290 -0
- package/src/interfaces/__tests__/composioRoutes.test.js +318 -0
- package/src/interfaces/webServer.js +436 -2
- package/src/interfaces/webServer.js.bak +7047 -0
- package/src/services/__tests__/aiService.core.test.js +420 -0
- package/src/services/__tests__/aiService.embed.test.js +172 -0
- package/src/services/__tests__/apiKeyManager.getEmbeddingApiKey.test.js +86 -0
- package/src/services/__tests__/codeMapStubRenderer.test.js +207 -0
- package/src/services/__tests__/codebaseKnowledgeService.test.js +427 -0
- package/src/services/__tests__/composioService.test.js +714 -0
- package/src/services/__tests__/memoryService.appendAndCatalog.test.js +139 -0
- package/src/services/__tests__/telegramService.test.js +91 -0
- package/src/services/aiService.js +137 -0
- package/src/services/apiKeyManager.js +61 -0
- package/src/services/codeMapStubRenderer.js +142 -0
- package/src/services/codebaseKnowledgeService.js +430 -0
- package/src/services/composioService.js +729 -0
- package/src/services/embeddings/__tests__/autoRecall.test.js +237 -0
- package/src/services/embeddings/__tests__/azureCustomProvider.test.js +232 -0
- package/src/services/embeddings/__tests__/cloudProviders.test.js +339 -0
- package/src/services/embeddings/__tests__/embeddingService.test.js +417 -0
- package/src/services/embeddings/__tests__/embeddingsConfig.test.js +182 -0
- package/src/services/embeddings/__tests__/inMemoryJsonStore.test.js +207 -0
- package/src/services/embeddings/__tests__/localProvider.test.js +263 -0
- package/src/services/embeddings/__tests__/providerInterface.test.js +209 -0
- package/src/services/embeddings/autoRecall.js +219 -0
- package/src/services/embeddings/embeddingService.js +452 -0
- package/src/services/embeddings/embeddingsConfig.js +203 -0
- package/src/services/embeddings/indexers/__tests__/agentIndexer.test.js +232 -0
- package/src/services/embeddings/indexers/__tests__/composioIndexer.test.js +265 -0
- package/src/services/embeddings/indexers/__tests__/memoryIndexer.test.js +418 -0
- package/src/services/embeddings/indexers/__tests__/reminisceIndexer.test.js +357 -0
- package/src/services/embeddings/indexers/__tests__/skillsIndexer.test.js +145 -0
- package/src/services/embeddings/indexers/__tests__/taskIndexer.test.js +146 -0
- package/src/services/embeddings/indexers/agentIndexer.js +249 -0
- package/src/services/embeddings/indexers/composioIndexer.js +279 -0
- package/src/services/embeddings/indexers/memoryIndexer.js +358 -0
- package/src/services/embeddings/indexers/reminisceIndexer.js +370 -0
- package/src/services/embeddings/indexers/skillsIndexer.js +154 -0
- package/src/services/embeddings/indexers/taskIndexer.js +155 -0
- package/src/services/embeddings/providerInterface.js +206 -0
- package/src/services/embeddings/providers/azureCustomProvider.js +154 -0
- package/src/services/embeddings/providers/azureProvider.js +122 -0
- package/src/services/embeddings/providers/cloudHttpTransport.js +205 -0
- package/src/services/embeddings/providers/localProvider.js +287 -0
- package/src/services/embeddings/providers/openaiProvider.js +101 -0
- package/src/services/embeddings/utilities/__tests__/textChunker.test.js +217 -0
- package/src/services/embeddings/utilities/textChunker.js +290 -0
- package/src/services/embeddings/vectorStore/__tests__/scoring.test.js +189 -0
- package/src/services/embeddings/vectorStore/inMemoryJsonStore.js +356 -0
- package/src/services/embeddings/vectorStore/scoring.js +128 -0
- package/src/services/embeddings/vectorStore/storeContractTests.js +179 -0
- package/src/services/embeddings/vectorStore/storeInterface.js +91 -0
- package/src/services/memoryService.js +98 -0
- package/src/services/telegramService.js +140 -1
- package/src/tools/__tests__/agentCommunicationTool.findAgent.test.js +226 -0
- package/src/tools/__tests__/agentCommunicationTool.test.js +17 -2
- package/src/tools/__tests__/baseTool.test.js +76 -10
- package/src/tools/__tests__/cloneDetectionTool.test.js +430 -0
- package/src/tools/__tests__/codeMapTool.pluralCanonical.test.js +83 -0
- package/src/tools/__tests__/composioTool.findAction.test.js +448 -0
- package/src/tools/__tests__/composioTool.test.js +499 -0
- package/src/tools/__tests__/dependencyResolverTool.test.js +567 -0
- package/src/tools/__tests__/docxTool.test.js +449 -0
- package/src/tools/__tests__/excelTool.test.js +486 -0
- package/src/tools/__tests__/importAnalyzerTool.test.js +368 -0
- package/src/tools/__tests__/memoryTool.forgetStale.test.js +272 -0
- package/src/tools/__tests__/memoryTool.pluralCanonical.test.js +189 -0
- package/src/tools/__tests__/memoryTool.reminisceSemanticSearch.test.js +301 -0
- package/src/tools/__tests__/memoryTool.semanticSearch.test.js +405 -0
- package/src/tools/__tests__/memoryTool.teamPool.test.js +293 -0
- package/src/tools/__tests__/memoryTool.test.js +1 -1
- package/src/tools/__tests__/officeTool.test.js +403 -0
- package/src/tools/__tests__/openaiFunctionSchemas.memoryReminisce.test.js +24 -25
- package/src/tools/__tests__/openaiFunctionSchemas.validity.test.js +268 -0
- package/src/tools/__tests__/pdfTool.test.js +457 -0
- package/src/tools/__tests__/singularToolReverseForgive.test.js +97 -0
- package/src/tools/__tests__/skillsTool.search.test.js +164 -0
- package/src/tools/__tests__/taskManagerTool.discipline.test.js +137 -0
- package/src/tools/__tests__/taskManagerTool.search.test.js +143 -0
- package/src/tools/__tests__/taskManagerTool.transition.test.js +236 -0
- package/src/tools/__tests__/toolShapeForgiveness.test.js +260 -0
- package/src/tools/agentCommunicationTool.js +120 -5
- package/src/tools/baseTool.js +28 -1
- package/src/tools/codeMapTool.js +1673 -1521
- package/src/tools/composioTool.js +617 -0
- package/src/tools/fileContentReplaceTool.js +893 -840
- package/src/tools/fileSystemTool.js +1372 -1314
- package/src/tools/fileTreeTool.js +7 -0
- package/src/tools/memoryTool.js +847 -82
- package/src/tools/office/officeDoc.js +425 -0
- package/src/tools/office/officePres.js +360 -0
- package/src/tools/office/officeSheet.js +350 -0
- package/src/tools/officeTool.js +313 -0
- package/src/tools/openaiFunctionSchemas.js +824 -44
- package/src/tools/platformControlTool.js +5 -0
- package/src/tools/seekTool.js +36 -1
- package/src/tools/skillsTool.js +133 -0
- package/src/tools/taskManagerTool.js +264 -16
- package/src/tools/terminalTool.js +23 -1
- package/src/tools/visionTool.js +7 -0
- package/src/tools/visualEditorTool.js +7 -0
- package/src/tools/webTool.js +28 -1
- package/src/tools/whatsappTool.js +7 -0
- package/src/utilities/authCache.js +47 -6
- package/src/utilities/authCache.js.backup-1779570472481 +121 -0
- package/src/utilities/toolConstants.js +3 -1
- package/web-ui/build/index.html +2 -2
- package/web-ui/build/static/1c-CTztA3Xo.js +1 -0
- package/web-ui/build/static/abap-BsUhLmBp.js +1 -0
- package/web-ui/build/static/abnf-CGKV2y5s.js +1 -0
- package/web-ui/build/static/abnf-vQPGuzu_.js +1 -0
- package/web-ui/build/static/accesslog-mUZocN9d.js +1 -0
- package/web-ui/build/static/actionscript-BmCHyr7v.js +1 -0
- package/web-ui/build/static/actionscript-Cc5vZvFE.js +1 -0
- package/web-ui/build/static/ada-BHR9NMNv.js +1 -0
- package/web-ui/build/static/ada-DnxQs2b9.js +1 -0
- package/web-ui/build/static/agda-CHEWVCEZ.js +1 -0
- package/web-ui/build/static/al-C0otNZjc.js +1 -0
- package/web-ui/build/static/angelscript-Co5e7ZdR.js +1 -0
- package/web-ui/build/static/antlr4-Dkky4AXR.js +1 -0
- package/web-ui/build/static/apache-BJkYIuV-.js +1 -0
- package/web-ui/build/static/apacheconf-XLif_lM5.js +1 -0
- package/web-ui/build/static/apex-DiKnugSK.js +1 -0
- package/web-ui/build/static/apl-R5OItFx8.js +1 -0
- package/web-ui/build/static/applescript-D8uiCoXI.js +1 -0
- package/web-ui/build/static/applescript-e5KOVzz4.js +1 -0
- package/web-ui/build/static/aql-Cvy5hwR1.js +1 -0
- package/web-ui/build/static/arcade-0iAjFk8w.js +1 -0
- package/web-ui/build/static/arduino-BJeuGqAT.js +1 -0
- package/web-ui/build/static/arduino-QJJjnM1j.js +1 -0
- package/web-ui/build/static/arff-C-i_E_-B.js +1 -0
- package/web-ui/build/static/armasm-ukFQKHGn.js +1 -0
- package/web-ui/build/static/asciidoc-B49qqHJJ.js +1 -0
- package/web-ui/build/static/asciidoc-Nkm1Ylrd.js +1 -0
- package/web-ui/build/static/asm6502-CMiM3nZs.js +1 -0
- package/web-ui/build/static/asmatmel-DG9XzIBf.js +1 -0
- package/web-ui/build/static/aspectj-DjRutrRk.js +1 -0
- package/web-ui/build/static/aspnet-DCNVRVi9.js +1 -0
- package/web-ui/build/static/autohotkey-C7eyvps0.js +1 -0
- package/web-ui/build/static/autohotkey-CiaZi-WO.js +1 -0
- package/web-ui/build/static/autoit-CaKUQkux.js +1 -0
- package/web-ui/build/static/autoit-D-CUHQgt.js +1 -0
- package/web-ui/build/static/avisynth-DFP3h4zu.js +1 -0
- package/web-ui/build/static/avrasm-BqvUj3fg.js +1 -0
- package/web-ui/build/static/avro-idl-D3l0ptuQ.js +1 -0
- package/web-ui/build/static/awk-BmDxAZFj.js +1 -0
- package/web-ui/build/static/axapta-B424jrgT.js +1 -0
- package/web-ui/build/static/bash-CgAffr8Z.js +1 -0
- package/web-ui/build/static/bash-D41aILLG.js +1 -0
- package/web-ui/build/static/basic-5DFTo35K.js +1 -0
- package/web-ui/build/static/basic-BONYG7D2.js +1 -0
- package/web-ui/build/static/batch-BnaDGMwS.js +1 -0
- package/web-ui/build/static/bbcode-Daujj4hU.js +1 -0
- package/web-ui/build/static/bicep-CXidcIK5.js +1 -0
- package/web-ui/build/static/birb-CcOzsnqB.js +1 -0
- package/web-ui/build/static/bison-rq0w5JFF.js +1 -0
- package/web-ui/build/static/bnf-C4uK1dK8.js +1 -0
- package/web-ui/build/static/bnf-CvXZ9crt.js +1 -0
- package/web-ui/build/static/brainfuck-B5Ezdg2y.js +1 -0
- package/web-ui/build/static/brainfuck-BZaTfZ97.js +1 -0
- package/web-ui/build/static/brightscript-D_2WBVxt.js +1 -0
- package/web-ui/build/static/bro-BD7GT6j_.js +1 -0
- package/web-ui/build/static/bsl-Bh-qcQ3w.js +1 -0
- package/web-ui/build/static/c-DNmZz1iT.js +1 -0
- package/web-ui/build/static/c-dUrSOcB2.js +1 -0
- package/web-ui/build/static/c-like-DfzKY8Uu.js +1 -0
- package/web-ui/build/static/cal-DgrFs4te.js +1 -0
- package/web-ui/build/static/capnproto-BxFR2k8w.js +1 -0
- package/web-ui/build/static/ceylon-B2Q7BIPM.js +1 -0
- package/web-ui/build/static/cfscript-DeaR8rww.js +1 -0
- package/web-ui/build/static/chaiscript-BeBIoz6b.js +1 -0
- package/web-ui/build/static/cil-YHiHOb4c.js +1 -0
- package/web-ui/build/static/clean-BgOl_0cN.js +1 -0
- package/web-ui/build/static/clojure-BlgOza7C.js +1 -0
- package/web-ui/build/static/clojure-PlKRYx3q.js +1 -0
- package/web-ui/build/static/clojure-repl-Dv2_THNB.js +1 -0
- package/web-ui/build/static/cmake-Ccf43gsy.js +1 -0
- package/web-ui/build/static/cmake-Dah_b5tK.js +1 -0
- package/web-ui/build/static/cobol-o9YRDzXA.js +1 -0
- package/web-ui/build/static/coffeescript-DTYLvxG9.js +1 -0
- package/web-ui/build/static/coffeescript-Dm4UcexP.js +1 -0
- package/web-ui/build/static/concurnas-1OxY7nFV.js +1 -0
- package/web-ui/build/static/coq-CvJBSoWT.js +1 -0
- package/web-ui/build/static/coq-DPZunybQ.js +1 -0
- package/web-ui/build/static/cos-BBstQgB4.js +1 -0
- package/web-ui/build/static/cpp-BR1pa5Wr.js +1 -0
- package/web-ui/build/static/cpp-C-_tTuKh.js +1 -0
- package/web-ui/build/static/crmsh-BIme7ihG.js +1 -0
- package/web-ui/build/static/crystal-C2hlJxaB.js +1 -0
- package/web-ui/build/static/crystal-Ca6D0fV7.js +1 -0
- package/web-ui/build/static/csharp-DGvdwvDH.js +1 -0
- package/web-ui/build/static/csharp-DbAjVltn.js +1 -0
- package/web-ui/build/static/cshtml-DVC84JPa.js +1 -0
- package/web-ui/build/static/csp-BawtG83z.js +1 -0
- package/web-ui/build/static/csp-BlaoxdTK.js +1 -0
- package/web-ui/build/static/css-52oqss7r.js +1 -0
- package/web-ui/build/static/css-extras-BoTVw2IW.js +1 -0
- package/web-ui/build/static/csv-nXBSv5kK.js +1 -0
- package/web-ui/build/static/cypher-WuesoPm2.js +1 -0
- package/web-ui/build/static/d-BmmTjwiV.js +1 -0
- package/web-ui/build/static/d-BwHf5A8R.js +1 -0
- package/web-ui/build/static/dart-BVZTRb8b.js +1 -0
- package/web-ui/build/static/dart-CbWzIBpX.js +1 -0
- package/web-ui/build/static/dataweave-qi_fpjJR.js +1 -0
- package/web-ui/build/static/dax-BpP02TD3.js +1 -0
- package/web-ui/build/static/delphi-TK0E0gLN.js +1 -0
- package/web-ui/build/static/dhall-jyNJwUbo.js +1 -0
- package/web-ui/build/static/diff-Dbu90HZq.js +1 -0
- package/web-ui/build/static/diff-Df6ezhAq.js +1 -0
- package/web-ui/build/static/django-BDy-xiWR.js +1 -0
- package/web-ui/build/static/django-CbmnWIX9.js +1 -0
- package/web-ui/build/static/dns-D_wmKRHl.js +1 -0
- package/web-ui/build/static/dns-zone-file-_1osc1Qk.js +1 -0
- package/web-ui/build/static/docker-D62hlkjX.js +1 -0
- package/web-ui/build/static/dockerfile-DQ080zHh.js +1 -0
- package/web-ui/build/static/dos-B5mA8Wna.js +1 -0
- package/web-ui/build/static/dot-D497WUfu.js +1 -0
- package/web-ui/build/static/dsconfig-dERMCQVk.js +1 -0
- package/web-ui/build/static/dts-DC3ujcbX.js +1 -0
- package/web-ui/build/static/dust-Bhm1VBQg.js +1 -0
- package/web-ui/build/static/ebnf-1lmwK0bv.js +1 -0
- package/web-ui/build/static/ebnf-qzzqKVXL.js +1 -0
- package/web-ui/build/static/editorconfig-CCe25wQr.js +1 -0
- package/web-ui/build/static/eiffel-BFOXbwEN.js +1 -0
- package/web-ui/build/static/ejs-D94vVkGZ.js +1 -0
- package/web-ui/build/static/elixir-B2W81YV0.js +1 -0
- package/web-ui/build/static/elixir-CD1szlP_.js +1 -0
- package/web-ui/build/static/elm-BUJhR-kM.js +1 -0
- package/web-ui/build/static/elm-DwLnLHSK.js +1 -0
- package/web-ui/build/static/erb-CcokD9Fu.js +1 -0
- package/web-ui/build/static/erb-lzhmSBEV.js +1 -0
- package/web-ui/build/static/erlang-C0jnu48-.js +1 -0
- package/web-ui/build/static/erlang-CrevXBnJ.js +1 -0
- package/web-ui/build/static/erlang-repl-CNY6yNoO.js +1 -0
- package/web-ui/build/static/etlua-BMO_ICdR.js +1 -0
- package/web-ui/build/static/excel-C5PbLrVC.js +1 -0
- package/web-ui/build/static/excel-formula-CX4pOnnV.js +1 -0
- package/web-ui/build/static/factor-bW3WUpa0.js +1 -0
- package/web-ui/build/static/false-CQx6Crbr.js +1 -0
- package/web-ui/build/static/firestore-security-rules-DT5oRNdf.js +1 -0
- package/web-ui/build/static/fix-C4IWe2LI.js +1 -0
- package/web-ui/build/static/flix-hi9-cLwA.js +1 -0
- package/web-ui/build/static/flow-CkX6DAhF.js +1 -0
- package/web-ui/build/static/fortran-C4rIX-2n.js +1 -0
- package/web-ui/build/static/fortran-Dvu3q_x_.js +1 -0
- package/web-ui/build/static/fsharp-Bwa1UrRI.js +1 -0
- package/web-ui/build/static/fsharp-CvadhLcA.js +1 -0
- package/web-ui/build/static/ftl-eFEI11YV.js +1 -0
- package/web-ui/build/static/gams-BxGx7deQ.js +1 -0
- package/web-ui/build/static/gap-Dcv7bqDd.js +1 -0
- package/web-ui/build/static/gauss-CcVoF4l8.js +1 -0
- package/web-ui/build/static/gcode-B1dc5sh5.js +1 -0
- package/web-ui/build/static/gcode-D5OxRG5t.js +1 -0
- package/web-ui/build/static/gdscript-CL-EA1wk.js +1 -0
- package/web-ui/build/static/gedcom-BbXrNsr0.js +1 -0
- package/web-ui/build/static/gherkin-B2wQMbT2.js +1 -0
- package/web-ui/build/static/gherkin-CnL4Y3j1.js +1 -0
- package/web-ui/build/static/git-DpdutSM5.js +1 -0
- package/web-ui/build/static/glsl-C7sgdZCA.js +1 -0
- package/web-ui/build/static/glsl-DVaNsn1Z.js +1 -0
- package/web-ui/build/static/gml-B_NppoA4.js +1 -0
- package/web-ui/build/static/gml-DFrn75UD.js +1 -0
- package/web-ui/build/static/gn-BhTU_aTW.js +1 -0
- package/web-ui/build/static/go-DKrUPrfb.js +1 -0
- package/web-ui/build/static/go-DLAYIsJl.js +1 -0
- package/web-ui/build/static/go-module-BXY6q1Ug.js +1 -0
- package/web-ui/build/static/golo-CKxjLRpC.js +1 -0
- package/web-ui/build/static/gradle-DN8lsmJj.js +1 -0
- package/web-ui/build/static/graphql-CMb_4vdm.js +1 -0
- package/web-ui/build/static/groovy-Bhi1VPv7.js +1 -0
- package/web-ui/build/static/groovy-D3X3r3EX.js +1 -0
- package/web-ui/build/static/haml-CvOCw9lL.js +1 -0
- package/web-ui/build/static/haml-DYs0wBJO.js +1 -0
- package/web-ui/build/static/handlebars-CLnuKGPm.js +1 -0
- package/web-ui/build/static/handlebars-CYGG_M1h.js +1 -0
- package/web-ui/build/static/haskell-0Ju0XclD.js +1 -0
- package/web-ui/build/static/haskell-CL5jUHSd.js +1 -0
- package/web-ui/build/static/haxe-BghRbBtK.js +1 -0
- package/web-ui/build/static/haxe-dfL7GzPv.js +1 -0
- package/web-ui/build/static/hcl-BZP2QME-.js +1 -0
- package/web-ui/build/static/hlsl-Djp0TiCX.js +1 -0
- package/web-ui/build/static/hoon-Df5gJVqA.js +1 -0
- package/web-ui/build/static/hpkp-Cy-hjB4V.js +1 -0
- package/web-ui/build/static/hsp-CntMIMs4.js +1 -0
- package/web-ui/build/static/hsts-BNBhETNx.js +1 -0
- package/web-ui/build/static/htmlbars-VCCYaDHA.js +1 -0
- package/web-ui/build/static/http-7DbskohZ.js +1 -0
- package/web-ui/build/static/http-BT5FYFAK.js +1 -0
- package/web-ui/build/static/hy-DuGSaK_b.js +1 -0
- package/web-ui/build/static/ichigojam-CjvnJmlr.js +1 -0
- package/web-ui/build/static/icon-BsBz6XP6.js +1 -0
- package/web-ui/build/static/icu-message-format-BEpv_nip.js +1 -0
- package/web-ui/build/static/idris-DiXQdMPU.js +1 -0
- package/web-ui/build/static/iecst-C9tYEzwP.js +1 -0
- package/web-ui/build/static/ignore-DNMpCRPN.js +1 -0
- package/web-ui/build/static/index-B-r71gxO.js +1 -0
- package/web-ui/build/static/index-CTtNXVAZ.js +1217 -0
- package/web-ui/build/static/index-DkBBEGYj.css +1 -0
- package/web-ui/build/static/index-PvzceRzr.js +13 -0
- package/web-ui/build/static/inform7-D38mj1Ty.js +1 -0
- package/web-ui/build/static/inform7-SwIRbrNQ.js +1 -0
- package/web-ui/build/static/ini-B9xO6J_m.js +1 -0
- package/web-ui/build/static/ini-zcp_esam.js +1 -0
- package/web-ui/build/static/io-C-Ay4jvg.js +1 -0
- package/web-ui/build/static/irpf90-BYnkitLq.js +1 -0
- package/web-ui/build/static/isbl-BYtdwd6v.js +1 -0
- package/web-ui/build/static/j-ByZQN5E4.js +1 -0
- package/web-ui/build/static/java-BNtb6JWL.js +1 -0
- package/web-ui/build/static/java-CQZL3scW.js +1 -0
- package/web-ui/build/static/javadoc-BciMZ8jg.js +1 -0
- package/web-ui/build/static/javadoclike-07BOTXmy.js +1 -0
- package/web-ui/build/static/javascript-CViZlg1q.js +1 -0
- package/web-ui/build/static/javastacktrace-bWyAK0up.js +1 -0
- package/web-ui/build/static/jboss-cli-hz5boSGB.js +1 -0
- package/web-ui/build/static/jexl-DdIINSXT.js +1 -0
- package/web-ui/build/static/jolie-CQnDX-f0.js +1 -0
- package/web-ui/build/static/jq-BzhF0CHG.js +1 -0
- package/web-ui/build/static/js-extras-jizEtT14.js +1 -0
- package/web-ui/build/static/js-templates-Dr1BqLAt.js +1 -0
- package/web-ui/build/static/jsdoc-CI-GPi6r.js +1 -0
- package/web-ui/build/static/json-2eDPxnHO.js +1 -0
- package/web-ui/build/static/json-BBqUMOAQ.js +1 -0
- package/web-ui/build/static/json5-CeIoln-Y.js +1 -0
- package/web-ui/build/static/jsonp-DWe9tbr2.js +1 -0
- package/web-ui/build/static/jsstacktrace-aE-go9tq.js +1 -0
- package/web-ui/build/static/jsx-BTXEPQYI.js +1 -0
- package/web-ui/build/static/julia-4VeOirXa.js +1 -0
- package/web-ui/build/static/julia-Da6yHEfz.js +1 -0
- package/web-ui/build/static/julia-repl-CFrizGkE.js +1 -0
- package/web-ui/build/static/keepalived-39SDM4j5.js +1 -0
- package/web-ui/build/static/keyman-DU5yOLYr.js +1 -0
- package/web-ui/build/static/kotlin-DJoqh3HG.js +1 -0
- package/web-ui/build/static/kotlin-DsKd3r_L.js +1 -0
- package/web-ui/build/static/kumir-CO96hby4.js +1 -0
- package/web-ui/build/static/kusto-DyuMf8l-.js +1 -0
- package/web-ui/build/static/lasso-BiPmQTXQ.js +1 -0
- package/web-ui/build/static/latex-Bd1ef5fi.js +1 -0
- package/web-ui/build/static/latex-DUrYkmWb.js +1 -0
- package/web-ui/build/static/latte-BSD-hpi5.js +1 -0
- package/web-ui/build/static/ldif-1ZMSg0qI.js +1 -0
- package/web-ui/build/static/leaf-Cg0eq01F.js +1 -0
- package/web-ui/build/static/less-BKcd1_xh.js +1 -0
- package/web-ui/build/static/less-SB5bcusC.js +1 -0
- package/web-ui/build/static/lilypond-BX_kuAqT.js +1 -0
- package/web-ui/build/static/liquid-C337T5bt.js +1 -0
- package/web-ui/build/static/lisp-B_bJRelF.js +1 -0
- package/web-ui/build/static/lisp-Du04Vdmx.js +1 -0
- package/web-ui/build/static/livecodeserver-BOkA9fV6.js +1 -0
- package/web-ui/build/static/livescript-DkMTCCBM.js +1 -0
- package/web-ui/build/static/livescript-rTaLq5oP.js +1 -0
- package/web-ui/build/static/llvm-BrBlvl5p.js +1 -0
- package/web-ui/build/static/llvm-DQbygw7z.js +1 -0
- package/web-ui/build/static/log-DoAzOt8c.js +1 -0
- package/web-ui/build/static/lolcode-DnB7KhRR.js +1 -0
- package/web-ui/build/static/lsl-DpzE7F5A.js +1 -0
- package/web-ui/build/static/lua-CIceROsO.js +1 -0
- package/web-ui/build/static/lua-DhnvJuMn.js +1 -0
- package/web-ui/build/static/magma-BwjzpKxi.js +1 -0
- package/web-ui/build/static/makefile-D10Y62dl.js +1 -0
- package/web-ui/build/static/makefile-esgkquGi.js +1 -0
- package/web-ui/build/static/markdown-B-Y7Y0Nn.js +1 -0
- package/web-ui/build/static/markdown-Cv3Onm-Q.js +1 -0
- package/web-ui/build/static/markup-templating-B1-9WWYa.js +1 -0
- package/web-ui/build/static/mathematica-gSyKdw2h.js +1 -0
- package/web-ui/build/static/matlab-6i1uXuBx.js +1 -0
- package/web-ui/build/static/matlab-CqcSZ1d9.js +1 -0
- package/web-ui/build/static/maxima-Bc-OnIOQ.js +1 -0
- package/web-ui/build/static/maxscript-Bce44o6c.js +1 -0
- package/web-ui/build/static/mel-0Jk3y-vw.js +1 -0
- package/web-ui/build/static/mel-DmA_8WPg.js +1 -0
- package/web-ui/build/static/mercury-DNdP1u-O.js +1 -0
- package/web-ui/build/static/mermaid-DrLkSIIb.js +1 -0
- package/web-ui/build/static/mipsasm-BIQVs3Ff.js +1 -0
- package/web-ui/build/static/mizar-BD5ZD_Rk.js +1 -0
- package/web-ui/build/static/mizar-DThX8Mdy.js +1 -0
- package/web-ui/build/static/mojolicious-Bra-ClwJ.js +1 -0
- package/web-ui/build/static/mongodb-DirByEEg.js +1 -0
- package/web-ui/build/static/monkey-C-Pvu43G.js +1 -0
- package/web-ui/build/static/monkey-n4IFmaA7.js +1 -0
- package/web-ui/build/static/moonscript-B1DM34lp.js +1 -0
- package/web-ui/build/static/moonscript-B82JBytX.js +1 -0
- package/web-ui/build/static/n1ql-C46iq3Hh.js +1 -0
- package/web-ui/build/static/n1ql-DOs3gJQo.js +1 -0
- package/web-ui/build/static/n4js-CPYgal3G.js +1 -0
- package/web-ui/build/static/nand2tetris-hdl-BhlUIq7M.js +1 -0
- package/web-ui/build/static/naniscript-D1YZXYcf.js +1 -0
- package/web-ui/build/static/nasm-2-TtCBo4.js +1 -0
- package/web-ui/build/static/neon-BzoXMDea.js +1 -0
- package/web-ui/build/static/nevod-DW_87wHj.js +1 -0
- package/web-ui/build/static/nginx-BgieYUhk.js +1 -0
- package/web-ui/build/static/nginx-DW0RVJbs.js +1 -0
- package/web-ui/build/static/nim-BbTa7YZN.js +1 -0
- package/web-ui/build/static/nim-VdXk3QT9.js +1 -0
- package/web-ui/build/static/nix-3tNNprEI.js +1 -0
- package/web-ui/build/static/nix-BDghlfzh.js +1 -0
- package/web-ui/build/static/node-repl-BBLv3tyt.js +1 -0
- package/web-ui/build/static/nsis-DxjfnSO8.js +1 -0
- package/web-ui/build/static/nsis-FY5xiiar.js +1 -0
- package/web-ui/build/static/objectivec-CXhf_sp_.js +1 -0
- package/web-ui/build/static/objectivec-DcRKjWcd.js +1 -0
- package/web-ui/build/static/ocaml-BLRL6Zro.js +1 -0
- package/web-ui/build/static/ocaml-C4S4QQtS.js +1 -0
- package/web-ui/build/static/opencl-ruEAYetM.js +1 -0
- package/web-ui/build/static/openqasm-D6r_FwIh.js +1 -0
- package/web-ui/build/static/openscad-BEPjoj_N.js +1 -0
- package/web-ui/build/static/oxygene-A61yc5Or.js +1 -0
- package/web-ui/build/static/oz-DICidCTs.js +1 -0
- package/web-ui/build/static/parigp-MjTNwy2s.js +1 -0
- package/web-ui/build/static/parser-DmI7lg_r.js +1 -0
- package/web-ui/build/static/parser3-Bv9kXAib.js +1 -0
- package/web-ui/build/static/pascal-B23PBLTj.js +1 -0
- package/web-ui/build/static/pascaligo-CPIJtX2C.js +1 -0
- package/web-ui/build/static/pcaxis-Bsj_6x8j.js +1 -0
- package/web-ui/build/static/peoplecode-VvQbMjsD.js +1 -0
- package/web-ui/build/static/perl-Cr6Y9-hl.js +1 -0
- package/web-ui/build/static/perl-D37oTJip.js +1 -0
- package/web-ui/build/static/pf-BKHaWcGm.js +1 -0
- package/web-ui/build/static/pgsql-ChusgWw2.js +1 -0
- package/web-ui/build/static/php-3Qr4hNV1.js +1 -0
- package/web-ui/build/static/php-CgxeEh4Y.js +1 -0
- package/web-ui/build/static/php-extras-DeLqwT6H.js +1 -0
- package/web-ui/build/static/php-template-DcOJxuIf.js +1 -0
- package/web-ui/build/static/phpdoc-amFph5Ax.js +1 -0
- package/web-ui/build/static/plaintext-mqBcO1hG.js +1 -0
- package/web-ui/build/static/plsql-ioyqfxP7.js +1 -0
- package/web-ui/build/static/pony-nxjy8Qot.js +1 -0
- package/web-ui/build/static/powerquery-Ci_Fxyg8.js +1 -0
- package/web-ui/build/static/powershell-CB_GgRqr.js +1 -0
- package/web-ui/build/static/powershell-au4fYIm7.js +1 -0
- package/web-ui/build/static/processing-Bkd3f-Wz.js +1 -0
- package/web-ui/build/static/processing-PgCPZm30.js +1 -0
- package/web-ui/build/static/profile-C2GBY6C9.js +1 -0
- package/web-ui/build/static/prolog-BRjYwjIO.js +1 -0
- package/web-ui/build/static/prolog-BheGlH8Q.js +1 -0
- package/web-ui/build/static/promql-CtCmTKys.js +1 -0
- package/web-ui/build/static/properties-BpLqVZha.js +1 -0
- package/web-ui/build/static/properties-UQxavHUY.js +1 -0
- package/web-ui/build/static/protobuf-BSuul6Uw.js +1 -0
- package/web-ui/build/static/protobuf-CLRi8VTE.js +1 -0
- package/web-ui/build/static/psl-CJsJilqO.js +1 -0
- package/web-ui/build/static/pug-5BY6sdv1.js +1 -0
- package/web-ui/build/static/puppet-DBg45gHV.js +1 -0
- package/web-ui/build/static/puppet-DPANCbOj.js +1 -0
- package/web-ui/build/static/pure-Cn4p-7Bj.js +1 -0
- package/web-ui/build/static/purebasic-CoXbIzZJ.js +1 -0
- package/web-ui/build/static/purebasic-DZ_eLoUV.js +1 -0
- package/web-ui/build/static/purescript-B98GoUb_.js +1 -0
- package/web-ui/build/static/python-B-Lm1OME.js +1 -0
- package/web-ui/build/static/python-C_ApFGS1.js +1 -0
- package/web-ui/build/static/python-repl-CJW5_RON.js +1 -0
- package/web-ui/build/static/q-BB2BYhxG.js +1 -0
- package/web-ui/build/static/q-DVqo_ScG.js +1 -0
- package/web-ui/build/static/qml-Co-8g096.js +1 -0
- package/web-ui/build/static/qml-Du0WFcoy.js +1 -0
- package/web-ui/build/static/qore-C6XBzy3U.js +1 -0
- package/web-ui/build/static/qsharp-BCMklAuq.js +1 -0
- package/web-ui/build/static/r-B5CGUQwN.js +1 -0
- package/web-ui/build/static/r-Dxhot-za.js +1 -0
- package/web-ui/build/static/racket-C0dCdrKh.js +1 -0
- package/web-ui/build/static/reason-DGJ1fFJs.js +1 -0
- package/web-ui/build/static/reasonml-gt_AvBg7.js +1 -0
- package/web-ui/build/static/regex-B5iNH8MZ.js +1 -0
- package/web-ui/build/static/rego-hfPajYet.js +1 -0
- package/web-ui/build/static/renpy-BkG5aM4I.js +1 -0
- package/web-ui/build/static/rest-C4uwtrF8.js +1 -0
- package/web-ui/build/static/rib-D32ew8Y7.js +1 -0
- package/web-ui/build/static/rip-BIEbWzxe.js +1 -0
- package/web-ui/build/static/roboconf-CMN8BoHf.js +1 -0
- package/web-ui/build/static/roboconf-GVMh3ioj.js +1 -0
- package/web-ui/build/static/robotframework-CUQybJQ9.js +1 -0
- package/web-ui/build/static/routeros-DUEdLmuc.js +1 -0
- package/web-ui/build/static/rsl-BsAePIwQ.js +1 -0
- package/web-ui/build/static/ruby-CZMMjJFw.js +1 -0
- package/web-ui/build/static/ruby-WOVZyoXO.js +1 -0
- package/web-ui/build/static/ruleslanguage-xV-HszUl.js +1 -0
- package/web-ui/build/static/rust-Da9GRxLz.js +1 -0
- package/web-ui/build/static/rust-uCND428m.js +1 -0
- package/web-ui/build/static/sas-BW15NPzf.js +1 -0
- package/web-ui/build/static/sas-DCx9gext.js +1 -0
- package/web-ui/build/static/sass-BMD7eETo.js +1 -0
- package/web-ui/build/static/scala-0wnxLTlF.js +1 -0
- package/web-ui/build/static/scala-D3Hk-q5-.js +1 -0
- package/web-ui/build/static/scheme-Ci9QOUcD.js +1 -0
- package/web-ui/build/static/scheme-CtqjB_HN.js +1 -0
- package/web-ui/build/static/scilab-CnITQd23.js +1 -0
- package/web-ui/build/static/scss-DCceV6xw.js +1 -0
- package/web-ui/build/static/scss-N5EuPQOS.js +1 -0
- package/web-ui/build/static/shell-BegJTton.js +1 -0
- package/web-ui/build/static/shell-session-BHBoosfJ.js +1 -0
- package/web-ui/build/static/smali-CoHePNQf.js +1 -0
- package/web-ui/build/static/smali-D64W1f0Y.js +1 -0
- package/web-ui/build/static/smalltalk-CagI-Ky8.js +1 -0
- package/web-ui/build/static/smalltalk-DHLuWDjp.js +1 -0
- package/web-ui/build/static/smarty-CSS2XBuu.js +1 -0
- package/web-ui/build/static/sml-D8Oyp9xr.js +1 -0
- package/web-ui/build/static/sml-DvC_VDmX.js +1 -0
- package/web-ui/build/static/solidity-DVkeulrL.js +1 -0
- package/web-ui/build/static/solution-file-Bd7qWzoo.js +1 -0
- package/web-ui/build/static/soy-BRSlVWf7.js +1 -0
- package/web-ui/build/static/sparql-DNnCQmqM.js +1 -0
- package/web-ui/build/static/splunk-spl-DXCDUv2Y.js +1 -0
- package/web-ui/build/static/sqf-C_IKzP5b.js +1 -0
- package/web-ui/build/static/sqf-DBqlUGoG.js +1 -0
- package/web-ui/build/static/sql-Dt3ZutCc.js +1 -0
- package/web-ui/build/static/sql-q0UMLqb7.js +1 -0
- package/web-ui/build/static/sql_more-DAuY5p3F.js +1 -0
- package/web-ui/build/static/squirrel-CgQZeaNT.js +1 -0
- package/web-ui/build/static/stan-D5kYsid7.js +1 -0
- package/web-ui/build/static/stan-JSHToKMA.js +1 -0
- package/web-ui/build/static/stata-DRVhVjVb.js +1 -0
- package/web-ui/build/static/step21-C7h5ssgs.js +1 -0
- package/web-ui/build/static/stylus-BXIDNFUe.js +1 -0
- package/web-ui/build/static/stylus-CyMBrStz.js +1 -0
- package/web-ui/build/static/subunit-Lbpuvy4t.js +1 -0
- package/web-ui/build/static/swift-BCxWOc8n.js +1 -0
- package/web-ui/build/static/swift-B_YEL6eF.js +1 -0
- package/web-ui/build/static/systemd-_zWfs8U5.js +1 -0
- package/web-ui/build/static/t4-cs-BCiVX6dp.js +1 -0
- package/web-ui/build/static/t4-templating-CDm61rWh.js +1 -0
- package/web-ui/build/static/t4-vb-OO2oZZrL.js +1 -0
- package/web-ui/build/static/taggerscript-CkXxiITO.js +1 -0
- package/web-ui/build/static/tap-C612JPhJ.js +1 -0
- package/web-ui/build/static/tap-J-zR66jL.js +1 -0
- package/web-ui/build/static/tcl-DIGan5K8.js +1 -0
- package/web-ui/build/static/tcl-SFVWFwbb.js +1 -0
- package/web-ui/build/static/textile-D0WxA5g8.js +1 -0
- package/web-ui/build/static/thrift-jboo4tJl.js +1 -0
- package/web-ui/build/static/toml-DIK32ROb.js +1 -0
- package/web-ui/build/static/tp-Bhs1iGD3.js +1 -0
- package/web-ui/build/static/tremor-4d_juLiN.js +1 -0
- package/web-ui/build/static/tsx-hEN3qQzd.js +1 -0
- package/web-ui/build/static/tt2-WU6EuPNO.js +1 -0
- package/web-ui/build/static/turtle-CUM3xwNI.js +1 -0
- package/web-ui/build/static/twig-B9JwTKv9.js +1 -0
- package/web-ui/build/static/twig-Crv6BtK7.js +1 -0
- package/web-ui/build/static/typescript-BmabW_ur.js +1 -0
- package/web-ui/build/static/typescript-oMKx2dph.js +1 -0
- package/web-ui/build/static/typoscript-X48MNTeK.js +1 -0
- package/web-ui/build/static/unrealscript-qnu9Ogmz.js +1 -0
- package/web-ui/build/static/uorazor-BicTvjGt.js +1 -0
- package/web-ui/build/static/uri-CyRoMB-u.js +1 -0
- package/web-ui/build/static/v-BDM6ZJR7.js +1 -0
- package/web-ui/build/static/vala-BWCf7DTx.js +1 -0
- package/web-ui/build/static/vala-COL5roWV.js +1 -0
- package/web-ui/build/static/vbnet-BHPgkiip.js +1 -0
- package/web-ui/build/static/vbnet-BadWmTKs.js +1 -0
- package/web-ui/build/static/vbscript-BfUpIAaV.js +1 -0
- package/web-ui/build/static/vbscript-html-BBR6zcvV.js +1 -0
- package/web-ui/build/static/velocity-k4gGPuiP.js +1 -0
- package/web-ui/build/static/verilog-BoNroxW8.js +1 -0
- package/web-ui/build/static/verilog-C7cplLIi.js +1 -0
- package/web-ui/build/static/vhdl-BrKkx69g.js +1 -0
- package/web-ui/build/static/vhdl-CWacsAXR.js +1 -0
- package/web-ui/build/static/vim-BcdueaEC.js +1 -0
- package/web-ui/build/static/vim-BwsUolG_.js +1 -0
- package/web-ui/build/static/visual-basic-DTXlX5HN.js +1 -0
- package/web-ui/build/static/warpscript-2w0_2KsB.js +1 -0
- package/web-ui/build/static/wasm-BPaXQO-A.js +1 -0
- package/web-ui/build/static/web-idl-BoCTFQod.js +1 -0
- package/web-ui/build/static/wiki-BkkCi9wm.js +1 -0
- package/web-ui/build/static/wolfram-CvRNTaAX.js +1 -0
- package/web-ui/build/static/wren-Bz8Smtz-.js +1 -0
- package/web-ui/build/static/x86asm-BM83B0N_.js +1 -0
- package/web-ui/build/static/xeora-BjuDukl7.js +1 -0
- package/web-ui/build/static/xl-ByiuKWwm.js +1 -0
- package/web-ui/build/static/xml-Dut2p53G.js +1 -0
- package/web-ui/build/static/xml-doc-CxgwiuaA.js +1 -0
- package/web-ui/build/static/xojo-CBqUB8JI.js +1 -0
- package/web-ui/build/static/xquery-D-agM4jx.js +1 -0
- package/web-ui/build/static/xquery-DL_eetrQ.js +1 -0
- package/web-ui/build/static/yaml-DZ7HVZSe.js +1 -0
- package/web-ui/build/static/yaml-DatJAv7_.js +1 -0
- package/web-ui/build/static/yang-D0nrKE-r.js +1 -0
- package/web-ui/build/static/zephir--M2g15-k.js +1 -0
- package/web-ui/build/static/zig-CK6rUH8E.js +1 -0
- package/web-ui/build/static/1c-DGpIT7i5.js +0 -1
- package/web-ui/build/static/abap-5wFDdWLh.js +0 -1
- package/web-ui/build/static/abnf-BP1dpNSE.js +0 -1
- package/web-ui/build/static/abnf-DBEIAl8g.js +0 -1
- package/web-ui/build/static/accesslog-CWSM_T5E.js +0 -1
- package/web-ui/build/static/actionscript-DONkco1J.js +0 -1
- package/web-ui/build/static/actionscript-FqBYk5er.js +0 -1
- package/web-ui/build/static/ada-C2JLRIaM.js +0 -1
- package/web-ui/build/static/ada-gKiygTRK.js +0 -1
- package/web-ui/build/static/agda-CkSODqK2.js +0 -1
- package/web-ui/build/static/al-BJ_YR6p7.js +0 -1
- package/web-ui/build/static/angelscript-Dg2byMGg.js +0 -1
- package/web-ui/build/static/antlr4-BnpyaFNr.js +0 -1
- package/web-ui/build/static/apache-Dffxsd7O.js +0 -1
- package/web-ui/build/static/apacheconf-DLitjtWj.js +0 -1
- package/web-ui/build/static/apex-Drr_IvU2.js +0 -1
- package/web-ui/build/static/apl-CF6qxmXG.js +0 -1
- package/web-ui/build/static/applescript-CjOlw3b_.js +0 -1
- package/web-ui/build/static/applescript-DjkSl1Ry.js +0 -1
- package/web-ui/build/static/aql-KwVmK1gP.js +0 -1
- package/web-ui/build/static/arcade-CENSXx0R.js +0 -1
- package/web-ui/build/static/arduino-B3Ta9Fll.js +0 -1
- package/web-ui/build/static/arduino-CzcsaB9_.js +0 -1
- package/web-ui/build/static/arff-CMJSVt_O.js +0 -1
- package/web-ui/build/static/armasm-0zSgSPB4.js +0 -1
- package/web-ui/build/static/asciidoc-B8K5ctWq.js +0 -1
- package/web-ui/build/static/asciidoc-bk2Sg6b6.js +0 -1
- package/web-ui/build/static/asm6502-ji6zm4FQ.js +0 -1
- package/web-ui/build/static/asmatmel-DJqObM4Y.js +0 -1
- package/web-ui/build/static/aspectj-DqQKI7J5.js +0 -1
- package/web-ui/build/static/aspnet-9cenTxW7.js +0 -1
- package/web-ui/build/static/autohotkey-C6EhiZvl.js +0 -1
- package/web-ui/build/static/autohotkey-sTGJOvMM.js +0 -1
- package/web-ui/build/static/autoit-B0Im8iQ1.js +0 -1
- package/web-ui/build/static/autoit-CO6pUD0H.js +0 -1
- package/web-ui/build/static/avisynth-OvOHTfj5.js +0 -1
- package/web-ui/build/static/avrasm-BLWZ5Mye.js +0 -1
- package/web-ui/build/static/avro-idl-BB2ODvnw.js +0 -1
- package/web-ui/build/static/awk-_jhMabQ0.js +0 -1
- package/web-ui/build/static/axapta-DdBRgoYy.js +0 -1
- package/web-ui/build/static/bash-CsaRGXBQ.js +0 -1
- package/web-ui/build/static/bash-CxLFkwAC.js +0 -1
- package/web-ui/build/static/basic-BJyy7JJE.js +0 -1
- package/web-ui/build/static/basic-CrMb-gv0.js +0 -1
- package/web-ui/build/static/batch-BvcykMe5.js +0 -1
- package/web-ui/build/static/bbcode-EOBuY5Y6.js +0 -1
- package/web-ui/build/static/bicep-QkDJBA34.js +0 -1
- package/web-ui/build/static/birb-TAOxKurn.js +0 -1
- package/web-ui/build/static/bison-BEK6cnad.js +0 -1
- package/web-ui/build/static/bnf-DfEODxsr.js +0 -1
- package/web-ui/build/static/bnf-DhbMjsuA.js +0 -1
- package/web-ui/build/static/brainfuck-BoVocOa7.js +0 -1
- package/web-ui/build/static/brainfuck-DDC5QXPK.js +0 -1
- package/web-ui/build/static/brightscript-DNN598w2.js +0 -1
- package/web-ui/build/static/bro-Cn_jjZ8P.js +0 -1
- package/web-ui/build/static/bsl-CMCN75Gu.js +0 -1
- package/web-ui/build/static/c-DbOGQnEJ.js +0 -1
- package/web-ui/build/static/c-kggwYFsy.js +0 -1
- package/web-ui/build/static/c-like-BIsuUvof.js +0 -1
- package/web-ui/build/static/cal-DpgMsBZE.js +0 -1
- package/web-ui/build/static/capnproto-C1AHYI-M.js +0 -1
- package/web-ui/build/static/ceylon-pvJffDe1.js +0 -1
- package/web-ui/build/static/cfscript-C1qylu52.js +0 -1
- package/web-ui/build/static/chaiscript-D417WKRI.js +0 -1
- package/web-ui/build/static/cil-CjbZHbcY.js +0 -1
- package/web-ui/build/static/clean-Dvc6R-F2.js +0 -1
- package/web-ui/build/static/clojure-CSVRQPMQ.js +0 -1
- package/web-ui/build/static/clojure-ig1Vkg7X.js +0 -1
- package/web-ui/build/static/clojure-repl-C1uyEabk.js +0 -1
- package/web-ui/build/static/cmake-DSbVcAB3.js +0 -1
- package/web-ui/build/static/cmake-Zp8kPwnH.js +0 -1
- package/web-ui/build/static/cobol-OsZSiK_P.js +0 -1
- package/web-ui/build/static/coffeescript-D8r0416S.js +0 -1
- package/web-ui/build/static/coffeescript-DCpgClxh.js +0 -1
- package/web-ui/build/static/concurnas-DKnsxUOc.js +0 -1
- package/web-ui/build/static/coq-BQFlywVI.js +0 -1
- package/web-ui/build/static/coq-BvS9mQB2.js +0 -1
- package/web-ui/build/static/cos-D3ze2791.js +0 -1
- package/web-ui/build/static/cpp-Bw-cV3P1.js +0 -1
- package/web-ui/build/static/cpp-vi1p7XpB.js +0 -1
- package/web-ui/build/static/crmsh-BClnJTeQ.js +0 -1
- package/web-ui/build/static/crystal-DGzOUYZq.js +0 -1
- package/web-ui/build/static/crystal-DMzk6EvA.js +0 -1
- package/web-ui/build/static/csharp-BTom8s2X.js +0 -1
- package/web-ui/build/static/csharp-Cp2V3jfR.js +0 -1
- package/web-ui/build/static/cshtml-Dmtt9Kto.js +0 -1
- package/web-ui/build/static/csp-WPVsLe9_.js +0 -1
- package/web-ui/build/static/csp-qddj5fu_.js +0 -1
- package/web-ui/build/static/css-B0FAm7kj.js +0 -1
- package/web-ui/build/static/css-extras-Bx3pvjiG.js +0 -1
- package/web-ui/build/static/csv-CH-edgS5.js +0 -1
- package/web-ui/build/static/cypher-c3G8Leew.js +0 -1
- package/web-ui/build/static/d-BMDSy22_.js +0 -1
- package/web-ui/build/static/d-BdH4oW8-.js +0 -1
- package/web-ui/build/static/dart-C-r72q-O.js +0 -1
- package/web-ui/build/static/dart-CwpBMrKa.js +0 -1
- package/web-ui/build/static/dataweave-BPvqdt4k.js +0 -1
- package/web-ui/build/static/dax-Eyy6ixcN.js +0 -1
- package/web-ui/build/static/delphi-DhEbPj_5.js +0 -1
- package/web-ui/build/static/dhall-Ct1L8sN1.js +0 -1
- package/web-ui/build/static/diff-CSTqCgwn.js +0 -1
- package/web-ui/build/static/diff-Da97B5vW.js +0 -1
- package/web-ui/build/static/django-DGit_lCg.js +0 -1
- package/web-ui/build/static/django-DPgqFB8k.js +0 -1
- package/web-ui/build/static/dns-DUyXuZ-a.js +0 -1
- package/web-ui/build/static/dns-zone-file-D79MDxVG.js +0 -1
- package/web-ui/build/static/docker-DTiy4o38.js +0 -1
- package/web-ui/build/static/dockerfile-CvwPP8wE.js +0 -1
- package/web-ui/build/static/dos-CaIUWxvb.js +0 -1
- package/web-ui/build/static/dot-D3504w6Y.js +0 -1
- package/web-ui/build/static/dsconfig-Smy1eeX_.js +0 -1
- package/web-ui/build/static/dts-DyTYSXZj.js +0 -1
- package/web-ui/build/static/dust-CrJyi6qA.js +0 -1
- package/web-ui/build/static/ebnf-C8nqfkBH.js +0 -1
- package/web-ui/build/static/ebnf-Cuh5Vh2-.js +0 -1
- package/web-ui/build/static/editorconfig-C7pTGl6n.js +0 -1
- package/web-ui/build/static/eiffel-C75MSJCA.js +0 -1
- package/web-ui/build/static/ejs-Dyo7DF5w.js +0 -1
- package/web-ui/build/static/elixir-D4yJefOc.js +0 -1
- package/web-ui/build/static/elixir-DKRow2SJ.js +0 -1
- package/web-ui/build/static/elm-CgbdDlkT.js +0 -1
- package/web-ui/build/static/elm-D3N-UgU0.js +0 -1
- package/web-ui/build/static/erb-BsITh8qW.js +0 -1
- package/web-ui/build/static/erb-lY_LyKyS.js +0 -1
- package/web-ui/build/static/erlang-BCnPiYmB.js +0 -1
- package/web-ui/build/static/erlang-JEghiPXc.js +0 -1
- package/web-ui/build/static/erlang-repl-DzU97ugC.js +0 -1
- package/web-ui/build/static/etlua-CsBo8cJa.js +0 -1
- package/web-ui/build/static/excel-formula-C2piiCYa.js +0 -1
- package/web-ui/build/static/excel-kqNypwQD.js +0 -1
- package/web-ui/build/static/factor-DZTOhkyU.js +0 -1
- package/web-ui/build/static/false-yLjhfaSw.js +0 -1
- package/web-ui/build/static/firestore-security-rules-oaQNoH8l.js +0 -1
- package/web-ui/build/static/fix-C9IfnTuS.js +0 -1
- package/web-ui/build/static/flix-EmJ_JhPo.js +0 -1
- package/web-ui/build/static/flow-DCUl7IAQ.js +0 -1
- package/web-ui/build/static/fortran-DvyxJmFN.js +0 -1
- package/web-ui/build/static/fortran-EEP9R3S5.js +0 -1
- package/web-ui/build/static/fsharp-D_98s3RX.js +0 -1
- package/web-ui/build/static/fsharp-Dt9jOO5G.js +0 -1
- package/web-ui/build/static/ftl-C8gMHWLo.js +0 -1
- package/web-ui/build/static/gams-BHxVPb4z.js +0 -1
- package/web-ui/build/static/gap-DFtyHk-q.js +0 -1
- package/web-ui/build/static/gauss-BwhJWUcg.js +0 -1
- package/web-ui/build/static/gcode-BvmXwp09.js +0 -1
- package/web-ui/build/static/gcode-gWcD6Vc7.js +0 -1
- package/web-ui/build/static/gdscript-btHoX8RE.js +0 -1
- package/web-ui/build/static/gedcom-MgPs9iqh.js +0 -1
- package/web-ui/build/static/gherkin-B9c_Q16A.js +0 -1
- package/web-ui/build/static/gherkin-BvOgkK6h.js +0 -1
- package/web-ui/build/static/git-D9XWOVcQ.js +0 -1
- package/web-ui/build/static/glsl-CshBHxHY.js +0 -1
- package/web-ui/build/static/glsl-fNRUMTDr.js +0 -1
- package/web-ui/build/static/gml-B78deHK8.js +0 -1
- package/web-ui/build/static/gml-Cj7d2u8O.js +0 -1
- package/web-ui/build/static/gn-CJLD-mF1.js +0 -1
- package/web-ui/build/static/go-CT93BEkL.js +0 -1
- package/web-ui/build/static/go-CTTlNuQO.js +0 -1
- package/web-ui/build/static/go-module-BgnXboUE.js +0 -1
- package/web-ui/build/static/golo-2S5tXS-l.js +0 -1
- package/web-ui/build/static/gradle-8W8DCcWJ.js +0 -1
- package/web-ui/build/static/graphql-DZfp6FNU.js +0 -1
- package/web-ui/build/static/groovy-BfsyMb3X.js +0 -1
- package/web-ui/build/static/groovy-Dxov7ENz.js +0 -1
- package/web-ui/build/static/haml-BlUFsdVV.js +0 -1
- package/web-ui/build/static/haml-CjVj6vvW.js +0 -1
- package/web-ui/build/static/handlebars-DxrQFkyA.js +0 -1
- package/web-ui/build/static/handlebars-FE6fotYl.js +0 -1
- package/web-ui/build/static/haskell-B6z0RCD_.js +0 -1
- package/web-ui/build/static/haskell-JBFmJTRy.js +0 -1
- package/web-ui/build/static/haxe-BtMZMi-_.js +0 -1
- package/web-ui/build/static/haxe-C1J8n-fH.js +0 -1
- package/web-ui/build/static/hcl-DJP-bFWE.js +0 -1
- package/web-ui/build/static/hlsl-DrGjhs1b.js +0 -1
- package/web-ui/build/static/hoon-Cg-ZhqIT.js +0 -1
- package/web-ui/build/static/hpkp-D07vgmoZ.js +0 -1
- package/web-ui/build/static/hsp-CsypPWoA.js +0 -1
- package/web-ui/build/static/hsts-B6DMRxvP.js +0 -1
- package/web-ui/build/static/htmlbars-BI7_Hw4e.js +0 -1
- package/web-ui/build/static/http-90ihEi4s.js +0 -1
- package/web-ui/build/static/http-Dp4QXj9E.js +0 -1
- package/web-ui/build/static/hy-BMgKvP4K.js +0 -1
- package/web-ui/build/static/ichigojam-D6wKvJDb.js +0 -1
- package/web-ui/build/static/icon-CrgkmCwl.js +0 -1
- package/web-ui/build/static/icu-message-format-Bi2JxCXs.js +0 -1
- package/web-ui/build/static/idris-DbUsyZt5.js +0 -1
- package/web-ui/build/static/iecst-CQZ9t8fW.js +0 -1
- package/web-ui/build/static/ignore-BaFgtNMs.js +0 -1
- package/web-ui/build/static/index-DEWSWosh.css +0 -1
- package/web-ui/build/static/index-Di1bjCFA.js +0 -13
- package/web-ui/build/static/index-otR_WSsL.js +0 -1
- package/web-ui/build/static/index-whZPU4as.js +0 -1183
- package/web-ui/build/static/inform7-ClyX1Gro.js +0 -1
- package/web-ui/build/static/inform7-tZHBS5XP.js +0 -1
- package/web-ui/build/static/ini-BrP5JNYL.js +0 -1
- package/web-ui/build/static/ini-CVkrAhwV.js +0 -1
- package/web-ui/build/static/io-BJ1Y6Bdc.js +0 -1
- package/web-ui/build/static/irpf90-fjjcKS_8.js +0 -1
- package/web-ui/build/static/isbl-ClpvfUIz.js +0 -1
- package/web-ui/build/static/j-CICW77xS.js +0 -1
- package/web-ui/build/static/java-B9DFK-0E.js +0 -1
- package/web-ui/build/static/java-BL_6rYko.js +0 -1
- package/web-ui/build/static/javadoc-Cc4HKpKK.js +0 -1
- package/web-ui/build/static/javadoclike-CgNkUDOm.js +0 -1
- package/web-ui/build/static/javascript-CM40ZECq.js +0 -1
- package/web-ui/build/static/javastacktrace-BHSqXfG5.js +0 -1
- package/web-ui/build/static/jboss-cli-Bv5NhVSZ.js +0 -1
- package/web-ui/build/static/jexl--Ohk_keA.js +0 -1
- package/web-ui/build/static/jolie-DMTN5Vdf.js +0 -1
- package/web-ui/build/static/jq-nXRLldXX.js +0 -1
- package/web-ui/build/static/js-extras-eLwv3frs.js +0 -1
- package/web-ui/build/static/js-templates-Ca0owlrg.js +0 -1
- package/web-ui/build/static/jsdoc-KERXp0da.js +0 -1
- package/web-ui/build/static/json-BTjLaRsy.js +0 -1
- package/web-ui/build/static/json-p7pU0qdW.js +0 -1
- package/web-ui/build/static/json5-Cxjy1udc.js +0 -1
- package/web-ui/build/static/jsonp-CO52H7Gy.js +0 -1
- package/web-ui/build/static/jsstacktrace-8YKfoyJP.js +0 -1
- package/web-ui/build/static/jsx-Ct_05KbM.js +0 -1
- package/web-ui/build/static/julia-23I1ubCE.js +0 -1
- package/web-ui/build/static/julia-d8rVGed_.js +0 -1
- package/web-ui/build/static/julia-repl-mwnHedW_.js +0 -1
- package/web-ui/build/static/keepalived-E85Rx_fF.js +0 -1
- package/web-ui/build/static/keyman-aWd3QUDq.js +0 -1
- package/web-ui/build/static/kotlin-Cu370hQq.js +0 -1
- package/web-ui/build/static/kotlin-DoJ2WnmZ.js +0 -1
- package/web-ui/build/static/kumir-oiOgqcQO.js +0 -1
- package/web-ui/build/static/kusto-Bp-B02K5.js +0 -1
- package/web-ui/build/static/lasso-BxoQVwOO.js +0 -1
- package/web-ui/build/static/latex-CANm5vsX.js +0 -1
- package/web-ui/build/static/latex-PMroeNch.js +0 -1
- package/web-ui/build/static/latte-2ErU_2XF.js +0 -1
- package/web-ui/build/static/ldif-ChPn_F7o.js +0 -1
- package/web-ui/build/static/leaf-UkCugDgG.js +0 -1
- package/web-ui/build/static/less-CCH5RA89.js +0 -1
- package/web-ui/build/static/less-CGZbVU1g.js +0 -1
- package/web-ui/build/static/lilypond-BoyM37sv.js +0 -1
- package/web-ui/build/static/liquid-DGJVpRBi.js +0 -1
- package/web-ui/build/static/lisp-93nne61u.js +0 -1
- package/web-ui/build/static/lisp-DYjIRsXz.js +0 -1
- package/web-ui/build/static/livecodeserver-CfNaxIE4.js +0 -1
- package/web-ui/build/static/livescript-C8kDlQkz.js +0 -1
- package/web-ui/build/static/livescript-CoarnRHq.js +0 -1
- package/web-ui/build/static/llvm-CBVyNmAh.js +0 -1
- package/web-ui/build/static/llvm-DGxq8a7u.js +0 -1
- package/web-ui/build/static/log-BivgwFql.js +0 -1
- package/web-ui/build/static/lolcode-l5sK2cZz.js +0 -1
- package/web-ui/build/static/lsl-Xm44xLRQ.js +0 -1
- package/web-ui/build/static/lua-CGvrzfKp.js +0 -1
- package/web-ui/build/static/lua-nHwXeY4c.js +0 -1
- package/web-ui/build/static/magma-DmNItmna.js +0 -1
- package/web-ui/build/static/makefile-CKJNNHGb.js +0 -1
- package/web-ui/build/static/makefile-DI6y5Qml.js +0 -1
- package/web-ui/build/static/markdown-BgpbxKd-.js +0 -1
- package/web-ui/build/static/markdown-CvcxA4yk.js +0 -1
- package/web-ui/build/static/markup-templating-DijqesiA.js +0 -1
- package/web-ui/build/static/mathematica-Cxll1Q10.js +0 -1
- package/web-ui/build/static/matlab-BJo2T1A-.js +0 -1
- package/web-ui/build/static/matlab-C6DlZX4l.js +0 -1
- package/web-ui/build/static/maxima-DJXO4sbL.js +0 -1
- package/web-ui/build/static/maxscript-DdLpUYBs.js +0 -1
- package/web-ui/build/static/mel-BIpfnSyZ.js +0 -1
- package/web-ui/build/static/mel-BYcTUZJW.js +0 -1
- package/web-ui/build/static/mercury-C_LSpbD8.js +0 -1
- package/web-ui/build/static/mermaid-D9yBWnrT.js +0 -1
- package/web-ui/build/static/mipsasm-nR_K2Ue-.js +0 -1
- package/web-ui/build/static/mizar-BeLUPncD.js +0 -1
- package/web-ui/build/static/mizar-BesIbZd9.js +0 -1
- package/web-ui/build/static/mojolicious-cBx3OWa-.js +0 -1
- package/web-ui/build/static/mongodb-DTWKy9ac.js +0 -1
- package/web-ui/build/static/monkey-B72bZC3c.js +0 -1
- package/web-ui/build/static/monkey-G9XELYPQ.js +0 -1
- package/web-ui/build/static/moonscript-BXYVQiqj.js +0 -1
- package/web-ui/build/static/moonscript-sDd-5knz.js +0 -1
- package/web-ui/build/static/n1ql-0vKSfFAO.js +0 -1
- package/web-ui/build/static/n1ql-C9_BSZfz.js +0 -1
- package/web-ui/build/static/n4js-B7Ct8dds.js +0 -1
- package/web-ui/build/static/nand2tetris-hdl-p9gpphTM.js +0 -1
- package/web-ui/build/static/naniscript-6ZVr8Aug.js +0 -1
- package/web-ui/build/static/nasm-Ca73yTUt.js +0 -1
- package/web-ui/build/static/neon-DNP49oyX.js +0 -1
- package/web-ui/build/static/nevod-Qhgt7Bce.js +0 -1
- package/web-ui/build/static/nginx-D5e7lu62.js +0 -1
- package/web-ui/build/static/nginx-DobnyESB.js +0 -1
- package/web-ui/build/static/nim-BPBivUOV.js +0 -1
- package/web-ui/build/static/nim-Baoug1Wa.js +0 -1
- package/web-ui/build/static/nix-CSPTQs5y.js +0 -1
- package/web-ui/build/static/nix-Dk4eNw49.js +0 -1
- package/web-ui/build/static/node-repl-NJNL8VFR.js +0 -1
- package/web-ui/build/static/nsis-BZ0oMzEw.js +0 -1
- package/web-ui/build/static/nsis-CKPCjtCU.js +0 -1
- package/web-ui/build/static/objectivec-BkfIRhhV.js +0 -1
- package/web-ui/build/static/objectivec-CnQgqhbJ.js +0 -1
- package/web-ui/build/static/ocaml-9rGNzRrK.js +0 -1
- package/web-ui/build/static/ocaml-CTolCqxL.js +0 -1
- package/web-ui/build/static/opencl-9Q3vRDxv.js +0 -1
- package/web-ui/build/static/openqasm-D2QiuFBp.js +0 -1
- package/web-ui/build/static/openscad-C3HyuzpB.js +0 -1
- package/web-ui/build/static/oxygene-4gi-VYy_.js +0 -1
- package/web-ui/build/static/oz-BGDEB-1A.js +0 -1
- package/web-ui/build/static/parigp-CfZzp1uE.js +0 -1
- package/web-ui/build/static/parser-UbGteTcy.js +0 -1
- package/web-ui/build/static/parser3-C-Jx-fy7.js +0 -1
- package/web-ui/build/static/pascal-D1_R0gW-.js +0 -1
- package/web-ui/build/static/pascaligo-B8C-98Np.js +0 -1
- package/web-ui/build/static/pcaxis-TGnlUKNs.js +0 -1
- package/web-ui/build/static/peoplecode-C5Vf1AH0.js +0 -1
- package/web-ui/build/static/perl-CBp1N62T.js +0 -1
- package/web-ui/build/static/perl-Z59j904t.js +0 -1
- package/web-ui/build/static/pf-Cq8B_xwQ.js +0 -1
- package/web-ui/build/static/pgsql-ofJbUHkL.js +0 -1
- package/web-ui/build/static/php-OlH7HLQJ.js +0 -1
- package/web-ui/build/static/php-extras-GqtrxLuk.js +0 -1
- package/web-ui/build/static/php-r09kMDOB.js +0 -1
- package/web-ui/build/static/php-template-18uT97Qo.js +0 -1
- package/web-ui/build/static/phpdoc-9tRFvup9.js +0 -1
- package/web-ui/build/static/plaintext-DsYT6Mu-.js +0 -1
- package/web-ui/build/static/plsql-RhWQNJVb.js +0 -1
- package/web-ui/build/static/pony-DD6JMLYI.js +0 -1
- package/web-ui/build/static/powerquery-CALow-bt.js +0 -1
- package/web-ui/build/static/powershell-C2QvIuKF.js +0 -1
- package/web-ui/build/static/powershell-yrbJEhCh.js +0 -1
- package/web-ui/build/static/processing-1T5w_Q03.js +0 -1
- package/web-ui/build/static/processing-DBim_dO-.js +0 -1
- package/web-ui/build/static/profile-Cdloh8mZ.js +0 -1
- package/web-ui/build/static/prolog-DRSsNnns.js +0 -1
- package/web-ui/build/static/prolog-D_ajweDr.js +0 -1
- package/web-ui/build/static/promql-BRuwn6Bn.js +0 -1
- package/web-ui/build/static/properties-D5Wyl4X4.js +0 -1
- package/web-ui/build/static/properties-kn4fl1bl.js +0 -1
- package/web-ui/build/static/protobuf-BMO76zWi.js +0 -1
- package/web-ui/build/static/protobuf-CTUCF-U-.js +0 -1
- package/web-ui/build/static/psl-CiqYdQbY.js +0 -1
- package/web-ui/build/static/pug-BLE2Qayj.js +0 -1
- package/web-ui/build/static/puppet-CFKLWXft.js +0 -1
- package/web-ui/build/static/puppet-DQci0Dl5.js +0 -1
- package/web-ui/build/static/pure-D2h_GynV.js +0 -1
- package/web-ui/build/static/purebasic-BF8MVw8V.js +0 -1
- package/web-ui/build/static/purebasic-BTtHiCkh.js +0 -1
- package/web-ui/build/static/purescript-D1ZSh-sH.js +0 -1
- package/web-ui/build/static/python-Cp9_Vdhb.js +0 -1
- package/web-ui/build/static/python-DdgNw8IW.js +0 -1
- package/web-ui/build/static/python-repl-DvK89VMC.js +0 -1
- package/web-ui/build/static/q-COaIgwhT.js +0 -1
- package/web-ui/build/static/q-Cm0dQkW8.js +0 -1
- package/web-ui/build/static/qml-BpsOqqJM.js +0 -1
- package/web-ui/build/static/qml-BziQXlU4.js +0 -1
- package/web-ui/build/static/qore-Cutz6g-2.js +0 -1
- package/web-ui/build/static/qsharp-B16619X1.js +0 -1
- package/web-ui/build/static/r-CFUIj5Hd.js +0 -1
- package/web-ui/build/static/r-CPrwCi5w.js +0 -1
- package/web-ui/build/static/racket-Bh08DFXF.js +0 -1
- package/web-ui/build/static/reason-BxjDq4e-.js +0 -1
- package/web-ui/build/static/reasonml-Ds5SsGP8.js +0 -1
- package/web-ui/build/static/regex-DhBIDIMI.js +0 -1
- package/web-ui/build/static/rego-DCwxZXcB.js +0 -1
- package/web-ui/build/static/renpy-C2fuQfqb.js +0 -1
- package/web-ui/build/static/rest-C52ZpxWQ.js +0 -1
- package/web-ui/build/static/rib-Cbl2Mzyj.js +0 -1
- package/web-ui/build/static/rip-BTOu5ZIE.js +0 -1
- package/web-ui/build/static/roboconf-3Oi2wuVk.js +0 -1
- package/web-ui/build/static/roboconf-ndLZLE39.js +0 -1
- package/web-ui/build/static/robotframework-BzHXiIj1.js +0 -1
- package/web-ui/build/static/routeros-CkpPoqx-.js +0 -1
- package/web-ui/build/static/rsl-C0bwOQ38.js +0 -1
- package/web-ui/build/static/ruby-C_hIhtuQ.js +0 -1
- package/web-ui/build/static/ruby-DvKfZPzj.js +0 -1
- package/web-ui/build/static/ruleslanguage-CbZJlddz.js +0 -1
- package/web-ui/build/static/rust-BFPIhB-X.js +0 -1
- package/web-ui/build/static/rust-sBpUq-qE.js +0 -1
- package/web-ui/build/static/sas-BCXvYN9x.js +0 -1
- package/web-ui/build/static/sas-D7GAsTY3.js +0 -1
- package/web-ui/build/static/sass-BdaErGMN.js +0 -1
- package/web-ui/build/static/scala-Cj81oCl9.js +0 -1
- package/web-ui/build/static/scala-CvbksfY6.js +0 -1
- package/web-ui/build/static/scheme-BM5ZqKnl.js +0 -1
- package/web-ui/build/static/scheme-BPvlu9Tk.js +0 -1
- package/web-ui/build/static/scilab-CJanLKQN.js +0 -1
- package/web-ui/build/static/scss-C53YF_7f.js +0 -1
- package/web-ui/build/static/scss-DPp8UZbr.js +0 -1
- package/web-ui/build/static/shell-CC9bQXMe.js +0 -1
- package/web-ui/build/static/shell-session-CuR3fbf-.js +0 -1
- package/web-ui/build/static/smali-CUgLls3D.js +0 -1
- package/web-ui/build/static/smali-YODSX8qt.js +0 -1
- package/web-ui/build/static/smalltalk-BMJQ4bbs.js +0 -1
- package/web-ui/build/static/smalltalk-BVGY3CTl.js +0 -1
- package/web-ui/build/static/smarty-C9aNt4-p.js +0 -1
- package/web-ui/build/static/sml-C3BIHhfq.js +0 -1
- package/web-ui/build/static/sml-DTipyRmY.js +0 -1
- package/web-ui/build/static/solidity-1yuPUqoC.js +0 -1
- package/web-ui/build/static/solution-file-BgzK4GOU.js +0 -1
- package/web-ui/build/static/soy-CFJXRvqc.js +0 -1
- package/web-ui/build/static/sparql-CAosYMpl.js +0 -1
- package/web-ui/build/static/splunk-spl-DkINtWr8.js +0 -1
- package/web-ui/build/static/sqf-DbrWIS2M.js +0 -1
- package/web-ui/build/static/sqf-nq8Q9J2W.js +0 -1
- package/web-ui/build/static/sql-9bwClhZQ.js +0 -1
- package/web-ui/build/static/sql-CqPkY-lX.js +0 -1
- package/web-ui/build/static/sql_more-CsY5ts77.js +0 -1
- package/web-ui/build/static/squirrel-BuqtzRBD.js +0 -1
- package/web-ui/build/static/stan-BNxBSglc.js +0 -1
- package/web-ui/build/static/stan-CZVMc34l.js +0 -1
- package/web-ui/build/static/stata-DKnVdHCd.js +0 -1
- package/web-ui/build/static/step21-Cu_TaBGF.js +0 -1
- package/web-ui/build/static/stylus-BS7-OJew.js +0 -1
- package/web-ui/build/static/stylus-DtFrp1Nk.js +0 -1
- package/web-ui/build/static/subunit-DDCoWkkc.js +0 -1
- package/web-ui/build/static/swift-BaguUZbl.js +0 -1
- package/web-ui/build/static/swift-mwBsb8Bx.js +0 -1
- package/web-ui/build/static/systemd-D6PpyDKk.js +0 -1
- package/web-ui/build/static/t4-cs-Cem8g4Ck.js +0 -1
- package/web-ui/build/static/t4-templating-BZo-HjmD.js +0 -1
- package/web-ui/build/static/t4-vb-B4oVnKa4.js +0 -1
- package/web-ui/build/static/taggerscript-DweAZ5pw.js +0 -1
- package/web-ui/build/static/tap-DpuvKHHF.js +0 -1
- package/web-ui/build/static/tap-hUKmJObZ.js +0 -1
- package/web-ui/build/static/tcl-BUvhAi7u.js +0 -1
- package/web-ui/build/static/tcl-Dsck63d8.js +0 -1
- package/web-ui/build/static/textile-CgKbqJ-j.js +0 -1
- package/web-ui/build/static/thrift-B5H6rApp.js +0 -1
- package/web-ui/build/static/toml-DggTpfOo.js +0 -1
- package/web-ui/build/static/tp-CazB2P2X.js +0 -1
- package/web-ui/build/static/tremor-B1jy7S5p.js +0 -1
- package/web-ui/build/static/tsx-BqF2lVDi.js +0 -1
- package/web-ui/build/static/tt2-BNoNXpEe.js +0 -1
- package/web-ui/build/static/turtle-B0evd5mn.js +0 -1
- package/web-ui/build/static/twig-B5A7nMdv.js +0 -1
- package/web-ui/build/static/twig-DZnLWvh8.js +0 -1
- package/web-ui/build/static/typescript-Bbe_P093.js +0 -1
- package/web-ui/build/static/typescript-BfhvmSSG.js +0 -1
- package/web-ui/build/static/typoscript-BjuZEIgw.js +0 -1
- package/web-ui/build/static/unrealscript-C3iUCFRi.js +0 -1
- package/web-ui/build/static/uorazor-CbZXwzIj.js +0 -1
- package/web-ui/build/static/uri-xMPSnp6m.js +0 -1
- package/web-ui/build/static/v-BKcGo5I6.js +0 -1
- package/web-ui/build/static/vala-BRoBE4am.js +0 -1
- package/web-ui/build/static/vala-B__Iyrma.js +0 -1
- package/web-ui/build/static/vbnet-DBxlMRvN.js +0 -1
- package/web-ui/build/static/vbnet-DjAXt5BE.js +0 -1
- package/web-ui/build/static/vbscript-BNA4oANi.js +0 -1
- package/web-ui/build/static/vbscript-html-o8ckLPKG.js +0 -1
- package/web-ui/build/static/velocity-D7sc5ggA.js +0 -1
- package/web-ui/build/static/verilog-BWJfMIng.js +0 -1
- package/web-ui/build/static/verilog-jW2GPC--.js +0 -1
- package/web-ui/build/static/vhdl-BIVlXRPa.js +0 -1
- package/web-ui/build/static/vhdl-BeqdhhxD.js +0 -1
- package/web-ui/build/static/vim-712lI4-g.js +0 -1
- package/web-ui/build/static/vim-DMROTzr0.js +0 -1
- package/web-ui/build/static/visual-basic-CQfbM-ta.js +0 -1
- package/web-ui/build/static/warpscript-DFAvCXFQ.js +0 -1
- package/web-ui/build/static/wasm-CiYoxBl0.js +0 -1
- package/web-ui/build/static/web-idl-DoCkPK8y.js +0 -1
- package/web-ui/build/static/wiki-bvz0AGzB.js +0 -1
- package/web-ui/build/static/wolfram-fBuyFEgU.js +0 -1
- package/web-ui/build/static/wren-DvATFxjF.js +0 -1
- package/web-ui/build/static/x86asm-r4bPbUR_.js +0 -1
- package/web-ui/build/static/xeora-B6iOnDJY.js +0 -1
- package/web-ui/build/static/xl-Ce6B5slc.js +0 -1
- package/web-ui/build/static/xml-DNjyPmhQ.js +0 -1
- package/web-ui/build/static/xml-doc-DydogmZD.js +0 -1
- package/web-ui/build/static/xojo-DCQLltvr.js +0 -1
- package/web-ui/build/static/xquery-C-fAnA0H.js +0 -1
- package/web-ui/build/static/xquery-CNeqzhLO.js +0 -1
- package/web-ui/build/static/yaml-BsVaGsk5.js +0 -1
- package/web-ui/build/static/yaml-kVZvwv_C.js +0 -1
- package/web-ui/build/static/yang-B_gq9JEq.js +0 -1
- package/web-ui/build/static/zephir-ECIXgXhX.js +0 -1
- package/web-ui/build/static/zig-DY325EKG.js +0 -1
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* skillsTool tests for search + backfill-search-index.
|
|
3
|
+
*
|
|
4
|
+
* Pins the wiring contracts only — SkillsIndexer's internals are
|
|
5
|
+
* covered by its own suite. We test:
|
|
6
|
+
* - search dispatches to indexer when enabled
|
|
7
|
+
* - search falls back to substring over service.listSkills() when disabled
|
|
8
|
+
* - missing query → clean error
|
|
9
|
+
* - backfill walks listSkills + readSkill for each + calls indexer.backfill
|
|
10
|
+
* - backfill is resilient when readSkill fails for one (uses metadata only)
|
|
11
|
+
*
|
|
12
|
+
* Mocks: SKILLS_ACTIONS enum (already extended), SkillsIndexer, and the
|
|
13
|
+
* underlying skills service the tool consumes.
|
|
14
|
+
*/
|
|
15
|
+
|
|
16
|
+
import { jest, describe, test, expect, beforeEach } from '@jest/globals';
|
|
17
|
+
|
|
18
|
+
const mockIndexerInstance = {
|
|
19
|
+
isEnabled: true,
|
|
20
|
+
indexOne: jest.fn().mockResolvedValue({ indexed: true }),
|
|
21
|
+
deleteOne: jest.fn().mockResolvedValue({ deleted: true }),
|
|
22
|
+
backfill: jest.fn().mockResolvedValue({ ok: true, indexed: 2, skipped: 0, failed: 0 }),
|
|
23
|
+
search: jest.fn().mockResolvedValue({ enabled: true, hits: [] }),
|
|
24
|
+
stats: jest.fn().mockResolvedValue({ count: 2, enabled: true }),
|
|
25
|
+
};
|
|
26
|
+
const MockSkillsIndexer = jest.fn(() => mockIndexerInstance);
|
|
27
|
+
jest.unstable_mockModule('../../services/embeddings/indexers/skillsIndexer.js', () => ({
|
|
28
|
+
SkillsIndexer: MockSkillsIndexer,
|
|
29
|
+
skillToText: () => '',
|
|
30
|
+
}));
|
|
31
|
+
|
|
32
|
+
// Mock the skills service. Needs `.initialize()` because the tool calls
|
|
33
|
+
// it via `_ensureSkillsService()` before dispatching.
|
|
34
|
+
const mockSkillsService = {
|
|
35
|
+
initialize: jest.fn().mockResolvedValue(undefined),
|
|
36
|
+
listSkills: jest.fn(),
|
|
37
|
+
readSkill: jest.fn(),
|
|
38
|
+
describeSkill: jest.fn(),
|
|
39
|
+
};
|
|
40
|
+
jest.unstable_mockModule('../../services/skillsService.js', () => ({
|
|
41
|
+
getSkillsService: () => mockSkillsService,
|
|
42
|
+
}));
|
|
43
|
+
|
|
44
|
+
const { default: SkillsTool } = await import('../skillsTool.js');
|
|
45
|
+
|
|
46
|
+
function makeTool({ embeddingsEnabled = true } = {}) {
|
|
47
|
+
const tool = new SkillsTool();
|
|
48
|
+
mockIndexerInstance.isEnabled = embeddingsEnabled;
|
|
49
|
+
mockIndexerInstance.search.mockClear();
|
|
50
|
+
mockIndexerInstance.backfill.mockClear();
|
|
51
|
+
MockSkillsIndexer.mockClear();
|
|
52
|
+
mockSkillsService.listSkills.mockClear();
|
|
53
|
+
mockSkillsService.readSkill.mockClear();
|
|
54
|
+
tool.aiService = { getEmbeddingService: () => ({ isEnabled: embeddingsEnabled }) };
|
|
55
|
+
tool._skillsIndexer = null;
|
|
56
|
+
return tool;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
const skillList = [
|
|
60
|
+
{ name: 'git-rebase-recovery', description: 'Recover from a broken rebase' },
|
|
61
|
+
{ name: 'docker-build-debug', description: 'Debug docker build failures' },
|
|
62
|
+
{ name: 'react-hook-deps', description: 'Fix exhaustive-deps warnings' },
|
|
63
|
+
];
|
|
64
|
+
|
|
65
|
+
describe('skillsTool — search wiring', () => {
|
|
66
|
+
test('missing query → clean error', async () => {
|
|
67
|
+
const tool = makeTool();
|
|
68
|
+
const r = await tool.execute({ action: 'search' });
|
|
69
|
+
expect(r.success).toBe(false);
|
|
70
|
+
expect(r.error).toMatch(/query/i);
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
test('disabled embeddings → substring fallback over service.listSkills', async () => {
|
|
74
|
+
const tool = makeTool({ embeddingsEnabled: false });
|
|
75
|
+
mockSkillsService.listSkills.mockResolvedValue(skillList);
|
|
76
|
+
const r = await tool.execute({ action: 'search', query: 'rebase' });
|
|
77
|
+
expect(mockIndexerInstance.search).not.toHaveBeenCalled();
|
|
78
|
+
expect(r.result.mode).toBe('substring-fallback');
|
|
79
|
+
expect(r.result.hits.some(s => s.name === 'git-rebase-recovery')).toBe(true);
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
test('enabled embeddings → forwards query + topK + hybrid to indexer', async () => {
|
|
83
|
+
const tool = makeTool();
|
|
84
|
+
mockIndexerInstance.search.mockResolvedValue({ enabled: true, hits: [] });
|
|
85
|
+
await tool.execute({ action: 'search', query: 'rebase', topK: 3, hybrid: false });
|
|
86
|
+
expect(mockIndexerInstance.search).toHaveBeenCalledWith('rebase', { topK: 3, hybrid: false });
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
test('enabled embeddings → returns hits in result', async () => {
|
|
90
|
+
const tool = makeTool();
|
|
91
|
+
mockIndexerInstance.search.mockResolvedValue({
|
|
92
|
+
enabled: true,
|
|
93
|
+
hits: [
|
|
94
|
+
{ id: 'git-rebase-recovery', score: 0.9, metadata: { description: 'Recover...' } },
|
|
95
|
+
],
|
|
96
|
+
});
|
|
97
|
+
const r = await tool.execute({ action: 'search', query: 'rebase' });
|
|
98
|
+
expect(r.success).toBe(true);
|
|
99
|
+
expect(r.result.mode).toBe('hybrid');
|
|
100
|
+
expect(r.result.hits[0].id).toBe('git-rebase-recovery');
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
test('indexer error surfaces in result', async () => {
|
|
104
|
+
const tool = makeTool();
|
|
105
|
+
mockIndexerInstance.search.mockResolvedValue({ enabled: true, hits: [], error: 'rate-limited' });
|
|
106
|
+
const r = await tool.execute({ action: 'search', query: 'q' });
|
|
107
|
+
expect(r.success).toBe(false);
|
|
108
|
+
expect(r.result.error).toBe('rate-limited');
|
|
109
|
+
});
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
describe('skillsTool — backfill-search-index wiring', () => {
|
|
113
|
+
test('disabled → clean error', async () => {
|
|
114
|
+
const tool = makeTool({ embeddingsEnabled: false });
|
|
115
|
+
const r = await tool.execute({ action: 'backfill-search-index' });
|
|
116
|
+
expect(r.success).toBe(false);
|
|
117
|
+
expect(r.message).toMatch(/not enabled/i);
|
|
118
|
+
expect(mockIndexerInstance.backfill).not.toHaveBeenCalled();
|
|
119
|
+
});
|
|
120
|
+
|
|
121
|
+
test('walks listSkills + readSkill for each + calls indexer.backfill', async () => {
|
|
122
|
+
const tool = makeTool();
|
|
123
|
+
mockSkillsService.listSkills.mockResolvedValue(skillList);
|
|
124
|
+
mockSkillsService.readSkill
|
|
125
|
+
.mockResolvedValueOnce({ content: 'rebase step 1...' })
|
|
126
|
+
.mockResolvedValueOnce({ content: 'docker tip 1...' })
|
|
127
|
+
.mockResolvedValueOnce({ content: 'react fix 1...' });
|
|
128
|
+
|
|
129
|
+
const r = await tool.execute({ action: 'backfill-search-index' });
|
|
130
|
+
|
|
131
|
+
expect(mockSkillsService.listSkills).toHaveBeenCalled();
|
|
132
|
+
expect(mockSkillsService.readSkill).toHaveBeenCalledTimes(3);
|
|
133
|
+
const passed = mockIndexerInstance.backfill.mock.calls[0][0];
|
|
134
|
+
expect(passed).toHaveLength(3);
|
|
135
|
+
expect(passed[0]).toMatchObject({ name: 'git-rebase-recovery', content: 'rebase step 1...' });
|
|
136
|
+
expect(r.success).toBe(true);
|
|
137
|
+
expect(r.result.indexed).toBe(2); // from the stub return
|
|
138
|
+
});
|
|
139
|
+
|
|
140
|
+
test('readSkill failure on one skill falls back to metadata only', async () => {
|
|
141
|
+
const tool = makeTool();
|
|
142
|
+
mockSkillsService.listSkills.mockResolvedValue([skillList[0], skillList[1]]);
|
|
143
|
+
mockSkillsService.readSkill
|
|
144
|
+
.mockRejectedValueOnce(new Error('file gone'))
|
|
145
|
+
.mockResolvedValueOnce({ content: 'docker tip' });
|
|
146
|
+
|
|
147
|
+
await tool.execute({ action: 'backfill-search-index' });
|
|
148
|
+
const passed = mockIndexerInstance.backfill.mock.calls[0][0];
|
|
149
|
+
expect(passed).toHaveLength(2);
|
|
150
|
+
// First skill made it in without content (failed-read fallback).
|
|
151
|
+
expect(passed[0]).toMatchObject({ name: 'git-rebase-recovery' });
|
|
152
|
+
expect(passed[0].content).toBeUndefined();
|
|
153
|
+
// Second one has its content.
|
|
154
|
+
expect(passed[1].content).toBe('docker tip');
|
|
155
|
+
});
|
|
156
|
+
|
|
157
|
+
test('listSkills throw → clean error', async () => {
|
|
158
|
+
const tool = makeTool();
|
|
159
|
+
mockSkillsService.listSkills.mockRejectedValue(new Error('disk full'));
|
|
160
|
+
const r = await tool.execute({ action: 'backfill-search-index' });
|
|
161
|
+
expect(r.success).toBe(false);
|
|
162
|
+
expect(r.message).toMatch(/listSkills failed/);
|
|
163
|
+
});
|
|
164
|
+
});
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tests for the TASK DISCIPLINE signal — `currentFocus` returned on
|
|
3
|
+
* every taskmanager response — and the OPERATING POSTURE guideline
|
|
4
|
+
* that pairs with it.
|
|
5
|
+
*
|
|
6
|
+
* Production observation (scripts/memory-bench/live-v2-*,
|
|
7
|
+
* agent-agent-v2-v2-s2-multi-topic-1779570320941): Kimi-K2.6 and gpt-5.4
|
|
8
|
+
* lost task focus after cascading tool errors and silently reverted
|
|
9
|
+
* to a prior task instead of completing the current one. The fix is
|
|
10
|
+
* two-pronged:
|
|
11
|
+
* 1. Surface `currentFocus` on every taskmanager response so the
|
|
12
|
+
* anchor stays visible across error cascades.
|
|
13
|
+
* 2. OPERATING POSTURE explicitly tells the agent: only one task
|
|
14
|
+
* in_progress at a time, transition before working, finish or
|
|
15
|
+
* release before switching.
|
|
16
|
+
*/
|
|
17
|
+
import { describe, test, expect } from '@jest/globals';
|
|
18
|
+
import TaskManagerTool from '../taskManagerTool.js';
|
|
19
|
+
import { BaseTool, ToolsRegistry } from '../baseTool.js';
|
|
20
|
+
|
|
21
|
+
const SILENT_LOGGER = { info() {}, warn() {}, error() {}, debug() {} };
|
|
22
|
+
|
|
23
|
+
function makeTool() {
|
|
24
|
+
const tool = new TaskManagerTool({ description: 'test' });
|
|
25
|
+
tool.logger = SILENT_LOGGER;
|
|
26
|
+
return tool;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
describe('_buildCurrentFocus — task-discipline signal', () => {
|
|
30
|
+
test('ok=true when exactly one task is in_progress', () => {
|
|
31
|
+
const focus = makeTool()._buildCurrentFocus([
|
|
32
|
+
{ id: 'task-1', title: 'Polish README', description: 'Rewrite intro', status: 'in_progress' },
|
|
33
|
+
{ id: 'task-2', title: 'Other thing', description: '...', status: 'pending' },
|
|
34
|
+
]);
|
|
35
|
+
expect(focus.ok).toBe(true);
|
|
36
|
+
expect(focus.inProgressCount).toBe(1);
|
|
37
|
+
expect(focus.current).toMatchObject({
|
|
38
|
+
taskId: 'task-1', title: 'Polish README', description: 'Rewrite intro',
|
|
39
|
+
});
|
|
40
|
+
expect(focus.warning).toBeUndefined();
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
test('ok=false with warning when 0 tasks are in_progress', () => {
|
|
44
|
+
const focus = makeTool()._buildCurrentFocus([
|
|
45
|
+
{ id: 'task-1', title: 'X', description: '...', status: 'pending' },
|
|
46
|
+
{ id: 'task-2', title: 'Y', description: '...', status: 'completed' },
|
|
47
|
+
]);
|
|
48
|
+
expect(focus.ok).toBe(false);
|
|
49
|
+
expect(focus.inProgressCount).toBe(0);
|
|
50
|
+
expect(focus.current).toBeNull();
|
|
51
|
+
expect(focus.warning).toMatch(/in_progress/);
|
|
52
|
+
expect(focus.warning).toMatch(/BEFORE/);
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
test('ok=false with warning when 2+ tasks are in_progress', () => {
|
|
56
|
+
const focus = makeTool()._buildCurrentFocus([
|
|
57
|
+
{ id: 'task-1', title: 'A', description: '...', status: 'in_progress' },
|
|
58
|
+
{ id: 'task-2', title: 'B', description: '...', status: 'in_progress' },
|
|
59
|
+
{ id: 'task-3', title: 'C', description: '...', status: 'pending' },
|
|
60
|
+
]);
|
|
61
|
+
expect(focus.ok).toBe(false);
|
|
62
|
+
expect(focus.inProgressCount).toBe(2);
|
|
63
|
+
expect(Array.isArray(focus.current)).toBe(true);
|
|
64
|
+
expect(focus.current).toHaveLength(2);
|
|
65
|
+
expect(focus.warning).toMatch(/Multiple tasks/);
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
test('empty task list reports 0 in_progress with warning', () => {
|
|
69
|
+
const focus = makeTool()._buildCurrentFocus([]);
|
|
70
|
+
expect(focus.ok).toBe(false);
|
|
71
|
+
expect(focus.inProgressCount).toBe(0);
|
|
72
|
+
expect(focus.current).toBeNull();
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
test('null/undefined input handled gracefully (no crash)', () => {
|
|
76
|
+
expect(() => makeTool()._buildCurrentFocus(null)).not.toThrow();
|
|
77
|
+
expect(() => makeTool()._buildCurrentFocus(undefined)).not.toThrow();
|
|
78
|
+
const f = makeTool()._buildCurrentFocus(null);
|
|
79
|
+
expect(f.inProgressCount).toBe(0);
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
test('long descriptions are truncated to 140 chars', () => {
|
|
83
|
+
const long = 'x'.repeat(500);
|
|
84
|
+
const focus = makeTool()._buildCurrentFocus([
|
|
85
|
+
{ id: 'task-1', title: 'T', description: long, status: 'in_progress' },
|
|
86
|
+
]);
|
|
87
|
+
expect(focus.current.description.length).toBeLessThanOrEqual(141);
|
|
88
|
+
expect(focus.current.description.endsWith('…')).toBe(true);
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
test('non-string description is coerced to empty (no crash)', () => {
|
|
92
|
+
const focus = makeTool()._buildCurrentFocus([
|
|
93
|
+
{ id: 'task-1', title: 'T', description: null, status: 'in_progress' },
|
|
94
|
+
]);
|
|
95
|
+
expect(focus.current.description).toBe('');
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
describe('OPERATING POSTURE — TASK DISCIPLINE section', () => {
|
|
100
|
+
// The OPERATING POSTURE block lives in baseTool.js and is built per
|
|
101
|
+
// agent based on its capabilities. We construct a BaseTool-derived
|
|
102
|
+
// tool registry stub and verify the block content directly.
|
|
103
|
+
function buildOperatingPosture(capabilities) {
|
|
104
|
+
// Use the real ToolsRegistry — it's the class that owns
|
|
105
|
+
// generateToolDescriptionsForPrompt. Register fake tools matching
|
|
106
|
+
// the capability list so the block emits its sections.
|
|
107
|
+
const reg = new ToolsRegistry(SILENT_LOGGER);
|
|
108
|
+
for (const id of capabilities) {
|
|
109
|
+
reg.tools.set(id, { id, getDescription: () => `# ${id}` });
|
|
110
|
+
}
|
|
111
|
+
return reg.generateToolDescriptionsForPrompt(capabilities);
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
test('section appears when taskmanager capability is present', () => {
|
|
115
|
+
const block = buildOperatingPosture(['memory', 'taskmanager']);
|
|
116
|
+
expect(block).toMatch(/TASK DISCIPLINE/);
|
|
117
|
+
expect(block).toMatch(/ONE.*task.*in_progress/);
|
|
118
|
+
expect(block).toMatch(/Transition first, then work/);
|
|
119
|
+
expect(block).toMatch(/Finish or release/);
|
|
120
|
+
expect(block).toMatch(/Anchor on tool failures/);
|
|
121
|
+
expect(block).toMatch(/currentFocus/);
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
test('section does NOT appear without taskmanager capability', () => {
|
|
125
|
+
const block = buildOperatingPosture(['memory']);
|
|
126
|
+
expect(block).not.toMatch(/TASK DISCIPLINE/);
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
test('section guidance is descriptive of cognitive effort, not bureaucratic checklist', () => {
|
|
130
|
+
// The aim is "task list reflects actual work", not "fill in fields".
|
|
131
|
+
const block = buildOperatingPosture(['memory', 'taskmanager']);
|
|
132
|
+
expect(block).toMatch(/cognitive effort/);
|
|
133
|
+
// Should describe what to do on tool failures — that's the main
|
|
134
|
+
// failure mode we observed.
|
|
135
|
+
expect(block).toMatch(/tool.*fail/i);
|
|
136
|
+
});
|
|
137
|
+
});
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* taskManagerTool tests for search + backfill-search-index.
|
|
3
|
+
*
|
|
4
|
+
* Pins the wiring contracts only — the TaskIndexer's internals have
|
|
5
|
+
* their own dedicated suite. We test:
|
|
6
|
+
* - search dispatches to indexer when embeddings are enabled
|
|
7
|
+
* - search falls back to substring-on-title/description when disabled
|
|
8
|
+
* - status filter forwards correctly
|
|
9
|
+
* - missing query → clean error
|
|
10
|
+
* - hits hydrate back to live tasks from agent.taskList
|
|
11
|
+
* - backfill walks agent.taskList.tasks + reports counts
|
|
12
|
+
*
|
|
13
|
+
* Mocks: stub TaskIndexer at the module boundary.
|
|
14
|
+
*/
|
|
15
|
+
|
|
16
|
+
import { jest, describe, test, expect, beforeEach } from '@jest/globals';
|
|
17
|
+
|
|
18
|
+
const mockIndexerInstance = {
|
|
19
|
+
isEnabled: true,
|
|
20
|
+
indexOne: jest.fn().mockResolvedValue({ indexed: true }),
|
|
21
|
+
deleteOne: jest.fn().mockResolvedValue({ deleted: true }),
|
|
22
|
+
backfill: jest.fn().mockResolvedValue({ ok: true, indexed: 0, skipped: 0, failed: 0 }),
|
|
23
|
+
search: jest.fn().mockResolvedValue({ enabled: true, hits: [] }),
|
|
24
|
+
};
|
|
25
|
+
const MockTaskIndexer = jest.fn(() => mockIndexerInstance);
|
|
26
|
+
jest.unstable_mockModule('../../services/embeddings/indexers/taskIndexer.js', () => ({
|
|
27
|
+
TaskIndexer: MockTaskIndexer,
|
|
28
|
+
taskToText: () => '',
|
|
29
|
+
}));
|
|
30
|
+
|
|
31
|
+
const { default: TaskManagerTool } = await import('../taskManagerTool.js');
|
|
32
|
+
|
|
33
|
+
function makeAgent(tasks = []) {
|
|
34
|
+
return {
|
|
35
|
+
id: 'agent-1',
|
|
36
|
+
taskList: { tasks },
|
|
37
|
+
status: 'active',
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
function makeTool({ embeddingsEnabled = true } = {}) {
|
|
42
|
+
const tool = new TaskManagerTool();
|
|
43
|
+
mockIndexerInstance.isEnabled = embeddingsEnabled;
|
|
44
|
+
mockIndexerInstance.search.mockClear();
|
|
45
|
+
mockIndexerInstance.backfill.mockClear();
|
|
46
|
+
MockTaskIndexer.mockClear();
|
|
47
|
+
tool.aiService = { getEmbeddingService: () => ({ isEnabled: embeddingsEnabled }) };
|
|
48
|
+
tool._taskIndexer = null;
|
|
49
|
+
return tool;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
const tasks = [
|
|
53
|
+
{ id: 't1', title: 'Refactor auth flow', description: 'Move to OAuth 2.1', status: 'pending', priority: 'high' },
|
|
54
|
+
{ id: 't2', title: 'Investigate Telegram dedup', description: 'Why are we flooding?', status: 'in_progress', priority: 'high' },
|
|
55
|
+
{ id: 't3', title: 'Update README', description: 'Add embeddings docs', status: 'completed', priority: 'medium' },
|
|
56
|
+
];
|
|
57
|
+
|
|
58
|
+
describe('taskManagerTool — search wiring', () => {
|
|
59
|
+
test('missing query → clean error', async () => {
|
|
60
|
+
const tool = makeTool();
|
|
61
|
+
const r = await tool.searchTasks(makeAgent(tasks), {});
|
|
62
|
+
expect(r.success).toBe(false);
|
|
63
|
+
expect(r.error).toMatch(/query/i);
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
test('disabled embeddings → substring fallback over title/description', async () => {
|
|
67
|
+
const tool = makeTool({ embeddingsEnabled: false });
|
|
68
|
+
const r = await tool.searchTasks(makeAgent(tasks), { query: 'telegram' });
|
|
69
|
+
expect(mockIndexerInstance.search).not.toHaveBeenCalled();
|
|
70
|
+
expect(r.mode).toBe('substring-fallback');
|
|
71
|
+
expect(r.results.some(t => t.id === 't2')).toBe(true);
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
test('disabled fallback respects status filter', async () => {
|
|
75
|
+
const tool = makeTool({ embeddingsEnabled: false });
|
|
76
|
+
const r = await tool.searchTasks(makeAgent(tasks), { query: 'auth', status: 'pending' });
|
|
77
|
+
expect(r.results.every(t => t.status === 'pending')).toBe(true);
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
test('enabled embeddings → forwards query + topK + hybrid + statusFilter to indexer', async () => {
|
|
81
|
+
const tool = makeTool();
|
|
82
|
+
mockIndexerInstance.search.mockResolvedValue({ enabled: true, hits: [] });
|
|
83
|
+
await tool.searchTasks(makeAgent(tasks), {
|
|
84
|
+
query: 'telegram', topK: 3, hybrid: false, status: 'in_progress',
|
|
85
|
+
});
|
|
86
|
+
expect(mockIndexerInstance.search).toHaveBeenCalledWith(
|
|
87
|
+
'agent-1', 'telegram',
|
|
88
|
+
{ topK: 3, hybrid: false, statusFilter: 'in_progress' },
|
|
89
|
+
);
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
test('enabled embeddings → hydrates hits back to live tasks', async () => {
|
|
93
|
+
const tool = makeTool();
|
|
94
|
+
mockIndexerInstance.search.mockResolvedValue({
|
|
95
|
+
enabled: true,
|
|
96
|
+
hits: [
|
|
97
|
+
{ id: 't2', score: 0.9, metadata: { title: 'snap', status: 'in_progress' } },
|
|
98
|
+
{ id: 'gone', score: 0.5, metadata: { title: 'archived', status: 'pending' } },
|
|
99
|
+
],
|
|
100
|
+
});
|
|
101
|
+
const r = await tool.searchTasks(makeAgent(tasks), { query: 'q' });
|
|
102
|
+
expect(r.results[0]).toMatchObject({ id: 't2', title: 'Investigate Telegram dedup', score: 0.9 });
|
|
103
|
+
expect(r.results[1]).toMatchObject({ id: 'gone', missing: true });
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
test('indexer error surfaces in result', async () => {
|
|
107
|
+
const tool = makeTool();
|
|
108
|
+
mockIndexerInstance.search.mockResolvedValue({ enabled: true, hits: [], error: 'rate-limited' });
|
|
109
|
+
const r = await tool.searchTasks(makeAgent(tasks), { query: 'q' });
|
|
110
|
+
expect(r.success).toBe(false);
|
|
111
|
+
expect(r.error).toBe('rate-limited');
|
|
112
|
+
});
|
|
113
|
+
});
|
|
114
|
+
|
|
115
|
+
describe('taskManagerTool — backfill-search-index wiring', () => {
|
|
116
|
+
test('disabled → clean error', async () => {
|
|
117
|
+
const tool = makeTool({ embeddingsEnabled: false });
|
|
118
|
+
const r = await tool.backfillTasksSearchIndex(makeAgent(tasks));
|
|
119
|
+
expect(r.success).toBe(false);
|
|
120
|
+
expect(r.message).toMatch(/not enabled/i);
|
|
121
|
+
expect(mockIndexerInstance.backfill).not.toHaveBeenCalled();
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
test('enabled → walks agent.taskList.tasks + calls indexer.backfill', async () => {
|
|
125
|
+
const tool = makeTool();
|
|
126
|
+
mockIndexerInstance.backfill.mockResolvedValue({ ok: true, indexed: 3, skipped: 0, failed: 0 });
|
|
127
|
+
const r = await tool.backfillTasksSearchIndex(makeAgent(tasks));
|
|
128
|
+
expect(mockIndexerInstance.backfill).toHaveBeenCalledWith('agent-1', tasks);
|
|
129
|
+
expect(r.success).toBe(true);
|
|
130
|
+
expect(r.indexed).toBe(3);
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
test('reports failure counts honestly', async () => {
|
|
134
|
+
const tool = makeTool();
|
|
135
|
+
mockIndexerInstance.backfill.mockResolvedValue({
|
|
136
|
+
ok: false, indexed: 0, skipped: 0, failed: 3, error: 'rate-limited',
|
|
137
|
+
});
|
|
138
|
+
const r = await tool.backfillTasksSearchIndex(makeAgent(tasks));
|
|
139
|
+
expect(r.success).toBe(false);
|
|
140
|
+
expect(r.failed).toBe(3);
|
|
141
|
+
expect(r.error).toBe('rate-limited');
|
|
142
|
+
});
|
|
143
|
+
});
|
|
@@ -0,0 +1,236 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tests for updateTask's status-transition handler.
|
|
3
|
+
*
|
|
4
|
+
* Covers the in_progress entry handler that:
|
|
5
|
+
* - Auto-loads `[memory:mem-...]` referenced memory into result.attachedMemory
|
|
6
|
+
* - Emits result.memoryNudge when no memory is attached
|
|
7
|
+
* - Surfaces a not-found error when the referenced memory was deleted
|
|
8
|
+
* - Does nothing on non-transitioning updates (already in_progress)
|
|
9
|
+
* - Does nothing for transitions to other statuses (e.g. blocked)
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
import { jest, describe, test, expect, beforeEach } from '@jest/globals';
|
|
13
|
+
import { createMockLogger } from '../../__test-utils__/mockFactories.js';
|
|
14
|
+
|
|
15
|
+
const mockLoadMemories = jest.fn();
|
|
16
|
+
const mockInitialize = jest.fn().mockResolvedValue(undefined);
|
|
17
|
+
const mockAddMemory = jest.fn();
|
|
18
|
+
jest.unstable_mockModule('../../services/memoryService.js', () => ({
|
|
19
|
+
getMemoryService: jest.fn(() => ({
|
|
20
|
+
initialize: mockInitialize,
|
|
21
|
+
addMemory: mockAddMemory,
|
|
22
|
+
loadMemories: mockLoadMemories,
|
|
23
|
+
})),
|
|
24
|
+
}));
|
|
25
|
+
|
|
26
|
+
let uuidCounter = 0;
|
|
27
|
+
jest.unstable_mockModule('uuid', () => ({
|
|
28
|
+
v4: jest.fn(() => `mock-uuid-${++uuidCounter}`),
|
|
29
|
+
}));
|
|
30
|
+
|
|
31
|
+
const { default: TaskManagerTool } = await import('../taskManagerTool.js');
|
|
32
|
+
|
|
33
|
+
function makeTool() {
|
|
34
|
+
const tool = new TaskManagerTool({ description: 'test' });
|
|
35
|
+
tool.logger = createMockLogger();
|
|
36
|
+
return tool;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
function makeContext({ taskList } = {}) {
|
|
40
|
+
const agent = {
|
|
41
|
+
id: 'agent-1',
|
|
42
|
+
name: 'Trans Test',
|
|
43
|
+
capabilities: ['memory', 'tools'],
|
|
44
|
+
taskList: taskList || { tasks: [], lastUpdated: new Date().toISOString() },
|
|
45
|
+
};
|
|
46
|
+
return {
|
|
47
|
+
agent,
|
|
48
|
+
context: {
|
|
49
|
+
agentId: 'agent-1',
|
|
50
|
+
agentName: 'Trans Test',
|
|
51
|
+
agent,
|
|
52
|
+
agentPool: {
|
|
53
|
+
getAgent: jest.fn().mockResolvedValue(agent),
|
|
54
|
+
persistAgentState: jest.fn().mockResolvedValue(undefined),
|
|
55
|
+
},
|
|
56
|
+
projectDir: '/tmp/test',
|
|
57
|
+
},
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
function makeTask(overrides = {}) {
|
|
62
|
+
return {
|
|
63
|
+
id: 'task-1',
|
|
64
|
+
title: 'Demo task',
|
|
65
|
+
description: 'No reference here',
|
|
66
|
+
status: 'pending',
|
|
67
|
+
priority: 'medium',
|
|
68
|
+
createdAt: new Date().toISOString(),
|
|
69
|
+
updatedAt: new Date().toISOString(),
|
|
70
|
+
...overrides,
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
beforeEach(() => {
|
|
75
|
+
uuidCounter = 0;
|
|
76
|
+
mockLoadMemories.mockReset();
|
|
77
|
+
mockInitialize.mockReset();
|
|
78
|
+
mockInitialize.mockResolvedValue(undefined);
|
|
79
|
+
mockAddMemory.mockReset();
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
describe('TaskManagerTool — updateTask in_progress transition handler', () => {
|
|
83
|
+
test('auto-loads attached memory when task description has [memory:mem-...] marker', async () => {
|
|
84
|
+
mockLoadMemories.mockResolvedValueOnce([
|
|
85
|
+
{ id: 'mem-abc', title: 'Task plan', content: 'step 1: ...' },
|
|
86
|
+
]);
|
|
87
|
+
const tool = makeTool();
|
|
88
|
+
const { agent, context } = makeContext();
|
|
89
|
+
agent.taskList.tasks = [makeTask({ description: '[memory:mem-abc] short summary' })];
|
|
90
|
+
|
|
91
|
+
const res = await tool.execute(
|
|
92
|
+
{ action: 'update', taskId: 'task-1', status: 'in_progress' },
|
|
93
|
+
context
|
|
94
|
+
);
|
|
95
|
+
|
|
96
|
+
expect(res.success).toBe(true);
|
|
97
|
+
expect(res.result.attachedMemory).toBeDefined();
|
|
98
|
+
expect(res.result.attachedMemory.id).toBe('mem-abc');
|
|
99
|
+
expect(res.result.attachedMemory.content).toBe('step 1: ...');
|
|
100
|
+
expect(res.result.attachedMemory._hint).toMatch(/memory append/);
|
|
101
|
+
expect(res.result.memoryNudge).toBeUndefined();
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
test('LOXIA_MEMORY_NUDGE_VARIANT=descriptive falls back to the older wording (for A/B validation)', async () => {
|
|
105
|
+
const prev = process.env.LOXIA_MEMORY_NUDGE_VARIANT;
|
|
106
|
+
process.env.LOXIA_MEMORY_NUDGE_VARIANT = 'descriptive';
|
|
107
|
+
try {
|
|
108
|
+
const tool = makeTool();
|
|
109
|
+
const { agent, context } = makeContext();
|
|
110
|
+
agent.taskList.tasks = [makeTask({ description: 'Plain task with no marker' })];
|
|
111
|
+
|
|
112
|
+
const res = await tool.execute(
|
|
113
|
+
{ action: 'update', taskId: 'task-1', status: 'in_progress' },
|
|
114
|
+
context
|
|
115
|
+
);
|
|
116
|
+
|
|
117
|
+
expect(res.success).toBe(true);
|
|
118
|
+
// Descriptive wording, NOT the imperative "VERY NEXT" phrasing.
|
|
119
|
+
expect(res.result.memoryNudge).toMatch(/Scan the.*AGENT MEMORY/);
|
|
120
|
+
expect(res.result.memoryNudge).not.toMatch(/VERY NEXT/);
|
|
121
|
+
} finally {
|
|
122
|
+
if (prev === undefined) delete process.env.LOXIA_MEMORY_NUDGE_VARIANT;
|
|
123
|
+
else process.env.LOXIA_MEMORY_NUDGE_VARIANT = prev;
|
|
124
|
+
}
|
|
125
|
+
});
|
|
126
|
+
|
|
127
|
+
test('LOXIA_MEMORY_NUDGE_VARIANT unset OR =directive emits the directive wording', async () => {
|
|
128
|
+
const prev = process.env.LOXIA_MEMORY_NUDGE_VARIANT;
|
|
129
|
+
delete process.env.LOXIA_MEMORY_NUDGE_VARIANT;
|
|
130
|
+
try {
|
|
131
|
+
const tool = makeTool();
|
|
132
|
+
const { agent, context } = makeContext();
|
|
133
|
+
agent.taskList.tasks = [makeTask({ description: 'Plain task with no marker' })];
|
|
134
|
+
|
|
135
|
+
const res = await tool.execute(
|
|
136
|
+
{ action: 'update', taskId: 'task-1', status: 'in_progress' },
|
|
137
|
+
context
|
|
138
|
+
);
|
|
139
|
+
|
|
140
|
+
expect(res.result.memoryNudge).toMatch(/VERY NEXT tool call/);
|
|
141
|
+
expect(res.result.memoryNudge).toMatch(/memory list/);
|
|
142
|
+
} finally {
|
|
143
|
+
if (prev === undefined) delete process.env.LOXIA_MEMORY_NUDGE_VARIANT;
|
|
144
|
+
else process.env.LOXIA_MEMORY_NUDGE_VARIANT = prev;
|
|
145
|
+
}
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
test('emits memoryNudge when transitioning to in_progress without any [memory:] marker', async () => {
|
|
149
|
+
const tool = makeTool();
|
|
150
|
+
const { agent, context } = makeContext();
|
|
151
|
+
agent.taskList.tasks = [makeTask({ description: 'Plain task with no marker' })];
|
|
152
|
+
|
|
153
|
+
const res = await tool.execute(
|
|
154
|
+
{ action: 'update', taskId: 'task-1', status: 'in_progress' },
|
|
155
|
+
context
|
|
156
|
+
);
|
|
157
|
+
|
|
158
|
+
expect(res.success).toBe(true);
|
|
159
|
+
expect(res.result.attachedMemory).toBeUndefined();
|
|
160
|
+
// Directive wording (post-optimization, 2026-05-19): the
|
|
161
|
+
// descriptive earlier nudge ("Scan the catalog...") scored 22% in
|
|
162
|
+
// the live multi-turn memory bench. Switching to "Your VERY NEXT
|
|
163
|
+
// tool call MUST be `memory list`" doubled it to 44%. See
|
|
164
|
+
// scripts/memory-bench/.
|
|
165
|
+
expect(res.result.memoryNudge).toMatch(/memory list/);
|
|
166
|
+
expect(res.result.memoryNudge).toMatch(/VERY NEXT tool call/);
|
|
167
|
+
expect(res.result.memoryNudge).toMatch(/memory add/);
|
|
168
|
+
expect(mockLoadMemories).not.toHaveBeenCalled();
|
|
169
|
+
});
|
|
170
|
+
|
|
171
|
+
test('surfaces error when [memory:] marker points at a deleted memory', async () => {
|
|
172
|
+
mockLoadMemories.mockResolvedValueOnce([]); // memory not found
|
|
173
|
+
const tool = makeTool();
|
|
174
|
+
const { agent, context } = makeContext();
|
|
175
|
+
agent.taskList.tasks = [makeTask({ description: '[memory:mem-ghost] gone' })];
|
|
176
|
+
|
|
177
|
+
const res = await tool.execute(
|
|
178
|
+
{ action: 'update', taskId: 'task-1', status: 'in_progress' },
|
|
179
|
+
context
|
|
180
|
+
);
|
|
181
|
+
|
|
182
|
+
expect(res.success).toBe(true);
|
|
183
|
+
expect(res.result.attachedMemory).toBeDefined();
|
|
184
|
+
expect(res.result.attachedMemory.id).toBe('mem-ghost');
|
|
185
|
+
expect(res.result.attachedMemory.error).toMatch(/not found/i);
|
|
186
|
+
expect(res.result.attachedMemory.content).toBeUndefined();
|
|
187
|
+
});
|
|
188
|
+
|
|
189
|
+
test('does NOT trigger handler when task was already in_progress (no transition)', async () => {
|
|
190
|
+
const tool = makeTool();
|
|
191
|
+
const { agent, context } = makeContext();
|
|
192
|
+
agent.taskList.tasks = [makeTask({ status: 'in_progress', description: '[memory:mem-xyz] x' })];
|
|
193
|
+
|
|
194
|
+
const res = await tool.execute(
|
|
195
|
+
{ action: 'update', taskId: 'task-1', status: 'in_progress' },
|
|
196
|
+
context
|
|
197
|
+
);
|
|
198
|
+
|
|
199
|
+
expect(res.success).toBe(true);
|
|
200
|
+
expect(res.result.attachedMemory).toBeUndefined();
|
|
201
|
+
expect(res.result.memoryNudge).toBeUndefined();
|
|
202
|
+
expect(mockLoadMemories).not.toHaveBeenCalled();
|
|
203
|
+
});
|
|
204
|
+
|
|
205
|
+
test('does NOT trigger handler for transitions to non-in_progress statuses', async () => {
|
|
206
|
+
const tool = makeTool();
|
|
207
|
+
const { agent, context } = makeContext();
|
|
208
|
+
agent.taskList.tasks = [makeTask({ status: 'pending', description: '[memory:mem-xyz] x' })];
|
|
209
|
+
|
|
210
|
+
const res = await tool.execute(
|
|
211
|
+
{ action: 'update', taskId: 'task-1', status: 'blocked' },
|
|
212
|
+
context
|
|
213
|
+
);
|
|
214
|
+
|
|
215
|
+
expect(res.success).toBe(true);
|
|
216
|
+
expect(res.result.attachedMemory).toBeUndefined();
|
|
217
|
+
expect(res.result.memoryNudge).toBeUndefined();
|
|
218
|
+
expect(mockLoadMemories).not.toHaveBeenCalled();
|
|
219
|
+
});
|
|
220
|
+
|
|
221
|
+
test('handler errors are swallowed (does not break update)', async () => {
|
|
222
|
+
mockLoadMemories.mockRejectedValueOnce(new Error('disk on fire'));
|
|
223
|
+
const tool = makeTool();
|
|
224
|
+
const { agent, context } = makeContext();
|
|
225
|
+
agent.taskList.tasks = [makeTask({ description: '[memory:mem-abc] x' })];
|
|
226
|
+
|
|
227
|
+
const res = await tool.execute(
|
|
228
|
+
{ action: 'update', taskId: 'task-1', status: 'in_progress' },
|
|
229
|
+
context
|
|
230
|
+
);
|
|
231
|
+
|
|
232
|
+
expect(res.success).toBe(true);
|
|
233
|
+
expect(res.result.attachedMemory).toBeUndefined();
|
|
234
|
+
expect(res.result.memoryNudge).toBeUndefined();
|
|
235
|
+
});
|
|
236
|
+
});
|