@crownpeak/dqm-react-component-dev-mcp 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (444) hide show
  1. package/README.md +138 -0
  2. package/data/.env.example +22 -0
  3. package/data/.gitattributes +47 -0
  4. package/data/.glfrc.json +7 -0
  5. package/data/.husky/pre-commit +5 -0
  6. package/data/.nvmrc +1 -0
  7. package/data/CHANGELOG.md +75 -0
  8. package/data/CODE_OF_CONDUCT.md +129 -0
  9. package/data/CONTRIBUTING.md +203 -0
  10. package/data/DOCS-STRUCTURE.md +307 -0
  11. package/data/I18N.md +292 -0
  12. package/data/LICENSE +22 -0
  13. package/data/README.md +315 -0
  14. package/data/SECURITY.md +125 -0
  15. package/data/WIKI-DEPLOYMENT.md +348 -0
  16. package/data/docs/AI-FEATURES.md +610 -0
  17. package/data/docs/API-REFERENCE.md +1022 -0
  18. package/data/docs/AUTHENTICATION.md +301 -0
  19. package/data/docs/BACKEND-API.md +468 -0
  20. package/data/docs/DEVELOPMENT.md +375 -0
  21. package/data/docs/EXAMPLES.md +622 -0
  22. package/data/docs/MCP-SERVER.md +307 -0
  23. package/data/docs/MIGRATION-GUIDE.md +367 -0
  24. package/data/docs/NPM-PUBLISH.md +193 -0
  25. package/data/docs/QUICKSTART.md +206 -0
  26. package/data/docs/REDIS-SETUP.md +162 -0
  27. package/data/docs/SERVER.md +228 -0
  28. package/data/docs/TROUBLESHOOTING.md +657 -0
  29. package/data/docs/WIDGET-GUIDE.md +638 -0
  30. package/data/docs/WIKI-HOME.md +58 -0
  31. package/data/docs/WIKI-SIDEBAR.md +39 -0
  32. package/data/package.json +171 -0
  33. package/data/playwright.config.ts +64 -0
  34. package/data/probe/.cargo/config.toml +10 -0
  35. package/data/probe/.claude/commands/performance-review.md +15 -0
  36. package/data/probe/.clinerules +288 -0
  37. package/data/probe/.dockerignore +57 -0
  38. package/data/probe/.githooks/post-commit +11 -0
  39. package/data/probe/.githooks/pre-commit +99 -0
  40. package/data/probe/.githooks/pre-commit-vow +9 -0
  41. package/data/probe/.prompts/engineer.md +41 -0
  42. package/data/probe/.roomodes +28 -0
  43. package/data/probe/.windsurfrules +0 -0
  44. package/data/probe/BASH_TOOL_SUMMARY.md +148 -0
  45. package/data/probe/BENCHMARKING.md +256 -0
  46. package/data/probe/CLAUDE.md +226 -0
  47. package/data/probe/CODE_OF_CONDUCT.md +128 -0
  48. package/data/probe/CONTRIBUTING.md +193 -0
  49. package/data/probe/Cargo.toml +120 -0
  50. package/data/probe/Cross.toml +10 -0
  51. package/data/probe/DOCKER-README.md +224 -0
  52. package/data/probe/Dockerfile +32 -0
  53. package/data/probe/ENHANCED_DEBUG_TELEMETRY.md +188 -0
  54. package/data/probe/LICENSE +201 -0
  55. package/data/probe/Makefile +210 -0
  56. package/data/probe/README.md +824 -0
  57. package/data/probe/SECURITY.md +67 -0
  58. package/data/probe/WINDOWS-GUIDE.md +294 -0
  59. package/data/probe/benches/parsing_benchmarks.rs +370 -0
  60. package/data/probe/benches/search_benchmarks.rs +599 -0
  61. package/data/probe/benches/simd_benchmarks.rs +372 -0
  62. package/data/probe/benches/timing_benchmarks.rs +287 -0
  63. package/data/probe/build-windows.bat +229 -0
  64. package/data/probe/codex-config/config.toml +6 -0
  65. package/data/probe/docs/PERFORMANCE_OPTIMIZATION.md +161 -0
  66. package/data/probe/examples/cache_demo.rs +46 -0
  67. package/data/probe/examples/chat/.dockerignore +37 -0
  68. package/data/probe/examples/chat/ChatSessionManager.js +295 -0
  69. package/data/probe/examples/chat/Dockerfile +98 -0
  70. package/data/probe/examples/chat/LICENSE +201 -0
  71. package/data/probe/examples/chat/LOCAL_IMAGE_SUPPORT.md +195 -0
  72. package/data/probe/examples/chat/MCP_INTEGRATION.md +400 -0
  73. package/data/probe/examples/chat/README.md +338 -0
  74. package/data/probe/examples/chat/TRACING.md +226 -0
  75. package/data/probe/examples/chat/appTracer.js +968 -0
  76. package/data/probe/examples/chat/auth.js +76 -0
  77. package/data/probe/examples/chat/bin/probe-chat.js +13 -0
  78. package/data/probe/examples/chat/build.js +104 -0
  79. package/data/probe/examples/chat/cancelRequest.js +84 -0
  80. package/data/probe/examples/chat/demo-agentic-image-flow.js +88 -0
  81. package/data/probe/examples/chat/demo-local-images.js +128 -0
  82. package/data/probe/examples/chat/fileSpanExporter.js +181 -0
  83. package/data/probe/examples/chat/implement/README.md +228 -0
  84. package/data/probe/examples/chat/implement/backends/AiderBackend.js +750 -0
  85. package/data/probe/examples/chat/implement/backends/BaseBackend.js +276 -0
  86. package/data/probe/examples/chat/implement/backends/ClaudeCodeBackend.js +767 -0
  87. package/data/probe/examples/chat/implement/backends/MockBackend.js +237 -0
  88. package/data/probe/examples/chat/implement/backends/registry.js +85 -0
  89. package/data/probe/examples/chat/implement/core/BackendManager.js +567 -0
  90. package/data/probe/examples/chat/implement/core/ImplementTool.js +354 -0
  91. package/data/probe/examples/chat/implement/core/config.js +428 -0
  92. package/data/probe/examples/chat/implement/core/timeouts.js +58 -0
  93. package/data/probe/examples/chat/implement/core/utils.js +496 -0
  94. package/data/probe/examples/chat/implement/types/BackendTypes.js +126 -0
  95. package/data/probe/examples/chat/index.js +669 -0
  96. package/data/probe/examples/chat/mcpServer.js +341 -0
  97. package/data/probe/examples/chat/npm/LICENSE +15 -0
  98. package/data/probe/examples/chat/npm/README.md +168 -0
  99. package/data/probe/examples/chat/npm/bin/probe-chat.js +156 -0
  100. package/data/probe/examples/chat/npm/index.js +259 -0
  101. package/data/probe/examples/chat/npm/package.json +54 -0
  102. package/data/probe/examples/chat/package.json +102 -0
  103. package/data/probe/examples/chat/probeChat.js +456 -0
  104. package/data/probe/examples/chat/probeTool.js +491 -0
  105. package/data/probe/examples/chat/storage/JsonChatStorage.js +476 -0
  106. package/data/probe/examples/chat/telemetry.js +281 -0
  107. package/data/probe/examples/chat/test/integration/chatFlows.test.js +320 -0
  108. package/data/probe/examples/chat/test/integration/toolCalling.test.js +471 -0
  109. package/data/probe/examples/chat/test/mocks/mockLLMProvider.js +269 -0
  110. package/data/probe/examples/chat/test/test-backends.js +90 -0
  111. package/data/probe/examples/chat/test/testUtils.js +530 -0
  112. package/data/probe/examples/chat/test/unit/backendTimeout.test.js +161 -0
  113. package/data/probe/examples/chat/test/unit/packageFiles.test.js +120 -0
  114. package/data/probe/examples/chat/test/verify-tests.js +118 -0
  115. package/data/probe/examples/chat/test-agentic-image-loading.js +294 -0
  116. package/data/probe/examples/chat/test-ai-sdk-telemetry.js +204 -0
  117. package/data/probe/examples/chat/test-chat-tracing.js +38 -0
  118. package/data/probe/examples/chat/test-direct-function.js +49 -0
  119. package/data/probe/examples/chat/test-file-size-validation.js +103 -0
  120. package/data/probe/examples/chat/test-full-mcp-integration.js +258 -0
  121. package/data/probe/examples/chat/test-github-context.txt +12 -0
  122. package/data/probe/examples/chat/test-hierarchy.js +203 -0
  123. package/data/probe/examples/chat/test-image-spans.js +37 -0
  124. package/data/probe/examples/chat/test-local-image-reading.js +176 -0
  125. package/data/probe/examples/chat/test-mcp-integration.js +136 -0
  126. package/data/probe/examples/chat/test-mcp-probe-server.js +161 -0
  127. package/data/probe/examples/chat/test-mcp-with-ai.js +279 -0
  128. package/data/probe/examples/chat/test-multiple-allowed-dirs.js +111 -0
  129. package/data/probe/examples/chat/test-probe-mcp-server.js +110 -0
  130. package/data/probe/examples/chat/test-security-validation.js +145 -0
  131. package/data/probe/examples/chat/test-simple-tracing.js +32 -0
  132. package/data/probe/examples/chat/test-trace-verification.js +235 -0
  133. package/data/probe/examples/chat/test-tracing.js +114 -0
  134. package/data/probe/examples/chat/tokenCounter.js +419 -0
  135. package/data/probe/examples/chat/tokenUsageDisplay.js +134 -0
  136. package/data/probe/examples/chat/webServer.js +1103 -0
  137. package/data/probe/examples/reranker/Cargo.toml +33 -0
  138. package/data/probe/examples/reranker/DEBUG_OUTPUT_ANALYSIS.md +71 -0
  139. package/data/probe/examples/reranker/MODELS.md +66 -0
  140. package/data/probe/examples/reranker/MODEL_COMPARISON.md +60 -0
  141. package/data/probe/examples/reranker/MULTI_MODEL_ANALYSIS.md +176 -0
  142. package/data/probe/examples/reranker/PERFORMANCE_SUMMARY.md +156 -0
  143. package/data/probe/examples/reranker/README.md +347 -0
  144. package/data/probe/examples/reranker/RUST_BERT_COMPARISON.md +82 -0
  145. package/data/probe/examples/reranker/TOKENIZATION_GUIDE.md +120 -0
  146. package/data/probe/examples/reranker/check_rust_tokenizer.py +108 -0
  147. package/data/probe/examples/reranker/convert_to_torchscript.py +109 -0
  148. package/data/probe/examples/reranker/debug_scoring.py +189 -0
  149. package/data/probe/examples/reranker/debug_tokenization.py +154 -0
  150. package/data/probe/examples/reranker/download_models.sh +73 -0
  151. package/data/probe/examples/reranker/requirements.txt +13 -0
  152. package/data/probe/examples/reranker/run_comprehensive_benchmark.sh +83 -0
  153. package/data/probe/examples/reranker/rust_bert_test/Cargo.toml +12 -0
  154. package/data/probe/examples/reranker/rust_bert_test/README.md +54 -0
  155. package/data/probe/examples/reranker/simple_test.py +50 -0
  156. package/data/probe/examples/reranker/test_all_models.sh +63 -0
  157. package/data/probe/examples/reranker/test_bert_results.sh +44 -0
  158. package/data/probe/examples/reranker/test_cross_encoder.py +334 -0
  159. package/data/probe/examples/reranker/test_cross_encoder.sh +80 -0
  160. package/data/probe/examples/reranker/test_exact_comparison.py +151 -0
  161. package/data/probe/examples/reranker/test_parallel_performance.sh +56 -0
  162. package/data/probe/examples/reranker/test_scores.py +132 -0
  163. package/data/probe/install.ps1 +508 -0
  164. package/data/probe/install.sh +460 -0
  165. package/data/probe/npm/CLONE_METHOD_EXAMPLES.md +596 -0
  166. package/data/probe/npm/CONTEXT_COMPACTION.md +303 -0
  167. package/data/probe/npm/DELEGATE_TOOL_README.md +166 -0
  168. package/data/probe/npm/MAID_INTEGRATION.md +313 -0
  169. package/data/probe/npm/MCP_INTEGRATION_SUMMARY.md +241 -0
  170. package/data/probe/npm/README.md +824 -0
  171. package/data/probe/npm/bin/.gitignore +7 -0
  172. package/data/probe/npm/bin/.gitkeep +0 -0
  173. package/data/probe/npm/bin/README.md +12 -0
  174. package/data/probe/npm/bin/probe +167 -0
  175. package/data/probe/npm/docs/CLAUDE_CODE_INTEGRATION.md +414 -0
  176. package/data/probe/npm/docs/CODEX_INTEGRATION.md +502 -0
  177. package/data/probe/npm/docs/EDIT_CREATE_TOOLS.md +233 -0
  178. package/data/probe/npm/docs/RETRY_AND_FALLBACK.md +674 -0
  179. package/data/probe/npm/example-usage.js +335 -0
  180. package/data/probe/npm/examples/multi-engine-demo.js +117 -0
  181. package/data/probe/npm/examples/probe-agent-cli.js +113 -0
  182. package/data/probe/npm/examples/test-agent-edit.js +114 -0
  183. package/data/probe/npm/examples/test-edit-create.js +120 -0
  184. package/data/probe/npm/examples/test-edit-direct.js +114 -0
  185. package/data/probe/npm/index.d.ts +744 -0
  186. package/data/probe/npm/jest.config.js +52 -0
  187. package/data/probe/npm/package.json +117 -0
  188. package/data/probe/npm/scripts/build-agent.cjs +75 -0
  189. package/data/probe/npm/scripts/build-cjs.js +124 -0
  190. package/data/probe/npm/scripts/build-mcp.cjs +36 -0
  191. package/data/probe/npm/scripts/postinstall.js +216 -0
  192. package/data/probe/npm/test-codex-e2e.js +78 -0
  193. package/data/probe/npm/test-download-lock.js +109 -0
  194. package/data/probe/npm/test-grep-security.js +94 -0
  195. package/data/probe/npm/test-grep-simplified.js +63 -0
  196. package/data/probe/npm/test-grep.js +51 -0
  197. package/data/probe/npm/tests/README.md +96 -0
  198. package/data/probe/npm/tests/agent-compact-history.test.js +174 -0
  199. package/data/probe/npm/tests/allow-tests-default.test.js +151 -0
  200. package/data/probe/npm/tests/contextCompactor.test.js +498 -0
  201. package/data/probe/npm/tests/delegate-config.test.js +353 -0
  202. package/data/probe/npm/tests/delegate-integration.test.js +348 -0
  203. package/data/probe/npm/tests/extractor-integration.test.js +162 -0
  204. package/data/probe/npm/tests/extractor.test.js +317 -0
  205. package/data/probe/npm/tests/fixtures/sampleDiagrams.js +267 -0
  206. package/data/probe/npm/tests/integration/claude-code-auto-fallback.spec.js +148 -0
  207. package/data/probe/npm/tests/integration/claude-code-multi-step.spec.js +127 -0
  208. package/data/probe/npm/tests/integration/claude-code-tool-events.spec.js +163 -0
  209. package/data/probe/npm/tests/integration/codex-auto-fallback.spec.js +191 -0
  210. package/data/probe/npm/tests/integration/codex-tool-events.spec.js +147 -0
  211. package/data/probe/npm/tests/integration/examplesChatMcp.test.js +402 -0
  212. package/data/probe/npm/tests/integration/mcpDotenvSupport.test.js +174 -0
  213. package/data/probe/npm/tests/integration/mcpErrorHandling.test.js +566 -0
  214. package/data/probe/npm/tests/integration/mcpRobustness.test.js +564 -0
  215. package/data/probe/npm/tests/integration/mcpStdoutPurity.test.js +355 -0
  216. package/data/probe/npm/tests/integration/probeAgentMcp.test.js +398 -0
  217. package/data/probe/npm/tests/integration/retryFallback.test.js +368 -0
  218. package/data/probe/npm/tests/integration/schema-in-initial-message.test.js +318 -0
  219. package/data/probe/npm/tests/integration/schema-validation-loop-prevention.test.js +244 -0
  220. package/data/probe/npm/tests/integration/schemaRetryLogic.test.js +94 -0
  221. package/data/probe/npm/tests/integration/validationFlow.test.js +329 -0
  222. package/data/probe/npm/tests/manual/test-codex-basic.js +110 -0
  223. package/data/probe/npm/tests/mcp/mcpClientManager.test.js +614 -0
  224. package/data/probe/npm/tests/mcp/mcpConfig.test.js +359 -0
  225. package/data/probe/npm/tests/mcp/mcpXmlBridge.test.js +436 -0
  226. package/data/probe/npm/tests/mcp/mockMcpServer.js +510 -0
  227. package/data/probe/npm/tests/mcp-strict-syntax.test.js +319 -0
  228. package/data/probe/npm/tests/mermaidQuoteEscaping.test.js +214 -0
  229. package/data/probe/npm/tests/nestedQuoteFix.test.js +40 -0
  230. package/data/probe/npm/tests/setup.js +46 -0
  231. package/data/probe/npm/tests/unit/allowed-tools.test.js +513 -0
  232. package/data/probe/npm/tests/unit/attempt-completion-closing-tag-in-content.test.js +188 -0
  233. package/data/probe/npm/tests/unit/attemptCompletionJsonFix.test.js +238 -0
  234. package/data/probe/npm/tests/unit/attemptCompletionJsonIssue.test.js +128 -0
  235. package/data/probe/npm/tests/unit/backtickAutoFix.test.js +35 -0
  236. package/data/probe/npm/tests/unit/bash-probe-agent-integration.test.js +389 -0
  237. package/data/probe/npm/tests/unit/bash-simple-commands.test.js +324 -0
  238. package/data/probe/npm/tests/unit/bash-tool-comprehensive.test.js +371 -0
  239. package/data/probe/npm/tests/unit/bash-tool-integration.test.js +310 -0
  240. package/data/probe/npm/tests/unit/bash-tool.test.js +341 -0
  241. package/data/probe/npm/tests/unit/completion-prompt.test.js +379 -0
  242. package/data/probe/npm/tests/unit/cwd-path-options.test.js +287 -0
  243. package/data/probe/npm/tests/unit/delegate-limits.test.js +422 -0
  244. package/data/probe/npm/tests/unit/direct-content-attempt-completion.test.js +235 -0
  245. package/data/probe/npm/tests/unit/edit-create-tools.test.js +609 -0
  246. package/data/probe/npm/tests/unit/enhancedMermaidValidation.test.js +577 -0
  247. package/data/probe/npm/tests/unit/extract-content.test.js +83 -0
  248. package/data/probe/npm/tests/unit/extract-multiple-targets.test.js +89 -0
  249. package/data/probe/npm/tests/unit/fallbackManager.test.js +442 -0
  250. package/data/probe/npm/tests/unit/githubCompatibilityValidation.test.js +258 -0
  251. package/data/probe/npm/tests/unit/imageConfig.test.js +149 -0
  252. package/data/probe/npm/tests/unit/imagePathResolution.test.js +345 -0
  253. package/data/probe/npm/tests/unit/json-fixing-agent.test.js +238 -0
  254. package/data/probe/npm/tests/unit/json-validation-enhanced-errors.test.js +199 -0
  255. package/data/probe/npm/tests/unit/jsonValidationInfiniteLoopFix.test.js +228 -0
  256. package/data/probe/npm/tests/unit/maidIntegration.test.js +139 -0
  257. package/data/probe/npm/tests/unit/maxIterationsWarning.test.js +195 -0
  258. package/data/probe/npm/tests/unit/mermaidEdgeLabelFix.test.js +161 -0
  259. package/data/probe/npm/tests/unit/mermaidHtmlEntities.test.js +76 -0
  260. package/data/probe/npm/tests/unit/mermaidInfiniteLoopFix.test.js +64 -0
  261. package/data/probe/npm/tests/unit/mermaidValidation.test.js +723 -0
  262. package/data/probe/npm/tests/unit/mermaidValidationVisorExample.test.js +309 -0
  263. package/data/probe/npm/tests/unit/probe-agent-clone-realistic.test.js +643 -0
  264. package/data/probe/npm/tests/unit/probe-agent-clone.test.js +476 -0
  265. package/data/probe/npm/tests/unit/probe-agent-delegate.test.js +400 -0
  266. package/data/probe/npm/tests/unit/probe-agent-model-option.test.js +118 -0
  267. package/data/probe/npm/tests/unit/probeTool-security.test.js +283 -0
  268. package/data/probe/npm/tests/unit/readImageTool.test.js +418 -0
  269. package/data/probe/npm/tests/unit/retryManager.test.js +317 -0
  270. package/data/probe/npm/tests/unit/schema-aware-reminders.test.js +288 -0
  271. package/data/probe/npm/tests/unit/schemaDefinitionDetection.test.js +115 -0
  272. package/data/probe/npm/tests/unit/schemaUtils.test.js +1268 -0
  273. package/data/probe/npm/tests/unit/simpleTelemetry.test.js +282 -0
  274. package/data/probe/npm/tests/unit/simplified-attempt-completion.test.js +274 -0
  275. package/data/probe/npm/tests/unit/single-quote-json-bug.test.js +231 -0
  276. package/data/probe/npm/tests/unit/subgraphAutoFix.test.js +110 -0
  277. package/data/probe/npm/tests/unit/system-prompt.test.js +32 -0
  278. package/data/probe/npm/tests/unit/types-probe-agent-options.test.js +42 -0
  279. package/data/probe/npm/tests/unit/xmlParsing.test.js +720 -0
  280. package/data/probe/npm/tsconfig.json +21 -0
  281. package/data/probe/result1.txt +19 -0
  282. package/data/probe/result2.txt +26 -0
  283. package/data/probe/scripts/benchmark.sh +270 -0
  284. package/data/probe/scripts/cache_memory_analysis.rs +844 -0
  285. package/data/probe/scripts/claude-hook-wrapper.sh +56 -0
  286. package/data/probe/site/.env.example +10 -0
  287. package/data/probe/site/DEPLOYMENT.md +86 -0
  288. package/data/probe/site/README.md +183 -0
  289. package/data/probe/site/adding-languages.md +135 -0
  290. package/data/probe/site/ai-chat.md +427 -0
  291. package/data/probe/site/ai-integration.md +1488 -0
  292. package/data/probe/site/blog/agentic-flow-custom-xml-protocol.md +407 -0
  293. package/data/probe/site/blog/index.md +118 -0
  294. package/data/probe/site/blog/v0.6.0-release.md +426 -0
  295. package/data/probe/site/blog.md +8 -0
  296. package/data/probe/site/changelog.md +200 -0
  297. package/data/probe/site/cli-mode.md +437 -0
  298. package/data/probe/site/code-extraction.md +436 -0
  299. package/data/probe/site/contributing/README.md +9 -0
  300. package/data/probe/site/contributing/documentation-cross-references.md +215 -0
  301. package/data/probe/site/contributing/documentation-maintenance.md +275 -0
  302. package/data/probe/site/contributing/documentation-structure.md +75 -0
  303. package/data/probe/site/documentation-cross-references.md +215 -0
  304. package/data/probe/site/documentation-guide.md +132 -0
  305. package/data/probe/site/documentation-maintenance.md +275 -0
  306. package/data/probe/site/features.md +147 -0
  307. package/data/probe/site/how-it-works.md +118 -0
  308. package/data/probe/site/index.md +175 -0
  309. package/data/probe/site/index.md.bak +133 -0
  310. package/data/probe/site/installation.md +235 -0
  311. package/data/probe/site/integrations/docker.md +248 -0
  312. package/data/probe/site/integrations/github-actions.md +413 -0
  313. package/data/probe/site/language-support-overview.md +168 -0
  314. package/data/probe/site/mcp-integration.md +587 -0
  315. package/data/probe/site/mcp-server.md +304 -0
  316. package/data/probe/site/navigation-structure.md +76 -0
  317. package/data/probe/site/nodejs-sdk.md +798 -0
  318. package/data/probe/site/output-formats.md +625 -0
  319. package/data/probe/site/package.json +21 -0
  320. package/data/probe/site/public/_headers +28 -0
  321. package/data/probe/site/public/_redirects +11 -0
  322. package/data/probe/site/quick-start.md +289 -0
  323. package/data/probe/site/search-functionality.md +291 -0
  324. package/data/probe/site/search-reference.md +291 -0
  325. package/data/probe/site/supported-languages.md +215 -0
  326. package/data/probe/site/use-cases/README.md +8 -0
  327. package/data/probe/site/use-cases/advanced-cli.md +253 -0
  328. package/data/probe/site/use-cases/ai-code-editors.md +239 -0
  329. package/data/probe/site/use-cases/building-ai-tools.md +529 -0
  330. package/data/probe/site/use-cases/cli-ai-workflows.md +285 -0
  331. package/data/probe/site/use-cases/deploying-probe-web-interface.md +255 -0
  332. package/data/probe/site/use-cases/integrating-probe-into-ai-code-editors.md +161 -0
  333. package/data/probe/site/use-cases/nodejs-sdk.md +596 -0
  334. package/data/probe/site/use-cases/team-chat.md +350 -0
  335. package/data/probe/site/web-interface.md +434 -0
  336. package/data/probe/site/wrangler.toml +9 -0
  337. package/data/probe/test-api-key.sh +1 -0
  338. package/data/probe/test-probe-implementation/hello.js +7 -0
  339. package/data/probe/test_cases/demonstrate_early_termination_issues.sh +176 -0
  340. package/data/probe/test_cases/early_termination_issues.rs +533 -0
  341. package/data/probe/test_data/test_nested_struct.go +26 -0
  342. package/data/probe/tests/README.md +286 -0
  343. package/data/probe/tests/README_search_determinism_tests.md +116 -0
  344. package/data/probe/tests/adjacent_comment_test.rs +152 -0
  345. package/data/probe/tests/apostrophe_handling_tests.rs +132 -0
  346. package/data/probe/tests/block_filtering_with_ast_tests.rs +669 -0
  347. package/data/probe/tests/block_merging_tests.rs +396 -0
  348. package/data/probe/tests/c_outline_format_tests.rs +2179 -0
  349. package/data/probe/tests/cache_invalidation_issues.rs.disabled +682 -0
  350. package/data/probe/tests/cache_order_tests.rs +147 -0
  351. package/data/probe/tests/cache_query_scoping_tests.rs +221 -0
  352. package/data/probe/tests/cli_tests.rs +680 -0
  353. package/data/probe/tests/comment_context_integration_test.rs +240 -0
  354. package/data/probe/tests/common.rs +33 -0
  355. package/data/probe/tests/complex_block_merging_tests.rs +599 -0
  356. package/data/probe/tests/complex_query_block_filtering_tests.rs +422 -0
  357. package/data/probe/tests/control_flow_closing_braces_test.rs +91 -0
  358. package/data/probe/tests/cpp_outline_format_tests.rs +1507 -0
  359. package/data/probe/tests/csharp_outline_format_tests.rs +941 -0
  360. package/data/probe/tests/elastic_query_integration_tests.rs +922 -0
  361. package/data/probe/tests/extract_command_tests.rs +1848 -0
  362. package/data/probe/tests/extract_deduplication_tests.rs +146 -0
  363. package/data/probe/tests/extract_input_file_tests.rs +84 -0
  364. package/data/probe/tests/extract_prompt_tests.rs +102 -0
  365. package/data/probe/tests/filename_search_tests.rs +96 -0
  366. package/data/probe/tests/fixtures/user/AssemblyInfo.cs +3 -0
  367. package/data/probe/tests/github_extract_tests.rs +234 -0
  368. package/data/probe/tests/go_comment_test.rs +253 -0
  369. package/data/probe/tests/go_outline_format_tests.rs +2587 -0
  370. package/data/probe/tests/go_path_resolver_tests.rs +96 -0
  371. package/data/probe/tests/html_outline_format_tests.rs +637 -0
  372. package/data/probe/tests/integration_tests.rs +837 -0
  373. package/data/probe/tests/ip_whitelist_test.rs +148 -0
  374. package/data/probe/tests/java_outline_format_tests.rs +1611 -0
  375. package/data/probe/tests/javascript_extract_tests.rs +315 -0
  376. package/data/probe/tests/javascript_outline_format_tests.rs +1464 -0
  377. package/data/probe/tests/json_format_tests.rs +436 -0
  378. package/data/probe/tests/json_schema_validation_tests.rs +450 -0
  379. package/data/probe/tests/lib_usage.rs +60 -0
  380. package/data/probe/tests/line_comment_context_extension_test.rs +459 -0
  381. package/data/probe/tests/line_map_cache_tests.rs +114 -0
  382. package/data/probe/tests/markdown_integration_tests.rs +190 -0
  383. package/data/probe/tests/mocks/test_ip_whitelist.go +11 -0
  384. package/data/probe/tests/mocks/test_object.js +27 -0
  385. package/data/probe/tests/mocks/test_struct.go +50 -0
  386. package/data/probe/tests/multi_keyword_pattern_tests.rs +464 -0
  387. package/data/probe/tests/multi_language_syntax_integration_tests.rs +218 -0
  388. package/data/probe/tests/multiple_capture_groups_tests.rs +169 -0
  389. package/data/probe/tests/negative_compound_word_tests.rs +246 -0
  390. package/data/probe/tests/nested_symbol_extraction_tests.rs +99 -0
  391. package/data/probe/tests/outline_cross_file_interference_test.rs +335 -0
  392. package/data/probe/tests/outline_keyword_preservation_test.rs +67 -0
  393. package/data/probe/tests/output_format_edge_cases_tests.rs +693 -0
  394. package/data/probe/tests/parallel_extraction_tests.rs +178 -0
  395. package/data/probe/tests/parallel_search_tests.rs +355 -0
  396. package/data/probe/tests/path_resolver_tests.rs +698 -0
  397. package/data/probe/tests/php_outline_format_extended_tests.rs +928 -0
  398. package/data/probe/tests/php_outline_format_tests.rs +768 -0
  399. package/data/probe/tests/property_tests.proptest-regressions +9 -0
  400. package/data/probe/tests/property_tests.rs +118 -0
  401. package/data/probe/tests/python_outline_format_tests.rs +1538 -0
  402. package/data/probe/tests/query_command_json_tests.rs +438 -0
  403. package/data/probe/tests/query_command_tests.rs +232 -0
  404. package/data/probe/tests/query_command_xml_tests.rs +569 -0
  405. package/data/probe/tests/quoted_term_with_negative_keyword_tests.rs +216 -0
  406. package/data/probe/tests/required_terms_filename_tests.rs +116 -0
  407. package/data/probe/tests/ruby_outline_format_tests.rs +1011 -0
  408. package/data/probe/tests/rust_line_comment_context_test.rs +151 -0
  409. package/data/probe/tests/rust_outline_format_enhanced_tests.rs +725 -0
  410. package/data/probe/tests/rust_outline_format_tests.rs +843 -0
  411. package/data/probe/tests/schemas/xml_output_schema.xsd +38 -0
  412. package/data/probe/tests/search_determinism_tests.rs +451 -0
  413. package/data/probe/tests/search_hints_tests.rs +253 -0
  414. package/data/probe/tests/special_character_escaping_tests.rs +417 -0
  415. package/data/probe/tests/stemming_compound_word_filtering_tests.rs +535 -0
  416. package/data/probe/tests/strict_elastic_syntax_tests.rs +404 -0
  417. package/data/probe/tests/swift_outline_format_tests.rs +3319 -0
  418. package/data/probe/tests/symbols_tests.rs +166 -0
  419. package/data/probe/tests/test_file.rs +45 -0
  420. package/data/probe/tests/test_tokenize.rs +28 -0
  421. package/data/probe/tests/timeout_tests.rs +82 -0
  422. package/data/probe/tests/tokenization_tests.rs +195 -0
  423. package/data/probe/tests/tokenized_block_filtering_tests.rs +174 -0
  424. package/data/probe/tests/typescript_extract_tests.rs +214 -0
  425. package/data/probe/tests/typescript_outline_format_tests.rs +2188 -0
  426. package/data/probe/tests/xml_format_tests.rs +568 -0
  427. package/data/probe/tests/xml_schema_validation_tests.rs +497 -0
  428. package/data/scripts/postinstall.mjs +9 -0
  429. package/data/scripts/set-version.js +0 -0
  430. package/data/scripts/wiki-build.sh +111 -0
  431. package/data/scripts/wiki-deploy.sh +73 -0
  432. package/data/serve.json +12 -0
  433. package/data/test/demo-dynamic.html +134 -0
  434. package/data/test/demo-esm.html +105 -0
  435. package/data/test/demo-iife.html +78 -0
  436. package/data/tsconfig.json +7 -0
  437. package/data/vite.server.ts +483 -0
  438. package/data/vitest.config.ts +40 -0
  439. package/data/wiki/Home.md +58 -0
  440. package/data/wiki/_Sidebar.md +39 -0
  441. package/docs-mcp.config.json +20 -0
  442. package/package.json +56 -0
  443. package/src/config.js +111 -0
  444. package/src/index.js +395 -0
