@browserbasehq/orca 3.0.9-alpha-3 → 3.1.0-patch.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/esm/index.d.ts +3 -0
- package/dist/esm/index.js +3 -0
- package/dist/esm/lib/inference.d.ts +65 -0
- package/dist/esm/lib/inference.js +333 -0
- package/dist/esm/lib/inference.js.map +1 -0
- package/dist/esm/lib/inferenceLogUtils.d.ts +12 -0
- package/dist/esm/lib/inferenceLogUtils.js +92 -0
- package/dist/esm/lib/inferenceLogUtils.js.map +1 -0
- package/dist/esm/lib/logger.d.ts +69 -0
- package/dist/esm/lib/logger.js +323 -0
- package/dist/esm/lib/logger.js.map +1 -0
- package/dist/esm/lib/modelUtils.d.ts +14 -0
- package/dist/esm/lib/modelUtils.js +48 -0
- package/dist/esm/lib/modelUtils.js.map +1 -0
- package/dist/esm/lib/prompt.d.ts +14 -0
- package/dist/esm/lib/prompt.js +230 -0
- package/dist/esm/lib/prompt.js.map +1 -0
- package/dist/esm/lib/utils.d.ts +68 -0
- package/dist/esm/lib/utils.js +654 -0
- package/dist/esm/lib/utils.js.map +1 -0
- package/dist/esm/lib/v3/agent/AgentClient.d.ts +19 -0
- package/dist/esm/lib/v3/agent/AgentClient.js +17 -0
- package/dist/esm/lib/v3/agent/AgentClient.js.map +1 -0
- package/dist/esm/lib/v3/agent/AgentProvider.d.ts +20 -0
- package/dist/esm/lib/v3/agent/AgentProvider.js +77 -0
- package/dist/esm/lib/v3/agent/AgentProvider.js.map +1 -0
- package/dist/esm/lib/v3/agent/AnthropicCUAClient.d.ts +57 -0
- package/dist/esm/lib/v3/agent/AnthropicCUAClient.js +822 -0
- package/dist/esm/lib/v3/agent/AnthropicCUAClient.js.map +1 -0
- package/dist/esm/lib/v3/agent/GoogleCUAClient.d.ts +74 -0
- package/dist/esm/lib/v3/agent/GoogleCUAClient.js +799 -0
- package/dist/esm/lib/v3/agent/GoogleCUAClient.js.map +1 -0
- package/dist/esm/lib/v3/agent/MicrosoftCUAClient.d.ts +71 -0
- package/dist/esm/lib/v3/agent/MicrosoftCUAClient.js +770 -0
- package/dist/esm/lib/v3/agent/MicrosoftCUAClient.js.map +1 -0
- package/dist/esm/lib/v3/agent/OpenAICUAClient.d.ts +69 -0
- package/dist/esm/lib/v3/agent/OpenAICUAClient.js +615 -0
- package/dist/esm/lib/v3/agent/OpenAICUAClient.js.map +1 -0
- package/dist/esm/lib/v3/agent/prompts/agentSystemPrompt.d.ts +12 -0
- package/dist/esm/lib/v3/agent/prompts/agentSystemPrompt.js +186 -0
- package/dist/esm/lib/v3/agent/prompts/agentSystemPrompt.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/act.d.ts +13 -0
- package/dist/esm/lib/v3/agent/tools/act.js +49 -0
- package/dist/esm/lib/v3/agent/tools/act.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/ariaTree.d.ts +5 -0
- package/dist/esm/lib/v3/agent/tools/ariaTree.js +31 -0
- package/dist/esm/lib/v3/agent/tools/ariaTree.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/click.d.ts +6 -0
- package/dist/esm/lib/v3/agent/tools/click.js +104 -0
- package/dist/esm/lib/v3/agent/tools/click.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/clickAndHold.d.ts +14 -0
- package/dist/esm/lib/v3/agent/tools/clickAndHold.js +68 -0
- package/dist/esm/lib/v3/agent/tools/clickAndHold.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/dragAndDrop.d.ts +7 -0
- package/dist/esm/lib/v3/agent/tools/dragAndDrop.js +105 -0
- package/dist/esm/lib/v3/agent/tools/dragAndDrop.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/extract.d.ts +21 -0
- package/dist/esm/lib/v3/agent/tools/extract.js +93 -0
- package/dist/esm/lib/v3/agent/tools/extract.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/fillFormVision.d.ts +12 -0
- package/dist/esm/lib/v3/agent/tools/fillFormVision.js +143 -0
- package/dist/esm/lib/v3/agent/tools/fillFormVision.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/fillform.d.ts +13 -0
- package/dist/esm/lib/v3/agent/tools/fillform.js +56 -0
- package/dist/esm/lib/v3/agent/tools/fillform.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/goto.d.ts +12 -0
- package/dist/esm/lib/v3/agent/tools/goto.js +31 -0
- package/dist/esm/lib/v3/agent/tools/goto.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/index.d.ts +92 -0
- package/dist/esm/lib/v3/agent/tools/index.js +74 -0
- package/dist/esm/lib/v3/agent/tools/index.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/keys.d.ts +24 -0
- package/dist/esm/lib/v3/agent/tools/keys.js +60 -0
- package/dist/esm/lib/v3/agent/tools/keys.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/navback.d.ts +6 -0
- package/dist/esm/lib/v3/agent/tools/navback.js +23 -0
- package/dist/esm/lib/v3/agent/tools/navback.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/screenshot.d.ts +6 -0
- package/dist/esm/lib/v3/agent/tools/screenshot.js +26 -0
- package/dist/esm/lib/v3/agent/tools/screenshot.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/scroll.d.ts +19 -0
- package/dist/esm/lib/v3/agent/tools/scroll.js +142 -0
- package/dist/esm/lib/v3/agent/tools/scroll.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/search.d.ts +15 -0
- package/dist/esm/lib/v3/agent/tools/search.js +73 -0
- package/dist/esm/lib/v3/agent/tools/search.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/think.d.ts +6 -0
- package/dist/esm/lib/v3/agent/tools/think.js +24 -0
- package/dist/esm/lib/v3/agent/tools/think.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/type.d.ts +7 -0
- package/dist/esm/lib/v3/agent/tools/type.js +106 -0
- package/dist/esm/lib/v3/agent/tools/type.js.map +1 -0
- package/dist/esm/lib/v3/agent/tools/wait.d.ts +5 -0
- package/dist/esm/lib/v3/agent/tools/wait.js +53 -0
- package/dist/esm/lib/v3/agent/tools/wait.js.map +1 -0
- package/dist/esm/lib/v3/agent/utils/actionMapping.d.ts +3 -0
- package/dist/esm/lib/v3/agent/utils/actionMapping.js +100 -0
- package/dist/esm/lib/v3/agent/utils/actionMapping.js.map +1 -0
- package/dist/esm/lib/v3/agent/utils/coordinateNormalization.d.ts +13 -0
- package/dist/esm/lib/v3/agent/utils/coordinateNormalization.js +28 -0
- package/dist/esm/lib/v3/agent/utils/coordinateNormalization.js.map +1 -0
- package/dist/esm/lib/v3/agent/utils/cuaKeyMapping.d.ts +10 -0
- package/dist/esm/lib/v3/agent/utils/cuaKeyMapping.js +62 -0
- package/dist/esm/lib/v3/agent/utils/cuaKeyMapping.js.map +1 -0
- package/dist/esm/lib/v3/agent/utils/googleCustomToolHandler.d.ts +25 -0
- package/dist/esm/lib/v3/agent/utils/googleCustomToolHandler.js +145 -0
- package/dist/esm/lib/v3/agent/utils/googleCustomToolHandler.js.map +1 -0
- package/dist/esm/lib/v3/agent/utils/handleDoneToolCall.d.ts +22 -0
- package/dist/esm/lib/v3/agent/utils/handleDoneToolCall.js +101 -0
- package/dist/esm/lib/v3/agent/utils/handleDoneToolCall.js.map +1 -0
- package/dist/esm/lib/v3/agent/utils/imageCompression.d.ts +53 -0
- package/dist/esm/lib/v3/agent/utils/imageCompression.js +204 -0
- package/dist/esm/lib/v3/agent/utils/imageCompression.js.map +1 -0
- package/dist/esm/lib/v3/agent/utils/messageProcessing.d.ts +12 -0
- package/dist/esm/lib/v3/agent/utils/messageProcessing.js +164 -0
- package/dist/esm/lib/v3/agent/utils/messageProcessing.js.map +1 -0
- package/dist/esm/lib/v3/agent/utils/screenshotHandler.d.ts +10 -0
- package/dist/esm/lib/v3/agent/utils/screenshotHandler.js +26 -0
- package/dist/esm/lib/v3/agent/utils/screenshotHandler.js.map +1 -0
- package/dist/esm/lib/v3/agent/utils/validateExperimentalFeatures.d.ts +26 -0
- package/dist/esm/lib/v3/agent/utils/validateExperimentalFeatures.js +79 -0
- package/dist/esm/lib/v3/agent/utils/validateExperimentalFeatures.js.map +1 -0
- package/dist/esm/lib/v3/agent/utils/xpath.d.ts +11 -0
- package/dist/esm/lib/v3/agent/utils/xpath.js +19 -0
- package/dist/esm/lib/v3/agent/utils/xpath.js.map +1 -0
- package/dist/esm/lib/v3/api.d.ts +86 -0
- package/dist/esm/lib/v3/api.js +484 -0
- package/dist/esm/lib/v3/api.js.map +1 -0
- package/dist/esm/lib/v3/cache/ActCache.d.ts +23 -0
- package/dist/esm/lib/v3/cache/ActCache.js +292 -0
- package/dist/esm/lib/v3/cache/ActCache.js.map +1 -0
- package/dist/esm/lib/v3/cache/AgentCache.d.ts +109 -0
- package/dist/esm/lib/v3/cache/AgentCache.js +640 -0
- package/dist/esm/lib/v3/cache/AgentCache.js.map +1 -0
- package/dist/esm/lib/v3/cache/CacheStorage.d.ts +17 -0
- package/dist/esm/lib/v3/cache/CacheStorage.js +98 -0
- package/dist/esm/lib/v3/cache/CacheStorage.js.map +1 -0
- package/dist/esm/lib/v3/cache/serverAgentCache.d.ts +7 -0
- package/dist/esm/lib/v3/cache/serverAgentCache.js +49 -0
- package/dist/esm/lib/v3/cache/serverAgentCache.js.map +1 -0
- package/dist/esm/lib/v3/cache/utils.d.ts +15 -0
- package/dist/esm/lib/v3/cache/utils.js +39 -0
- package/dist/esm/lib/v3/cache/utils.js.map +1 -0
- package/dist/esm/lib/v3/dom/a11yScripts/index.d.ts +11 -0
- package/dist/esm/lib/v3/dom/a11yScripts/index.js +117 -0
- package/dist/esm/lib/v3/dom/a11yScripts/index.js.map +1 -0
- package/dist/esm/lib/v3/dom/build/a11yScripts.generated.d.ts +16 -0
- package/dist/esm/lib/v3/dom/build/a11yScripts.generated.js +20 -0
- package/dist/esm/lib/v3/dom/build/a11yScripts.generated.js.map +1 -0
- package/dist/esm/lib/v3/dom/build/locatorScripts.generated.d.ts +52 -0
- package/dist/esm/lib/v3/dom/build/locatorScripts.generated.js +56 -0
- package/dist/esm/lib/v3/dom/build/locatorScripts.generated.js.map +1 -0
- package/dist/esm/lib/v3/dom/build/reRenderScriptContent.d.ts +1 -0
- package/dist/esm/lib/v3/dom/build/reRenderScriptContent.js +2 -0
- package/dist/esm/lib/v3/dom/build/reRenderScriptContent.js.map +1 -0
- package/dist/esm/lib/v3/dom/build/rerender-index.js +1 -0
- package/dist/esm/lib/v3/dom/build/screenshotScripts.generated.d.ts +4 -0
- package/dist/esm/lib/v3/dom/build/screenshotScripts.generated.js +8 -0
- package/dist/esm/lib/v3/dom/build/screenshotScripts.generated.js.map +1 -0
- package/dist/esm/lib/v3/dom/build/scriptV3Content.d.ts +1 -0
- package/dist/esm/lib/v3/dom/build/scriptV3Content.js +2 -0
- package/dist/esm/lib/v3/dom/build/scriptV3Content.js.map +1 -0
- package/dist/esm/lib/v3/dom/build/v3-index.js +1 -0
- package/dist/esm/lib/v3/dom/genA11yScripts.d.ts +1 -0
- package/dist/esm/lib/v3/dom/genA11yScripts.js +54 -0
- package/dist/esm/lib/v3/dom/genA11yScripts.js.map +1 -0
- package/dist/esm/lib/v3/dom/genDomScripts.d.ts +1 -0
- package/dist/esm/lib/v3/dom/genDomScripts.js +38 -0
- package/dist/esm/lib/v3/dom/genDomScripts.js.map +1 -0
- package/dist/esm/lib/v3/dom/genLocatorScripts.d.ts +1 -0
- package/dist/esm/lib/v3/dom/genLocatorScripts.js +51 -0
- package/dist/esm/lib/v3/dom/genLocatorScripts.js.map +1 -0
- package/dist/esm/lib/v3/dom/genScreenshotScripts.d.ts +1 -0
- package/dist/esm/lib/v3/dom/genScreenshotScripts.js +37 -0
- package/dist/esm/lib/v3/dom/genScreenshotScripts.js.map +1 -0
- package/dist/esm/lib/v3/dom/index.d.ts +1 -0
- package/dist/esm/lib/v3/dom/index.js +2 -0
- package/dist/esm/lib/v3/dom/index.js.map +1 -0
- package/dist/esm/lib/v3/dom/locatorScripts/counts.d.ts +15 -0
- package/dist/esm/lib/v3/dom/locatorScripts/counts.js +272 -0
- package/dist/esm/lib/v3/dom/locatorScripts/counts.js.map +1 -0
- package/dist/esm/lib/v3/dom/locatorScripts/index.d.ts +4 -0
- package/dist/esm/lib/v3/dom/locatorScripts/index.js +5 -0
- package/dist/esm/lib/v3/dom/locatorScripts/index.js.map +1 -0
- package/dist/esm/lib/v3/dom/locatorScripts/scripts.d.ts +37 -0
- package/dist/esm/lib/v3/dom/locatorScripts/scripts.js +458 -0
- package/dist/esm/lib/v3/dom/locatorScripts/scripts.js.map +1 -0
- package/dist/esm/lib/v3/dom/locatorScripts/selectors.d.ts +4 -0
- package/dist/esm/lib/v3/dom/locatorScripts/selectors.js +283 -0
- package/dist/esm/lib/v3/dom/locatorScripts/selectors.js.map +1 -0
- package/dist/esm/lib/v3/dom/locatorScripts/waitForSelector.d.ts +19 -0
- package/dist/esm/lib/v3/dom/locatorScripts/waitForSelector.js +283 -0
- package/dist/esm/lib/v3/dom/locatorScripts/waitForSelector.js.map +1 -0
- package/dist/esm/lib/v3/dom/locatorScripts/xpathParser.d.ts +76 -0
- package/dist/esm/lib/v3/dom/locatorScripts/xpathParser.js +376 -0
- package/dist/esm/lib/v3/dom/locatorScripts/xpathParser.js.map +1 -0
- package/dist/esm/lib/v3/dom/locatorScripts/xpathResolver.d.ts +9 -0
- package/dist/esm/lib/v3/dom/locatorScripts/xpathResolver.js +196 -0
- package/dist/esm/lib/v3/dom/locatorScripts/xpathResolver.js.map +1 -0
- package/dist/esm/lib/v3/dom/piercer.entry.d.ts +1 -0
- package/dist/esm/lib/v3/dom/piercer.entry.js +3 -0
- package/dist/esm/lib/v3/dom/piercer.entry.js.map +1 -0
- package/dist/esm/lib/v3/dom/piercer.runtime.d.ts +23 -0
- package/dist/esm/lib/v3/dom/piercer.runtime.js +90 -0
- package/dist/esm/lib/v3/dom/piercer.runtime.js.map +1 -0
- package/dist/esm/lib/v3/dom/rerenderMissingShadows.entry.d.ts +1 -0
- package/dist/esm/lib/v3/dom/rerenderMissingShadows.entry.js +3 -0
- package/dist/esm/lib/v3/dom/rerenderMissingShadows.entry.js.map +1 -0
- package/dist/esm/lib/v3/dom/rerenderMissingShadows.runtime.d.ts +1 -0
- package/dist/esm/lib/v3/dom/rerenderMissingShadows.runtime.js +40 -0
- package/dist/esm/lib/v3/dom/rerenderMissingShadows.runtime.js.map +1 -0
- package/dist/esm/lib/v3/dom/screenshotScripts/index.d.ts +1 -0
- package/dist/esm/lib/v3/dom/screenshotScripts/index.js +2 -0
- package/dist/esm/lib/v3/dom/screenshotScripts/index.js.map +1 -0
- package/dist/esm/lib/v3/dom/screenshotScripts/resolveMaskRect.d.ts +8 -0
- package/dist/esm/lib/v3/dom/screenshotScripts/resolveMaskRect.js +82 -0
- package/dist/esm/lib/v3/dom/screenshotScripts/resolveMaskRect.js.map +1 -0
- package/dist/esm/lib/v3/external_clients/aisdk.d.ts +11 -0
- package/dist/esm/lib/v3/external_clients/aisdk.js +103 -0
- package/dist/esm/lib/v3/external_clients/aisdk.js.map +1 -0
- package/dist/esm/lib/v3/external_clients/customOpenAI.d.ts +18 -0
- package/dist/esm/lib/v3/external_clients/customOpenAI.js +220 -0
- package/dist/esm/lib/v3/external_clients/customOpenAI.js.map +1 -0
- package/dist/esm/lib/v3/flowLogger.d.ts +139 -0
- package/dist/esm/lib/v3/flowLogger.js +868 -0
- package/dist/esm/lib/v3/flowLogger.js.map +1 -0
- package/dist/esm/lib/v3/handlers/actHandler.d.ts +21 -0
- package/dist/esm/lib/v3/handlers/actHandler.js +340 -0
- package/dist/esm/lib/v3/handlers/actHandler.js.map +1 -0
- package/dist/esm/lib/v3/handlers/extractHandler.d.ts +31 -0
- package/dist/esm/lib/v3/handlers/extractHandler.js +139 -0
- package/dist/esm/lib/v3/handlers/extractHandler.js.map +1 -0
- package/dist/esm/lib/v3/handlers/handlerUtils/actHandlerUtils.d.ts +24 -0
- package/dist/esm/lib/v3/handlers/handlerUtils/actHandlerUtils.js +623 -0
- package/dist/esm/lib/v3/handlers/handlerUtils/actHandlerUtils.js.map +1 -0
- package/dist/esm/lib/v3/handlers/handlerUtils/timeoutGuard.d.ts +2 -0
- package/dist/esm/lib/v3/handlers/handlerUtils/timeoutGuard.js +14 -0
- package/dist/esm/lib/v3/handlers/handlerUtils/timeoutGuard.js.map +1 -0
- package/dist/esm/lib/v3/handlers/observeHandler.d.ts +17 -0
- package/dist/esm/lib/v3/handlers/observeHandler.js +156 -0
- package/dist/esm/lib/v3/handlers/observeHandler.js.map +1 -0
- package/dist/esm/lib/v3/handlers/v3AgentHandler.d.ts +32 -0
- package/dist/esm/lib/v3/handlers/v3AgentHandler.js +461 -0
- package/dist/esm/lib/v3/handlers/v3AgentHandler.js.map +1 -0
- package/dist/esm/lib/v3/handlers/v3CuaAgentHandler.d.ts +33 -0
- package/dist/esm/lib/v3/handlers/v3CuaAgentHandler.js +528 -0
- package/dist/esm/lib/v3/handlers/v3CuaAgentHandler.js.map +1 -0
- package/dist/esm/lib/v3/index.d.ts +17 -0
- package/dist/esm/lib/v3/index.js +13 -0
- package/dist/esm/lib/v3/index.js.map +1 -0
- package/dist/esm/lib/v3/launch/browserbase.d.ts +7 -0
- package/dist/esm/lib/v3/launch/browserbase.js +46 -0
- package/dist/esm/lib/v3/launch/browserbase.js.map +1 -0
- package/dist/esm/lib/v3/launch/local.d.ts +15 -0
- package/dist/esm/lib/v3/launch/local.js +98 -0
- package/dist/esm/lib/v3/launch/local.js.map +1 -0
- package/dist/esm/lib/v3/llm/AnthropicClient.d.ts +16 -0
- package/dist/esm/lib/v3/llm/AnthropicClient.js +239 -0
- package/dist/esm/lib/v3/llm/AnthropicClient.js.map +1 -0
- package/dist/esm/lib/v3/llm/CerebrasClient.d.ts +17 -0
- package/dist/esm/lib/v3/llm/CerebrasClient.js +235 -0
- package/dist/esm/lib/v3/llm/CerebrasClient.js.map +1 -0
- package/dist/esm/lib/v3/llm/GoogleClient.d.ts +19 -0
- package/dist/esm/lib/v3/llm/GoogleClient.js +369 -0
- package/dist/esm/lib/v3/llm/GoogleClient.js.map +1 -0
- package/dist/esm/lib/v3/llm/GroqClient.d.ts +17 -0
- package/dist/esm/lib/v3/llm/GroqClient.js +236 -0
- package/dist/esm/lib/v3/llm/GroqClient.js.map +1 -0
- package/dist/esm/lib/v3/llm/LLMClient.d.ts +121 -0
- package/dist/esm/lib/v3/llm/LLMClient.js +23 -0
- package/dist/esm/lib/v3/llm/LLMClient.js.map +1 -0
- package/dist/esm/lib/v3/llm/LLMProvider.d.ts +13 -0
- package/dist/esm/lib/v3/llm/LLMProvider.js +194 -0
- package/dist/esm/lib/v3/llm/LLMProvider.js.map +1 -0
- package/dist/esm/lib/v3/llm/OpenAIClient.d.ts +15 -0
- package/dist/esm/lib/v3/llm/OpenAIClient.js +329 -0
- package/dist/esm/lib/v3/llm/OpenAIClient.js.map +1 -0
- package/dist/esm/lib/v3/llm/aisdk.d.ts +15 -0
- package/dist/esm/lib/v3/llm/aisdk.js +348 -0
- package/dist/esm/lib/v3/llm/aisdk.js.map +1 -0
- package/dist/esm/lib/v3/logger.d.ts +9 -0
- package/dist/esm/lib/v3/logger.js +96 -0
- package/dist/esm/lib/v3/logger.js.map +1 -0
- package/dist/esm/lib/v3/mcp/connection.d.ts +11 -0
- package/dist/esm/lib/v3/mcp/connection.js +49 -0
- package/dist/esm/lib/v3/mcp/connection.js.map +1 -0
- package/dist/esm/lib/v3/mcp/utils.d.ts +3 -0
- package/dist/esm/lib/v3/mcp/utils.js +36 -0
- package/dist/esm/lib/v3/mcp/utils.js.map +1 -0
- package/dist/esm/lib/v3/shutdown/cleanupLocal.d.ts +14 -0
- package/dist/esm/lib/v3/shutdown/cleanupLocal.js +30 -0
- package/dist/esm/lib/v3/shutdown/cleanupLocal.js.map +1 -0
- package/dist/esm/lib/v3/shutdown/supervisor.d.ts +9 -0
- package/dist/esm/lib/v3/shutdown/supervisor.js +156 -0
- package/dist/esm/lib/v3/shutdown/supervisor.js.map +1 -0
- package/dist/esm/lib/v3/shutdown/supervisorClient.d.ts +15 -0
- package/dist/esm/lib/v3/shutdown/supervisorClient.js +97 -0
- package/dist/esm/lib/v3/shutdown/supervisorClient.js.map +1 -0
- package/dist/esm/lib/v3/tests/agent-abort-signal.spec.js +113 -0
- package/dist/esm/lib/v3/tests/agent-abort-signal.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/agent-cache-self-heal.spec.js +80 -0
- package/dist/esm/lib/v3/tests/agent-cache-self-heal.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/agent-callbacks.spec.js +374 -0
- package/dist/esm/lib/v3/tests/agent-callbacks.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/agent-experimental-validation.spec.js +357 -0
- package/dist/esm/lib/v3/tests/agent-experimental-validation.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/agent-hybrid-mode.spec.js +247 -0
- package/dist/esm/lib/v3/tests/agent-hybrid-mode.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/agent-message-continuation.spec.js +105 -0
- package/dist/esm/lib/v3/tests/agent-message-continuation.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/agent-streaming.spec.js +126 -0
- package/dist/esm/lib/v3/tests/agent-streaming.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/cdp-session-detached.spec.js +44 -0
- package/dist/esm/lib/v3/tests/cdp-session-detached.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/click-count.spec.js +112 -0
- package/dist/esm/lib/v3/tests/click-count.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/connect-to-existing-browser.spec.js +54 -0
- package/dist/esm/lib/v3/tests/connect-to-existing-browser.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/context-addInitScript.spec.js +176 -0
- package/dist/esm/lib/v3/tests/context-addInitScript.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/default-page-tracking.spec.js +53 -0
- package/dist/esm/lib/v3/tests/default-page-tracking.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/downloads.spec.js +58 -0
- package/dist/esm/lib/v3/tests/downloads.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/envReporter.js +57 -0
- package/dist/esm/lib/v3/tests/envReporter.js.map +7 -0
- package/dist/esm/lib/v3/tests/frame-get-location-and-click.spec.js +53 -0
- package/dist/esm/lib/v3/tests/frame-get-location-and-click.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/iframe-ctx-addInitScript.spec.js +447 -0
- package/dist/esm/lib/v3/tests/iframe-ctx-addInitScript.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/keep-alive.child.js +92 -0
- package/dist/esm/lib/v3/tests/keep-alive.child.js.map +7 -0
- package/dist/esm/lib/v3/tests/keep-alive.helpers.js +532 -0
- package/dist/esm/lib/v3/tests/keep-alive.helpers.js.map +7 -0
- package/dist/esm/lib/v3/tests/keep-alive.spec.js +19 -0
- package/dist/esm/lib/v3/tests/keep-alive.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/keyboard.spec.js +296 -0
- package/dist/esm/lib/v3/tests/keyboard.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/locator-backend-node-id.spec.js +159 -0
- package/dist/esm/lib/v3/tests/locator-backend-node-id.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/locator-content-methods.spec.js +191 -0
- package/dist/esm/lib/v3/tests/locator-content-methods.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/locator-count-iframe.spec.js +108 -0
- package/dist/esm/lib/v3/tests/locator-count-iframe.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/locator-count.spec.js +71 -0
- package/dist/esm/lib/v3/tests/locator-count.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/locator-fill.spec.js +118 -0
- package/dist/esm/lib/v3/tests/locator-fill.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/locator-input-methods.spec.js +136 -0
- package/dist/esm/lib/v3/tests/locator-input-methods.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/locator-nth.spec.js +157 -0
- package/dist/esm/lib/v3/tests/locator-nth.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/locator-select-option.spec.js +242 -0
- package/dist/esm/lib/v3/tests/locator-select-option.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/logger-initialization.spec.js +552 -0
- package/dist/esm/lib/v3/tests/logger-initialization.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/multi-instance-logger.spec.js +269 -0
- package/dist/esm/lib/v3/tests/multi-instance-logger.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/nested-div.spec.js +23 -0
- package/dist/esm/lib/v3/tests/nested-div.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/page-addInitScript.spec.js +90 -0
- package/dist/esm/lib/v3/tests/page-addInitScript.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/page-console.spec.js +56 -0
- package/dist/esm/lib/v3/tests/page-console.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/page-drag-and-drop.spec.js +418 -0
- package/dist/esm/lib/v3/tests/page-drag-and-drop.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/page-goto-response.spec.js +35 -0
- package/dist/esm/lib/v3/tests/page-goto-response.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/page-hover.spec.js +167 -0
- package/dist/esm/lib/v3/tests/page-hover.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/page-screenshot.spec.js +273 -0
- package/dist/esm/lib/v3/tests/page-screenshot.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/page-scroll.spec.js +182 -0
- package/dist/esm/lib/v3/tests/page-scroll.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/page-send-cdp.spec.js +46 -0
- package/dist/esm/lib/v3/tests/page-send-cdp.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/perform-understudy-method.spec.js +98 -0
- package/dist/esm/lib/v3/tests/perform-understudy-method.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/setinputfiles.spec.js +126 -0
- package/dist/esm/lib/v3/tests/setinputfiles.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/shadow-iframe-oopif.spec.js +134 -0
- package/dist/esm/lib/v3/tests/shadow-iframe-oopif.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/shadow-iframe-spif.spec.js +134 -0
- package/dist/esm/lib/v3/tests/shadow-iframe-spif.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/testUtils.js +31 -0
- package/dist/esm/lib/v3/tests/testUtils.js.map +7 -0
- package/dist/esm/lib/v3/tests/text-selector-innermost.spec.js +100 -0
- package/dist/esm/lib/v3/tests/text-selector-innermost.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/timeouts.spec.js +32 -0
- package/dist/esm/lib/v3/tests/timeouts.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/user-data-dir.spec.js +43 -0
- package/dist/esm/lib/v3/tests/user-data-dir.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/v3.config.js +15 -0
- package/dist/esm/lib/v3/tests/v3.config.js.map +7 -0
- package/dist/esm/lib/v3/tests/v3.dynamic.config.js +43 -0
- package/dist/esm/lib/v3/tests/v3.dynamic.config.js.map +7 -0
- package/dist/esm/lib/v3/tests/v3.playwright.config.js +98 -0
- package/dist/esm/lib/v3/tests/v3.playwright.config.js.map +7 -0
- package/dist/esm/lib/v3/tests/wait-for-selector.spec.js +593 -0
- package/dist/esm/lib/v3/tests/wait-for-selector.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/wait-for-timeout.spec.js +97 -0
- package/dist/esm/lib/v3/tests/wait-for-timeout.spec.js.map +7 -0
- package/dist/esm/lib/v3/tests/xpath-for-location-deep.spec.js +77 -0
- package/dist/esm/lib/v3/tests/xpath-for-location-deep.spec.js.map +7 -0
- package/dist/esm/lib/v3/timeoutConfig.d.ts +2 -0
- package/dist/esm/lib/v3/timeoutConfig.js +27 -0
- package/dist/esm/lib/v3/timeoutConfig.js.map +1 -0
- package/dist/esm/lib/v3/types/private/agent.d.ts +6 -0
- package/dist/esm/lib/v3/types/private/agent.js +2 -0
- package/dist/esm/lib/v3/types/private/agent.js.map +1 -0
- package/dist/esm/lib/v3/types/private/api.d.ts +11 -0
- package/dist/esm/lib/v3/types/private/api.js +2 -0
- package/dist/esm/lib/v3/types/private/api.js.map +1 -0
- package/dist/esm/lib/v3/types/private/cache.d.ts +128 -0
- package/dist/esm/lib/v3/types/private/cache.js +2 -0
- package/dist/esm/lib/v3/types/private/cache.js.map +1 -0
- package/dist/esm/lib/v3/types/private/evaluator.d.ts +40 -0
- package/dist/esm/lib/v3/types/private/evaluator.js +2 -0
- package/dist/esm/lib/v3/types/private/evaluator.js.map +1 -0
- package/dist/esm/lib/v3/types/private/handlers.d.ts +38 -0
- package/dist/esm/lib/v3/types/private/handlers.js +16 -0
- package/dist/esm/lib/v3/types/private/handlers.js.map +1 -0
- package/dist/esm/lib/v3/types/private/index.d.ts +7 -0
- package/dist/esm/lib/v3/types/private/index.js +8 -0
- package/dist/esm/lib/v3/types/private/index.js.map +1 -0
- package/dist/esm/lib/v3/types/private/internal.d.ts +39 -0
- package/dist/esm/lib/v3/types/private/internal.js +2 -0
- package/dist/esm/lib/v3/types/private/internal.js.map +1 -0
- package/dist/esm/lib/v3/types/private/locator.d.ts +9 -0
- package/dist/esm/lib/v3/types/private/locator.js +2 -0
- package/dist/esm/lib/v3/types/private/locator.js.map +1 -0
- package/dist/esm/lib/v3/types/private/network.d.ts +34 -0
- package/dist/esm/lib/v3/types/private/network.js +3 -0
- package/dist/esm/lib/v3/types/private/network.js.map +1 -0
- package/dist/esm/lib/v3/types/private/shutdown.d.ts +31 -0
- package/dist/esm/lib/v3/types/private/shutdown.js +5 -0
- package/dist/esm/lib/v3/types/private/shutdown.js.map +1 -0
- package/dist/esm/lib/v3/types/private/shutdownErrors.d.ts +12 -0
- package/dist/esm/lib/v3/types/private/shutdownErrors.js +22 -0
- package/dist/esm/lib/v3/types/private/shutdownErrors.js.map +1 -0
- package/dist/esm/lib/v3/types/private/snapshot.d.ts +117 -0
- package/dist/esm/lib/v3/types/private/snapshot.js +2 -0
- package/dist/esm/lib/v3/types/private/snapshot.js.map +1 -0
- package/dist/esm/lib/v3/types/public/agent.d.ts +595 -0
- package/dist/esm/lib/v3/types/public/agent.js +15 -0
- package/dist/esm/lib/v3/types/public/agent.js.map +1 -0
- package/dist/esm/lib/v3/types/public/api.d.ts +1211 -0
- package/dist/esm/lib/v3/types/public/api.js +915 -0
- package/dist/esm/lib/v3/types/public/api.js.map +1 -0
- package/dist/esm/lib/v3/types/public/apiErrors.d.ts +18 -0
- package/dist/esm/lib/v3/types/public/apiErrors.js +32 -0
- package/dist/esm/lib/v3/types/public/apiErrors.js.map +1 -0
- package/dist/esm/lib/v3/types/public/index.d.ts +12 -0
- package/dist/esm/lib/v3/types/public/index.js +14 -0
- package/dist/esm/lib/v3/types/public/index.js.map +1 -0
- package/dist/esm/lib/v3/types/public/locator.d.ts +9 -0
- package/dist/esm/lib/v3/types/public/locator.js +2 -0
- package/dist/esm/lib/v3/types/public/locator.js.map +1 -0
- package/dist/esm/lib/v3/types/public/logs.d.ts +23 -0
- package/dist/esm/lib/v3/types/public/logs.js +13 -0
- package/dist/esm/lib/v3/types/public/logs.js.map +1 -0
- package/dist/esm/lib/v3/types/public/methods.d.ts +56 -0
- package/dist/esm/lib/v3/types/public/methods.js +15 -0
- package/dist/esm/lib/v3/types/public/methods.js.map +1 -0
- package/dist/esm/lib/v3/types/public/metrics.d.ts +27 -0
- package/dist/esm/lib/v3/types/public/metrics.js +2 -0
- package/dist/esm/lib/v3/types/public/metrics.js.map +1 -0
- package/dist/esm/lib/v3/types/public/model.d.ts +65 -0
- package/dist/esm/lib/v3/types/public/model.js +2 -0
- package/dist/esm/lib/v3/types/public/model.js.map +1 -0
- package/dist/esm/lib/v3/types/public/options.d.ts +70 -0
- package/dist/esm/lib/v3/types/public/options.js +4 -0
- package/dist/esm/lib/v3/types/public/options.js.map +1 -0
- package/dist/esm/lib/v3/types/public/page.d.ts +18 -0
- package/dist/esm/lib/v3/types/public/page.js +3 -0
- package/dist/esm/lib/v3/types/public/page.js.map +1 -0
- package/dist/esm/lib/v3/types/public/screenshotTypes.d.ts +25 -0
- package/dist/esm/lib/v3/types/public/screenshotTypes.js +2 -0
- package/dist/esm/lib/v3/types/public/screenshotTypes.js.map +1 -0
- package/dist/esm/lib/v3/types/public/sdkErrors.d.ts +152 -0
- package/dist/esm/lib/v3/types/public/sdkErrors.js +305 -0
- package/dist/esm/lib/v3/types/public/sdkErrors.js.map +1 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/a11yTree.d.ts +15 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/a11yTree.js +196 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/a11yTree.js.map +1 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/activeElement.d.ts +8 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/activeElement.js +121 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/activeElement.js.map +1 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/capture.d.ts +77 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/capture.js +336 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/capture.js.map +1 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/coordinateResolver.d.ts +7 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/coordinateResolver.js +129 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/coordinateResolver.js.map +1 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/domTree.d.ts +46 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/domTree.js +274 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/domTree.js.map +1 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/focusSelectors.d.ts +24 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/focusSelectors.js +216 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/focusSelectors.js.map +1 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/index.d.ts +4 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/index.js +5 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/index.js.map +1 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/sessions.d.ts +16 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/sessions.js +22 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/sessions.js.map +1 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/treeFormatUtils.d.ts +28 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/treeFormatUtils.js +135 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/treeFormatUtils.js.map +1 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/xpathUtils.d.ts +26 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/xpathUtils.js +102 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/xpathUtils.js.map +1 -0
- package/dist/esm/lib/v3/understudy/a11yInvocation.d.ts +8 -0
- package/dist/esm/lib/v3/understudy/a11yInvocation.js +12 -0
- package/dist/esm/lib/v3/understudy/a11yInvocation.js.map +1 -0
- package/dist/esm/lib/v3/understudy/cdp.d.ts +69 -0
- package/dist/esm/lib/v3/understudy/cdp.js +251 -0
- package/dist/esm/lib/v3/understudy/cdp.js.map +1 -0
- package/dist/esm/lib/v3/understudy/consoleMessage.d.ts +22 -0
- package/dist/esm/lib/v3/understudy/consoleMessage.js +66 -0
- package/dist/esm/lib/v3/understudy/consoleMessage.js.map +1 -0
- package/dist/esm/lib/v3/understudy/context.d.ts +132 -0
- package/dist/esm/lib/v3/understudy/context.js +687 -0
- package/dist/esm/lib/v3/understudy/context.js.map +1 -0
- package/dist/esm/lib/v3/understudy/deepLocator.d.ts +87 -0
- package/dist/esm/lib/v3/understudy/deepLocator.js +218 -0
- package/dist/esm/lib/v3/understudy/deepLocator.js.map +1 -0
- package/dist/esm/lib/v3/understudy/executionContextRegistry.d.ts +15 -0
- package/dist/esm/lib/v3/understudy/executionContextRegistry.js +83 -0
- package/dist/esm/lib/v3/understudy/executionContextRegistry.js.map +1 -0
- package/dist/esm/lib/v3/understudy/fileUploadUtils.d.ts +13 -0
- package/dist/esm/lib/v3/understudy/fileUploadUtils.js +81 -0
- package/dist/esm/lib/v3/understudy/fileUploadUtils.js.map +1 -0
- package/dist/esm/lib/v3/understudy/frame.d.ts +69 -0
- package/dist/esm/lib/v3/understudy/frame.js +211 -0
- package/dist/esm/lib/v3/understudy/frame.js.map +1 -0
- package/dist/esm/lib/v3/understudy/frameLocator.d.ts +50 -0
- package/dist/esm/lib/v3/understudy/frameLocator.js +255 -0
- package/dist/esm/lib/v3/understudy/frameLocator.js.map +1 -0
- package/dist/esm/lib/v3/understudy/frameRegistry.d.ts +101 -0
- package/dist/esm/lib/v3/understudy/frameRegistry.js +298 -0
- package/dist/esm/lib/v3/understudy/frameRegistry.js.map +1 -0
- package/dist/esm/lib/v3/understudy/initScripts.d.ts +2 -0
- package/dist/esm/lib/v3/understudy/initScripts.js +33 -0
- package/dist/esm/lib/v3/understudy/initScripts.js.map +1 -0
- package/dist/esm/lib/v3/understudy/lifecycleWatcher.d.ts +64 -0
- package/dist/esm/lib/v3/understudy/lifecycleWatcher.js +245 -0
- package/dist/esm/lib/v3/understudy/lifecycleWatcher.js.map +1 -0
- package/dist/esm/lib/v3/understudy/locator.d.ts +194 -0
- package/dist/esm/lib/v3/understudy/locator.js +753 -0
- package/dist/esm/lib/v3/understudy/locator.js.map +1 -0
- package/dist/esm/lib/v3/understudy/locatorInvocation.d.ts +8 -0
- package/dist/esm/lib/v3/understudy/locatorInvocation.js +12 -0
- package/dist/esm/lib/v3/understudy/locatorInvocation.js.map +1 -0
- package/dist/esm/lib/v3/understudy/navigationResponseTracker.d.ts +84 -0
- package/dist/esm/lib/v3/understudy/navigationResponseTracker.js +224 -0
- package/dist/esm/lib/v3/understudy/navigationResponseTracker.js.map +1 -0
- package/dist/esm/lib/v3/understudy/networkManager.d.ts +53 -0
- package/dist/esm/lib/v3/understudy/networkManager.js +306 -0
- package/dist/esm/lib/v3/understudy/networkManager.js.map +1 -0
- package/dist/esm/lib/v3/understudy/page.d.ts +354 -0
- package/dist/esm/lib/v3/understudy/page.js +1941 -0
- package/dist/esm/lib/v3/understudy/page.js.map +1 -0
- package/dist/esm/lib/v3/understudy/piercer.d.ts +4 -0
- package/dist/esm/lib/v3/understudy/piercer.js +61 -0
- package/dist/esm/lib/v3/understudy/piercer.js.map +1 -0
- package/dist/esm/lib/v3/understudy/response.d.ts +137 -0
- package/dist/esm/lib/v3/understudy/response.js +330 -0
- package/dist/esm/lib/v3/understudy/response.js.map +1 -0
- package/dist/esm/lib/v3/understudy/screenshotUtils.d.ts +16 -0
- package/dist/esm/lib/v3/understudy/screenshotUtils.js +352 -0
- package/dist/esm/lib/v3/understudy/screenshotUtils.js.map +1 -0
- package/dist/esm/lib/v3/understudy/selectorResolver.d.ts +38 -0
- package/dist/esm/lib/v3/understudy/selectorResolver.js +296 -0
- package/dist/esm/lib/v3/understudy/selectorResolver.js.map +1 -0
- package/dist/esm/lib/v3/v3.d.ts +191 -0
- package/dist/esm/lib/v3/v3.js +1572 -0
- package/dist/esm/lib/v3/v3.js.map +1 -0
- package/dist/esm/lib/v3/zodCompat.d.ts +12 -0
- package/dist/esm/lib/v3/zodCompat.js +17 -0
- package/dist/esm/lib/v3/zodCompat.js.map +1 -0
- package/dist/esm/lib/v3Evaluator.d.ts +19 -0
- package/dist/esm/lib/v3Evaluator.js +210 -0
- package/dist/esm/lib/v3Evaluator.js.map +1 -0
- package/dist/esm/lib/version.d.ts +5 -0
- package/dist/esm/lib/version.js +6 -0
- package/dist/esm/lib/version.js.map +1 -0
- package/dist/esm/package.json +3 -0
- package/dist/esm/tests/agent-execution-model.test.js +139 -0
- package/dist/esm/tests/agent-execution-model.test.js.map +7 -0
- package/dist/esm/tests/browserbase-session-accessors.test.js +101 -0
- package/dist/esm/tests/browserbase-session-accessors.test.js.map +7 -0
- package/dist/esm/tests/cache-llm-resolution.test.js +187 -0
- package/dist/esm/tests/cache-llm-resolution.test.js.map +7 -0
- package/dist/esm/tests/helpers/mockCDPSession.js +27 -0
- package/dist/esm/tests/helpers/mockCDPSession.js.map +7 -0
- package/dist/esm/tests/llm-provider.test.js +57 -0
- package/dist/esm/tests/llm-provider.test.js.map +7 -0
- package/dist/esm/tests/model-deprecation.test.js +135 -0
- package/dist/esm/tests/model-deprecation.test.js.map +7 -0
- package/dist/esm/tests/model-utils.test.js +43 -0
- package/dist/esm/tests/model-utils.test.js.map +7 -0
- package/dist/esm/tests/page-snapshot.test.js +36 -0
- package/dist/esm/tests/page-snapshot.test.js.map +7 -0
- package/dist/esm/tests/public-api/export-surface.test.js +53 -0
- package/dist/esm/tests/public-api/export-surface.test.js.map +7 -0
- package/dist/esm/tests/public-api/llm-and-agents.test.js +128 -0
- package/dist/esm/tests/public-api/llm-and-agents.test.js.map +7 -0
- package/dist/esm/tests/public-api/public-error-types.test.js +71 -0
- package/dist/esm/tests/public-api/public-error-types.test.js.map +7 -0
- package/dist/esm/tests/public-api/public-types.test.js +74 -0
- package/dist/esm/tests/public-api/public-types.test.js.map +7 -0
- package/dist/esm/tests/public-api/runtime-utils.test.js +31 -0
- package/dist/esm/tests/public-api/runtime-utils.test.js.map +7 -0
- package/dist/esm/tests/public-api/schema-utils.test.js +78 -0
- package/dist/esm/tests/public-api/schema-utils.test.js.map +7 -0
- package/dist/esm/tests/public-api/timeout-error-types.test.js +81 -0
- package/dist/esm/tests/public-api/timeout-error-types.test.js.map +7 -0
- package/dist/esm/tests/public-api/tool-type-export.test.js +25 -0
- package/dist/esm/tests/public-api/tool-type-export.test.js.map +7 -0
- package/dist/esm/tests/public-api/v3-core.test.js +82 -0
- package/dist/esm/tests/public-api/v3-core.test.js.map +7 -0
- package/dist/esm/tests/safety-confirmation.test.js +134 -0
- package/dist/esm/tests/safety-confirmation.test.js.map +7 -0
- package/dist/esm/tests/snapshot-a11y-resolvers.test.js +348 -0
- package/dist/esm/tests/snapshot-a11y-resolvers.test.js.map +7 -0
- package/dist/esm/tests/snapshot-a11y-tree-utils.test.js +300 -0
- package/dist/esm/tests/snapshot-a11y-tree-utils.test.js.map +7 -0
- package/dist/esm/tests/snapshot-capture-orchestration.test.js +381 -0
- package/dist/esm/tests/snapshot-capture-orchestration.test.js.map +7 -0
- package/dist/esm/tests/snapshot-cbor.test.js +197 -0
- package/dist/esm/tests/snapshot-cbor.test.js.map +7 -0
- package/dist/esm/tests/snapshot-dom-session-builders.test.js +251 -0
- package/dist/esm/tests/snapshot-dom-session-builders.test.js.map +7 -0
- package/dist/esm/tests/snapshot-dom-tree-utils.test.js +109 -0
- package/dist/esm/tests/snapshot-dom-tree-utils.test.js.map +7 -0
- package/dist/esm/tests/snapshot-focus-selectors-utils.test.js +49 -0
- package/dist/esm/tests/snapshot-focus-selectors-utils.test.js.map +7 -0
- package/dist/esm/tests/snapshot-frame-merge.test.js +391 -0
- package/dist/esm/tests/snapshot-frame-merge.test.js.map +7 -0
- package/dist/esm/tests/snapshot-tree-format-utils.test.js +113 -0
- package/dist/esm/tests/snapshot-tree-format-utils.test.js.map +7 -0
- package/dist/esm/tests/snapshot-xpath-utils.test.js +79 -0
- package/dist/esm/tests/snapshot-xpath-utils.test.js.map +7 -0
- package/dist/esm/tests/timeout-handlers.test.js +850 -0
- package/dist/esm/tests/timeout-handlers.test.js.map +7 -0
- package/dist/esm/tests/xpath-parser.test.js +317 -0
- package/dist/esm/tests/xpath-parser.test.js.map +7 -0
- package/dist/esm/tests/xpath-resolver.test.js +73 -0
- package/dist/esm/tests/xpath-resolver.test.js.map +7 -0
- package/dist/esm/tests/zod-enum-compatibility.test.js +97 -0
- package/dist/esm/tests/zod-enum-compatibility.test.js.map +7 -0
- package/package.json +42 -27
- package/dist/index.d.ts +0 -4321
- package/dist/index.js +0 -69585
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../tests/safety-confirmation.test.ts"],
|
|
4
|
+
"sourcesContent": ["import { describe, it, expect, vi } from \"vitest\";\nimport { OpenAICUAClient } from \"../lib/v3/agent/OpenAICUAClient.js\";\nimport { GoogleCUAClient } from \"../lib/v3/agent/GoogleCUAClient.js\";\nimport type {\n SafetyCheck,\n SafetyConfirmationHandler,\n} from \"../lib/v3/types/public/agent.js\";\nimport type { LogLine } from \"../lib/v3/types/public/logs.js\";\n\ntype LoggerMock = (message: LogLine) => void;\n\nconst openAISafetyInvoker = (\n OpenAICUAClient.prototype as unknown as {\n handleSafetyConfirmation: (\n this: OpenAICUAClient,\n pendingSafetyChecks: SafetyCheck[],\n logger: LoggerMock,\n ) => Promise<SafetyCheck[] | undefined>;\n }\n).handleSafetyConfirmation;\n\nconst googleSafetyInvoker = (\n GoogleCUAClient.prototype as unknown as {\n handleSafetyConfirmation: (\n this: GoogleCUAClient,\n safetyDecision: unknown,\n logger: LoggerMock,\n ) => Promise<string | undefined>;\n }\n).handleSafetyConfirmation;\n\nfunction createOpenAIClient(): OpenAICUAClient {\n return new OpenAICUAClient(\n \"openai\",\n \"openai/computer-use-preview\",\n \"test instructions\",\n { apiKey: \"test\" },\n );\n}\n\nfunction createGoogleClient(): GoogleCUAClient {\n return new GoogleCUAClient(\n \"google\",\n \"google/gemini-2.5-computer-use-preview-10-2025\",\n \"test instructions\",\n { apiKey: \"test\" },\n );\n}\n\ndescribe(\"Safety Confirmation Handler\", () => {\n describe(\"OpenAI-style (pending_safety_checks)\", () => {\n const mockChecks: SafetyCheck[] = [\n {\n id: \"check-1\",\n code: \"malicious_instructions\",\n message: \"Potentially harmful action detected\",\n },\n ];\n\n it(\"returns checks when handler acknowledges\", async () => {\n const client = createOpenAIClient();\n const handler: SafetyConfirmationHandler = vi.fn(async () => ({\n acknowledged: true,\n }));\n client.setSafetyConfirmationHandler(handler);\n const logger = vi.fn<LoggerMock>();\n const result = await openAISafetyInvoker.call(client, mockChecks, logger);\n\n expect(handler).toHaveBeenCalledWith(mockChecks);\n expect(result).toEqual(mockChecks);\n });\n\n it(\"returns undefined when handler rejects\", async () => {\n const client = createOpenAIClient();\n const handler: SafetyConfirmationHandler = vi.fn(async () => ({\n acknowledged: false,\n }));\n client.setSafetyConfirmationHandler(handler);\n const logger = vi.fn<LoggerMock>();\n const result = await openAISafetyInvoker.call(client, mockChecks, logger);\n\n expect(handler).toHaveBeenCalledWith(mockChecks);\n expect(result).toBeUndefined();\n });\n\n it(\"auto-acknowledges when no handler is set\", async () => {\n const client = createOpenAIClient();\n const logger = vi.fn<LoggerMock>();\n const result = await openAISafetyInvoker.call(client, mockChecks, logger);\n expect(result).toEqual(mockChecks);\n });\n });\n\n describe(\"Google-style (safety_decision)\", () => {\n const mockDecision = {\n decision: \"require_confirmation\",\n explanation: \"Cookie consent dialog detected\",\n };\n\n it(\"returns 'true' when handler acknowledges\", async () => {\n const client = createGoogleClient();\n const handler: SafetyConfirmationHandler = vi.fn(async () => ({\n acknowledged: true,\n }));\n client.setSafetyConfirmationHandler(handler);\n const logger = vi.fn<LoggerMock>();\n const result = await googleSafetyInvoker.call(\n client,\n mockDecision,\n logger,\n );\n\n expect(handler).toHaveBeenCalledWith([\n {\n id: \"google-safety-decision\",\n code: \"safety_decision\",\n message: JSON.stringify(mockDecision, null, 2),\n },\n ]);\n expect(result).toBe(\"true\");\n });\n\n it(\"returns undefined when handler rejects\", async () => {\n const client = createGoogleClient();\n const handler: SafetyConfirmationHandler = vi.fn(async () => ({\n acknowledged: false,\n }));\n client.setSafetyConfirmationHandler(handler);\n const logger = vi.fn<LoggerMock>();\n const result = await googleSafetyInvoker.call(\n client,\n mockDecision,\n logger,\n );\n\n expect(handler).toHaveBeenCalled();\n expect(result).toBeUndefined();\n });\n\n it(\"auto-acknowledges when no handler is set\", async () => {\n const client = createGoogleClient();\n const logger = vi.fn<LoggerMock>();\n const result = await googleSafetyInvoker.call(\n client,\n mockDecision,\n logger,\n );\n expect(result).toBe(\"true\");\n });\n\n it(\"handles string safety decisions\", async () => {\n const client = createGoogleClient();\n const handler: SafetyConfirmationHandler = vi.fn(async () => ({\n acknowledged: true,\n }));\n client.setSafetyConfirmationHandler(handler);\n const logger = vi.fn<LoggerMock>();\n const result = await googleSafetyInvoker.call(\n client,\n \"Simple string decision\",\n logger,\n );\n\n expect(handler).toHaveBeenCalledWith([\n {\n id: \"google-safety-decision\",\n code: \"safety_decision\",\n message: \"Simple string decision\",\n },\n ]);\n expect(result).toBe(\"true\");\n });\n });\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,348 @@
|
|
|
1
|
+
import { beforeEach, describe, expect, it, vi } from "vitest";
|
|
2
|
+
import { a11yForFrame } from "../lib/v3/understudy/a11y/snapshot/a11yTree.js";
|
|
3
|
+
import * as focusSelectors from "../lib/v3/understudy/a11y/snapshot/focusSelectors.js";
|
|
4
|
+
import { MockCDPSession } from "./helpers/mockCDPSession.js";
|
|
5
|
+
import { executionContexts } from "../lib/v3/understudy/executionContextRegistry.js";
|
|
6
|
+
import { tryScopedSnapshot } from "../lib/v3/understudy/a11y/snapshot/capture.js";
|
|
7
|
+
import * as domTree from "../lib/v3/understudy/a11y/snapshot/domTree.js";
|
|
8
|
+
import * as a11yTree from "../lib/v3/understudy/a11y/snapshot/a11yTree.js";
|
|
9
|
+
import * as logger from "../lib/v3/logger.js";
|
|
10
|
+
const stringType = "string";
|
|
11
|
+
const baseAxNodes = () => [
|
|
12
|
+
{
|
|
13
|
+
nodeId: "1",
|
|
14
|
+
role: { type: stringType, value: "RootWebArea" },
|
|
15
|
+
backendDOMNodeId: 100,
|
|
16
|
+
childIds: ["2"],
|
|
17
|
+
ignored: false
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
nodeId: "2",
|
|
21
|
+
role: { type: stringType, value: "link" },
|
|
22
|
+
name: { type: stringType, value: "Docs" },
|
|
23
|
+
backendDOMNodeId: 101,
|
|
24
|
+
parentId: "1",
|
|
25
|
+
childIds: [],
|
|
26
|
+
properties: [
|
|
27
|
+
{
|
|
28
|
+
name: "url",
|
|
29
|
+
value: { type: stringType, value: "https://example.com" }
|
|
30
|
+
}
|
|
31
|
+
],
|
|
32
|
+
ignored: false
|
|
33
|
+
}
|
|
34
|
+
];
|
|
35
|
+
const baseHandlers = {
|
|
36
|
+
"Accessibility.enable": async () => ({}),
|
|
37
|
+
"Runtime.enable": async () => ({}),
|
|
38
|
+
"DOM.enable": async () => ({})
|
|
39
|
+
};
|
|
40
|
+
describe("a11yForFrame", () => {
|
|
41
|
+
beforeEach(() => {
|
|
42
|
+
vi.restoreAllMocks();
|
|
43
|
+
});
|
|
44
|
+
it("returns full outline and url map when no focus selector is provided", async () => {
|
|
45
|
+
const session = new MockCDPSession({
|
|
46
|
+
...baseHandlers,
|
|
47
|
+
"Accessibility.getFullAXTree": async () => ({ nodes: baseAxNodes() })
|
|
48
|
+
});
|
|
49
|
+
const opts = {
|
|
50
|
+
focusSelector: void 0,
|
|
51
|
+
experimental: false,
|
|
52
|
+
tagNameMap: { "enc-100": "#document", "enc-101": "a" },
|
|
53
|
+
scrollableMap: {},
|
|
54
|
+
encode: (backend) => `enc-${backend}`
|
|
55
|
+
};
|
|
56
|
+
const result = await a11yForFrame(session, void 0, opts);
|
|
57
|
+
expect(result.scopeApplied).toBe(false);
|
|
58
|
+
expect(result.urlMap["enc-101"]).toBe("https://example.com");
|
|
59
|
+
expect(result.outline).toContain("Docs");
|
|
60
|
+
});
|
|
61
|
+
it("scopes the tree to the resolved focus selector target", async () => {
|
|
62
|
+
const nodes = baseAxNodes().map(
|
|
63
|
+
(n) => n.nodeId === "2" ? {
|
|
64
|
+
...n,
|
|
65
|
+
childIds: ["3"]
|
|
66
|
+
} : n
|
|
67
|
+
);
|
|
68
|
+
nodes.push({
|
|
69
|
+
nodeId: "3",
|
|
70
|
+
parentId: "2",
|
|
71
|
+
childIds: [],
|
|
72
|
+
role: { type: stringType, value: "StaticText" },
|
|
73
|
+
backendDOMNodeId: 102,
|
|
74
|
+
ignored: false
|
|
75
|
+
});
|
|
76
|
+
let scopedOnce = false;
|
|
77
|
+
const session = new MockCDPSession({
|
|
78
|
+
...baseHandlers,
|
|
79
|
+
"Accessibility.getFullAXTree": async (params) => {
|
|
80
|
+
if (params?.frameId && !scopedOnce) {
|
|
81
|
+
scopedOnce = true;
|
|
82
|
+
throw new Error("does not belong to the target");
|
|
83
|
+
}
|
|
84
|
+
return { nodes };
|
|
85
|
+
},
|
|
86
|
+
"DOM.describeNode": async () => ({
|
|
87
|
+
node: { backendNodeId: 101 }
|
|
88
|
+
})
|
|
89
|
+
});
|
|
90
|
+
const resolveSpy = vi.spyOn(focusSelectors, "resolveObjectIdForXPath").mockResolvedValue("object-1");
|
|
91
|
+
const opts = {
|
|
92
|
+
focusSelector: "xpath=//a",
|
|
93
|
+
experimental: false,
|
|
94
|
+
tagNameMap: { "enc-101": "a" },
|
|
95
|
+
scrollableMap: {},
|
|
96
|
+
encode: (backend) => `enc-${backend}`
|
|
97
|
+
};
|
|
98
|
+
const result = await a11yForFrame(session, "frame-1", opts);
|
|
99
|
+
expect(result.scopeApplied).toBe(true);
|
|
100
|
+
expect(result.outline).not.toContain("RootWebArea");
|
|
101
|
+
expect(resolveSpy).toHaveBeenCalled();
|
|
102
|
+
resolveSpy.mockRestore();
|
|
103
|
+
});
|
|
104
|
+
it("falls back to full tree when resolveObjectId throws", async () => {
|
|
105
|
+
const session = new MockCDPSession({
|
|
106
|
+
...baseHandlers,
|
|
107
|
+
"Accessibility.getFullAXTree": async () => ({ nodes: baseAxNodes() })
|
|
108
|
+
});
|
|
109
|
+
vi.spyOn(focusSelectors, "resolveObjectIdForCss").mockRejectedValue(
|
|
110
|
+
new Error("fail")
|
|
111
|
+
);
|
|
112
|
+
const opts = {
|
|
113
|
+
focusSelector: ".btn",
|
|
114
|
+
experimental: false,
|
|
115
|
+
tagNameMap: {},
|
|
116
|
+
scrollableMap: {},
|
|
117
|
+
encode: (backend) => `enc-${backend}`
|
|
118
|
+
};
|
|
119
|
+
const result = await a11yForFrame(session, "frame-1", opts);
|
|
120
|
+
expect(result.scopeApplied).toBe(false);
|
|
121
|
+
});
|
|
122
|
+
});
|
|
123
|
+
describe("resolveObjectIdForXPath", () => {
|
|
124
|
+
beforeEach(() => {
|
|
125
|
+
vi.restoreAllMocks();
|
|
126
|
+
});
|
|
127
|
+
it("evaluates in the target frame's main world when available", async () => {
|
|
128
|
+
vi.spyOn(executionContexts, "waitForMainWorld").mockResolvedValue(42);
|
|
129
|
+
vi.spyOn(executionContexts, "getMainWorld").mockReturnValue(void 0);
|
|
130
|
+
const session = new MockCDPSession({
|
|
131
|
+
"Runtime.evaluate": async (params) => {
|
|
132
|
+
expect(params?.contextId).toBe(42);
|
|
133
|
+
return { result: { objectId: "node-obj" } };
|
|
134
|
+
}
|
|
135
|
+
});
|
|
136
|
+
const objectId = await focusSelectors.resolveObjectIdForXPath(
|
|
137
|
+
session,
|
|
138
|
+
"//div",
|
|
139
|
+
"frame-1"
|
|
140
|
+
);
|
|
141
|
+
expect(objectId).toBe("node-obj");
|
|
142
|
+
});
|
|
143
|
+
it("returns null when evaluation throws or reports exception details", async () => {
|
|
144
|
+
vi.spyOn(executionContexts, "waitForMainWorld").mockRejectedValue(
|
|
145
|
+
new Error("missing")
|
|
146
|
+
);
|
|
147
|
+
vi.spyOn(executionContexts, "getMainWorld").mockReturnValue(void 0);
|
|
148
|
+
const session = new MockCDPSession({
|
|
149
|
+
"Runtime.evaluate": async () => ({
|
|
150
|
+
result: {},
|
|
151
|
+
exceptionDetails: { exception: { description: "bad" } }
|
|
152
|
+
})
|
|
153
|
+
});
|
|
154
|
+
const objectId = await focusSelectors.resolveObjectIdForXPath(
|
|
155
|
+
session,
|
|
156
|
+
"//div",
|
|
157
|
+
"frame-2"
|
|
158
|
+
);
|
|
159
|
+
expect(objectId).toBeNull();
|
|
160
|
+
});
|
|
161
|
+
});
|
|
162
|
+
describe("resolveObjectIdForCss", () => {
|
|
163
|
+
beforeEach(() => {
|
|
164
|
+
vi.restoreAllMocks();
|
|
165
|
+
});
|
|
166
|
+
it("returns primary evaluation result when available", async () => {
|
|
167
|
+
vi.spyOn(executionContexts, "waitForMainWorld").mockResolvedValue(7);
|
|
168
|
+
const session = new MockCDPSession({
|
|
169
|
+
"Runtime.evaluate": async () => ({
|
|
170
|
+
result: { objectId: "primary-obj" }
|
|
171
|
+
})
|
|
172
|
+
});
|
|
173
|
+
const objectId = await focusSelectors.resolveObjectIdForCss(
|
|
174
|
+
session,
|
|
175
|
+
".btn",
|
|
176
|
+
"frame-1"
|
|
177
|
+
);
|
|
178
|
+
expect(objectId).toBe("primary-obj");
|
|
179
|
+
});
|
|
180
|
+
it("falls back to the pierce selector when the primary lookup fails", async () => {
|
|
181
|
+
let call = 0;
|
|
182
|
+
const session = new MockCDPSession({
|
|
183
|
+
"Runtime.evaluate": async (params) => {
|
|
184
|
+
call++;
|
|
185
|
+
if (call === 1) {
|
|
186
|
+
expect(String(params?.expression)).toContain("resolveCssSelector");
|
|
187
|
+
return { result: {} };
|
|
188
|
+
}
|
|
189
|
+
expect(String(params?.expression)).toContain(
|
|
190
|
+
"resolveCssSelectorPierce"
|
|
191
|
+
);
|
|
192
|
+
return { result: { objectId: "css-obj" } };
|
|
193
|
+
}
|
|
194
|
+
});
|
|
195
|
+
const objectId = await focusSelectors.resolveObjectIdForCss(
|
|
196
|
+
session,
|
|
197
|
+
".btn",
|
|
198
|
+
void 0
|
|
199
|
+
);
|
|
200
|
+
expect(objectId).toBe("css-obj");
|
|
201
|
+
});
|
|
202
|
+
it("returns null when both primary and fallback evaluations throw", async () => {
|
|
203
|
+
vi.spyOn(executionContexts, "waitForMainWorld").mockResolvedValue(11);
|
|
204
|
+
vi.spyOn(executionContexts, "getMainWorld").mockReturnValue(void 0);
|
|
205
|
+
const session = new MockCDPSession({
|
|
206
|
+
"Runtime.evaluate": async () => ({
|
|
207
|
+
result: {},
|
|
208
|
+
exceptionDetails: { exception: { description: "fail" } }
|
|
209
|
+
})
|
|
210
|
+
});
|
|
211
|
+
const objectId = await focusSelectors.resolveObjectIdForCss(
|
|
212
|
+
session,
|
|
213
|
+
".missing",
|
|
214
|
+
"frame-1"
|
|
215
|
+
);
|
|
216
|
+
expect(objectId).toBeNull();
|
|
217
|
+
});
|
|
218
|
+
});
|
|
219
|
+
describe("tryScopedSnapshot", () => {
|
|
220
|
+
const ordinal = (frameId) => frameId === "frame-1" ? 0 : 1;
|
|
221
|
+
const context = {
|
|
222
|
+
rootId: "frame-1",
|
|
223
|
+
frames: ["frame-1", "frame-2"],
|
|
224
|
+
parentByFrame: /* @__PURE__ */ new Map([
|
|
225
|
+
["frame-1", null],
|
|
226
|
+
["frame-2", "frame-1"]
|
|
227
|
+
])
|
|
228
|
+
};
|
|
229
|
+
const makePage = (session, overrides) => ({
|
|
230
|
+
mainFrameId: () => "frame-1",
|
|
231
|
+
asProtocolFrameTree: () => ({
|
|
232
|
+
frame: { id: "frame-1" },
|
|
233
|
+
childFrames: [{ frame: { id: "frame-2" } }]
|
|
234
|
+
}),
|
|
235
|
+
listAllFrameIds: () => ["frame-1", "frame-2"],
|
|
236
|
+
getSessionForFrame: () => session,
|
|
237
|
+
getOrdinal: (fid) => ordinal(fid),
|
|
238
|
+
...overrides
|
|
239
|
+
});
|
|
240
|
+
beforeEach(() => {
|
|
241
|
+
vi.restoreAllMocks();
|
|
242
|
+
});
|
|
243
|
+
it("returns scoped snapshot when focus selector resolves via CSS hops", async () => {
|
|
244
|
+
const session = new MockCDPSession({});
|
|
245
|
+
const domMapsSpy = vi.spyOn(domTree, "domMapsForSession").mockResolvedValue({
|
|
246
|
+
tagNameMap: { "1-10": "div" },
|
|
247
|
+
xpathMap: { "1-10": "/div[1]" },
|
|
248
|
+
scrollableMap: {}
|
|
249
|
+
});
|
|
250
|
+
const a11ySpy = vi.spyOn(a11yTree, "a11yForFrame").mockResolvedValue({
|
|
251
|
+
outline: "[1-10] div",
|
|
252
|
+
urlMap: { "1-10": "https://example.com" },
|
|
253
|
+
scopeApplied: true
|
|
254
|
+
});
|
|
255
|
+
vi.spyOn(focusSelectors, "resolveCssFocusFrameAndTail").mockResolvedValue({
|
|
256
|
+
targetFrameId: "frame-2",
|
|
257
|
+
tailSelector: ".btn-inner",
|
|
258
|
+
absPrefix: "/html/body/iframe[1]"
|
|
259
|
+
});
|
|
260
|
+
const result = await tryScopedSnapshot(
|
|
261
|
+
makePage(session),
|
|
262
|
+
{ focusSelector: ".btn" },
|
|
263
|
+
context,
|
|
264
|
+
true
|
|
265
|
+
);
|
|
266
|
+
expect(result).not.toBeNull();
|
|
267
|
+
expect(result?.combinedXpathMap["1-10"]).toBe(
|
|
268
|
+
"/html/body/iframe[1]/div[1]"
|
|
269
|
+
);
|
|
270
|
+
expect(domMapsSpy).toHaveBeenCalled();
|
|
271
|
+
expect(a11ySpy).toHaveBeenCalled();
|
|
272
|
+
});
|
|
273
|
+
it("returns null and logs fallback when scope is not applied", async () => {
|
|
274
|
+
const session = new MockCDPSession({});
|
|
275
|
+
vi.spyOn(domTree, "domMapsForSession").mockResolvedValue({
|
|
276
|
+
tagNameMap: { "1-10": "div" },
|
|
277
|
+
xpathMap: { "1-10": "/div[1]" },
|
|
278
|
+
scrollableMap: {}
|
|
279
|
+
});
|
|
280
|
+
vi.spyOn(a11yTree, "a11yForFrame").mockResolvedValue({
|
|
281
|
+
outline: "ignored",
|
|
282
|
+
urlMap: {},
|
|
283
|
+
scopeApplied: false
|
|
284
|
+
});
|
|
285
|
+
const loggerSpy = vi.spyOn(logger, "v3Logger").mockImplementation(() => {
|
|
286
|
+
});
|
|
287
|
+
const result = await tryScopedSnapshot(
|
|
288
|
+
makePage(session),
|
|
289
|
+
{ focusSelector: ".btn" },
|
|
290
|
+
context,
|
|
291
|
+
false
|
|
292
|
+
);
|
|
293
|
+
expect(result).toBeNull();
|
|
294
|
+
expect(loggerSpy).toHaveBeenCalled();
|
|
295
|
+
});
|
|
296
|
+
it("returns null immediately when no focus selector is provided", async () => {
|
|
297
|
+
const result = await tryScopedSnapshot(
|
|
298
|
+
makePage(new MockCDPSession({})),
|
|
299
|
+
{},
|
|
300
|
+
context,
|
|
301
|
+
true
|
|
302
|
+
);
|
|
303
|
+
expect(result).toBeNull();
|
|
304
|
+
});
|
|
305
|
+
it("supports XPath focus resolution branch", async () => {
|
|
306
|
+
const session = new MockCDPSession({});
|
|
307
|
+
vi.spyOn(domTree, "domMapsForSession").mockResolvedValue({
|
|
308
|
+
tagNameMap: { "1-10": "div" },
|
|
309
|
+
xpathMap: { "1-10": "/div[1]" },
|
|
310
|
+
scrollableMap: {}
|
|
311
|
+
});
|
|
312
|
+
vi.spyOn(a11yTree, "a11yForFrame").mockResolvedValue({
|
|
313
|
+
outline: "[1-10] div",
|
|
314
|
+
urlMap: {},
|
|
315
|
+
scopeApplied: true
|
|
316
|
+
});
|
|
317
|
+
vi.spyOn(focusSelectors, "resolveFocusFrameAndTail").mockResolvedValue({
|
|
318
|
+
targetFrameId: "frame-1",
|
|
319
|
+
tailXPath: "//div[1]",
|
|
320
|
+
absPrefix: ""
|
|
321
|
+
});
|
|
322
|
+
const result = await tryScopedSnapshot(
|
|
323
|
+
makePage(session),
|
|
324
|
+
{ focusSelector: "xpath=//div" },
|
|
325
|
+
context,
|
|
326
|
+
true
|
|
327
|
+
);
|
|
328
|
+
expect(result).not.toBeNull();
|
|
329
|
+
expect(result?.combinedXpathMap["1-10"]).toBe("/div[1]");
|
|
330
|
+
});
|
|
331
|
+
it("logs and returns null when resolver throws", async () => {
|
|
332
|
+
const session = new MockCDPSession({});
|
|
333
|
+
vi.spyOn(focusSelectors, "resolveCssFocusFrameAndTail").mockRejectedValue(
|
|
334
|
+
new Error("bad selector")
|
|
335
|
+
);
|
|
336
|
+
const loggerSpy = vi.spyOn(logger, "v3Logger").mockImplementation(() => {
|
|
337
|
+
});
|
|
338
|
+
const result = await tryScopedSnapshot(
|
|
339
|
+
makePage(session),
|
|
340
|
+
{ focusSelector: ".bad" },
|
|
341
|
+
context,
|
|
342
|
+
true
|
|
343
|
+
);
|
|
344
|
+
expect(result).toBeNull();
|
|
345
|
+
expect(loggerSpy).toHaveBeenCalled();
|
|
346
|
+
});
|
|
347
|
+
});
|
|
348
|
+
//# sourceMappingURL=snapshot-a11y-resolvers.test.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../tests/snapshot-a11y-resolvers.test.ts"],
|
|
4
|
+
"sourcesContent": ["import type { Protocol } from \"devtools-protocol\";\nimport { beforeEach, describe, expect, it, vi } from \"vitest\";\nimport { a11yForFrame } from \"../lib/v3/understudy/a11y/snapshot/a11yTree.js\";\nimport type { AccessibilityTreeResult } from \"../lib/v3/types/private/index.js\";\nimport * as focusSelectors from \"../lib/v3/understudy/a11y/snapshot/focusSelectors.js\";\nimport { MockCDPSession } from \"./helpers/mockCDPSession.js\";\nimport { executionContexts } from \"../lib/v3/understudy/executionContextRegistry.js\";\nimport { tryScopedSnapshot } from \"../lib/v3/understudy/a11y/snapshot/capture.js\";\nimport type {\n FrameContext,\n A11yOptions,\n} from \"../lib/v3/types/private/index.js\";\nimport type { Page } from \"../lib/v3/understudy/page.js\";\nimport * as domTree from \"../lib/v3/understudy/a11y/snapshot/domTree.js\";\nimport * as a11yTree from \"../lib/v3/understudy/a11y/snapshot/a11yTree.js\";\nimport * as logger from \"../lib/v3/logger.js\";\n\nconst stringType = \"string\" as Protocol.Accessibility.AXValueType;\n\nconst baseAxNodes = (): Protocol.Accessibility.AXNode[] => [\n {\n nodeId: \"1\",\n role: { type: stringType, value: \"RootWebArea\" },\n backendDOMNodeId: 100,\n childIds: [\"2\"],\n ignored: false,\n },\n {\n nodeId: \"2\",\n role: { type: stringType, value: \"link\" },\n name: { type: stringType, value: \"Docs\" },\n backendDOMNodeId: 101,\n parentId: \"1\",\n childIds: [],\n properties: [\n {\n name: \"url\",\n value: { type: stringType, value: \"https://example.com\" },\n },\n ],\n ignored: false,\n },\n];\n\nconst baseHandlers = {\n \"Accessibility.enable\": async () => ({}),\n \"Runtime.enable\": async () => ({}),\n \"DOM.enable\": async () => ({}),\n};\n\ndescribe(\"a11yForFrame\", () => {\n beforeEach(() => {\n vi.restoreAllMocks();\n });\n\n it(\"returns full outline and url map when no focus selector is provided\", async () => {\n const session = new MockCDPSession({\n ...baseHandlers,\n \"Accessibility.getFullAXTree\": async () => ({ nodes: baseAxNodes() }),\n });\n\n const opts: A11yOptions = {\n focusSelector: undefined,\n experimental: false,\n tagNameMap: { \"enc-100\": \"#document\", \"enc-101\": \"a\" },\n scrollableMap: {},\n encode: (backend) => `enc-${backend}`,\n };\n\n const result = await a11yForFrame(session, undefined, opts);\n\n expect(result.scopeApplied).toBe(false);\n expect(result.urlMap[\"enc-101\"]).toBe(\"https://example.com\");\n expect(result.outline).toContain(\"Docs\");\n });\n\n it(\"scopes the tree to the resolved focus selector target\", async () => {\n const nodes = baseAxNodes().map((n) =>\n n.nodeId === \"2\"\n ? {\n ...n,\n childIds: [\"3\"],\n }\n : n,\n );\n nodes.push({\n nodeId: \"3\",\n parentId: \"2\",\n childIds: [],\n role: { type: stringType, value: \"StaticText\" },\n backendDOMNodeId: 102,\n ignored: false,\n });\n\n let scopedOnce = false;\n const session = new MockCDPSession({\n ...baseHandlers,\n \"Accessibility.getFullAXTree\": async (params) => {\n if (params?.frameId && !scopedOnce) {\n scopedOnce = true;\n throw new Error(\"does not belong to the target\");\n }\n return { nodes };\n },\n \"DOM.describeNode\": async () => ({\n node: { backendNodeId: 101 },\n }),\n });\n\n const resolveSpy = vi\n .spyOn(focusSelectors, \"resolveObjectIdForXPath\")\n .mockResolvedValue(\"object-1\");\n\n const opts: A11yOptions = {\n focusSelector: \"xpath=//a\",\n experimental: false,\n tagNameMap: { \"enc-101\": \"a\" },\n scrollableMap: {},\n encode: (backend) => `enc-${backend}`,\n };\n\n const result = await a11yForFrame(session, \"frame-1\", opts);\n\n expect(result.scopeApplied).toBe(true);\n expect(result.outline).not.toContain(\"RootWebArea\");\n expect(resolveSpy).toHaveBeenCalled();\n resolveSpy.mockRestore();\n });\n\n it(\"falls back to full tree when resolveObjectId throws\", async () => {\n const session = new MockCDPSession({\n ...baseHandlers,\n \"Accessibility.getFullAXTree\": async () => ({ nodes: baseAxNodes() }),\n });\n vi.spyOn(focusSelectors, \"resolveObjectIdForCss\").mockRejectedValue(\n new Error(\"fail\"),\n );\n const opts: A11yOptions = {\n focusSelector: \".btn\",\n experimental: false,\n tagNameMap: {},\n scrollableMap: {},\n encode: (backend) => `enc-${backend}`,\n };\n\n const result = await a11yForFrame(session, \"frame-1\", opts);\n expect(result.scopeApplied).toBe(false);\n });\n});\n\ndescribe(\"resolveObjectIdForXPath\", () => {\n beforeEach(() => {\n vi.restoreAllMocks();\n });\n\n it(\"evaluates in the target frame's main world when available\", async () => {\n vi.spyOn(executionContexts, \"waitForMainWorld\").mockResolvedValue(42);\n vi.spyOn(executionContexts, \"getMainWorld\").mockReturnValue(undefined);\n const session = new MockCDPSession({\n \"Runtime.evaluate\": async (params) => {\n expect(params?.contextId).toBe(42);\n return { result: { objectId: \"node-obj\" } };\n },\n });\n\n const objectId = await focusSelectors.resolveObjectIdForXPath(\n session,\n \"//div\",\n \"frame-1\",\n );\n expect(objectId).toBe(\"node-obj\");\n });\n\n it(\"returns null when evaluation throws or reports exception details\", async () => {\n vi.spyOn(executionContexts, \"waitForMainWorld\").mockRejectedValue(\n new Error(\"missing\"),\n );\n vi.spyOn(executionContexts, \"getMainWorld\").mockReturnValue(undefined);\n const session = new MockCDPSession({\n \"Runtime.evaluate\": async () => ({\n result: {},\n exceptionDetails: { exception: { description: \"bad\" } },\n }),\n });\n\n const objectId = await focusSelectors.resolveObjectIdForXPath(\n session,\n \"//div\",\n \"frame-2\",\n );\n expect(objectId).toBeNull();\n });\n});\n\ndescribe(\"resolveObjectIdForCss\", () => {\n beforeEach(() => {\n vi.restoreAllMocks();\n });\n\n it(\"returns primary evaluation result when available\", async () => {\n vi.spyOn(executionContexts, \"waitForMainWorld\").mockResolvedValue(7);\n const session = new MockCDPSession({\n \"Runtime.evaluate\": async () => ({\n result: { objectId: \"primary-obj\" },\n }),\n });\n const objectId = await focusSelectors.resolveObjectIdForCss(\n session,\n \".btn\",\n \"frame-1\",\n );\n expect(objectId).toBe(\"primary-obj\");\n });\n\n it(\"falls back to the pierce selector when the primary lookup fails\", async () => {\n let call = 0;\n const session = new MockCDPSession({\n \"Runtime.evaluate\": async (params) => {\n call++;\n if (call === 1) {\n expect(String(params?.expression)).toContain(\"resolveCssSelector\");\n return { result: {} };\n }\n expect(String(params?.expression)).toContain(\n \"resolveCssSelectorPierce\",\n );\n return { result: { objectId: \"css-obj\" } };\n },\n });\n\n const objectId = await focusSelectors.resolveObjectIdForCss(\n session,\n \".btn\",\n undefined,\n );\n expect(objectId).toBe(\"css-obj\");\n });\n\n it(\"returns null when both primary and fallback evaluations throw\", async () => {\n vi.spyOn(executionContexts, \"waitForMainWorld\").mockResolvedValue(11);\n vi.spyOn(executionContexts, \"getMainWorld\").mockReturnValue(undefined);\n const session = new MockCDPSession({\n \"Runtime.evaluate\": async () => ({\n result: {},\n exceptionDetails: { exception: { description: \"fail\" } },\n }),\n });\n\n const objectId = await focusSelectors.resolveObjectIdForCss(\n session,\n \".missing\",\n \"frame-1\",\n );\n expect(objectId).toBeNull();\n });\n});\n\ndescribe(\"tryScopedSnapshot\", () => {\n const ordinal = (frameId: string) => (frameId === \"frame-1\" ? 0 : 1);\n const context: FrameContext = {\n rootId: \"frame-1\",\n frames: [\"frame-1\", \"frame-2\"],\n parentByFrame: new Map([\n [\"frame-1\", null],\n [\"frame-2\", \"frame-1\"],\n ]),\n };\n\n const makePage = (session: MockCDPSession, overrides?: Partial<Page>): Page =>\n ({\n mainFrameId: () => \"frame-1\",\n asProtocolFrameTree: () => ({\n frame: { id: \"frame-1\" as Protocol.Page.FrameId },\n childFrames: [{ frame: { id: \"frame-2\" as Protocol.Page.FrameId } }],\n }),\n listAllFrameIds: () => [\"frame-1\", \"frame-2\"],\n getSessionForFrame: () => session,\n getOrdinal: (fid: string) => ordinal(fid),\n ...overrides,\n }) as unknown as Page;\n\n beforeEach(() => {\n vi.restoreAllMocks();\n });\n\n it(\"returns scoped snapshot when focus selector resolves via CSS hops\", async () => {\n const session = new MockCDPSession({});\n const domMapsSpy = vi\n .spyOn(domTree, \"domMapsForSession\")\n .mockResolvedValue({\n tagNameMap: { \"1-10\": \"div\" },\n xpathMap: { \"1-10\": \"/div[1]\" },\n scrollableMap: {},\n });\n const a11ySpy = vi.spyOn(a11yTree, \"a11yForFrame\").mockResolvedValue({\n outline: \"[1-10] div\",\n urlMap: { \"1-10\": \"https://example.com\" },\n scopeApplied: true,\n } as AccessibilityTreeResult);\n vi.spyOn(focusSelectors, \"resolveCssFocusFrameAndTail\").mockResolvedValue({\n targetFrameId: \"frame-2\",\n tailSelector: \".btn-inner\",\n absPrefix: \"/html/body/iframe[1]\",\n });\n\n const result = await tryScopedSnapshot(\n makePage(session),\n { focusSelector: \".btn\" },\n context,\n true,\n );\n\n expect(result).not.toBeNull();\n expect(result?.combinedXpathMap[\"1-10\"]).toBe(\n \"/html/body/iframe[1]/div[1]\",\n );\n expect(domMapsSpy).toHaveBeenCalled();\n expect(a11ySpy).toHaveBeenCalled();\n });\n\n it(\"returns null and logs fallback when scope is not applied\", async () => {\n const session = new MockCDPSession({});\n vi.spyOn(domTree, \"domMapsForSession\").mockResolvedValue({\n tagNameMap: { \"1-10\": \"div\" },\n xpathMap: { \"1-10\": \"/div[1]\" },\n scrollableMap: {},\n });\n vi.spyOn(a11yTree, \"a11yForFrame\").mockResolvedValue({\n outline: \"ignored\",\n urlMap: {},\n scopeApplied: false,\n } as AccessibilityTreeResult);\n const loggerSpy = vi.spyOn(logger, \"v3Logger\").mockImplementation(() => {});\n\n const result = await tryScopedSnapshot(\n makePage(session),\n { focusSelector: \".btn\" },\n context,\n false,\n );\n\n expect(result).toBeNull();\n expect(loggerSpy).toHaveBeenCalled();\n });\n\n it(\"returns null immediately when no focus selector is provided\", async () => {\n const result = await tryScopedSnapshot(\n makePage(new MockCDPSession({})),\n {},\n context,\n true,\n );\n expect(result).toBeNull();\n });\n\n it(\"supports XPath focus resolution branch\", async () => {\n const session = new MockCDPSession({});\n vi.spyOn(domTree, \"domMapsForSession\").mockResolvedValue({\n tagNameMap: { \"1-10\": \"div\" },\n xpathMap: { \"1-10\": \"/div[1]\" },\n scrollableMap: {},\n });\n vi.spyOn(a11yTree, \"a11yForFrame\").mockResolvedValue({\n outline: \"[1-10] div\",\n urlMap: {},\n scopeApplied: true,\n } as AccessibilityTreeResult);\n vi.spyOn(focusSelectors, \"resolveFocusFrameAndTail\").mockResolvedValue({\n targetFrameId: \"frame-1\",\n tailXPath: \"//div[1]\",\n absPrefix: \"\",\n });\n\n const result = await tryScopedSnapshot(\n makePage(session),\n { focusSelector: \"xpath=//div\" },\n context,\n true,\n );\n\n expect(result).not.toBeNull();\n expect(result?.combinedXpathMap[\"1-10\"]).toBe(\"/div[1]\");\n });\n\n it(\"logs and returns null when resolver throws\", async () => {\n const session = new MockCDPSession({});\n vi.spyOn(focusSelectors, \"resolveCssFocusFrameAndTail\").mockRejectedValue(\n new Error(\"bad selector\"),\n );\n const loggerSpy = vi.spyOn(logger, \"v3Logger\").mockImplementation(() => {});\n\n const result = await tryScopedSnapshot(\n makePage(session),\n { focusSelector: \".bad\" },\n context,\n true,\n );\n\n expect(result).toBeNull();\n expect(loggerSpy).toHaveBeenCalled();\n });\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|