@browserbasehq/orca 3.4.0-preview.0 → 3.5.0-preview.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/cjs/lib/inference.d.ts +2 -1
- package/dist/cjs/lib/inference.js +10 -3
- package/dist/cjs/lib/inference.js.map +1 -1
- package/dist/cjs/lib/prompt.d.ts +2 -2
- package/dist/cjs/lib/prompt.js +19 -4
- package/dist/cjs/lib/prompt.js.map +1 -1
- package/dist/cjs/lib/v3/agent/AgentProvider.d.ts +1 -1
- package/dist/cjs/lib/v3/agent/AgentProvider.js.map +1 -1
- package/dist/cjs/lib/v3/agent/AnthropicCUAClient.js +10 -0
- package/dist/cjs/lib/v3/agent/AnthropicCUAClient.js.map +1 -1
- package/dist/cjs/lib/v3/handlers/extractHandler.js +19 -2
- package/dist/cjs/lib/v3/handlers/extractHandler.js.map +1 -1
- package/dist/cjs/lib/v3/handlers/observeHandler.js +2 -1
- package/dist/cjs/lib/v3/handlers/observeHandler.js.map +1 -1
- package/dist/cjs/lib/v3/handlers/v3CuaAgentHandler.js +1 -0
- package/dist/cjs/lib/v3/handlers/v3CuaAgentHandler.js.map +1 -1
- package/dist/cjs/lib/v3/index.d.ts +1 -0
- package/dist/cjs/lib/v3/index.js.map +1 -1
- package/dist/cjs/lib/v3/launch/local.d.ts +2 -7
- package/dist/cjs/lib/v3/launch/local.js +47 -7
- package/dist/cjs/lib/v3/launch/local.js.map +1 -1
- package/dist/cjs/lib/v3/llm/aisdk.js +5 -0
- package/dist/cjs/lib/v3/llm/aisdk.js.map +1 -1
- package/dist/cjs/lib/v3/types/private/handlers.d.ts +2 -0
- package/dist/cjs/lib/v3/types/private/handlers.js.map +1 -1
- package/dist/cjs/lib/v3/types/private/snapshot.d.ts +2 -0
- package/dist/cjs/lib/v3/types/private/snapshot.js.map +1 -1
- package/dist/cjs/lib/v3/types/public/agent.d.ts +1 -1
- package/dist/cjs/lib/v3/types/public/agent.js.map +1 -1
- package/dist/cjs/lib/v3/types/public/api.d.ts +287 -0
- package/dist/cjs/lib/v3/types/public/api.js +61 -3
- package/dist/cjs/lib/v3/types/public/api.js.map +1 -1
- package/dist/cjs/lib/v3/types/public/methods.d.ts +2 -0
- package/dist/cjs/lib/v3/types/public/methods.js.map +1 -1
- package/dist/cjs/lib/v3/types/public/model.d.ts +11 -7
- package/dist/cjs/lib/v3/types/public/model.js.map +1 -1
- package/dist/cjs/lib/v3/understudy/a11y/snapshot/a11yTree.js +25 -0
- package/dist/cjs/lib/v3/understudy/a11y/snapshot/a11yTree.js.map +1 -1
- package/dist/cjs/lib/v3/understudy/a11y/snapshot/treeFormatUtils.js +10 -1
- package/dist/cjs/lib/v3/understudy/a11y/snapshot/treeFormatUtils.js.map +1 -1
- package/dist/cjs/lib/v3/v3.js +7 -47
- package/dist/cjs/lib/v3/v3.js.map +1 -1
- package/dist/cjs/lib/v3Evaluator.d.ts +20 -12
- package/dist/cjs/lib/v3Evaluator.js +41 -199
- package/dist/cjs/lib/v3Evaluator.js.map +1 -1
- package/dist/cjs/lib/v3LegacyEvaluator.d.ts +20 -0
- package/dist/cjs/lib/v3LegacyEvaluator.js +215 -0
- package/dist/cjs/lib/v3LegacyEvaluator.js.map +1 -0
- package/dist/cjs/lib/version.d.ts +1 -1
- package/dist/cjs/lib/version.js +1 -1
- package/dist/cjs/lib/version.js.map +1 -1
- package/dist/esm/lib/inference.d.ts +2 -1
- package/dist/esm/lib/inference.js +10 -3
- package/dist/esm/lib/inference.js.map +1 -1
- package/dist/esm/lib/prompt.d.ts +2 -2
- package/dist/esm/lib/prompt.js +19 -4
- package/dist/esm/lib/prompt.js.map +1 -1
- package/dist/esm/lib/v3/agent/AgentProvider.d.ts +1 -1
- package/dist/esm/lib/v3/agent/AgentProvider.js.map +1 -1
- package/dist/esm/lib/v3/agent/AnthropicCUAClient.js +10 -0
- package/dist/esm/lib/v3/agent/AnthropicCUAClient.js.map +1 -1
- package/dist/esm/lib/v3/handlers/extractHandler.js +19 -2
- package/dist/esm/lib/v3/handlers/extractHandler.js.map +1 -1
- package/dist/esm/lib/v3/handlers/observeHandler.js +2 -1
- package/dist/esm/lib/v3/handlers/observeHandler.js.map +1 -1
- package/dist/esm/lib/v3/handlers/v3CuaAgentHandler.js +1 -0
- package/dist/esm/lib/v3/handlers/v3CuaAgentHandler.js.map +1 -1
- package/dist/esm/lib/v3/index.d.ts +1 -0
- package/dist/esm/lib/v3/index.js.map +1 -1
- package/dist/esm/lib/v3/launch/local.d.ts +2 -7
- package/dist/esm/lib/v3/launch/local.js +48 -8
- package/dist/esm/lib/v3/launch/local.js.map +1 -1
- package/dist/esm/lib/v3/llm/aisdk.js +5 -0
- package/dist/esm/lib/v3/llm/aisdk.js.map +1 -1
- package/dist/esm/lib/v3/types/private/handlers.d.ts +2 -0
- package/dist/esm/lib/v3/types/private/handlers.js.map +1 -1
- package/dist/esm/lib/v3/types/private/snapshot.d.ts +2 -0
- package/dist/esm/lib/v3/types/private/snapshot.js.map +1 -1
- package/dist/esm/lib/v3/types/public/agent.d.ts +1 -1
- package/dist/esm/lib/v3/types/public/agent.js.map +1 -1
- package/dist/esm/lib/v3/types/public/api.d.ts +287 -0
- package/dist/esm/lib/v3/types/public/api.js +59 -1
- package/dist/esm/lib/v3/types/public/api.js.map +1 -1
- package/dist/esm/lib/v3/types/public/methods.d.ts +2 -0
- package/dist/esm/lib/v3/types/public/methods.js.map +1 -1
- package/dist/esm/lib/v3/types/public/model.d.ts +11 -7
- package/dist/esm/lib/v3/types/public/model.js.map +1 -1
- package/dist/esm/lib/v3/understudy/a11y/snapshot/a11yTree.js +25 -0
- package/dist/esm/lib/v3/understudy/a11y/snapshot/a11yTree.js.map +1 -1
- package/dist/esm/lib/v3/understudy/a11y/snapshot/treeFormatUtils.js +10 -1
- package/dist/esm/lib/v3/understudy/a11y/snapshot/treeFormatUtils.js.map +1 -1
- package/dist/esm/lib/v3/v3.js +7 -47
- package/dist/esm/lib/v3/v3.js.map +1 -1
- package/dist/esm/lib/v3Evaluator.d.ts +20 -12
- package/dist/esm/lib/v3Evaluator.js +41 -199
- package/dist/esm/lib/v3Evaluator.js.map +1 -1
- package/dist/esm/lib/v3LegacyEvaluator.d.ts +20 -0
- package/dist/esm/lib/v3LegacyEvaluator.js +211 -0
- package/dist/esm/lib/v3LegacyEvaluator.js.map +1 -0
- package/dist/esm/lib/version.d.ts +1 -1
- package/dist/esm/lib/version.js +1 -1
- package/dist/esm/lib/version.js.map +1 -1
- package/package.json +30 -18
- package/dist/cjs/tests/cache-variables.test.d.ts +0 -1
- package/dist/cjs/tests/cache-variables.test.js +0 -221
- package/dist/cjs/tests/cache-variables.test.js.map +0 -1
- package/dist/cjs/tests/integration/agent-abort-signal.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/agent-abort-signal.spec.js +0 -123
- package/dist/cjs/tests/integration/agent-abort-signal.spec.js.map +0 -1
- package/dist/cjs/tests/integration/agent-cache-self-heal.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/agent-cache-self-heal.spec.js +0 -83
- package/dist/cjs/tests/integration/agent-cache-self-heal.spec.js.map +0 -1
- package/dist/cjs/tests/integration/agent-callbacks.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/agent-callbacks.spec.js +0 -385
- package/dist/cjs/tests/integration/agent-callbacks.spec.js.map +0 -1
- package/dist/cjs/tests/integration/agent-experimental-validation.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/agent-experimental-validation.spec.js +0 -362
- package/dist/cjs/tests/integration/agent-experimental-validation.spec.js.map +0 -1
- package/dist/cjs/tests/integration/agent-hybrid-mode.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/agent-hybrid-mode.spec.js +0 -262
- package/dist/cjs/tests/integration/agent-hybrid-mode.spec.js.map +0 -1
- package/dist/cjs/tests/integration/agent-message-continuation.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/agent-message-continuation.spec.js +0 -112
- package/dist/cjs/tests/integration/agent-message-continuation.spec.js.map +0 -1
- package/dist/cjs/tests/integration/agent-streaming.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/agent-streaming.spec.js +0 -140
- package/dist/cjs/tests/integration/agent-streaming.spec.js.map +0 -1
- package/dist/cjs/tests/integration/cdp-close-api-region.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/cdp-close-api-region.spec.js +0 -41
- package/dist/cjs/tests/integration/cdp-close-api-region.spec.js.map +0 -1
- package/dist/cjs/tests/integration/cdp-connection-close.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/cdp-connection-close.spec.js +0 -76
- package/dist/cjs/tests/integration/cdp-connection-close.spec.js.map +0 -1
- package/dist/cjs/tests/integration/cdp-session-detached.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/cdp-session-detached.spec.js +0 -45
- package/dist/cjs/tests/integration/cdp-session-detached.spec.js.map +0 -1
- package/dist/cjs/tests/integration/chrome-newtab-page-tracking.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/chrome-newtab-page-tracking.spec.js +0 -56
- package/dist/cjs/tests/integration/chrome-newtab-page-tracking.spec.js.map +0 -1
- package/dist/cjs/tests/integration/click-count.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/click-count.spec.js +0 -163
- package/dist/cjs/tests/integration/click-count.spec.js.map +0 -1
- package/dist/cjs/tests/integration/connect-to-existing-browser.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/connect-to-existing-browser.spec.js +0 -99
- package/dist/cjs/tests/integration/connect-to-existing-browser.spec.js.map +0 -1
- package/dist/cjs/tests/integration/context-addInitScript.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/context-addInitScript.spec.js +0 -285
- package/dist/cjs/tests/integration/context-addInitScript.spec.js.map +0 -1
- package/dist/cjs/tests/integration/context-extra-http-headers.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/context-extra-http-headers.spec.js +0 -49
- package/dist/cjs/tests/integration/context-extra-http-headers.spec.js.map +0 -1
- package/dist/cjs/tests/integration/cookies.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/cookies.spec.js +0 -187
- package/dist/cjs/tests/integration/cookies.spec.js.map +0 -1
- package/dist/cjs/tests/integration/default-page-tracking.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/default-page-tracking.spec.js +0 -52
- package/dist/cjs/tests/integration/default-page-tracking.spec.js.map +0 -1
- package/dist/cjs/tests/integration/downloads.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/downloads.spec.js +0 -52
- package/dist/cjs/tests/integration/downloads.spec.js.map +0 -1
- package/dist/cjs/tests/integration/flowLogger.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/flowLogger.spec.js +0 -718
- package/dist/cjs/tests/integration/flowLogger.spec.js.map +0 -1
- package/dist/cjs/tests/integration/frame-get-location-and-click.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/frame-get-location-and-click.spec.js +0 -57
- package/dist/cjs/tests/integration/frame-get-location-and-click.spec.js.map +0 -1
- package/dist/cjs/tests/integration/iframe-ctx-addInitScript-race.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/iframe-ctx-addInitScript-race.spec.js +0 -219
- package/dist/cjs/tests/integration/iframe-ctx-addInitScript-race.spec.js.map +0 -1
- package/dist/cjs/tests/integration/iframe-ctx-addInitScript.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/iframe-ctx-addInitScript.spec.js +0 -474
- package/dist/cjs/tests/integration/iframe-ctx-addInitScript.spec.js.map +0 -1
- package/dist/cjs/tests/integration/keep-alive.child.d.ts +0 -1
- package/dist/cjs/tests/integration/keep-alive.child.js +0 -85
- package/dist/cjs/tests/integration/keep-alive.child.js.map +0 -1
- package/dist/cjs/tests/integration/keep-alive.spec.d.ts +0 -22
- package/dist/cjs/tests/integration/keep-alive.spec.js +0 -490
- package/dist/cjs/tests/integration/keep-alive.spec.js.map +0 -1
- package/dist/cjs/tests/integration/keyboard.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/keyboard.spec.js +0 -259
- package/dist/cjs/tests/integration/keyboard.spec.js.map +0 -1
- package/dist/cjs/tests/integration/locator-backend-node-id.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/locator-backend-node-id.spec.js +0 -150
- package/dist/cjs/tests/integration/locator-backend-node-id.spec.js.map +0 -1
- package/dist/cjs/tests/integration/locator-content-methods.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/locator-content-methods.spec.js +0 -180
- package/dist/cjs/tests/integration/locator-content-methods.spec.js.map +0 -1
- package/dist/cjs/tests/integration/locator-count-iframe.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/locator-count-iframe.spec.js +0 -129
- package/dist/cjs/tests/integration/locator-count-iframe.spec.js.map +0 -1
- package/dist/cjs/tests/integration/locator-count.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/locator-count.spec.js +0 -68
- package/dist/cjs/tests/integration/locator-count.spec.js.map +0 -1
- package/dist/cjs/tests/integration/locator-fill.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/locator-fill.spec.js +0 -117
- package/dist/cjs/tests/integration/locator-fill.spec.js.map +0 -1
- package/dist/cjs/tests/integration/locator-input-methods.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/locator-input-methods.spec.js +0 -127
- package/dist/cjs/tests/integration/locator-input-methods.spec.js.map +0 -1
- package/dist/cjs/tests/integration/locator-nth.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/locator-nth.spec.js +0 -175
- package/dist/cjs/tests/integration/locator-nth.spec.js.map +0 -1
- package/dist/cjs/tests/integration/locator-select-option.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/locator-select-option.spec.js +0 -216
- package/dist/cjs/tests/integration/locator-select-option.spec.js.map +0 -1
- package/dist/cjs/tests/integration/logger-initialization.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/logger-initialization.spec.js +0 -597
- package/dist/cjs/tests/integration/logger-initialization.spec.js.map +0 -1
- package/dist/cjs/tests/integration/multi-instance-logger.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/multi-instance-logger.spec.js +0 -293
- package/dist/cjs/tests/integration/multi-instance-logger.spec.js.map +0 -1
- package/dist/cjs/tests/integration/nested-div.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/nested-div.spec.js +0 -22
- package/dist/cjs/tests/integration/nested-div.spec.js.map +0 -1
- package/dist/cjs/tests/integration/observe-element-id-format.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/observe-element-id-format.spec.js +0 -130
- package/dist/cjs/tests/integration/observe-element-id-format.spec.js.map +0 -1
- package/dist/cjs/tests/integration/page-addInitScript.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/page-addInitScript.spec.js +0 -94
- package/dist/cjs/tests/integration/page-addInitScript.spec.js.map +0 -1
- package/dist/cjs/tests/integration/page-console.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/page-console.spec.js +0 -47
- package/dist/cjs/tests/integration/page-console.spec.js.map +0 -1
- package/dist/cjs/tests/integration/page-drag-and-drop.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/page-drag-and-drop.spec.js +0 -437
- package/dist/cjs/tests/integration/page-drag-and-drop.spec.js.map +0 -1
- package/dist/cjs/tests/integration/page-extra-http-headers.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/page-extra-http-headers.spec.js +0 -85
- package/dist/cjs/tests/integration/page-extra-http-headers.spec.js.map +0 -1
- package/dist/cjs/tests/integration/page-goto-response.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/page-goto-response.spec.js +0 -34
- package/dist/cjs/tests/integration/page-goto-response.spec.js.map +0 -1
- package/dist/cjs/tests/integration/page-hover.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/page-hover.spec.js +0 -165
- package/dist/cjs/tests/integration/page-hover.spec.js.map +0 -1
- package/dist/cjs/tests/integration/page-screenshot.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/page-screenshot.spec.js +0 -292
- package/dist/cjs/tests/integration/page-screenshot.spec.js.map +0 -1
- package/dist/cjs/tests/integration/page-scroll.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/page-scroll.spec.js +0 -183
- package/dist/cjs/tests/integration/page-scroll.spec.js.map +0 -1
- package/dist/cjs/tests/integration/page-send-cdp.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/page-send-cdp.spec.js +0 -47
- package/dist/cjs/tests/integration/page-send-cdp.spec.js.map +0 -1
- package/dist/cjs/tests/integration/perform-understudy-method.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/perform-understudy-method.spec.js +0 -63
- package/dist/cjs/tests/integration/perform-understudy-method.spec.js.map +0 -1
- package/dist/cjs/tests/integration/setinputfiles.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/setinputfiles.spec.js +0 -133
- package/dist/cjs/tests/integration/setinputfiles.spec.js.map +0 -1
- package/dist/cjs/tests/integration/shadow-iframe-oopif.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/shadow-iframe-oopif.spec.js +0 -161
- package/dist/cjs/tests/integration/shadow-iframe-oopif.spec.js.map +0 -1
- package/dist/cjs/tests/integration/shadow-iframe-spif.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/shadow-iframe-spif.spec.js +0 -160
- package/dist/cjs/tests/integration/shadow-iframe-spif.spec.js.map +0 -1
- package/dist/cjs/tests/integration/testUtils.d.ts +0 -40
- package/dist/cjs/tests/integration/testUtils.js +0 -188
- package/dist/cjs/tests/integration/testUtils.js.map +0 -1
- package/dist/cjs/tests/integration/text-selector-innermost.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/text-selector-innermost.spec.js +0 -105
- package/dist/cjs/tests/integration/text-selector-innermost.spec.js.map +0 -1
- package/dist/cjs/tests/integration/timeouts.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/timeouts.spec.js +0 -309
- package/dist/cjs/tests/integration/timeouts.spec.js.map +0 -1
- package/dist/cjs/tests/integration/user-data-dir.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/user-data-dir.spec.js +0 -77
- package/dist/cjs/tests/integration/user-data-dir.spec.js.map +0 -1
- package/dist/cjs/tests/integration/v3.config.d.ts +0 -4
- package/dist/cjs/tests/integration/v3.config.js +0 -11
- package/dist/cjs/tests/integration/v3.config.js.map +0 -1
- package/dist/cjs/tests/integration/v3.dynamic.config.d.ts +0 -4
- package/dist/cjs/tests/integration/v3.dynamic.config.js +0 -48
- package/dist/cjs/tests/integration/v3.dynamic.config.js.map +0 -1
- package/dist/cjs/tests/integration/v3.playwright.config.d.ts +0 -2
- package/dist/cjs/tests/integration/v3.playwright.config.js +0 -48
- package/dist/cjs/tests/integration/v3.playwright.config.js.map +0 -1
- package/dist/cjs/tests/integration/wait-for-selector.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/wait-for-selector.spec.js +0 -683
- package/dist/cjs/tests/integration/wait-for-selector.spec.js.map +0 -1
- package/dist/cjs/tests/integration/wait-for-timeout.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/wait-for-timeout.spec.js +0 -118
- package/dist/cjs/tests/integration/wait-for-timeout.spec.js.map +0 -1
- package/dist/cjs/tests/integration/xpath-for-location-deep.spec.d.ts +0 -1
- package/dist/cjs/tests/integration/xpath-for-location-deep.spec.js +0 -87
- package/dist/cjs/tests/integration/xpath-for-location-deep.spec.js.map +0 -1
- package/dist/cjs/tests/unit/agent-captcha-hooks.test.d.ts +0 -1
- package/dist/cjs/tests/unit/agent-captcha-hooks.test.js +0 -341
- package/dist/cjs/tests/unit/agent-captcha-hooks.test.js.map +0 -1
- package/dist/cjs/tests/unit/agent-execution-model.test.d.ts +0 -1
- package/dist/cjs/tests/unit/agent-execution-model.test.js +0 -150
- package/dist/cjs/tests/unit/agent-execution-model.test.js.map +0 -1
- package/dist/cjs/tests/unit/agent-metrics.test.d.ts +0 -1
- package/dist/cjs/tests/unit/agent-metrics.test.js +0 -112
- package/dist/cjs/tests/unit/agent-metrics.test.js.map +0 -1
- package/dist/cjs/tests/unit/agent-mode-routing.test.d.ts +0 -1
- package/dist/cjs/tests/unit/agent-mode-routing.test.js +0 -88
- package/dist/cjs/tests/unit/agent-mode-routing.test.js.map +0 -1
- package/dist/cjs/tests/unit/agent-system-prompt-variables.test.d.ts +0 -1
- package/dist/cjs/tests/unit/agent-system-prompt-variables.test.js +0 -23
- package/dist/cjs/tests/unit/agent-system-prompt-variables.test.js.map +0 -1
- package/dist/cjs/tests/unit/agent-temperature.test.d.ts +0 -1
- package/dist/cjs/tests/unit/agent-temperature.test.js +0 -191
- package/dist/cjs/tests/unit/agent-temperature.test.js.map +0 -1
- package/dist/cjs/tests/unit/agent-variables-validation.test.d.ts +0 -1
- package/dist/cjs/tests/unit/agent-variables-validation.test.js +0 -43
- package/dist/cjs/tests/unit/agent-variables-validation.test.js.map +0 -1
- package/dist/cjs/tests/unit/aisdk-clients.test.d.ts +0 -1
- package/dist/cjs/tests/unit/aisdk-clients.test.js +0 -86
- package/dist/cjs/tests/unit/aisdk-clients.test.js.map +0 -1
- package/dist/cjs/tests/unit/anthropic-cua-adaptive-thinking.test.d.ts +0 -1
- package/dist/cjs/tests/unit/anthropic-cua-adaptive-thinking.test.js +0 -250
- package/dist/cjs/tests/unit/anthropic-cua-adaptive-thinking.test.js.map +0 -1
- package/dist/cjs/tests/unit/api-client-observe-variables.test.d.ts +0 -1
- package/dist/cjs/tests/unit/api-client-observe-variables.test.js +0 -133
- package/dist/cjs/tests/unit/api-client-observe-variables.test.js.map +0 -1
- package/dist/cjs/tests/unit/api-multiregion.test.d.ts +0 -1
- package/dist/cjs/tests/unit/api-multiregion.test.js +0 -58
- package/dist/cjs/tests/unit/api-multiregion.test.js.map +0 -1
- package/dist/cjs/tests/unit/api-optional-model-api-key.test.d.ts +0 -1
- package/dist/cjs/tests/unit/api-optional-model-api-key.test.js +0 -155
- package/dist/cjs/tests/unit/api-optional-model-api-key.test.js.map +0 -1
- package/dist/cjs/tests/unit/api-variables-schema.test.d.ts +0 -1
- package/dist/cjs/tests/unit/api-variables-schema.test.js +0 -62
- package/dist/cjs/tests/unit/api-variables-schema.test.js.map +0 -1
- package/dist/cjs/tests/unit/browserbase-session-accessors.test.d.ts +0 -1
- package/dist/cjs/tests/unit/browserbase-session-accessors.test.js +0 -142
- package/dist/cjs/tests/unit/browserbase-session-accessors.test.js.map +0 -1
- package/dist/cjs/tests/unit/cache-llm-resolution.test.d.ts +0 -1
- package/dist/cjs/tests/unit/cache-llm-resolution.test.js +0 -186
- package/dist/cjs/tests/unit/cache-llm-resolution.test.js.map +0 -1
- package/dist/cjs/tests/unit/captcha-solver.test.d.ts +0 -1
- package/dist/cjs/tests/unit/captcha-solver.test.js +0 -154
- package/dist/cjs/tests/unit/captcha-solver.test.js.map +0 -1
- package/dist/cjs/tests/unit/cdp-connection-close.test.d.ts +0 -1
- package/dist/cjs/tests/unit/cdp-connection-close.test.js +0 -74
- package/dist/cjs/tests/unit/cdp-connection-close.test.js.map +0 -1
- package/dist/cjs/tests/unit/context-extra-http-headers.test.d.ts +0 -1
- package/dist/cjs/tests/unit/context-extra-http-headers.test.js +0 -58
- package/dist/cjs/tests/unit/context-extra-http-headers.test.js.map +0 -1
- package/dist/cjs/tests/unit/cookies.test.d.ts +0 -1
- package/dist/cjs/tests/unit/cookies.test.js +0 -944
- package/dist/cjs/tests/unit/cookies.test.js.map +0 -1
- package/dist/cjs/tests/unit/flowlogger-capturing-cdp.test.d.ts +0 -1
- package/dist/cjs/tests/unit/flowlogger-capturing-cdp.test.js +0 -95
- package/dist/cjs/tests/unit/flowlogger-capturing-cdp.test.js.map +0 -1
- package/dist/cjs/tests/unit/flowlogger-capturing-llm.test.d.ts +0 -1
- package/dist/cjs/tests/unit/flowlogger-capturing-llm.test.js +0 -43
- package/dist/cjs/tests/unit/flowlogger-capturing-llm.test.js.map +0 -1
- package/dist/cjs/tests/unit/flowlogger-eventstore.test.d.ts +0 -1
- package/dist/cjs/tests/unit/flowlogger-eventstore.test.js +0 -250
- package/dist/cjs/tests/unit/flowlogger-eventstore.test.js.map +0 -1
- package/dist/cjs/tests/unit/frame-registry-oopif-adoption.test.d.ts +0 -1
- package/dist/cjs/tests/unit/frame-registry-oopif-adoption.test.js +0 -60
- package/dist/cjs/tests/unit/frame-registry-oopif-adoption.test.js.map +0 -1
- package/dist/cjs/tests/unit/helpers/mockCDPSession.d.ts +0 -19
- package/dist/cjs/tests/unit/helpers/mockCDPSession.js +0 -29
- package/dist/cjs/tests/unit/helpers/mockCDPSession.js.map +0 -1
- package/dist/cjs/tests/unit/inference-temperature.test.d.ts +0 -1
- package/dist/cjs/tests/unit/inference-temperature.test.js +0 -65
- package/dist/cjs/tests/unit/inference-temperature.test.js.map +0 -1
- package/dist/cjs/tests/unit/llm-middleware.test.d.ts +0 -1
- package/dist/cjs/tests/unit/llm-middleware.test.js +0 -495
- package/dist/cjs/tests/unit/llm-middleware.test.js.map +0 -1
- package/dist/cjs/tests/unit/llm-provider.test.d.ts +0 -1
- package/dist/cjs/tests/unit/llm-provider.test.js +0 -64
- package/dist/cjs/tests/unit/llm-provider.test.js.map +0 -1
- package/dist/cjs/tests/unit/microsoft-cua-client.test.d.ts +0 -1
- package/dist/cjs/tests/unit/microsoft-cua-client.test.js +0 -86
- package/dist/cjs/tests/unit/microsoft-cua-client.test.js.map +0 -1
- package/dist/cjs/tests/unit/model-deprecation.test.d.ts +0 -1
- package/dist/cjs/tests/unit/model-deprecation.test.js +0 -142
- package/dist/cjs/tests/unit/model-deprecation.test.js.map +0 -1
- package/dist/cjs/tests/unit/model-utils.test.d.ts +0 -1
- package/dist/cjs/tests/unit/model-utils.test.js +0 -42
- package/dist/cjs/tests/unit/model-utils.test.js.map +0 -1
- package/dist/cjs/tests/unit/openai-compatible-temperature.test.d.ts +0 -1
- package/dist/cjs/tests/unit/openai-compatible-temperature.test.js +0 -84
- package/dist/cjs/tests/unit/openai-compatible-temperature.test.js.map +0 -1
- package/dist/cjs/tests/unit/openai-cua-client.test.d.ts +0 -1
- package/dist/cjs/tests/unit/openai-cua-client.test.js +0 -71
- package/dist/cjs/tests/unit/openai-cua-client.test.js.map +0 -1
- package/dist/cjs/tests/unit/page-extra-http-headers.test.d.ts +0 -1
- package/dist/cjs/tests/unit/page-extra-http-headers.test.js +0 -92
- package/dist/cjs/tests/unit/page-extra-http-headers.test.js.map +0 -1
- package/dist/cjs/tests/unit/page-snapshot.test.d.ts +0 -1
- package/dist/cjs/tests/unit/page-snapshot.test.js +0 -75
- package/dist/cjs/tests/unit/page-snapshot.test.js.map +0 -1
- package/dist/cjs/tests/unit/prompt-observe-variables.test.d.ts +0 -1
- package/dist/cjs/tests/unit/prompt-observe-variables.test.js +0 -25
- package/dist/cjs/tests/unit/prompt-observe-variables.test.js.map +0 -1
- package/dist/cjs/tests/unit/public-api/export-surface.test.d.ts +0 -1
- package/dist/cjs/tests/unit/public-api/export-surface.test.js +0 -107
- package/dist/cjs/tests/unit/public-api/export-surface.test.js.map +0 -1
- package/dist/cjs/tests/unit/public-api/llm-and-agents.test.d.ts +0 -1
- package/dist/cjs/tests/unit/public-api/llm-and-agents.test.js +0 -179
- package/dist/cjs/tests/unit/public-api/llm-and-agents.test.js.map +0 -1
- package/dist/cjs/tests/unit/public-api/public-error-types.test.d.ts +0 -62
- package/dist/cjs/tests/unit/public-api/public-error-types.test.js +0 -110
- package/dist/cjs/tests/unit/public-api/public-error-types.test.js.map +0 -1
- package/dist/cjs/tests/unit/public-api/public-types.test.d.ts +0 -1
- package/dist/cjs/tests/unit/public-api/public-types.test.js +0 -99
- package/dist/cjs/tests/unit/public-api/public-types.test.js.map +0 -1
- package/dist/cjs/tests/unit/public-api/runtime-utils.test.d.ts +0 -1
- package/dist/cjs/tests/unit/public-api/runtime-utils.test.js +0 -60
- package/dist/cjs/tests/unit/public-api/runtime-utils.test.js.map +0 -1
- package/dist/cjs/tests/unit/public-api/schema-utils.test.d.ts +0 -1
- package/dist/cjs/tests/unit/public-api/schema-utils.test.js +0 -95
- package/dist/cjs/tests/unit/public-api/schema-utils.test.js.map +0 -1
- package/dist/cjs/tests/unit/public-api/timeout-error-types.test.d.ts +0 -1
- package/dist/cjs/tests/unit/public-api/timeout-error-types.test.js +0 -121
- package/dist/cjs/tests/unit/public-api/timeout-error-types.test.js.map +0 -1
- package/dist/cjs/tests/unit/public-api/tool-type-export.test.d.ts +0 -1
- package/dist/cjs/tests/unit/public-api/tool-type-export.test.js +0 -65
- package/dist/cjs/tests/unit/public-api/tool-type-export.test.js.map +0 -1
- package/dist/cjs/tests/unit/public-api/v3-core.test.d.ts +0 -1
- package/dist/cjs/tests/unit/public-api/v3-core.test.js +0 -108
- package/dist/cjs/tests/unit/public-api/v3-core.test.js.map +0 -1
- package/dist/cjs/tests/unit/safety-confirmation.test.d.ts +0 -1
- package/dist/cjs/tests/unit/safety-confirmation.test.js +0 -110
- package/dist/cjs/tests/unit/safety-confirmation.test.js.map +0 -1
- package/dist/cjs/tests/unit/snapshot-a11y-resolvers.test.d.ts +0 -1
- package/dist/cjs/tests/unit/snapshot-a11y-resolvers.test.js +0 -431
- package/dist/cjs/tests/unit/snapshot-a11y-resolvers.test.js.map +0 -1
- package/dist/cjs/tests/unit/snapshot-a11y-tree-utils.test.d.ts +0 -1
- package/dist/cjs/tests/unit/snapshot-a11y-tree-utils.test.js +0 -306
- package/dist/cjs/tests/unit/snapshot-a11y-tree-utils.test.js.map +0 -1
- package/dist/cjs/tests/unit/snapshot-capture-orchestration.test.d.ts +0 -1
- package/dist/cjs/tests/unit/snapshot-capture-orchestration.test.js +0 -504
- package/dist/cjs/tests/unit/snapshot-capture-orchestration.test.js.map +0 -1
- package/dist/cjs/tests/unit/snapshot-cbor.test.d.ts +0 -1
- package/dist/cjs/tests/unit/snapshot-cbor.test.js +0 -204
- package/dist/cjs/tests/unit/snapshot-cbor.test.js.map +0 -1
- package/dist/cjs/tests/unit/snapshot-dom-session-builders.test.d.ts +0 -1
- package/dist/cjs/tests/unit/snapshot-dom-session-builders.test.js +0 -220
- package/dist/cjs/tests/unit/snapshot-dom-session-builders.test.js.map +0 -1
- package/dist/cjs/tests/unit/snapshot-dom-tree-utils.test.d.ts +0 -1
- package/dist/cjs/tests/unit/snapshot-dom-tree-utils.test.js +0 -107
- package/dist/cjs/tests/unit/snapshot-dom-tree-utils.test.js.map +0 -1
- package/dist/cjs/tests/unit/snapshot-focus-selectors-utils.test.d.ts +0 -1
- package/dist/cjs/tests/unit/snapshot-focus-selectors-utils.test.js +0 -89
- package/dist/cjs/tests/unit/snapshot-focus-selectors-utils.test.js.map +0 -1
- package/dist/cjs/tests/unit/snapshot-frame-merge.test.d.ts +0 -1
- package/dist/cjs/tests/unit/snapshot-frame-merge.test.js +0 -335
- package/dist/cjs/tests/unit/snapshot-frame-merge.test.js.map +0 -1
- package/dist/cjs/tests/unit/snapshot-tree-format-utils.test.d.ts +0 -1
- package/dist/cjs/tests/unit/snapshot-tree-format-utils.test.js +0 -84
- package/dist/cjs/tests/unit/snapshot-tree-format-utils.test.js.map +0 -1
- package/dist/cjs/tests/unit/snapshot-xpath-utils.test.d.ts +0 -1
- package/dist/cjs/tests/unit/snapshot-xpath-utils.test.js +0 -74
- package/dist/cjs/tests/unit/snapshot-xpath-utils.test.js.map +0 -1
- package/dist/cjs/tests/unit/timeout-handlers.test.d.ts +0 -1
- package/dist/cjs/tests/unit/timeout-handlers.test.js +0 -897
- package/dist/cjs/tests/unit/timeout-handlers.test.js.map +0 -1
- package/dist/cjs/tests/unit/understudy-command-exception.test.d.ts +0 -1
- package/dist/cjs/tests/unit/understudy-command-exception.test.js +0 -57
- package/dist/cjs/tests/unit/understudy-command-exception.test.js.map +0 -1
- package/dist/cjs/tests/unit/xpath-parser.test.d.ts +0 -1
- package/dist/cjs/tests/unit/xpath-parser.test.js +0 -311
- package/dist/cjs/tests/unit/xpath-parser.test.js.map +0 -1
- package/dist/cjs/tests/unit/xpath-resolver.test.d.ts +0 -1
- package/dist/cjs/tests/unit/xpath-resolver.test.js +0 -80
- package/dist/cjs/tests/unit/xpath-resolver.test.js.map +0 -1
- package/dist/cjs/tests/unit/zod-enum-compatibility.test.d.ts +0 -1
- package/dist/cjs/tests/unit/zod-enum-compatibility.test.js +0 -149
- package/dist/cjs/tests/unit/zod-enum-compatibility.test.js.map +0 -1
- package/dist/esm/tests/cache-variables.test.d.ts +0 -1
- package/dist/esm/tests/cache-variables.test.js +0 -219
- package/dist/esm/tests/cache-variables.test.js.map +0 -1
- package/dist/esm/tests/integration/agent-abort-signal.spec.d.ts +0 -1
- package/dist/esm/tests/integration/agent-abort-signal.spec.js +0 -121
- package/dist/esm/tests/integration/agent-abort-signal.spec.js.map +0 -1
- package/dist/esm/tests/integration/agent-cache-self-heal.spec.d.ts +0 -1
- package/dist/esm/tests/integration/agent-cache-self-heal.spec.js +0 -78
- package/dist/esm/tests/integration/agent-cache-self-heal.spec.js.map +0 -1
- package/dist/esm/tests/integration/agent-callbacks.spec.d.ts +0 -1
- package/dist/esm/tests/integration/agent-callbacks.spec.js +0 -383
- package/dist/esm/tests/integration/agent-callbacks.spec.js.map +0 -1
- package/dist/esm/tests/integration/agent-experimental-validation.spec.d.ts +0 -1
- package/dist/esm/tests/integration/agent-experimental-validation.spec.js +0 -360
- package/dist/esm/tests/integration/agent-experimental-validation.spec.js.map +0 -1
- package/dist/esm/tests/integration/agent-hybrid-mode.spec.d.ts +0 -1
- package/dist/esm/tests/integration/agent-hybrid-mode.spec.js +0 -260
- package/dist/esm/tests/integration/agent-hybrid-mode.spec.js.map +0 -1
- package/dist/esm/tests/integration/agent-message-continuation.spec.d.ts +0 -1
- package/dist/esm/tests/integration/agent-message-continuation.spec.js +0 -110
- package/dist/esm/tests/integration/agent-message-continuation.spec.js.map +0 -1
- package/dist/esm/tests/integration/agent-streaming.spec.d.ts +0 -1
- package/dist/esm/tests/integration/agent-streaming.spec.js +0 -138
- package/dist/esm/tests/integration/agent-streaming.spec.js.map +0 -1
- package/dist/esm/tests/integration/cdp-close-api-region.spec.d.ts +0 -1
- package/dist/esm/tests/integration/cdp-close-api-region.spec.js +0 -39
- package/dist/esm/tests/integration/cdp-close-api-region.spec.js.map +0 -1
- package/dist/esm/tests/integration/cdp-connection-close.spec.d.ts +0 -1
- package/dist/esm/tests/integration/cdp-connection-close.spec.js +0 -74
- package/dist/esm/tests/integration/cdp-connection-close.spec.js.map +0 -1
- package/dist/esm/tests/integration/cdp-session-detached.spec.d.ts +0 -1
- package/dist/esm/tests/integration/cdp-session-detached.spec.js +0 -43
- package/dist/esm/tests/integration/cdp-session-detached.spec.js.map +0 -1
- package/dist/esm/tests/integration/chrome-newtab-page-tracking.spec.d.ts +0 -1
- package/dist/esm/tests/integration/chrome-newtab-page-tracking.spec.js +0 -54
- package/dist/esm/tests/integration/chrome-newtab-page-tracking.spec.js.map +0 -1
- package/dist/esm/tests/integration/click-count.spec.d.ts +0 -1
- package/dist/esm/tests/integration/click-count.spec.js +0 -161
- package/dist/esm/tests/integration/click-count.spec.js.map +0 -1
- package/dist/esm/tests/integration/connect-to-existing-browser.spec.d.ts +0 -1
- package/dist/esm/tests/integration/connect-to-existing-browser.spec.js +0 -97
- package/dist/esm/tests/integration/connect-to-existing-browser.spec.js.map +0 -1
- package/dist/esm/tests/integration/context-addInitScript.spec.d.ts +0 -1
- package/dist/esm/tests/integration/context-addInitScript.spec.js +0 -283
- package/dist/esm/tests/integration/context-addInitScript.spec.js.map +0 -1
- package/dist/esm/tests/integration/context-extra-http-headers.spec.d.ts +0 -1
- package/dist/esm/tests/integration/context-extra-http-headers.spec.js +0 -47
- package/dist/esm/tests/integration/context-extra-http-headers.spec.js.map +0 -1
- package/dist/esm/tests/integration/cookies.spec.d.ts +0 -1
- package/dist/esm/tests/integration/cookies.spec.js +0 -185
- package/dist/esm/tests/integration/cookies.spec.js.map +0 -1
- package/dist/esm/tests/integration/default-page-tracking.spec.d.ts +0 -1
- package/dist/esm/tests/integration/default-page-tracking.spec.js +0 -50
- package/dist/esm/tests/integration/default-page-tracking.spec.js.map +0 -1
- package/dist/esm/tests/integration/downloads.spec.d.ts +0 -1
- package/dist/esm/tests/integration/downloads.spec.js +0 -47
- package/dist/esm/tests/integration/downloads.spec.js.map +0 -1
- package/dist/esm/tests/integration/flowLogger.spec.d.ts +0 -1
- package/dist/esm/tests/integration/flowLogger.spec.js +0 -716
- package/dist/esm/tests/integration/flowLogger.spec.js.map +0 -1
- package/dist/esm/tests/integration/frame-get-location-and-click.spec.d.ts +0 -1
- package/dist/esm/tests/integration/frame-get-location-and-click.spec.js +0 -55
- package/dist/esm/tests/integration/frame-get-location-and-click.spec.js.map +0 -1
- package/dist/esm/tests/integration/iframe-ctx-addInitScript-race.spec.d.ts +0 -1
- package/dist/esm/tests/integration/iframe-ctx-addInitScript-race.spec.js +0 -217
- package/dist/esm/tests/integration/iframe-ctx-addInitScript-race.spec.js.map +0 -1
- package/dist/esm/tests/integration/iframe-ctx-addInitScript.spec.d.ts +0 -1
- package/dist/esm/tests/integration/iframe-ctx-addInitScript.spec.js +0 -472
- package/dist/esm/tests/integration/iframe-ctx-addInitScript.spec.js.map +0 -1
- package/dist/esm/tests/integration/keep-alive.child.d.ts +0 -1
- package/dist/esm/tests/integration/keep-alive.child.js +0 -83
- package/dist/esm/tests/integration/keep-alive.child.js.map +0 -1
- package/dist/esm/tests/integration/keep-alive.spec.d.ts +0 -22
- package/dist/esm/tests/integration/keep-alive.spec.js +0 -482
- package/dist/esm/tests/integration/keep-alive.spec.js.map +0 -1
- package/dist/esm/tests/integration/keyboard.spec.d.ts +0 -1
- package/dist/esm/tests/integration/keyboard.spec.js +0 -257
- package/dist/esm/tests/integration/keyboard.spec.js.map +0 -1
- package/dist/esm/tests/integration/locator-backend-node-id.spec.d.ts +0 -1
- package/dist/esm/tests/integration/locator-backend-node-id.spec.js +0 -148
- package/dist/esm/tests/integration/locator-backend-node-id.spec.js.map +0 -1
- package/dist/esm/tests/integration/locator-content-methods.spec.d.ts +0 -1
- package/dist/esm/tests/integration/locator-content-methods.spec.js +0 -178
- package/dist/esm/tests/integration/locator-content-methods.spec.js.map +0 -1
- package/dist/esm/tests/integration/locator-count-iframe.spec.d.ts +0 -1
- package/dist/esm/tests/integration/locator-count-iframe.spec.js +0 -127
- package/dist/esm/tests/integration/locator-count-iframe.spec.js.map +0 -1
- package/dist/esm/tests/integration/locator-count.spec.d.ts +0 -1
- package/dist/esm/tests/integration/locator-count.spec.js +0 -66
- package/dist/esm/tests/integration/locator-count.spec.js.map +0 -1
- package/dist/esm/tests/integration/locator-fill.spec.d.ts +0 -1
- package/dist/esm/tests/integration/locator-fill.spec.js +0 -115
- package/dist/esm/tests/integration/locator-fill.spec.js.map +0 -1
- package/dist/esm/tests/integration/locator-input-methods.spec.d.ts +0 -1
- package/dist/esm/tests/integration/locator-input-methods.spec.js +0 -125
- package/dist/esm/tests/integration/locator-input-methods.spec.js.map +0 -1
- package/dist/esm/tests/integration/locator-nth.spec.d.ts +0 -1
- package/dist/esm/tests/integration/locator-nth.spec.js +0 -173
- package/dist/esm/tests/integration/locator-nth.spec.js.map +0 -1
- package/dist/esm/tests/integration/locator-select-option.spec.d.ts +0 -1
- package/dist/esm/tests/integration/locator-select-option.spec.js +0 -214
- package/dist/esm/tests/integration/locator-select-option.spec.js.map +0 -1
- package/dist/esm/tests/integration/logger-initialization.spec.d.ts +0 -1
- package/dist/esm/tests/integration/logger-initialization.spec.js +0 -595
- package/dist/esm/tests/integration/logger-initialization.spec.js.map +0 -1
- package/dist/esm/tests/integration/multi-instance-logger.spec.d.ts +0 -1
- package/dist/esm/tests/integration/multi-instance-logger.spec.js +0 -291
- package/dist/esm/tests/integration/multi-instance-logger.spec.js.map +0 -1
- package/dist/esm/tests/integration/nested-div.spec.d.ts +0 -1
- package/dist/esm/tests/integration/nested-div.spec.js +0 -20
- package/dist/esm/tests/integration/nested-div.spec.js.map +0 -1
- package/dist/esm/tests/integration/observe-element-id-format.spec.d.ts +0 -1
- package/dist/esm/tests/integration/observe-element-id-format.spec.js +0 -128
- package/dist/esm/tests/integration/observe-element-id-format.spec.js.map +0 -1
- package/dist/esm/tests/integration/page-addInitScript.spec.d.ts +0 -1
- package/dist/esm/tests/integration/page-addInitScript.spec.js +0 -92
- package/dist/esm/tests/integration/page-addInitScript.spec.js.map +0 -1
- package/dist/esm/tests/integration/page-console.spec.d.ts +0 -1
- package/dist/esm/tests/integration/page-console.spec.js +0 -45
- package/dist/esm/tests/integration/page-console.spec.js.map +0 -1
- package/dist/esm/tests/integration/page-drag-and-drop.spec.d.ts +0 -1
- package/dist/esm/tests/integration/page-drag-and-drop.spec.js +0 -435
- package/dist/esm/tests/integration/page-drag-and-drop.spec.js.map +0 -1
- package/dist/esm/tests/integration/page-extra-http-headers.spec.d.ts +0 -1
- package/dist/esm/tests/integration/page-extra-http-headers.spec.js +0 -83
- package/dist/esm/tests/integration/page-extra-http-headers.spec.js.map +0 -1
- package/dist/esm/tests/integration/page-goto-response.spec.d.ts +0 -1
- package/dist/esm/tests/integration/page-goto-response.spec.js +0 -32
- package/dist/esm/tests/integration/page-goto-response.spec.js.map +0 -1
- package/dist/esm/tests/integration/page-hover.spec.d.ts +0 -1
- package/dist/esm/tests/integration/page-hover.spec.js +0 -163
- package/dist/esm/tests/integration/page-hover.spec.js.map +0 -1
- package/dist/esm/tests/integration/page-screenshot.spec.d.ts +0 -1
- package/dist/esm/tests/integration/page-screenshot.spec.js +0 -257
- package/dist/esm/tests/integration/page-screenshot.spec.js.map +0 -1
- package/dist/esm/tests/integration/page-scroll.spec.d.ts +0 -1
- package/dist/esm/tests/integration/page-scroll.spec.js +0 -181
- package/dist/esm/tests/integration/page-scroll.spec.js.map +0 -1
- package/dist/esm/tests/integration/page-send-cdp.spec.d.ts +0 -1
- package/dist/esm/tests/integration/page-send-cdp.spec.js +0 -45
- package/dist/esm/tests/integration/page-send-cdp.spec.js.map +0 -1
- package/dist/esm/tests/integration/perform-understudy-method.spec.d.ts +0 -1
- package/dist/esm/tests/integration/perform-understudy-method.spec.js +0 -61
- package/dist/esm/tests/integration/perform-understudy-method.spec.js.map +0 -1
- package/dist/esm/tests/integration/setinputfiles.spec.d.ts +0 -1
- package/dist/esm/tests/integration/setinputfiles.spec.js +0 -128
- package/dist/esm/tests/integration/setinputfiles.spec.js.map +0 -1
- package/dist/esm/tests/integration/shadow-iframe-oopif.spec.d.ts +0 -1
- package/dist/esm/tests/integration/shadow-iframe-oopif.spec.js +0 -156
- package/dist/esm/tests/integration/shadow-iframe-oopif.spec.js.map +0 -1
- package/dist/esm/tests/integration/shadow-iframe-spif.spec.d.ts +0 -1
- package/dist/esm/tests/integration/shadow-iframe-spif.spec.js +0 -155
- package/dist/esm/tests/integration/shadow-iframe-spif.spec.js.map +0 -1
- package/dist/esm/tests/integration/testUtils.d.ts +0 -40
- package/dist/esm/tests/integration/testUtils.js +0 -178
- package/dist/esm/tests/integration/testUtils.js.map +0 -1
- package/dist/esm/tests/integration/text-selector-innermost.spec.d.ts +0 -1
- package/dist/esm/tests/integration/text-selector-innermost.spec.js +0 -103
- package/dist/esm/tests/integration/text-selector-innermost.spec.js.map +0 -1
- package/dist/esm/tests/integration/timeouts.spec.d.ts +0 -1
- package/dist/esm/tests/integration/timeouts.spec.js +0 -307
- package/dist/esm/tests/integration/timeouts.spec.js.map +0 -1
- package/dist/esm/tests/integration/user-data-dir.spec.d.ts +0 -1
- package/dist/esm/tests/integration/user-data-dir.spec.js +0 -42
- package/dist/esm/tests/integration/user-data-dir.spec.js.map +0 -1
- package/dist/esm/tests/integration/v3.config.d.ts +0 -4
- package/dist/esm/tests/integration/v3.config.js +0 -7
- package/dist/esm/tests/integration/v3.config.js.map +0 -1
- package/dist/esm/tests/integration/v3.dynamic.config.d.ts +0 -4
- package/dist/esm/tests/integration/v3.dynamic.config.js +0 -44
- package/dist/esm/tests/integration/v3.dynamic.config.js.map +0 -1
- package/dist/esm/tests/integration/v3.playwright.config.d.ts +0 -2
- package/dist/esm/tests/integration/v3.playwright.config.js +0 -46
- package/dist/esm/tests/integration/v3.playwright.config.js.map +0 -1
- package/dist/esm/tests/integration/wait-for-selector.spec.d.ts +0 -1
- package/dist/esm/tests/integration/wait-for-selector.spec.js +0 -681
- package/dist/esm/tests/integration/wait-for-selector.spec.js.map +0 -1
- package/dist/esm/tests/integration/wait-for-timeout.spec.d.ts +0 -1
- package/dist/esm/tests/integration/wait-for-timeout.spec.js +0 -116
- package/dist/esm/tests/integration/wait-for-timeout.spec.js.map +0 -1
- package/dist/esm/tests/integration/xpath-for-location-deep.spec.d.ts +0 -1
- package/dist/esm/tests/integration/xpath-for-location-deep.spec.js +0 -85
- package/dist/esm/tests/integration/xpath-for-location-deep.spec.js.map +0 -1
- package/dist/esm/tests/unit/agent-captcha-hooks.test.d.ts +0 -1
- package/dist/esm/tests/unit/agent-captcha-hooks.test.js +0 -339
- package/dist/esm/tests/unit/agent-captcha-hooks.test.js.map +0 -1
- package/dist/esm/tests/unit/agent-execution-model.test.d.ts +0 -1
- package/dist/esm/tests/unit/agent-execution-model.test.js +0 -148
- package/dist/esm/tests/unit/agent-execution-model.test.js.map +0 -1
- package/dist/esm/tests/unit/agent-metrics.test.d.ts +0 -1
- package/dist/esm/tests/unit/agent-metrics.test.js +0 -110
- package/dist/esm/tests/unit/agent-metrics.test.js.map +0 -1
- package/dist/esm/tests/unit/agent-mode-routing.test.d.ts +0 -1
- package/dist/esm/tests/unit/agent-mode-routing.test.js +0 -86
- package/dist/esm/tests/unit/agent-mode-routing.test.js.map +0 -1
- package/dist/esm/tests/unit/agent-system-prompt-variables.test.d.ts +0 -1
- package/dist/esm/tests/unit/agent-system-prompt-variables.test.js +0 -21
- package/dist/esm/tests/unit/agent-system-prompt-variables.test.js.map +0 -1
- package/dist/esm/tests/unit/agent-temperature.test.d.ts +0 -1
- package/dist/esm/tests/unit/agent-temperature.test.js +0 -189
- package/dist/esm/tests/unit/agent-temperature.test.js.map +0 -1
- package/dist/esm/tests/unit/agent-variables-validation.test.d.ts +0 -1
- package/dist/esm/tests/unit/agent-variables-validation.test.js +0 -41
- package/dist/esm/tests/unit/agent-variables-validation.test.js.map +0 -1
- package/dist/esm/tests/unit/aisdk-clients.test.d.ts +0 -1
- package/dist/esm/tests/unit/aisdk-clients.test.js +0 -84
- package/dist/esm/tests/unit/aisdk-clients.test.js.map +0 -1
- package/dist/esm/tests/unit/anthropic-cua-adaptive-thinking.test.d.ts +0 -1
- package/dist/esm/tests/unit/anthropic-cua-adaptive-thinking.test.js +0 -245
- package/dist/esm/tests/unit/anthropic-cua-adaptive-thinking.test.js.map +0 -1
- package/dist/esm/tests/unit/api-client-observe-variables.test.d.ts +0 -1
- package/dist/esm/tests/unit/api-client-observe-variables.test.js +0 -131
- package/dist/esm/tests/unit/api-client-observe-variables.test.js.map +0 -1
- package/dist/esm/tests/unit/api-multiregion.test.d.ts +0 -1
- package/dist/esm/tests/unit/api-multiregion.test.js +0 -56
- package/dist/esm/tests/unit/api-multiregion.test.js.map +0 -1
- package/dist/esm/tests/unit/api-optional-model-api-key.test.d.ts +0 -1
- package/dist/esm/tests/unit/api-optional-model-api-key.test.js +0 -153
- package/dist/esm/tests/unit/api-optional-model-api-key.test.js.map +0 -1
- package/dist/esm/tests/unit/api-variables-schema.test.d.ts +0 -1
- package/dist/esm/tests/unit/api-variables-schema.test.js +0 -60
- package/dist/esm/tests/unit/api-variables-schema.test.js.map +0 -1
- package/dist/esm/tests/unit/browserbase-session-accessors.test.d.ts +0 -1
- package/dist/esm/tests/unit/browserbase-session-accessors.test.js +0 -140
- package/dist/esm/tests/unit/browserbase-session-accessors.test.js.map +0 -1
- package/dist/esm/tests/unit/cache-llm-resolution.test.d.ts +0 -1
- package/dist/esm/tests/unit/cache-llm-resolution.test.js +0 -184
- package/dist/esm/tests/unit/cache-llm-resolution.test.js.map +0 -1
- package/dist/esm/tests/unit/captcha-solver.test.d.ts +0 -1
- package/dist/esm/tests/unit/captcha-solver.test.js +0 -152
- package/dist/esm/tests/unit/captcha-solver.test.js.map +0 -1
- package/dist/esm/tests/unit/cdp-connection-close.test.d.ts +0 -1
- package/dist/esm/tests/unit/cdp-connection-close.test.js +0 -72
- package/dist/esm/tests/unit/cdp-connection-close.test.js.map +0 -1
- package/dist/esm/tests/unit/context-extra-http-headers.test.d.ts +0 -1
- package/dist/esm/tests/unit/context-extra-http-headers.test.js +0 -56
- package/dist/esm/tests/unit/context-extra-http-headers.test.js.map +0 -1
- package/dist/esm/tests/unit/cookies.test.d.ts +0 -1
- package/dist/esm/tests/unit/cookies.test.js +0 -909
- package/dist/esm/tests/unit/cookies.test.js.map +0 -1
- package/dist/esm/tests/unit/flowlogger-capturing-cdp.test.d.ts +0 -1
- package/dist/esm/tests/unit/flowlogger-capturing-cdp.test.js +0 -93
- package/dist/esm/tests/unit/flowlogger-capturing-cdp.test.js.map +0 -1
- package/dist/esm/tests/unit/flowlogger-capturing-llm.test.d.ts +0 -1
- package/dist/esm/tests/unit/flowlogger-capturing-llm.test.js +0 -41
- package/dist/esm/tests/unit/flowlogger-capturing-llm.test.js.map +0 -1
- package/dist/esm/tests/unit/flowlogger-eventstore.test.d.ts +0 -1
- package/dist/esm/tests/unit/flowlogger-eventstore.test.js +0 -248
- package/dist/esm/tests/unit/flowlogger-eventstore.test.js.map +0 -1
- package/dist/esm/tests/unit/frame-registry-oopif-adoption.test.d.ts +0 -1
- package/dist/esm/tests/unit/frame-registry-oopif-adoption.test.js +0 -58
- package/dist/esm/tests/unit/frame-registry-oopif-adoption.test.js.map +0 -1
- package/dist/esm/tests/unit/helpers/mockCDPSession.d.ts +0 -19
- package/dist/esm/tests/unit/helpers/mockCDPSession.js +0 -25
- package/dist/esm/tests/unit/helpers/mockCDPSession.js.map +0 -1
- package/dist/esm/tests/unit/inference-temperature.test.d.ts +0 -1
- package/dist/esm/tests/unit/inference-temperature.test.js +0 -63
- package/dist/esm/tests/unit/inference-temperature.test.js.map +0 -1
- package/dist/esm/tests/unit/llm-middleware.test.d.ts +0 -1
- package/dist/esm/tests/unit/llm-middleware.test.js +0 -460
- package/dist/esm/tests/unit/llm-middleware.test.js.map +0 -1
- package/dist/esm/tests/unit/llm-provider.test.d.ts +0 -1
- package/dist/esm/tests/unit/llm-provider.test.js +0 -62
- package/dist/esm/tests/unit/llm-provider.test.js.map +0 -1
- package/dist/esm/tests/unit/microsoft-cua-client.test.d.ts +0 -1
- package/dist/esm/tests/unit/microsoft-cua-client.test.js +0 -84
- package/dist/esm/tests/unit/microsoft-cua-client.test.js.map +0 -1
- package/dist/esm/tests/unit/model-deprecation.test.d.ts +0 -1
- package/dist/esm/tests/unit/model-deprecation.test.js +0 -140
- package/dist/esm/tests/unit/model-deprecation.test.js.map +0 -1
- package/dist/esm/tests/unit/model-utils.test.d.ts +0 -1
- package/dist/esm/tests/unit/model-utils.test.js +0 -40
- package/dist/esm/tests/unit/model-utils.test.js.map +0 -1
- package/dist/esm/tests/unit/openai-compatible-temperature.test.d.ts +0 -1
- package/dist/esm/tests/unit/openai-compatible-temperature.test.js +0 -82
- package/dist/esm/tests/unit/openai-compatible-temperature.test.js.map +0 -1
- package/dist/esm/tests/unit/openai-cua-client.test.d.ts +0 -1
- package/dist/esm/tests/unit/openai-cua-client.test.js +0 -69
- package/dist/esm/tests/unit/openai-cua-client.test.js.map +0 -1
- package/dist/esm/tests/unit/page-extra-http-headers.test.d.ts +0 -1
- package/dist/esm/tests/unit/page-extra-http-headers.test.js +0 -90
- package/dist/esm/tests/unit/page-extra-http-headers.test.js.map +0 -1
- package/dist/esm/tests/unit/page-snapshot.test.d.ts +0 -1
- package/dist/esm/tests/unit/page-snapshot.test.js +0 -40
- package/dist/esm/tests/unit/page-snapshot.test.js.map +0 -1
- package/dist/esm/tests/unit/prompt-observe-variables.test.d.ts +0 -1
- package/dist/esm/tests/unit/prompt-observe-variables.test.js +0 -23
- package/dist/esm/tests/unit/prompt-observe-variables.test.js.map +0 -1
- package/dist/esm/tests/unit/public-api/export-surface.test.d.ts +0 -1
- package/dist/esm/tests/unit/public-api/export-surface.test.js +0 -72
- package/dist/esm/tests/unit/public-api/export-surface.test.js.map +0 -1
- package/dist/esm/tests/unit/public-api/llm-and-agents.test.d.ts +0 -1
- package/dist/esm/tests/unit/public-api/llm-and-agents.test.js +0 -144
- package/dist/esm/tests/unit/public-api/llm-and-agents.test.js.map +0 -1
- package/dist/esm/tests/unit/public-api/public-error-types.test.d.ts +0 -62
- package/dist/esm/tests/unit/public-api/public-error-types.test.js +0 -74
- package/dist/esm/tests/unit/public-api/public-error-types.test.js.map +0 -1
- package/dist/esm/tests/unit/public-api/public-types.test.d.ts +0 -1
- package/dist/esm/tests/unit/public-api/public-types.test.js +0 -97
- package/dist/esm/tests/unit/public-api/public-types.test.js.map +0 -1
- package/dist/esm/tests/unit/public-api/runtime-utils.test.d.ts +0 -1
- package/dist/esm/tests/unit/public-api/runtime-utils.test.js +0 -25
- package/dist/esm/tests/unit/public-api/runtime-utils.test.js.map +0 -1
- package/dist/esm/tests/unit/public-api/schema-utils.test.d.ts +0 -1
- package/dist/esm/tests/unit/public-api/schema-utils.test.js +0 -60
- package/dist/esm/tests/unit/public-api/schema-utils.test.js.map +0 -1
- package/dist/esm/tests/unit/public-api/timeout-error-types.test.d.ts +0 -1
- package/dist/esm/tests/unit/public-api/timeout-error-types.test.js +0 -86
- package/dist/esm/tests/unit/public-api/timeout-error-types.test.js.map +0 -1
- package/dist/esm/tests/unit/public-api/tool-type-export.test.d.ts +0 -1
- package/dist/esm/tests/unit/public-api/tool-type-export.test.js +0 -30
- package/dist/esm/tests/unit/public-api/tool-type-export.test.js.map +0 -1
- package/dist/esm/tests/unit/public-api/v3-core.test.d.ts +0 -1
- package/dist/esm/tests/unit/public-api/v3-core.test.js +0 -73
- package/dist/esm/tests/unit/public-api/v3-core.test.js.map +0 -1
- package/dist/esm/tests/unit/safety-confirmation.test.d.ts +0 -1
- package/dist/esm/tests/unit/safety-confirmation.test.js +0 -108
- package/dist/esm/tests/unit/safety-confirmation.test.js.map +0 -1
- package/dist/esm/tests/unit/snapshot-a11y-resolvers.test.d.ts +0 -1
- package/dist/esm/tests/unit/snapshot-a11y-resolvers.test.js +0 -396
- package/dist/esm/tests/unit/snapshot-a11y-resolvers.test.js.map +0 -1
- package/dist/esm/tests/unit/snapshot-a11y-tree-utils.test.d.ts +0 -1
- package/dist/esm/tests/unit/snapshot-a11y-tree-utils.test.js +0 -304
- package/dist/esm/tests/unit/snapshot-a11y-tree-utils.test.js.map +0 -1
- package/dist/esm/tests/unit/snapshot-capture-orchestration.test.d.ts +0 -1
- package/dist/esm/tests/unit/snapshot-capture-orchestration.test.js +0 -469
- package/dist/esm/tests/unit/snapshot-capture-orchestration.test.js.map +0 -1
- package/dist/esm/tests/unit/snapshot-cbor.test.d.ts +0 -1
- package/dist/esm/tests/unit/snapshot-cbor.test.js +0 -202
- package/dist/esm/tests/unit/snapshot-cbor.test.js.map +0 -1
- package/dist/esm/tests/unit/snapshot-dom-session-builders.test.d.ts +0 -1
- package/dist/esm/tests/unit/snapshot-dom-session-builders.test.js +0 -218
- package/dist/esm/tests/unit/snapshot-dom-session-builders.test.js.map +0 -1
- package/dist/esm/tests/unit/snapshot-dom-tree-utils.test.d.ts +0 -1
- package/dist/esm/tests/unit/snapshot-dom-tree-utils.test.js +0 -105
- package/dist/esm/tests/unit/snapshot-dom-tree-utils.test.js.map +0 -1
- package/dist/esm/tests/unit/snapshot-focus-selectors-utils.test.d.ts +0 -1
- package/dist/esm/tests/unit/snapshot-focus-selectors-utils.test.js +0 -87
- package/dist/esm/tests/unit/snapshot-focus-selectors-utils.test.js.map +0 -1
- package/dist/esm/tests/unit/snapshot-frame-merge.test.d.ts +0 -1
- package/dist/esm/tests/unit/snapshot-frame-merge.test.js +0 -333
- package/dist/esm/tests/unit/snapshot-frame-merge.test.js.map +0 -1
- package/dist/esm/tests/unit/snapshot-tree-format-utils.test.d.ts +0 -1
- package/dist/esm/tests/unit/snapshot-tree-format-utils.test.js +0 -82
- package/dist/esm/tests/unit/snapshot-tree-format-utils.test.js.map +0 -1
- package/dist/esm/tests/unit/snapshot-xpath-utils.test.d.ts +0 -1
- package/dist/esm/tests/unit/snapshot-xpath-utils.test.js +0 -72
- package/dist/esm/tests/unit/snapshot-xpath-utils.test.js.map +0 -1
- package/dist/esm/tests/unit/timeout-handlers.test.d.ts +0 -1
- package/dist/esm/tests/unit/timeout-handlers.test.js +0 -862
- package/dist/esm/tests/unit/timeout-handlers.test.js.map +0 -1
- package/dist/esm/tests/unit/understudy-command-exception.test.d.ts +0 -1
- package/dist/esm/tests/unit/understudy-command-exception.test.js +0 -55
- package/dist/esm/tests/unit/understudy-command-exception.test.js.map +0 -1
- package/dist/esm/tests/unit/xpath-parser.test.d.ts +0 -1
- package/dist/esm/tests/unit/xpath-parser.test.js +0 -309
- package/dist/esm/tests/unit/xpath-parser.test.js.map +0 -1
- package/dist/esm/tests/unit/xpath-resolver.test.d.ts +0 -1
- package/dist/esm/tests/unit/xpath-resolver.test.js +0 -78
- package/dist/esm/tests/unit/xpath-resolver.test.js.map +0 -1
- package/dist/esm/tests/unit/zod-enum-compatibility.test.d.ts +0 -1
- package/dist/esm/tests/unit/zod-enum-compatibility.test.js +0 -114
- package/dist/esm/tests/unit/zod-enum-compatibility.test.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"keep-alive.child.js","sourceRoot":"","sources":["../../../../tests/integration/keep-alive.child.ts"],"names":[],"mappings":"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","sourcesContent":["import { V3 } from \"../../lib/v3/v3.js\";\n\nasync function main(): Promise<void> {\n const encoded = process.argv.find((arg) => arg.startsWith(\"cfg:\"));\n if (!encoded) {\n throw new Error(\"Missing child config payload.\");\n }\n const raw = Buffer.from(encoded.slice(4), \"base64\").toString(\"utf8\");\n const cfg = JSON.parse(raw) as {\n env: \"LOCAL\" | \"BROWSERBASE\";\n keepAlive: boolean;\n disableAPI: boolean;\n scenario: string;\n apiKey?: string;\n projectId?: string;\n debug?: boolean;\n viewMs?: number;\n };\n const {\n env,\n keepAlive,\n disableAPI,\n scenario,\n apiKey,\n projectId,\n debug = false,\n viewMs = 0,\n } = cfg;\n\n const log = (message: string): void => {\n if (debug) {\n console.log(message);\n }\n };\n\n if (env !== \"LOCAL\" && env !== \"BROWSERBASE\") {\n throw new Error(\"KEEP_ALIVE_ENV must be LOCAL or BROWSERBASE\");\n }\n if (!scenario) {\n throw new Error(\"KEEP_ALIVE_SCENARIO is required\");\n }\n\n log(\n `[keep-alive-child] env=${env} keepAlive=${keepAlive} disableAPI=${disableAPI} ` +\n `scenario=${scenario} apiKey=${apiKey ? \"set\" : \"missing\"} ` +\n `projectId=${projectId ? \"set\" : \"missing\"}`,\n );\n\n const showBrowser = viewMs > 0;\n const v3 = new V3({\n env,\n keepAlive,\n disableAPI,\n apiKey,\n projectId,\n browserbaseSessionCreateParams: undefined,\n localBrowserLaunchOptions:\n env === \"LOCAL\"\n ? {\n executablePath: process.env.CHROME_PATH,\n args: process.env.CI ? [\"--no-sandbox\"] : undefined,\n headless: !showBrowser,\n viewport: { width: 1288, height: 711 },\n }\n : undefined,\n verbose: debug ? 2 : 0,\n disablePino: true,\n logger: debug ? (line) => console.log(line) : undefined,\n });\n\n await v3.init();\n\n const info = {\n connectURL: v3.connectURL(),\n sessionId: v3.browserbaseSessionId ?? null,\n };\n await new Promise<void>((resolve, reject) => {\n process.stdout.write(`__KEEPALIVE__${JSON.stringify(info)}\\n`, (error) => {\n if (error) {\n reject(error);\n return;\n }\n resolve();\n });\n });\n\n if (env === \"LOCAL\" && viewMs > 0) {\n await new Promise((r) => setTimeout(r, viewMs));\n }\n\n if (scenario === \"close\") {\n await v3.close().catch(() => {});\n process.exit(0);\n }\n\n if (scenario === \"sigterm\") {\n return;\n }\n\n if (scenario === \"sigint\") {\n return;\n }\n\n if (scenario === \"unhandled\") {\n setTimeout(() => {\n void Promise.reject(new Error(\"keepAlive unhandled rejection\"));\n }, 0);\n return;\n }\n\n throw new Error(`Unknown scenario: ${scenario}`);\n}\n\nmain().catch((err) => {\n console.error(err);\n process.exit(1);\n});\n"]}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
export type EnvKind = "LOCAL" | "BROWSERBASE";
|
|
2
|
-
export type ScenarioKind = "unhandled" | "close" | "sigterm" | "sigint";
|
|
3
|
-
export type KeepAliveCase = {
|
|
4
|
-
title: string;
|
|
5
|
-
env: EnvKind;
|
|
6
|
-
envLabel: string;
|
|
7
|
-
keepAlive: boolean;
|
|
8
|
-
disableAPI: boolean;
|
|
9
|
-
kind: ScenarioKind;
|
|
10
|
-
requiresBrowserbase: boolean;
|
|
11
|
-
};
|
|
12
|
-
export declare function getKeepAliveEnvConfig(): {
|
|
13
|
-
testEnv: EnvKind;
|
|
14
|
-
apiKey?: string;
|
|
15
|
-
projectId?: string;
|
|
16
|
-
hasBrowserbaseCreds: boolean;
|
|
17
|
-
};
|
|
18
|
-
export declare function buildKeepAliveCases(testEnv: EnvKind): KeepAliveCase[];
|
|
19
|
-
export declare function runKeepAliveCase(testCase: KeepAliveCase, envConfig: {
|
|
20
|
-
apiKey?: string;
|
|
21
|
-
projectId?: string;
|
|
22
|
-
}): Promise<void>;
|
|
@@ -1,490 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.getKeepAliveEnvConfig = getKeepAliveEnvConfig;
|
|
7
|
-
exports.buildKeepAliveCases = buildKeepAliveCases;
|
|
8
|
-
exports.runKeepAliveCase = runKeepAliveCase;
|
|
9
|
-
const test_1 = require("@playwright/test");
|
|
10
|
-
const node_child_process_1 = require("node:child_process");
|
|
11
|
-
const node_fs_1 = __importDefault(require("node:fs"));
|
|
12
|
-
const sdk_1 = __importDefault(require("@browserbasehq/sdk"));
|
|
13
|
-
const ws_1 = __importDefault(require("ws"));
|
|
14
|
-
const v3_dynamic_config_js_1 = require("./v3.dynamic.config.js");
|
|
15
|
-
const runtimePaths_js_1 = require("../../lib/v3/runtimePaths.js");
|
|
16
|
-
const coreDir = (0, runtimePaths_js_1.getPackageRootDir)();
|
|
17
|
-
const resolveChildRunner = () => {
|
|
18
|
-
const distJsPath = `${coreDir}/dist/esm/tests/integration/keep-alive.child.js`;
|
|
19
|
-
if (node_fs_1.default.existsSync(distJsPath)) {
|
|
20
|
-
return { command: process.execPath, args: [distJsPath] };
|
|
21
|
-
}
|
|
22
|
-
return null;
|
|
23
|
-
};
|
|
24
|
-
const childRunner = resolveChildRunner();
|
|
25
|
-
const DEBUG = process.env.KEEP_ALIVE_DEBUG === "1";
|
|
26
|
-
const VIEW_MS = Number(process.env.KEEP_ALIVE_VIEW_MS ?? "0");
|
|
27
|
-
const LOCAL_TIMEOUT_MS = Number(process.env.KEEP_ALIVE_LOCAL_TIMEOUT_MS ?? "8000");
|
|
28
|
-
const BB_TIMEOUT_MS = Number(process.env.KEEP_ALIVE_BB_TIMEOUT_MS ?? "30000");
|
|
29
|
-
const STAY_OPEN_MS = Number(process.env.KEEP_ALIVE_STAY_OPEN_MS ?? "6000");
|
|
30
|
-
const ACTION_EXIT_TIMEOUT_MS = Number(process.env.KEEP_ALIVE_ACTION_EXIT_TIMEOUT_MS ?? "3000");
|
|
31
|
-
const LOCAL_INFO_TIMEOUT_MS = Number(process.env.KEEP_ALIVE_LOCAL_INFO_TIMEOUT_MS ?? "15000");
|
|
32
|
-
const BB_INFO_TIMEOUT_MS = Number(process.env.KEEP_ALIVE_BB_INFO_TIMEOUT_MS ??
|
|
33
|
-
(process.env.CI ? "45000" : "30000"));
|
|
34
|
-
const getInfoTimeoutMs = (env) => env === "BROWSERBASE" ? BB_INFO_TIMEOUT_MS : LOCAL_INFO_TIMEOUT_MS;
|
|
35
|
-
function debugLog(message) {
|
|
36
|
-
if (DEBUG) {
|
|
37
|
-
console.log(message);
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
function parseChildInfo(line) {
|
|
41
|
-
const prefix = "__KEEPALIVE__";
|
|
42
|
-
if (!line.startsWith(prefix))
|
|
43
|
-
return null;
|
|
44
|
-
try {
|
|
45
|
-
return JSON.parse(line.slice(prefix.length));
|
|
46
|
-
}
|
|
47
|
-
catch {
|
|
48
|
-
return null;
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
async function runScenario(config) {
|
|
52
|
-
const payload = {
|
|
53
|
-
env: config.env,
|
|
54
|
-
keepAlive: config.keepAlive,
|
|
55
|
-
disableAPI: config.disableAPI,
|
|
56
|
-
scenario: config.kind,
|
|
57
|
-
apiKey: config.apiKey,
|
|
58
|
-
projectId: config.projectId,
|
|
59
|
-
debug: config.debug,
|
|
60
|
-
viewMs: config.viewMs,
|
|
61
|
-
};
|
|
62
|
-
const encoded = `cfg:${Buffer.from(JSON.stringify(payload)).toString("base64")}`;
|
|
63
|
-
if (!childRunner) {
|
|
64
|
-
throw new Error("keep-alive child script not found at dist/esm/tests/integration/keep-alive.child.js");
|
|
65
|
-
}
|
|
66
|
-
const child = (0, node_child_process_1.spawn)(childRunner.command, [...childRunner.args, encoded], {
|
|
67
|
-
cwd: coreDir,
|
|
68
|
-
env: { ...process.env },
|
|
69
|
-
stdio: ["ignore", "pipe", "pipe"],
|
|
70
|
-
});
|
|
71
|
-
const logs = { stdout: [], stderr: [] };
|
|
72
|
-
let buffer = "";
|
|
73
|
-
let stderr = "";
|
|
74
|
-
let resolved = false;
|
|
75
|
-
const infoTimeoutMs = getInfoTimeoutMs(config.env);
|
|
76
|
-
const infoPromise = new Promise((resolve, reject) => {
|
|
77
|
-
const timeout = setTimeout(() => {
|
|
78
|
-
child.kill("SIGKILL");
|
|
79
|
-
const stdoutDetails = logs.stdout.length > 0
|
|
80
|
-
? `\nChild stdout:\n${logs.stdout.join("\n")}`
|
|
81
|
-
: "";
|
|
82
|
-
const details = stderr.trim();
|
|
83
|
-
const suffix = details
|
|
84
|
-
? `\nChild stderr:\n${details}`
|
|
85
|
-
: "\nChild did not emit keepAlive info.";
|
|
86
|
-
reject(new Error(`Child timed out waiting for info after ${infoTimeoutMs}ms (env=${config.env}, keepAlive=${config.keepAlive}, disableAPI=${config.disableAPI}, scenario=${config.kind}).${suffix}${stdoutDetails}`));
|
|
87
|
-
}, infoTimeoutMs);
|
|
88
|
-
child.stdout.on("data", (chunk) => {
|
|
89
|
-
buffer += chunk.toString();
|
|
90
|
-
let idx = buffer.indexOf("\n");
|
|
91
|
-
while (idx !== -1) {
|
|
92
|
-
const line = buffer.slice(0, idx).trim();
|
|
93
|
-
buffer = buffer.slice(idx + 1);
|
|
94
|
-
const parsed = parseChildInfo(line);
|
|
95
|
-
if (parsed && !resolved) {
|
|
96
|
-
resolved = true;
|
|
97
|
-
clearTimeout(timeout);
|
|
98
|
-
resolve(parsed);
|
|
99
|
-
}
|
|
100
|
-
else if (line.length > 0) {
|
|
101
|
-
logs.stdout.push(line);
|
|
102
|
-
debugLog(`[keep-alive-child] ${line}`);
|
|
103
|
-
}
|
|
104
|
-
idx = buffer.indexOf("\n");
|
|
105
|
-
}
|
|
106
|
-
});
|
|
107
|
-
child.on("exit", (code, signal) => {
|
|
108
|
-
if (resolved)
|
|
109
|
-
return;
|
|
110
|
-
clearTimeout(timeout);
|
|
111
|
-
const stdoutDetails = logs.stdout.length > 0
|
|
112
|
-
? `\nChild stdout:\n${logs.stdout.join("\n")}`
|
|
113
|
-
: "";
|
|
114
|
-
const details = stderr.trim();
|
|
115
|
-
const suffix = details
|
|
116
|
-
? `\nChild stderr:\n${details}`
|
|
117
|
-
: "\nChild exited without emitting keepAlive info.";
|
|
118
|
-
reject(new Error(`Child exited (code=${code ?? "null"}, signal=${signal ?? "null"}) before emitting keepAlive info (env=${config.env}, keepAlive=${config.keepAlive}, disableAPI=${config.disableAPI}, scenario=${config.kind}).${suffix}${stdoutDetails}`));
|
|
119
|
-
});
|
|
120
|
-
child.on("error", (error) => {
|
|
121
|
-
if (resolved)
|
|
122
|
-
return;
|
|
123
|
-
clearTimeout(timeout);
|
|
124
|
-
reject(error);
|
|
125
|
-
});
|
|
126
|
-
});
|
|
127
|
-
child.stderr.on("data", (chunk) => {
|
|
128
|
-
const text = chunk.toString();
|
|
129
|
-
stderr += text;
|
|
130
|
-
const trimmed = text.trim();
|
|
131
|
-
if (trimmed.length > 0) {
|
|
132
|
-
logs.stderr.push(trimmed);
|
|
133
|
-
debugLog(`[keep-alive-child] ${trimmed}`);
|
|
134
|
-
}
|
|
135
|
-
});
|
|
136
|
-
const info = await infoPromise;
|
|
137
|
-
return { info, child, logs };
|
|
138
|
-
}
|
|
139
|
-
async function stopChild(child) {
|
|
140
|
-
if (child.exitCode !== null)
|
|
141
|
-
return;
|
|
142
|
-
try {
|
|
143
|
-
child.kill("SIGKILL");
|
|
144
|
-
}
|
|
145
|
-
catch {
|
|
146
|
-
return;
|
|
147
|
-
}
|
|
148
|
-
await new Promise((resolve) => {
|
|
149
|
-
const timer = setTimeout(() => resolve(), 2000);
|
|
150
|
-
child.once("exit", () => {
|
|
151
|
-
clearTimeout(timer);
|
|
152
|
-
resolve();
|
|
153
|
-
});
|
|
154
|
-
});
|
|
155
|
-
}
|
|
156
|
-
async function waitForChildExit(child, timeoutMs) {
|
|
157
|
-
if (child.exitCode !== null)
|
|
158
|
-
return;
|
|
159
|
-
await new Promise((resolve) => {
|
|
160
|
-
const timer = setTimeout(() => resolve(), timeoutMs);
|
|
161
|
-
child.once("exit", () => {
|
|
162
|
-
clearTimeout(timer);
|
|
163
|
-
resolve();
|
|
164
|
-
});
|
|
165
|
-
});
|
|
166
|
-
}
|
|
167
|
-
async function checkLocalAlive(connectURL) {
|
|
168
|
-
let port;
|
|
169
|
-
try {
|
|
170
|
-
port = new URL(connectURL).port;
|
|
171
|
-
}
|
|
172
|
-
catch {
|
|
173
|
-
return { alive: false, status: "INVALID_URL" };
|
|
174
|
-
}
|
|
175
|
-
if (!port)
|
|
176
|
-
return { alive: false, status: "MISSING_PORT" };
|
|
177
|
-
const controller = new AbortController();
|
|
178
|
-
const timer = setTimeout(() => controller.abort(), 1500);
|
|
179
|
-
try {
|
|
180
|
-
const resp = await fetch(`http://127.0.0.1:${port}/json/version`, {
|
|
181
|
-
signal: controller.signal,
|
|
182
|
-
});
|
|
183
|
-
if (!resp.ok) {
|
|
184
|
-
return { alive: false, status: `HTTP_${resp.status}` };
|
|
185
|
-
}
|
|
186
|
-
const json = (await resp.json());
|
|
187
|
-
const ws = json?.webSocketDebuggerUrl;
|
|
188
|
-
if (!ws) {
|
|
189
|
-
return { alive: false, status: "MISSING_WS" };
|
|
190
|
-
}
|
|
191
|
-
if (ws !== connectURL) {
|
|
192
|
-
return { alive: false, status: "WS_MISMATCH" };
|
|
193
|
-
}
|
|
194
|
-
return { alive: true, status: "MATCH" };
|
|
195
|
-
}
|
|
196
|
-
catch {
|
|
197
|
-
return { alive: false, status: "FETCH_ERROR" };
|
|
198
|
-
}
|
|
199
|
-
finally {
|
|
200
|
-
clearTimeout(timer);
|
|
201
|
-
}
|
|
202
|
-
}
|
|
203
|
-
async function closeLocalBrowser(connectURL) {
|
|
204
|
-
await new Promise((resolve) => {
|
|
205
|
-
const ws = new ws_1.default(connectURL);
|
|
206
|
-
const timer = setTimeout(() => {
|
|
207
|
-
ws.terminate();
|
|
208
|
-
resolve();
|
|
209
|
-
}, 2000);
|
|
210
|
-
ws.on("open", () => {
|
|
211
|
-
ws.send(JSON.stringify({ id: 1, method: "Browser.close" }));
|
|
212
|
-
});
|
|
213
|
-
ws.on("error", () => {
|
|
214
|
-
clearTimeout(timer);
|
|
215
|
-
resolve();
|
|
216
|
-
});
|
|
217
|
-
ws.on("close", () => {
|
|
218
|
-
clearTimeout(timer);
|
|
219
|
-
resolve();
|
|
220
|
-
});
|
|
221
|
-
});
|
|
222
|
-
}
|
|
223
|
-
async function checkBrowserbaseAlive(sessionId, apiKey) {
|
|
224
|
-
if (!apiKey)
|
|
225
|
-
return { alive: false, status: "NO_API_KEY" };
|
|
226
|
-
const bb = new sdk_1.default({ apiKey });
|
|
227
|
-
try {
|
|
228
|
-
const snapshot = (await bb.sessions.retrieve(sessionId));
|
|
229
|
-
if (DEBUG) {
|
|
230
|
-
const status = snapshot?.status ?? "<missing>";
|
|
231
|
-
debugLog(`[keep-alive] session ${sessionId} status=${status}`);
|
|
232
|
-
}
|
|
233
|
-
const status = snapshot?.status;
|
|
234
|
-
return { alive: status === "RUNNING", status };
|
|
235
|
-
}
|
|
236
|
-
catch (error) {
|
|
237
|
-
debugLog(`[keep-alive] session ${sessionId} retrieve failed: ${String(error)}`);
|
|
238
|
-
return { alive: false, status: "RETRIEVE_FAILED" };
|
|
239
|
-
}
|
|
240
|
-
}
|
|
241
|
-
async function endBrowserbaseSession(sessionId, apiKey, projectId) {
|
|
242
|
-
if (!apiKey || !projectId)
|
|
243
|
-
return;
|
|
244
|
-
const bb = new sdk_1.default({ apiKey });
|
|
245
|
-
try {
|
|
246
|
-
await bb.sessions.update(sessionId, {
|
|
247
|
-
status: "REQUEST_RELEASE",
|
|
248
|
-
projectId,
|
|
249
|
-
});
|
|
250
|
-
}
|
|
251
|
-
catch {
|
|
252
|
-
// best-effort cleanup
|
|
253
|
-
}
|
|
254
|
-
}
|
|
255
|
-
async function assertStaysOpen(check, durationMs, intervalMs = 500) {
|
|
256
|
-
const start = Date.now();
|
|
257
|
-
const deadline = start + durationMs;
|
|
258
|
-
let lastStatus;
|
|
259
|
-
while (Date.now() < deadline) {
|
|
260
|
-
const result = await check();
|
|
261
|
-
lastStatus = result.status ?? lastStatus;
|
|
262
|
-
if (!result.alive) {
|
|
263
|
-
const elapsed = Date.now() - start;
|
|
264
|
-
const status = lastStatus ? ` (last status ${lastStatus})` : "";
|
|
265
|
-
throw new Error(`Browser closed after ${elapsed}ms (expected ${durationMs}ms)${status}.`);
|
|
266
|
-
}
|
|
267
|
-
await new Promise((r) => setTimeout(r, intervalMs));
|
|
268
|
-
}
|
|
269
|
-
return { durationMs: Date.now() - start, lastStatus };
|
|
270
|
-
}
|
|
271
|
-
async function waitForClosed(check, timeoutMs, intervalMs = 500) {
|
|
272
|
-
const start = Date.now();
|
|
273
|
-
let lastStatus;
|
|
274
|
-
while (Date.now() - start < timeoutMs) {
|
|
275
|
-
const result = await check();
|
|
276
|
-
lastStatus = result.status ?? lastStatus;
|
|
277
|
-
if (!result.alive) {
|
|
278
|
-
return { durationMs: Date.now() - start, lastStatus };
|
|
279
|
-
}
|
|
280
|
-
await new Promise((r) => setTimeout(r, intervalMs));
|
|
281
|
-
}
|
|
282
|
-
const status = lastStatus ? ` (last status ${lastStatus})` : "";
|
|
283
|
-
throw new Error(`Browser still alive after ${timeoutMs}ms${status}.`);
|
|
284
|
-
}
|
|
285
|
-
async function assertBrowserState(env, info, shouldStayOpen, apiKey, projectId) {
|
|
286
|
-
const expected = shouldStayOpen ? "open" : "closed";
|
|
287
|
-
if (env === "LOCAL") {
|
|
288
|
-
if (shouldStayOpen) {
|
|
289
|
-
const result = await assertStaysOpen(() => checkLocalAlive(info.connectURL), STAY_OPEN_MS);
|
|
290
|
-
const outcome = {
|
|
291
|
-
expected,
|
|
292
|
-
actual: "open",
|
|
293
|
-
durationMs: result.durationMs,
|
|
294
|
-
lastStatus: result.lastStatus,
|
|
295
|
-
};
|
|
296
|
-
await closeLocalBrowser(info.connectURL);
|
|
297
|
-
return outcome;
|
|
298
|
-
}
|
|
299
|
-
const result = await waitForClosed(() => checkLocalAlive(info.connectURL), LOCAL_TIMEOUT_MS);
|
|
300
|
-
return {
|
|
301
|
-
expected,
|
|
302
|
-
actual: "closed",
|
|
303
|
-
durationMs: result.durationMs,
|
|
304
|
-
lastStatus: result.lastStatus,
|
|
305
|
-
};
|
|
306
|
-
}
|
|
307
|
-
if (!info.sessionId) {
|
|
308
|
-
throw new Error("Browserbase sessionId missing");
|
|
309
|
-
}
|
|
310
|
-
if (shouldStayOpen) {
|
|
311
|
-
const result = await assertStaysOpen(() => checkBrowserbaseAlive(info.sessionId, apiKey), STAY_OPEN_MS, 1000);
|
|
312
|
-
const outcome = {
|
|
313
|
-
expected,
|
|
314
|
-
actual: "open",
|
|
315
|
-
durationMs: result.durationMs,
|
|
316
|
-
lastStatus: result.lastStatus,
|
|
317
|
-
};
|
|
318
|
-
await endBrowserbaseSession(info.sessionId, apiKey, projectId);
|
|
319
|
-
return outcome;
|
|
320
|
-
}
|
|
321
|
-
const result = await waitForClosed(() => checkBrowserbaseAlive(info.sessionId, apiKey), BB_TIMEOUT_MS, 1000);
|
|
322
|
-
return {
|
|
323
|
-
expected,
|
|
324
|
-
actual: "closed",
|
|
325
|
-
durationMs: result.durationMs,
|
|
326
|
-
lastStatus: result.lastStatus,
|
|
327
|
-
};
|
|
328
|
-
}
|
|
329
|
-
function dumpLogs(logs) {
|
|
330
|
-
if (logs.stdout.length > 0) {
|
|
331
|
-
console.log("[keep-alive] child stdout:");
|
|
332
|
-
for (const line of logs.stdout) {
|
|
333
|
-
console.log(` ${line}`);
|
|
334
|
-
}
|
|
335
|
-
}
|
|
336
|
-
if (logs.stderr.length > 0) {
|
|
337
|
-
console.log("[keep-alive] child stderr:");
|
|
338
|
-
for (const line of logs.stderr) {
|
|
339
|
-
console.log(` ${line}`);
|
|
340
|
-
}
|
|
341
|
-
}
|
|
342
|
-
}
|
|
343
|
-
function logCaseResult(label, envLabel, keepAlive, outcome, error) {
|
|
344
|
-
const prefix = `[keep-alive] ${envLabel} keepAlive=${keepAlive} ${label}`;
|
|
345
|
-
if (error) {
|
|
346
|
-
console.log(`${prefix} FAIL: ${error.message}`);
|
|
347
|
-
return;
|
|
348
|
-
}
|
|
349
|
-
if (!outcome) {
|
|
350
|
-
console.log(`${prefix} FAIL: missing outcome`);
|
|
351
|
-
return;
|
|
352
|
-
}
|
|
353
|
-
const status = outcome.lastStatus !== undefined
|
|
354
|
-
? ` (last status ${outcome.lastStatus})`
|
|
355
|
-
: "";
|
|
356
|
-
if (outcome.actual === "open") {
|
|
357
|
-
console.log(`${prefix} PASS: stayed open for ${outcome.durationMs}ms${status}`);
|
|
358
|
-
}
|
|
359
|
-
else {
|
|
360
|
-
console.log(`${prefix} PASS: closed after ${outcome.durationMs}ms${status}`);
|
|
361
|
-
}
|
|
362
|
-
}
|
|
363
|
-
function getKeepAliveEnvConfig() {
|
|
364
|
-
const testEnv = v3_dynamic_config_js_1.v3DynamicTestConfig.env;
|
|
365
|
-
const apiKey = testEnv === "BROWSERBASE"
|
|
366
|
-
? v3_dynamic_config_js_1.v3DynamicTestConfig.apiKey
|
|
367
|
-
: undefined;
|
|
368
|
-
const projectId = testEnv === "BROWSERBASE"
|
|
369
|
-
? v3_dynamic_config_js_1.v3DynamicTestConfig.projectId
|
|
370
|
-
: undefined;
|
|
371
|
-
const hasBrowserbaseCreds = Boolean(apiKey && projectId);
|
|
372
|
-
return { testEnv, apiKey, projectId, hasBrowserbaseCreds };
|
|
373
|
-
}
|
|
374
|
-
function buildKeepAliveCases(testEnv) {
|
|
375
|
-
const scenarios = [
|
|
376
|
-
{ kind: "unhandled", label: "unhandled rejection" },
|
|
377
|
-
{ kind: "close", label: "stagehand.close()" },
|
|
378
|
-
{ kind: "sigterm", label: "SIGTERM" },
|
|
379
|
-
{ kind: "sigint", label: "SIGINT" },
|
|
380
|
-
];
|
|
381
|
-
const environments = testEnv === "BROWSERBASE"
|
|
382
|
-
? [
|
|
383
|
-
{
|
|
384
|
-
env: "BROWSERBASE",
|
|
385
|
-
label: "bb direct ws",
|
|
386
|
-
disableAPI: true,
|
|
387
|
-
requiresBrowserbase: true,
|
|
388
|
-
},
|
|
389
|
-
{
|
|
390
|
-
env: "BROWSERBASE",
|
|
391
|
-
label: "bb via api",
|
|
392
|
-
disableAPI: false,
|
|
393
|
-
requiresBrowserbase: true,
|
|
394
|
-
},
|
|
395
|
-
]
|
|
396
|
-
: [
|
|
397
|
-
{
|
|
398
|
-
env: "LOCAL",
|
|
399
|
-
label: "local",
|
|
400
|
-
disableAPI: false,
|
|
401
|
-
requiresBrowserbase: false,
|
|
402
|
-
},
|
|
403
|
-
];
|
|
404
|
-
const cases = [];
|
|
405
|
-
for (const keepAlive of [true, false]) {
|
|
406
|
-
for (const envConfig of environments) {
|
|
407
|
-
for (const scenario of scenarios) {
|
|
408
|
-
const expectation = keepAlive ? "expect open" : "expect closed";
|
|
409
|
-
cases.push({
|
|
410
|
-
title: `${envConfig.label} keepAlive=${keepAlive} ${scenario.label} (${expectation})`,
|
|
411
|
-
env: envConfig.env,
|
|
412
|
-
envLabel: envConfig.label,
|
|
413
|
-
keepAlive,
|
|
414
|
-
disableAPI: envConfig.disableAPI,
|
|
415
|
-
kind: scenario.kind,
|
|
416
|
-
requiresBrowserbase: envConfig.requiresBrowserbase,
|
|
417
|
-
});
|
|
418
|
-
}
|
|
419
|
-
}
|
|
420
|
-
}
|
|
421
|
-
return cases;
|
|
422
|
-
}
|
|
423
|
-
async function runKeepAliveCase(testCase, envConfig) {
|
|
424
|
-
let info;
|
|
425
|
-
let child;
|
|
426
|
-
let logs;
|
|
427
|
-
try {
|
|
428
|
-
({ info, child, logs } = await runScenario({
|
|
429
|
-
env: testCase.env,
|
|
430
|
-
keepAlive: testCase.keepAlive,
|
|
431
|
-
disableAPI: testCase.disableAPI,
|
|
432
|
-
kind: testCase.kind,
|
|
433
|
-
debug: DEBUG,
|
|
434
|
-
viewMs: VIEW_MS,
|
|
435
|
-
apiKey: envConfig.apiKey,
|
|
436
|
-
projectId: envConfig.projectId,
|
|
437
|
-
}));
|
|
438
|
-
}
|
|
439
|
-
catch (error) {
|
|
440
|
-
logCaseResult(testCase.title, testCase.envLabel, testCase.keepAlive, undefined, error);
|
|
441
|
-
throw error;
|
|
442
|
-
}
|
|
443
|
-
if (testCase.kind === "sigterm") {
|
|
444
|
-
child.kill("SIGTERM");
|
|
445
|
-
}
|
|
446
|
-
else if (testCase.kind === "sigint") {
|
|
447
|
-
child.kill("SIGINT");
|
|
448
|
-
}
|
|
449
|
-
let outcome;
|
|
450
|
-
let failure;
|
|
451
|
-
try {
|
|
452
|
-
if (testCase.kind === "close" ||
|
|
453
|
-
testCase.kind === "unhandled" ||
|
|
454
|
-
testCase.kind === "sigterm" ||
|
|
455
|
-
testCase.kind === "sigint") {
|
|
456
|
-
await waitForChildExit(child, ACTION_EXIT_TIMEOUT_MS);
|
|
457
|
-
}
|
|
458
|
-
outcome = await assertBrowserState(testCase.env, info, testCase.keepAlive, envConfig.apiKey, envConfig.projectId);
|
|
459
|
-
}
|
|
460
|
-
catch (error) {
|
|
461
|
-
failure = error;
|
|
462
|
-
if (logs) {
|
|
463
|
-
dumpLogs(logs);
|
|
464
|
-
}
|
|
465
|
-
throw error;
|
|
466
|
-
}
|
|
467
|
-
finally {
|
|
468
|
-
logCaseResult(testCase.title, testCase.envLabel, testCase.keepAlive, outcome, failure);
|
|
469
|
-
await stopChild(child);
|
|
470
|
-
if (testCase.env === "LOCAL" && info.connectURL) {
|
|
471
|
-
await closeLocalBrowser(info.connectURL);
|
|
472
|
-
}
|
|
473
|
-
if (testCase.env === "BROWSERBASE" && info.sessionId) {
|
|
474
|
-
await endBrowserbaseSession(info.sessionId, envConfig.apiKey, envConfig.projectId);
|
|
475
|
-
}
|
|
476
|
-
}
|
|
477
|
-
}
|
|
478
|
-
test_1.test.describe.parallel("keepAlive behavior", () => {
|
|
479
|
-
const { testEnv, apiKey, projectId, hasBrowserbaseCreds } = getKeepAliveEnvConfig();
|
|
480
|
-
const cases = buildKeepAliveCases(testEnv);
|
|
481
|
-
for (const testCase of cases) {
|
|
482
|
-
(0, test_1.test)(testCase.title, async () => {
|
|
483
|
-
if (testCase.requiresBrowserbase) {
|
|
484
|
-
test_1.test.skip(!hasBrowserbaseCreds, "Browserbase credentials required");
|
|
485
|
-
}
|
|
486
|
-
await runKeepAliveCase(testCase, { apiKey, projectId });
|
|
487
|
-
});
|
|
488
|
-
}
|
|
489
|
-
});
|
|
490
|
-
//# sourceMappingURL=keep-alive.spec.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"keep-alive.spec.js","sourceRoot":"","sources":["../../../../tests/integration/keep-alive.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import { test } from \"@playwright/test\";\nimport { spawn } from \"node:child_process\";\nimport fs from \"node:fs\";\nimport Browserbase from \"@browserbasehq/sdk\";\nimport WebSocket from \"ws\";\nimport { v3DynamicTestConfig } from \"./v3.dynamic.config.js\";\nimport { getPackageRootDir } from \"../../lib/v3/runtimePaths.js\";\n\nexport type EnvKind = \"LOCAL\" | \"BROWSERBASE\";\nexport type ScenarioKind = \"unhandled\" | \"close\" | \"sigterm\" | \"sigint\";\n\nexport type KeepAliveCase = {\n title: string;\n env: EnvKind;\n envLabel: string;\n keepAlive: boolean;\n disableAPI: boolean;\n kind: ScenarioKind;\n requiresBrowserbase: boolean;\n};\n\ntype ScenarioConfig = {\n env: EnvKind;\n keepAlive: boolean;\n disableAPI: boolean;\n kind: ScenarioKind;\n debug: boolean;\n viewMs: number;\n apiKey?: string;\n projectId?: string;\n};\n\ntype ChildInfo = {\n connectURL: string;\n sessionId: string | null;\n};\n\ntype ChildLogs = {\n stdout: string[];\n stderr: string[];\n};\n\ntype CheckResult = {\n alive: boolean;\n status?: string;\n};\n\ntype Outcome = {\n expected: \"open\" | \"closed\";\n actual: \"open\" | \"closed\";\n durationMs: number;\n lastStatus?: string;\n};\n\nconst coreDir = getPackageRootDir();\n\nconst resolveChildRunner = (): { command: string; args: string[] } | null => {\n const distJsPath = `${coreDir}/dist/esm/tests/integration/keep-alive.child.js`;\n if (fs.existsSync(distJsPath)) {\n return { command: process.execPath, args: [distJsPath] };\n }\n\n return null;\n};\n\nconst childRunner = resolveChildRunner();\n\nconst DEBUG = process.env.KEEP_ALIVE_DEBUG === \"1\";\nconst VIEW_MS = Number(process.env.KEEP_ALIVE_VIEW_MS ?? \"0\");\nconst LOCAL_TIMEOUT_MS = Number(\n process.env.KEEP_ALIVE_LOCAL_TIMEOUT_MS ?? \"8000\",\n);\nconst BB_TIMEOUT_MS = Number(process.env.KEEP_ALIVE_BB_TIMEOUT_MS ?? \"30000\");\nconst STAY_OPEN_MS = Number(process.env.KEEP_ALIVE_STAY_OPEN_MS ?? \"6000\");\nconst ACTION_EXIT_TIMEOUT_MS = Number(\n process.env.KEEP_ALIVE_ACTION_EXIT_TIMEOUT_MS ?? \"3000\",\n);\nconst LOCAL_INFO_TIMEOUT_MS = Number(\n process.env.KEEP_ALIVE_LOCAL_INFO_TIMEOUT_MS ?? \"15000\",\n);\nconst BB_INFO_TIMEOUT_MS = Number(\n process.env.KEEP_ALIVE_BB_INFO_TIMEOUT_MS ??\n (process.env.CI ? \"45000\" : \"30000\"),\n);\n\nconst getInfoTimeoutMs = (env: EnvKind): number =>\n env === \"BROWSERBASE\" ? BB_INFO_TIMEOUT_MS : LOCAL_INFO_TIMEOUT_MS;\n\nfunction debugLog(message: string): void {\n if (DEBUG) {\n console.log(message);\n }\n}\n\nfunction parseChildInfo(line: string): ChildInfo | null {\n const prefix = \"__KEEPALIVE__\";\n if (!line.startsWith(prefix)) return null;\n try {\n return JSON.parse(line.slice(prefix.length)) as ChildInfo;\n } catch {\n return null;\n }\n}\n\nasync function runScenario(config: ScenarioConfig): Promise<{\n info: ChildInfo;\n child: ReturnType<typeof spawn>;\n logs: ChildLogs;\n}> {\n const payload = {\n env: config.env,\n keepAlive: config.keepAlive,\n disableAPI: config.disableAPI,\n scenario: config.kind,\n apiKey: config.apiKey,\n projectId: config.projectId,\n debug: config.debug,\n viewMs: config.viewMs,\n };\n const encoded = `cfg:${Buffer.from(JSON.stringify(payload)).toString(\"base64\")}`;\n\n if (!childRunner) {\n throw new Error(\n \"keep-alive child script not found at dist/esm/tests/integration/keep-alive.child.js\",\n );\n }\n\n const child = spawn(childRunner.command, [...childRunner.args, encoded], {\n cwd: coreDir,\n env: { ...process.env },\n stdio: [\"ignore\", \"pipe\", \"pipe\"],\n });\n\n const logs: ChildLogs = { stdout: [], stderr: [] };\n let buffer = \"\";\n let stderr = \"\";\n let resolved = false;\n const infoTimeoutMs = getInfoTimeoutMs(config.env);\n\n const infoPromise = new Promise<ChildInfo>((resolve, reject) => {\n const timeout = setTimeout(() => {\n child.kill(\"SIGKILL\");\n const stdoutDetails =\n logs.stdout.length > 0\n ? `\\nChild stdout:\\n${logs.stdout.join(\"\\n\")}`\n : \"\";\n const details = stderr.trim();\n const suffix = details\n ? `\\nChild stderr:\\n${details}`\n : \"\\nChild did not emit keepAlive info.\";\n reject(\n new Error(\n `Child timed out waiting for info after ${infoTimeoutMs}ms (env=${config.env}, keepAlive=${config.keepAlive}, disableAPI=${config.disableAPI}, scenario=${config.kind}).${suffix}${stdoutDetails}`,\n ),\n );\n }, infoTimeoutMs);\n\n child.stdout.on(\"data\", (chunk) => {\n buffer += chunk.toString();\n let idx = buffer.indexOf(\"\\n\");\n while (idx !== -1) {\n const line = buffer.slice(0, idx).trim();\n buffer = buffer.slice(idx + 1);\n const parsed = parseChildInfo(line);\n if (parsed && !resolved) {\n resolved = true;\n clearTimeout(timeout);\n resolve(parsed);\n } else if (line.length > 0) {\n logs.stdout.push(line);\n debugLog(`[keep-alive-child] ${line}`);\n }\n idx = buffer.indexOf(\"\\n\");\n }\n });\n\n child.on(\"exit\", (code, signal) => {\n if (resolved) return;\n clearTimeout(timeout);\n const stdoutDetails =\n logs.stdout.length > 0\n ? `\\nChild stdout:\\n${logs.stdout.join(\"\\n\")}`\n : \"\";\n const details = stderr.trim();\n const suffix = details\n ? `\\nChild stderr:\\n${details}`\n : \"\\nChild exited without emitting keepAlive info.\";\n reject(\n new Error(\n `Child exited (code=${code ?? \"null\"}, signal=${signal ?? \"null\"}) before emitting keepAlive info (env=${config.env}, keepAlive=${config.keepAlive}, disableAPI=${config.disableAPI}, scenario=${config.kind}).${suffix}${stdoutDetails}`,\n ),\n );\n });\n\n child.on(\"error\", (error) => {\n if (resolved) return;\n clearTimeout(timeout);\n reject(error);\n });\n });\n\n child.stderr.on(\"data\", (chunk) => {\n const text = chunk.toString();\n stderr += text;\n const trimmed = text.trim();\n if (trimmed.length > 0) {\n logs.stderr.push(trimmed);\n debugLog(`[keep-alive-child] ${trimmed}`);\n }\n });\n\n const info = await infoPromise;\n return { info, child, logs };\n}\n\nasync function stopChild(child: ReturnType<typeof spawn>): Promise<void> {\n if (child.exitCode !== null) return;\n try {\n child.kill(\"SIGKILL\");\n } catch {\n return;\n }\n await new Promise<void>((resolve) => {\n const timer = setTimeout(() => resolve(), 2000);\n child.once(\"exit\", () => {\n clearTimeout(timer);\n resolve();\n });\n });\n}\n\nasync function waitForChildExit(\n child: ReturnType<typeof spawn>,\n timeoutMs: number,\n): Promise<void> {\n if (child.exitCode !== null) return;\n await new Promise<void>((resolve) => {\n const timer = setTimeout(() => resolve(), timeoutMs);\n child.once(\"exit\", () => {\n clearTimeout(timer);\n resolve();\n });\n });\n}\n\nasync function checkLocalAlive(connectURL: string): Promise<CheckResult> {\n let port: string;\n try {\n port = new URL(connectURL).port;\n } catch {\n return { alive: false, status: \"INVALID_URL\" };\n }\n if (!port) return { alive: false, status: \"MISSING_PORT\" };\n\n const controller = new AbortController();\n const timer = setTimeout(() => controller.abort(), 1500);\n try {\n const resp = await fetch(`http://127.0.0.1:${port}/json/version`, {\n signal: controller.signal,\n });\n if (!resp.ok) {\n return { alive: false, status: `HTTP_${resp.status}` };\n }\n const json = (await resp.json()) as { webSocketDebuggerUrl?: string };\n const ws = json?.webSocketDebuggerUrl;\n if (!ws) {\n return { alive: false, status: \"MISSING_WS\" };\n }\n if (ws !== connectURL) {\n return { alive: false, status: \"WS_MISMATCH\" };\n }\n return { alive: true, status: \"MATCH\" };\n } catch {\n return { alive: false, status: \"FETCH_ERROR\" };\n } finally {\n clearTimeout(timer);\n }\n}\n\nasync function closeLocalBrowser(connectURL: string): Promise<void> {\n await new Promise<void>((resolve) => {\n const ws = new WebSocket(connectURL);\n const timer = setTimeout(() => {\n ws.terminate();\n resolve();\n }, 2000);\n ws.on(\"open\", () => {\n ws.send(JSON.stringify({ id: 1, method: \"Browser.close\" }));\n });\n ws.on(\"error\", () => {\n clearTimeout(timer);\n resolve();\n });\n ws.on(\"close\", () => {\n clearTimeout(timer);\n resolve();\n });\n });\n}\n\nasync function checkBrowserbaseAlive(\n sessionId: string,\n apiKey?: string,\n): Promise<CheckResult> {\n if (!apiKey) return { alive: false, status: \"NO_API_KEY\" };\n\n const bb = new Browserbase({ apiKey });\n try {\n const snapshot = (await bb.sessions.retrieve(sessionId)) as {\n status?: string;\n };\n if (DEBUG) {\n const status = snapshot?.status ?? \"<missing>\";\n debugLog(`[keep-alive] session ${sessionId} status=${status}`);\n }\n const status = snapshot?.status;\n return { alive: status === \"RUNNING\", status };\n } catch (error) {\n debugLog(\n `[keep-alive] session ${sessionId} retrieve failed: ${String(error)}`,\n );\n return { alive: false, status: \"RETRIEVE_FAILED\" };\n }\n}\n\nasync function endBrowserbaseSession(\n sessionId: string,\n apiKey?: string,\n projectId?: string,\n): Promise<void> {\n if (!apiKey || !projectId) return;\n const bb = new Browserbase({ apiKey });\n try {\n await bb.sessions.update(sessionId, {\n status: \"REQUEST_RELEASE\",\n projectId,\n });\n } catch {\n // best-effort cleanup\n }\n}\n\nasync function assertStaysOpen(\n check: () => Promise<CheckResult>,\n durationMs: number,\n intervalMs = 500,\n): Promise<{ durationMs: number; lastStatus?: string }> {\n const start = Date.now();\n const deadline = start + durationMs;\n let lastStatus: string | undefined;\n while (Date.now() < deadline) {\n const result = await check();\n lastStatus = result.status ?? lastStatus;\n if (!result.alive) {\n const elapsed = Date.now() - start;\n const status = lastStatus ? ` (last status ${lastStatus})` : \"\";\n throw new Error(\n `Browser closed after ${elapsed}ms (expected ${durationMs}ms)${status}.`,\n );\n }\n await new Promise((r) => setTimeout(r, intervalMs));\n }\n return { durationMs: Date.now() - start, lastStatus };\n}\n\nasync function waitForClosed(\n check: () => Promise<CheckResult>,\n timeoutMs: number,\n intervalMs = 500,\n): Promise<{ durationMs: number; lastStatus?: string }> {\n const start = Date.now();\n let lastStatus: string | undefined;\n while (Date.now() - start < timeoutMs) {\n const result = await check();\n lastStatus = result.status ?? lastStatus;\n if (!result.alive) {\n return { durationMs: Date.now() - start, lastStatus };\n }\n await new Promise((r) => setTimeout(r, intervalMs));\n }\n const status = lastStatus ? ` (last status ${lastStatus})` : \"\";\n throw new Error(`Browser still alive after ${timeoutMs}ms${status}.`);\n}\n\nasync function assertBrowserState(\n env: EnvKind,\n info: ChildInfo,\n shouldStayOpen: boolean,\n apiKey?: string,\n projectId?: string,\n): Promise<Outcome> {\n const expected: Outcome[\"expected\"] = shouldStayOpen ? \"open\" : \"closed\";\n if (env === \"LOCAL\") {\n if (shouldStayOpen) {\n const result = await assertStaysOpen(\n () => checkLocalAlive(info.connectURL),\n STAY_OPEN_MS,\n );\n const outcome: Outcome = {\n expected,\n actual: \"open\",\n durationMs: result.durationMs,\n lastStatus: result.lastStatus,\n };\n await closeLocalBrowser(info.connectURL);\n return outcome;\n }\n\n const result = await waitForClosed(\n () => checkLocalAlive(info.connectURL),\n LOCAL_TIMEOUT_MS,\n );\n return {\n expected,\n actual: \"closed\",\n durationMs: result.durationMs,\n lastStatus: result.lastStatus,\n };\n }\n\n if (!info.sessionId) {\n throw new Error(\"Browserbase sessionId missing\");\n }\n\n if (shouldStayOpen) {\n const result = await assertStaysOpen(\n () => checkBrowserbaseAlive(info.sessionId!, apiKey),\n STAY_OPEN_MS,\n 1000,\n );\n const outcome: Outcome = {\n expected,\n actual: \"open\",\n durationMs: result.durationMs,\n lastStatus: result.lastStatus,\n };\n await endBrowserbaseSession(info.sessionId, apiKey, projectId);\n return outcome;\n }\n\n const result = await waitForClosed(\n () => checkBrowserbaseAlive(info.sessionId!, apiKey),\n BB_TIMEOUT_MS,\n 1000,\n );\n return {\n expected,\n actual: \"closed\",\n durationMs: result.durationMs,\n lastStatus: result.lastStatus,\n };\n}\n\nfunction dumpLogs(logs: ChildLogs): void {\n if (logs.stdout.length > 0) {\n console.log(\"[keep-alive] child stdout:\");\n for (const line of logs.stdout) {\n console.log(` ${line}`);\n }\n }\n if (logs.stderr.length > 0) {\n console.log(\"[keep-alive] child stderr:\");\n for (const line of logs.stderr) {\n console.log(` ${line}`);\n }\n }\n}\n\nfunction logCaseResult(\n label: string,\n envLabel: string,\n keepAlive: boolean,\n outcome?: Outcome,\n error?: Error,\n): void {\n const prefix = `[keep-alive] ${envLabel} keepAlive=${keepAlive} ${label}`;\n if (error) {\n console.log(`${prefix} FAIL: ${error.message}`);\n return;\n }\n if (!outcome) {\n console.log(`${prefix} FAIL: missing outcome`);\n return;\n }\n const status =\n outcome.lastStatus !== undefined\n ? ` (last status ${outcome.lastStatus})`\n : \"\";\n if (outcome.actual === \"open\") {\n console.log(\n `${prefix} PASS: stayed open for ${outcome.durationMs}ms${status}`,\n );\n } else {\n console.log(\n `${prefix} PASS: closed after ${outcome.durationMs}ms${status}`,\n );\n }\n}\n\nexport function getKeepAliveEnvConfig(): {\n testEnv: EnvKind;\n apiKey?: string;\n projectId?: string;\n hasBrowserbaseCreds: boolean;\n} {\n const testEnv = v3DynamicTestConfig.env;\n const apiKey =\n testEnv === \"BROWSERBASE\"\n ? (v3DynamicTestConfig.apiKey as string | undefined)\n : undefined;\n const projectId =\n testEnv === \"BROWSERBASE\"\n ? (v3DynamicTestConfig.projectId as string | undefined)\n : undefined;\n const hasBrowserbaseCreds = Boolean(apiKey && projectId);\n return { testEnv, apiKey, projectId, hasBrowserbaseCreds };\n}\n\nexport function buildKeepAliveCases(testEnv: EnvKind): KeepAliveCase[] {\n const scenarios: Array<{ kind: ScenarioKind; label: string }> = [\n { kind: \"unhandled\", label: \"unhandled rejection\" },\n { kind: \"close\", label: \"stagehand.close()\" },\n { kind: \"sigterm\", label: \"SIGTERM\" },\n { kind: \"sigint\", label: \"SIGINT\" },\n ];\n\n const environments: Array<{\n env: EnvKind;\n label: string;\n disableAPI: boolean;\n requiresBrowserbase: boolean;\n }> =\n testEnv === \"BROWSERBASE\"\n ? [\n {\n env: \"BROWSERBASE\",\n label: \"bb direct ws\",\n disableAPI: true,\n requiresBrowserbase: true,\n },\n {\n env: \"BROWSERBASE\",\n label: \"bb via api\",\n disableAPI: false,\n requiresBrowserbase: true,\n },\n ]\n : [\n {\n env: \"LOCAL\",\n label: \"local\",\n disableAPI: false,\n requiresBrowserbase: false,\n },\n ];\n\n const cases: KeepAliveCase[] = [];\n for (const keepAlive of [true, false]) {\n for (const envConfig of environments) {\n for (const scenario of scenarios) {\n const expectation = keepAlive ? \"expect open\" : \"expect closed\";\n cases.push({\n title: `${envConfig.label} keepAlive=${keepAlive} ${scenario.label} (${expectation})`,\n env: envConfig.env,\n envLabel: envConfig.label,\n keepAlive,\n disableAPI: envConfig.disableAPI,\n kind: scenario.kind,\n requiresBrowserbase: envConfig.requiresBrowserbase,\n });\n }\n }\n }\n return cases;\n}\n\nexport async function runKeepAliveCase(\n testCase: KeepAliveCase,\n envConfig: {\n apiKey?: string;\n projectId?: string;\n },\n): Promise<void> {\n let info: ChildInfo | undefined;\n let child: ReturnType<typeof spawn> | undefined;\n let logs: ChildLogs | undefined;\n try {\n ({ info, child, logs } = await runScenario({\n env: testCase.env,\n keepAlive: testCase.keepAlive,\n disableAPI: testCase.disableAPI,\n kind: testCase.kind,\n debug: DEBUG,\n viewMs: VIEW_MS,\n apiKey: envConfig.apiKey,\n projectId: envConfig.projectId,\n }));\n } catch (error) {\n logCaseResult(\n testCase.title,\n testCase.envLabel,\n testCase.keepAlive,\n undefined,\n error as Error,\n );\n throw error;\n }\n\n if (testCase.kind === \"sigterm\") {\n child.kill(\"SIGTERM\");\n } else if (testCase.kind === \"sigint\") {\n child.kill(\"SIGINT\");\n }\n\n let outcome: Outcome | undefined;\n let failure: Error | undefined;\n try {\n if (\n testCase.kind === \"close\" ||\n testCase.kind === \"unhandled\" ||\n testCase.kind === \"sigterm\" ||\n testCase.kind === \"sigint\"\n ) {\n await waitForChildExit(child, ACTION_EXIT_TIMEOUT_MS);\n }\n outcome = await assertBrowserState(\n testCase.env,\n info,\n testCase.keepAlive,\n envConfig.apiKey,\n envConfig.projectId,\n );\n } catch (error) {\n failure = error as Error;\n if (logs) {\n dumpLogs(logs);\n }\n throw error;\n } finally {\n logCaseResult(\n testCase.title,\n testCase.envLabel,\n testCase.keepAlive,\n outcome,\n failure,\n );\n await stopChild(child);\n if (testCase.env === \"LOCAL\" && info.connectURL) {\n await closeLocalBrowser(info.connectURL);\n }\n if (testCase.env === \"BROWSERBASE\" && info.sessionId) {\n await endBrowserbaseSession(\n info.sessionId,\n envConfig.apiKey,\n envConfig.projectId,\n );\n }\n }\n}\n\ntest.describe.parallel(\"keepAlive behavior\", () => {\n const { testEnv, apiKey, projectId, hasBrowserbaseCreds } =\n getKeepAliveEnvConfig();\n const cases = buildKeepAliveCases(testEnv);\n\n for (const testCase of cases) {\n test(testCase.title, async () => {\n if (testCase.requiresBrowserbase) {\n test.skip(!hasBrowserbaseCreds, \"Browserbase credentials required\");\n }\n\n await runKeepAliveCase(testCase, { apiKey, projectId });\n });\n }\n});\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|