@@ -0,0 +1,513 @@
1
+ import { describe, test, expect, beforeEach } from '@jest/globals';
2
+ import { ProbeAgent } from '../../src/agent/ProbeAgent.js';
3
+
4
+ describe('ProbeAgent allowedTools option', () => {
5
+ describe('_parseAllowedTools helper', () => {
6
+ test('should default to all tools when allowedTools is undefined', () => {
7
+ const agent = new ProbeAgent({
8
+ path: process.cwd()
9
+ });
10
+
11
+ expect(agent.allowedTools.mode).toBe('all');
12
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
13
+ expect(agent.allowedTools.isEnabled('query')).toBe(true);
14
+ expect(agent.allowedTools.isEnabled('bash')).toBe(true);
15
+ });
16
+
17
+ test('should allow all tools with ["*"]', () => {
18
+ const agent = new ProbeAgent({
19
+ path: process.cwd(),
20
+ allowedTools: ['*']
21
+ });
22
+
23
+ expect(agent.allowedTools.mode).toBe('all');
24
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
25
+ expect(agent.allowedTools.isEnabled('query')).toBe(true);
26
+ expect(agent.allowedTools.isEnabled('bash')).toBe(true);
27
+ expect(agent.allowedTools.isEnabled('implement')).toBe(true);
28
+ });
29
+
30
+ test('should support exclusions with "*" and "!" prefix', () => {
31
+ const agent = new ProbeAgent({
32
+ path: process.cwd(),
33
+ allowedTools: ['*', '!bash', '!implement']
34
+ });
35
+
36
+ expect(agent.allowedTools.mode).toBe('all');
37
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
38
+ expect(agent.allowedTools.isEnabled('query')).toBe(true);
39
+ expect(agent.allowedTools.isEnabled('bash')).toBe(false);
40
+ expect(agent.allowedTools.isEnabled('implement')).toBe(false);
41
+ });
42
+
43
+ test('should disable all tools with empty array', () => {
44
+ const agent = new ProbeAgent({
45
+ path: process.cwd(),
46
+ allowedTools: []
47
+ });
48
+
49
+ expect(agent.allowedTools.mode).toBe('none');
50
+ expect(agent.allowedTools.isEnabled('search')).toBe(false);
51
+ expect(agent.allowedTools.isEnabled('query')).toBe(false);
52
+ expect(agent.allowedTools.isEnabled('bash')).toBe(false);
53
+ expect(agent.allowedTools.isEnabled('attempt_completion')).toBe(false);
54
+ });
55
+
56
+ test('should allow specific tools only (whitelist mode)', () => {
57
+ const agent = new ProbeAgent({
58
+ path: process.cwd(),
59
+ allowedTools: ['search', 'query', 'extract']
60
+ });
61
+
62
+ expect(agent.allowedTools.mode).toBe('whitelist');
63
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
64
+ expect(agent.allowedTools.isEnabled('query')).toBe(true);
65
+ expect(agent.allowedTools.isEnabled('extract')).toBe(true);
66
+ expect(agent.allowedTools.isEnabled('bash')).toBe(false);
67
+ expect(agent.allowedTools.isEnabled('implement')).toBe(false);
68
+ expect(agent.allowedTools.isEnabled('listFiles')).toBe(false);
69
+ });
70
+
71
+ test('should ignore exclusions in whitelist mode', () => {
72
+ const agent = new ProbeAgent({
73
+ path: process.cwd(),
74
+ allowedTools: ['search', 'query', '!bash']
75
+ });
76
+
77
+ expect(agent.allowedTools.mode).toBe('whitelist');
78
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
79
+ expect(agent.allowedTools.isEnabled('query')).toBe(true);
80
+ expect(agent.allowedTools.isEnabled('bash')).toBe(false);
81
+ });
82
+ });
83
+
84
+ describe('tool filtering behavior', () => {
85
+ test('should not initialize tools when disableTools is true', async () => {
86
+ const agent = new ProbeAgent({
87
+ path: process.cwd(),
88
+ disableTools: true
89
+ });
90
+
91
+ // initializeTools runs in constructor; initialize() not required for toolImplementations
92
+ expect(agent.toolImplementations.search).toBeUndefined();
93
+ expect(agent.toolImplementations.query).toBeUndefined();
94
+ expect(agent.toolImplementations.extract).toBeUndefined();
95
+ expect(agent.toolImplementations.listFiles).toBeUndefined();
96
+ expect(agent.toolImplementations.readImage).toBeUndefined();
97
+ });
98
+
99
+ test('should only initialize allowed tools', async () => {
100
+ const agent = new ProbeAgent({
101
+ path: process.cwd(),
102
+ allowedTools: ['search', 'query']
103
+ });
104
+
105
+ expect(agent.toolImplementations.search).toBeDefined();
106
+ expect(agent.toolImplementations.query).toBeDefined();
107
+ expect(agent.toolImplementations.extract).toBeUndefined();
108
+ expect(agent.toolImplementations.listFiles).toBeUndefined();
109
+ expect(agent.toolImplementations.readImage).toBeUndefined();
110
+ });
111
+
112
+ test('should filter tools in initialization', async () => {
113
+ const agent = new ProbeAgent({
114
+ path: process.cwd(),
115
+ allowedTools: ['search', 'extract']
116
+ });
117
+
118
+ // Tool implementations should respect the filter
119
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
120
+ expect(agent.allowedTools.isEnabled('extract')).toBe(true);
121
+ expect(agent.allowedTools.isEnabled('query')).toBe(false);
122
+ expect(agent.allowedTools.isEnabled('bash')).toBe(false);
123
+ });
124
+
125
+ test('should respect both allowEdit flag and allowedTools', () => {
126
+ const agent = new ProbeAgent({
127
+ path: process.cwd(),
128
+ allowEdit: true,
129
+ allowedTools: ['*', '!implement']
130
+ });
131
+
132
+ // Edit and create should be enabled (allowEdit=true, not in exclusion list)
133
+ expect(agent.allowedTools.isEnabled('edit')).toBe(true);
134
+ expect(agent.allowedTools.isEnabled('create')).toBe(true);
135
+ // Implement should be excluded (in exclusion list)
136
+ expect(agent.allowedTools.isEnabled('implement')).toBe(false);
137
+ });
138
+
139
+ test('should respect both enableBash flag and allowedTools', () => {
140
+ const agent = new ProbeAgent({
141
+ path: process.cwd(),
142
+ enableBash: true,
143
+ allowedTools: ['search', 'extract']
144
+ });
145
+
146
+ // Bash should not be allowed even though enableBash=true
147
+ // because it's not in the allowedTools whitelist
148
+ expect(agent.allowedTools.isEnabled('bash')).toBe(false);
149
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
150
+ expect(agent.allowedTools.isEnabled('extract')).toBe(true);
151
+ });
152
+
153
+ test('should allow bash when both enableBash and allowedTools permit it', () => {
154
+ const agent = new ProbeAgent({
155
+ path: process.cwd(),
156
+ enableBash: true,
157
+ allowedTools: ['*']
158
+ });
159
+
160
+ expect(agent.allowedTools.isEnabled('bash')).toBe(true);
161
+ });
162
+ });
163
+
164
+ describe('tool execution with allowedTools', () => {
165
+ test('should block tool execution when not in allowedTools', async () => {
166
+ const agent = new ProbeAgent({
167
+ path: process.cwd(),
168
+ allowedTools: ['search', 'attempt_completion']
169
+ });
170
+ await agent.initialize();
171
+
172
+ // Mock the AI to try using the 'query' tool which is not allowed
173
+ const mockAIResponse = `<thinking>I need to use the query tool</thinking>
174
+ <query>
175
+ <pattern>function</pattern>
176
+ <path>.</path>
177
+ </query>`;
178
+
179
+ // We can't easily test the full flow without mocking, but we can verify
180
+ // that the tool check works in the _parseAllowedTools logic
181
+ expect(agent.allowedTools.isEnabled('query')).toBe(false);
182
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
183
+ });
184
+ });
185
+
186
+ describe('raw AI mode (no tools)', () => {
187
+ test('should set raw AI mode with empty allowedTools array', () => {
188
+ const agent = new ProbeAgent({
189
+ path: process.cwd(),
190
+ allowedTools: []
191
+ });
192
+
193
+ expect(agent.allowedTools.mode).toBe('none');
194
+ expect(agent.allowedTools.isEnabled('search')).toBe(false);
195
+ expect(agent.allowedTools.isEnabled('attempt_completion')).toBe(false);
196
+ });
197
+ });
198
+
199
+ describe('clone with allowedTools', () => {
200
+ test('should preserve allowedTools configuration in clone', () => {
201
+ const baseAgent = new ProbeAgent({
202
+ path: process.cwd(),
203
+ allowedTools: ['search', 'query']
204
+ });
205
+
206
+ const cloned = baseAgent.clone();
207
+
208
+ expect(cloned.allowedTools.mode).toBe('whitelist');
209
+ expect(cloned.allowedTools.isEnabled('search')).toBe(true);
210
+ expect(cloned.allowedTools.isEnabled('query')).toBe(true);
211
+ expect(cloned.allowedTools.isEnabled('bash')).toBe(false);
212
+ });
213
+
214
+ test('should preserve exclusions in clone', () => {
215
+ const baseAgent = new ProbeAgent({
216
+ path: process.cwd(),
217
+ allowedTools: ['*', '!bash', '!implement']
218
+ });
219
+
220
+ const cloned = baseAgent.clone();
221
+
222
+ expect(cloned.allowedTools.mode).toBe('all');
223
+ expect(cloned.allowedTools.isEnabled('search')).toBe(true);
224
+ expect(cloned.allowedTools.isEnabled('query')).toBe(true);
225
+ expect(cloned.allowedTools.isEnabled('bash')).toBe(false);
226
+ expect(cloned.allowedTools.isEnabled('implement')).toBe(false);
227
+ });
228
+
229
+ test('should allow override of allowedTools in clone', () => {
230
+ const baseAgent = new ProbeAgent({
231
+ path: process.cwd(),
232
+ allowedTools: ['search']
233
+ });
234
+
235
+ const cloned = baseAgent.clone({
236
+ overrides: {
237
+ allowedTools: ['query', 'extract']
238
+ }
239
+ });
240
+
241
+ expect(baseAgent.allowedTools.isEnabled('search')).toBe(true);
242
+ expect(baseAgent.allowedTools.isEnabled('query')).toBe(false);
243
+
244
+ expect(cloned.allowedTools.isEnabled('search')).toBe(false);
245
+ expect(cloned.allowedTools.isEnabled('query')).toBe(true);
246
+ expect(cloned.allowedTools.isEnabled('extract')).toBe(true);
247
+ });
248
+ });
249
+
250
+ describe('invalid tool names', () => {
251
+ test('should accept invalid tool names in whitelist mode without error', () => {
252
+ // This allows for forward compatibility with new tools
253
+ const agent = new ProbeAgent({
254
+ path: process.cwd(),
255
+ allowedTools: ['search', 'nonexistent', 'another_fake']
256
+ });
257
+
258
+ expect(agent.allowedTools.mode).toBe('whitelist');
259
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
260
+ expect(agent.allowedTools.isEnabled('nonexistent')).toBe(true);
261
+ expect(agent.allowedTools.isEnabled('query')).toBe(false);
262
+ });
263
+
264
+ test('should handle all invalid tool names gracefully', () => {
265
+ const agent = new ProbeAgent({
266
+ path: process.cwd(),
267
+ allowedTools: ['nope', 'invalid', 'fake']
268
+ });
269
+
270
+ expect(agent.allowedTools.mode).toBe('whitelist');
271
+ // Invalid tools are "allowed" but won't match any real tools
272
+ expect(agent.allowedTools.isEnabled('nope')).toBe(true);
273
+ expect(agent.allowedTools.isEnabled('search')).toBe(false);
274
+ expect(agent.allowedTools.isEnabled('query')).toBe(false);
275
+ });
276
+ });
277
+
278
+ describe('validTools array in agentic loop', () => {
279
+ test('should respect allowedTools when building validTools array', async () => {
280
+ const agent = new ProbeAgent({
281
+ path: process.cwd(),
282
+ allowedTools: ['search', 'extract', 'attempt_completion']
283
+ });
284
+ await agent.initialize();
285
+
286
+ // Verify allowedTools configuration
287
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
288
+ expect(agent.allowedTools.isEnabled('extract')).toBe(true);
289
+ expect(agent.allowedTools.isEnabled('attempt_completion')).toBe(true);
290
+ expect(agent.allowedTools.isEnabled('query')).toBe(false);
291
+ expect(agent.allowedTools.isEnabled('listFiles')).toBe(false);
292
+ });
293
+
294
+ test('should build empty validTools array when disableTools is true', async () => {
295
+ const agent = new ProbeAgent({
296
+ path: process.cwd(),
297
+ disableTools: true
298
+ });
299
+ await agent.initialize();
300
+
301
+ // Verify that no tools are enabled
302
+ expect(agent.allowedTools.mode).toBe('none');
303
+ expect(agent.allowedTools.isEnabled('search')).toBe(false);
304
+ expect(agent.allowedTools.isEnabled('query')).toBe(false);
305
+ expect(agent.allowedTools.isEnabled('extract')).toBe(false);
306
+ expect(agent.allowedTools.isEnabled('attempt_completion')).toBe(false);
307
+ });
308
+
309
+ test('should respect both enableBash flag and allowedTools in validTools', async () => {
310
+ const agent = new ProbeAgent({
311
+ path: process.cwd(),
312
+ enableBash: true,
313
+ allowedTools: ['search', 'bash', 'attempt_completion']
314
+ });
315
+ await agent.initialize();
316
+
317
+ // Bash should be enabled because both enableBash=true AND it's in allowedTools
318
+ expect(agent.allowedTools.isEnabled('bash')).toBe(true);
319
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
320
+ expect(agent.allowedTools.isEnabled('attempt_completion')).toBe(true);
321
+ // Query is not in allowedTools
322
+ expect(agent.allowedTools.isEnabled('query')).toBe(false);
323
+ });
324
+
325
+ test('should not include bash in validTools when not in allowedTools', async () => {
326
+ const agent = new ProbeAgent({
327
+ path: process.cwd(),
328
+ enableBash: true,
329
+ allowedTools: ['search', 'query', 'attempt_completion']
330
+ });
331
+ await agent.initialize();
332
+
333
+ // Bash should NOT be enabled even though enableBash=true
334
+ // because it's not in the allowedTools list
335
+ expect(agent.allowedTools.isEnabled('bash')).toBe(false);
336
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
337
+ expect(agent.allowedTools.isEnabled('query')).toBe(true);
338
+ });
339
+
340
+ test('should not include edit tools in validTools when not in allowedTools', async () => {
341
+ const agent = new ProbeAgent({
342
+ path: process.cwd(),
343
+ allowEdit: true,
344
+ allowedTools: ['search', 'query', 'attempt_completion']
345
+ });
346
+ await agent.initialize();
347
+
348
+ // Edit tools should NOT be enabled even though allowEdit=true
349
+ // because they're not in the allowedTools list
350
+ expect(agent.allowedTools.isEnabled('implement')).toBe(false);
351
+ expect(agent.allowedTools.isEnabled('edit')).toBe(false);
352
+ expect(agent.allowedTools.isEnabled('create')).toBe(false);
353
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
354
+ });
355
+
356
+ test('should include edit tools in validTools when in allowedTools', async () => {
357
+ const agent = new ProbeAgent({
358
+ path: process.cwd(),
359
+ allowEdit: true,
360
+ allowedTools: ['search', 'implement', 'attempt_completion']
361
+ });
362
+ await agent.initialize();
363
+
364
+ // Implement should be enabled because both allowEdit=true AND it's in allowedTools
365
+ expect(agent.allowedTools.isEnabled('implement')).toBe(true);
366
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
367
+ expect(agent.allowedTools.isEnabled('attempt_completion')).toBe(true);
368
+ });
369
+ });
370
+
371
+ describe('disableTools convenience flag', () => {
372
+ test('should disable all tools when disableTools is true', () => {
373
+ const agent = new ProbeAgent({
374
+ path: process.cwd(),
375
+ disableTools: true
376
+ });
377
+
378
+ expect(agent.allowedTools.mode).toBe('none');
379
+ expect(agent.allowedTools.isEnabled('search')).toBe(false);
380
+ expect(agent.allowedTools.isEnabled('query')).toBe(false);
381
+ expect(agent.allowedTools.isEnabled('attempt_completion')).toBe(false);
382
+ });
383
+
384
+ test('should take precedence over allowedTools when both are set', () => {
385
+ const agent = new ProbeAgent({
386
+ path: process.cwd(),
387
+ allowedTools: ['search', 'query', 'extract'],
388
+ disableTools: true // This should win
389
+ });
390
+
391
+ expect(agent.allowedTools.mode).toBe('none');
392
+ expect(agent.allowedTools.isEnabled('search')).toBe(false);
393
+ expect(agent.allowedTools.isEnabled('query')).toBe(false);
394
+ });
395
+
396
+ test('should not affect allowedTools when disableTools is false', () => {
397
+ const agent = new ProbeAgent({
398
+ path: process.cwd(),
399
+ allowedTools: ['search', 'query'],
400
+ disableTools: false
401
+ });
402
+
403
+ expect(agent.allowedTools.mode).toBe('whitelist');
404
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
405
+ expect(agent.allowedTools.isEnabled('query')).toBe(true);
406
+ });
407
+ });
408
+
409
+ describe('CLI parsing compatibility', () => {
410
+ test('should support CLI exclusion syntax: "*,!bash,!implement"', () => {
411
+ // Simulate CLI parsing: --allowed-tools "*,!bash,!implement"
412
+ const toolsArg = '*,!bash,!implement';
413
+ const allowedTools = toolsArg.split(',').map(t => t.trim()).filter(t => t.length > 0);
414
+
415
+ const agent = new ProbeAgent({
416
+ path: process.cwd(),
417
+ allowedTools: allowedTools
418
+ });
419
+
420
+ expect(allowedTools).toEqual(['*', '!bash', '!implement']);
421
+ expect(agent.allowedTools.mode).toBe('all');
422
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
423
+ expect(agent.allowedTools.isEnabled('query')).toBe(true);
424
+ expect(agent.allowedTools.isEnabled('bash')).toBe(false);
425
+ expect(agent.allowedTools.isEnabled('implement')).toBe(false);
426
+ });
427
+
428
+ test('should support CLI whitelist syntax: "search,query,extract"', () => {
429
+ // Simulate CLI parsing: --allowed-tools "search,query,extract"
430
+ const toolsArg = 'search,query,extract';
431
+ const allowedTools = toolsArg.split(',').map(t => t.trim()).filter(t => t.length > 0);
432
+
433
+ const agent = new ProbeAgent({
434
+ path: process.cwd(),
435
+ allowedTools: allowedTools
436
+ });
437
+
438
+ expect(allowedTools).toEqual(['search', 'query', 'extract']);
439
+ expect(agent.allowedTools.mode).toBe('whitelist');
440
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
441
+ expect(agent.allowedTools.isEnabled('query')).toBe(true);
442
+ expect(agent.allowedTools.isEnabled('extract')).toBe(true);
443
+ expect(agent.allowedTools.isEnabled('bash')).toBe(false);
444
+ });
445
+
446
+ test('should support CLI MCP wildcard syntax: "mcp__filesystem__*,search"', () => {
447
+ // Simulate CLI parsing: --allowed-tools "mcp__filesystem__*,search"
448
+ const toolsArg = 'mcp__filesystem__*,search';
449
+ const allowedTools = toolsArg.split(',').map(t => t.trim()).filter(t => t.length > 0);
450
+
451
+ const agent = new ProbeAgent({
452
+ path: process.cwd(),
453
+ allowedTools: allowedTools
454
+ });
455
+
456
+ expect(allowedTools).toEqual(['mcp__filesystem__*', 'search']);
457
+ expect(agent.allowedTools.mode).toBe('whitelist');
458
+ expect(agent.allowedTools.isEnabled('mcp__filesystem__read_file')).toBe(true);
459
+ expect(agent.allowedTools.isEnabled('mcp__filesystem__write_file')).toBe(true);
460
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
461
+ expect(agent.allowedTools.isEnabled('mcp__github__list_issues')).toBe(false);
462
+ });
463
+ });
464
+
465
+ describe('MCP tool filtering with mcp__ prefix', () => {
466
+ test('should allow MCP tools with mcp__ prefix', () => {
467
+ const agent = new ProbeAgent({
468
+ path: process.cwd(),
469
+ allowedTools: ['mcp__filesystem__read_file', 'search']
470
+ });
471
+
472
+ expect(agent.allowedTools.isEnabled('mcp__filesystem__read_file')).toBe(true);
473
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
474
+ expect(agent.allowedTools.isEnabled('query')).toBe(false);
475
+ });
476
+
477
+ test('should support wildcard patterns for MCP tools', () => {
478
+ const agent = new ProbeAgent({
479
+ path: process.cwd(),
480
+ allowedTools: ['mcp__filesystem__*', 'search']
481
+ });
482
+
483
+ expect(agent.allowedTools.isEnabled('mcp__filesystem__read_file')).toBe(true);
484
+ expect(agent.allowedTools.isEnabled('mcp__filesystem__write_file')).toBe(true);
485
+ expect(agent.allowedTools.isEnabled('mcp__github__list_issues')).toBe(false);
486
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
487
+ });
488
+
489
+ test('should block MCP tools with exclusion patterns', () => {
490
+ const agent = new ProbeAgent({
491
+ path: process.cwd(),
492
+ allowedTools: ['*', '!mcp__*']
493
+ });
494
+
495
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
496
+ expect(agent.allowedTools.isEnabled('query')).toBe(true);
497
+ expect(agent.allowedTools.isEnabled('mcp__filesystem__read_file')).toBe(false);
498
+ expect(agent.allowedTools.isEnabled('mcp__github__list_issues')).toBe(false);
499
+ });
500
+
501
+ test('should support specific MCP server exclusions', () => {
502
+ const agent = new ProbeAgent({
503
+ path: process.cwd(),
504
+ allowedTools: ['*', '!mcp__filesystem__*']
505
+ });
506
+
507
+ expect(agent.allowedTools.isEnabled('search')).toBe(true);
508
+ expect(agent.allowedTools.isEnabled('mcp__github__list_issues')).toBe(true);
509
+ expect(agent.allowedTools.isEnabled('mcp__filesystem__read_file')).toBe(false);
510
+ expect(agent.allowedTools.isEnabled('mcp__filesystem__write_file')).toBe(false);
511
+ });
512
+ });
513
+ });