@testdriverai/agent 7.8.0-canary.10
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/.claude/settings.local.json +7 -0
- package/.env.example +4 -0
- package/.prettierignore +4 -0
- package/.prettierrc +1 -0
- package/CHANGELOG.md +953 -0
- package/README.md +81 -0
- package/agent/events.js +135 -0
- package/agent/index.js +2450 -0
- package/agent/interface.js +35 -0
- package/agent/lib/analytics.js +22 -0
- package/agent/lib/censorship.js +75 -0
- package/agent/lib/commander.js +246 -0
- package/agent/lib/commands.js +1684 -0
- package/agent/lib/config.js +60 -0
- package/agent/lib/generator.js +91 -0
- package/agent/lib/http.js +144 -0
- package/agent/lib/logger.js +56 -0
- package/agent/lib/outputs.js +29 -0
- package/agent/lib/parser.js +209 -0
- package/agent/lib/redraw.js +386 -0
- package/agent/lib/resources/cursor-2.png +0 -0
- package/agent/lib/sandbox.js +1104 -0
- package/agent/lib/sdk.js +633 -0
- package/agent/lib/session.js +25 -0
- package/agent/lib/source-mapper.js +342 -0
- package/agent/lib/subimage/index.js +77 -0
- package/agent/lib/subimage/opencv.js +69 -0
- package/agent/lib/system.js +204 -0
- package/agent/lib/theme.js +14 -0
- package/agent/lib/valid-version.js +21 -0
- package/agent/lib/validation.js +169 -0
- package/ai/.claude-plugin/plugin.json +9 -0
- package/ai/agents/testdriver.md +638 -0
- package/ai/skills/testdriver-ai/SKILL.md +204 -0
- package/ai/skills/testdriver-assert/SKILL.md +315 -0
- package/ai/skills/testdriver-aws-setup/SKILL.md +448 -0
- package/ai/skills/testdriver-cache/SKILL.md +221 -0
- package/ai/skills/testdriver-caching/SKILL.md +124 -0
- package/ai/skills/testdriver-captcha/SKILL.md +158 -0
- package/ai/skills/testdriver-ci-cd/SKILL.md +602 -0
- package/ai/skills/testdriver-click/SKILL.md +286 -0
- package/ai/skills/testdriver-client/SKILL.md +477 -0
- package/ai/skills/testdriver-cloud/SKILL.md +119 -0
- package/ai/skills/testdriver-customizing-devices/SKILL.md +319 -0
- package/ai/skills/testdriver-dashcam/SKILL.md +418 -0
- package/ai/skills/testdriver-debugging-with-screenshots/SKILL.md +401 -0
- package/ai/skills/testdriver-device-config/SKILL.md +317 -0
- package/ai/skills/testdriver-double-click/SKILL.md +102 -0
- package/ai/skills/testdriver-elements/SKILL.md +605 -0
- package/ai/skills/testdriver-enterprise/SKILL.md +114 -0
- package/ai/skills/testdriver-errors/SKILL.md +246 -0
- package/ai/skills/testdriver-events/SKILL.md +356 -0
- package/ai/skills/testdriver-examples/SKILL.md +7 -0
- package/ai/skills/testdriver-exec/SKILL.md +317 -0
- package/ai/skills/testdriver-find/SKILL.md +829 -0
- package/ai/skills/testdriver-focus-application/SKILL.md +293 -0
- package/ai/skills/testdriver-generating-tests/SKILL.md +36 -0
- package/ai/skills/testdriver-hover/SKILL.md +278 -0
- package/ai/skills/testdriver-locating-elements/SKILL.md +71 -0
- package/ai/skills/testdriver-making-assertions/SKILL.md +32 -0
- package/ai/skills/testdriver-mcp/SKILL.md +7 -0
- package/ai/skills/testdriver-mcp-workflow/SKILL.md +410 -0
- package/ai/skills/testdriver-mouse-down/SKILL.md +161 -0
- package/ai/skills/testdriver-mouse-up/SKILL.md +164 -0
- package/ai/skills/testdriver-parse/SKILL.md +236 -0
- package/ai/skills/testdriver-performing-actions/SKILL.md +54 -0
- package/ai/skills/testdriver-press-keys/SKILL.md +348 -0
- package/ai/skills/testdriver-provision/SKILL.md +331 -0
- package/ai/skills/testdriver-quickstart/SKILL.md +144 -0
- package/ai/skills/testdriver-redraw/SKILL.md +214 -0
- package/ai/skills/testdriver-reusable-code/SKILL.md +249 -0
- package/ai/skills/testdriver-right-click/SKILL.md +123 -0
- package/ai/skills/testdriver-running-tests/SKILL.md +185 -0
- package/ai/skills/testdriver-screenshot/SKILL.md +248 -0
- package/ai/skills/testdriver-screenshots/SKILL.md +184 -0
- package/ai/skills/testdriver-scroll/SKILL.md +335 -0
- package/ai/skills/testdriver-secrets/SKILL.md +115 -0
- package/ai/skills/testdriver-self-hosted/SKILL.md +65 -0
- package/ai/skills/testdriver-test-writer/SKILL.md +448 -0
- package/ai/skills/testdriver-testdriver/SKILL.md +628 -0
- package/ai/skills/testdriver-testdriver-mechanic/SKILL.md +165 -0
- package/ai/skills/testdriver-type/SKILL.md +357 -0
- package/ai/skills/testdriver-variables/SKILL.md +111 -0
- package/ai/skills/testdriver-wait/SKILL.md +50 -0
- package/ai/skills/testdriver-waiting-for-elements/SKILL.md +90 -0
- package/ai/skills/testdriver-what-is-testdriver/SKILL.md +54 -0
- package/bin/testdriverai.js +22 -0
- package/debugger/bg.png +0 -0
- package/debugger/icon.png +0 -0
- package/debugger/index.html +469 -0
- package/debugger/td.png +0 -0
- package/debugger/tray-buffered.png +0 -0
- package/debugger/tray.png +0 -0
- package/docs/GITHUB_COMMENTS.md +330 -0
- package/docs/GITHUB_COMMENTS_ANNOUNCEMENT.md +167 -0
- package/docs/QUICK-START-GITHUB-COMMENTS.md +84 -0
- package/docs/TEST-GITHUB-COMMENTS.md +129 -0
- package/docs/_data/examples-manifest.json +177 -0
- package/docs/_data/examples-manifest.schema.json +41 -0
- package/docs/_scripts/extract-example-urls.js +165 -0
- package/docs/_scripts/generate-examples.js +560 -0
- package/docs/_scripts/generate-skills.js +154 -0
- package/docs/_scripts/link-replacer.js +164 -0
- package/docs/_scripts/upload-docs-to-openai.js +284 -0
- package/docs/changelog.mdx +161 -0
- package/docs/claude-mcp-plugin.mdx +160 -0
- package/docs/docs.json +442 -0
- package/docs/github-integration-setup.md +266 -0
- package/docs/guide/best-practices-polling.mdx +174 -0
- package/docs/images/content/account/newprojectsettings.png +0 -0
- package/docs/images/content/account/projectpage.png +0 -0
- package/docs/images/content/account/projectreplays.png +0 -0
- package/docs/images/content/account/team-manage.png +0 -0
- package/docs/images/content/account/teampage.png +0 -0
- package/docs/images/content/extension/cursor.svg +1 -0
- package/docs/images/content/extension/vscode.svg +57 -0
- package/docs/images/content/extension/windsurf.svg +3 -0
- package/docs/images/content/parse/output.png +0 -0
- package/docs/images/content/self-hosted/launchtemplateid.png +0 -0
- package/docs/images/content/side-by-side.png +0 -0
- package/docs/images/content/vscode/ide-full.png +0 -0
- package/docs/images/content/vscode/running.png +0 -0
- package/docs/images/content/vscode/v7-chat.png +0 -0
- package/docs/images/content/vscode/v7-choose-agent.png +0 -0
- package/docs/images/content/vscode/v7-full.png +0 -0
- package/docs/images/content/vscode/v7-onboarding.png +0 -0
- package/docs/images/content/vscode/vscode-2-assert.png +0 -0
- package/docs/images/content/vscode/vscode-agent-preview.png +0 -0
- package/docs/images/content/vscode/vscode-copilot-ask.png +0 -0
- package/docs/images/content/vscode/vscode-file-creation.png +0 -0
- package/docs/images/content/vscode/vscode-install.png +0 -0
- package/docs/images/content/vscode/vscode-overview.png +0 -0
- package/docs/images/content/vscode/vscode-setup-walkthrough.png +0 -0
- package/docs/images/content/vscode/vscode-stopchat.png +0 -0
- package/docs/images/content/vscode/vscode-stoptest.png +0 -0
- package/docs/images/content/vscode/vscode-tdservice.png +0 -0
- package/docs/images/content/vscode/vscode-test-output.png +0 -0
- package/docs/images/content/vscode/vscode-testhistory.png +0 -0
- package/docs/images/content/vscode/vscode-testpane-runtests.png +0 -0
- package/docs/images/content/vscode/vscode-testpane.png +0 -0
- package/docs/images/template/dark.png +0 -0
- package/docs/images/template/icon.png +0 -0
- package/docs/images/template/light.png +0 -0
- package/docs/snippets/calendar-link.mdx +4 -0
- package/docs/snippets/gitignore-warning.mdx +7 -0
- package/docs/snippets/lifecycle-warning.mdx +6 -0
- package/docs/snippets/test-prereqs.mdx +12 -0
- package/docs/snippets/tests/assert-replay.mdx +7 -0
- package/docs/snippets/tests/assert-yaml.mdx +8 -0
- package/docs/snippets/tests/exec-js-replay.mdx +7 -0
- package/docs/snippets/tests/exec-js-yaml.mdx +32 -0
- package/docs/snippets/tests/exec-shell-replay.mdx +7 -0
- package/docs/snippets/tests/exec-shell-yaml.mdx +15 -0
- package/docs/snippets/tests/hover-image-replay.mdx +7 -0
- package/docs/snippets/tests/hover-image-yaml.mdx +17 -0
- package/docs/snippets/tests/hover-text-replay.mdx +7 -0
- package/docs/snippets/tests/hover-text-with-description-replay.mdx +7 -0
- package/docs/snippets/tests/hover-text-with-description-yaml.mdx +24 -0
- package/docs/snippets/tests/hover-text-yaml.mdx +14 -0
- package/docs/snippets/tests/match-image-replay.mdx +7 -0
- package/docs/snippets/tests/match-image-yaml.mdx +17 -0
- package/docs/snippets/tests/press-keys-replay.mdx +7 -0
- package/docs/snippets/tests/press-keys-yaml.mdx +36 -0
- package/docs/snippets/tests/remember-replay.mdx +7 -0
- package/docs/snippets/tests/remember-yaml.mdx +28 -0
- package/docs/snippets/tests/scroll-replay.mdx +7 -0
- package/docs/snippets/tests/scroll-until-image-replay.mdx +7 -0
- package/docs/snippets/tests/scroll-until-image-yaml.mdx +14 -0
- package/docs/snippets/tests/scroll-until-text-replay.mdx +7 -0
- package/docs/snippets/tests/scroll-until-text-yaml.mdx +17 -0
- package/docs/snippets/tests/scroll-yaml.mdx +30 -0
- package/docs/snippets/tests/type-repeated-replay.mdx +7 -0
- package/docs/snippets/tests/type-repeated-yaml.mdx +22 -0
- package/docs/snippets/tests/type-replay.mdx +7 -0
- package/docs/snippets/tests/type-yaml.mdx +28 -0
- package/docs/snippets/tests/wait-for-image-replay.mdx +7 -0
- package/docs/snippets/tests/wait-for-image-yaml.mdx +18 -0
- package/docs/snippets/tests/wait-for-text-replay.mdx +7 -0
- package/docs/snippets/tests/wait-for-text-yaml.mdx +18 -0
- package/docs/snippets/tests/wait-replay.mdx +7 -0
- package/docs/snippets/tests/wait-yaml.mdx +13 -0
- package/docs/styles.css +65 -0
- package/docs/v6/account/dashboard.mdx +16 -0
- package/docs/v6/account/enterprise.mdx +110 -0
- package/docs/v6/account/pricing.mdx +33 -0
- package/docs/v6/account/projects.mdx +33 -0
- package/docs/v6/account/team.mdx +35 -0
- package/docs/v6/action/ami.mdx +109 -0
- package/docs/v6/action/performance.mdx +105 -0
- package/docs/v6/action/secrets.mdx +93 -0
- package/docs/v6/apps/chrome-extensions.mdx +48 -0
- package/docs/v6/apps/desktop-apps.mdx +93 -0
- package/docs/v6/apps/mobile-apps.mdx +26 -0
- package/docs/v6/apps/static-websites.mdx +54 -0
- package/docs/v6/apps/tauri-apps.mdx +361 -0
- package/docs/v6/bugs/jira.mdx +232 -0
- package/docs/v6/cli/overview.mdx +66 -0
- package/docs/v6/commands/assert.mdx +45 -0
- package/docs/v6/commands/exec.mdx +276 -0
- package/docs/v6/commands/focus-application.mdx +44 -0
- package/docs/v6/commands/hover-image.mdx +69 -0
- package/docs/v6/commands/hover-text.mdx +47 -0
- package/docs/v6/commands/if.mdx +53 -0
- package/docs/v6/commands/match-image.mdx +67 -0
- package/docs/v6/commands/press-keys.mdx +87 -0
- package/docs/v6/commands/remember.mdx +49 -0
- package/docs/v6/commands/run.mdx +44 -0
- package/docs/v6/commands/scroll-until-image.mdx +66 -0
- package/docs/v6/commands/scroll-until-text.mdx +60 -0
- package/docs/v6/commands/scroll.mdx +69 -0
- package/docs/v6/commands/type.mdx +45 -0
- package/docs/v6/commands/wait-for-image.mdx +54 -0
- package/docs/v6/commands/wait-for-text.mdx +48 -0
- package/docs/v6/commands/wait.mdx +45 -0
- package/docs/v6/exporting/junit.mdx +218 -0
- package/docs/v6/exporting/playwright.mdx +197 -0
- package/docs/v6/features/auto-healing.mdx +144 -0
- package/docs/v6/features/generation.mdx +116 -0
- package/docs/v6/features/parallel-testing.mdx +151 -0
- package/docs/v6/features/reusable-snippets.mdx +131 -0
- package/docs/v6/features/selectorless.mdx +80 -0
- package/docs/v6/features/visual-assertions.mdx +139 -0
- package/docs/v6/getting-started/ci.mdx +146 -0
- package/docs/v6/getting-started/cli.mdx +91 -0
- package/docs/v6/getting-started/editing.mdx +100 -0
- package/docs/v6/getting-started/playwright.mdx +342 -0
- package/docs/v6/getting-started/running.mdx +48 -0
- package/docs/v6/getting-started/self-hosting.mdx +408 -0
- package/docs/v6/getting-started/vscode.mdx +88 -0
- package/docs/v6/guide/assertions.mdx +189 -0
- package/docs/v6/guide/authentication.mdx +136 -0
- package/docs/v6/guide/code.mdx +65 -0
- package/docs/v6/guide/dashcam.mdx +118 -0
- package/docs/v6/guide/environment-variables.mdx +26 -0
- package/docs/v6/guide/lifecycle.mdx +242 -0
- package/docs/v6/guide/locating.mdx +141 -0
- package/docs/v6/guide/protips.mdx +43 -0
- package/docs/v6/guide/variables.mdx +143 -0
- package/docs/v6/guide/waiting.mdx +130 -0
- package/docs/v6/importing/csv.mdx +196 -0
- package/docs/v6/importing/gherkin.mdx +143 -0
- package/docs/v6/importing/jira.mdx +164 -0
- package/docs/v6/importing/testrail.mdx +162 -0
- package/docs/v6/integrations/electron.mdx +146 -0
- package/docs/v6/integrations/netlify.mdx +100 -0
- package/docs/v6/integrations/vercel.mdx +125 -0
- package/docs/v6/interactive/explore.mdx +99 -0
- package/docs/v6/interactive/run.mdx +52 -0
- package/docs/v6/interactive/save.mdx +63 -0
- package/docs/v6/overview/comparison.mdx +101 -0
- package/docs/v6/overview/faq.mdx +162 -0
- package/docs/v6/overview/performance.mdx +52 -0
- package/docs/v6/overview/quickstart.mdx +137 -0
- package/docs/v6/overview/what-is-testdriver.mdx +85 -0
- package/docs/v6/scenarios/ai-chatbot.mdx +28 -0
- package/docs/v6/scenarios/cookie-banner.mdx +32 -0
- package/docs/v6/scenarios/file-upload.mdx +33 -0
- package/docs/v6/scenarios/form-filling.mdx +32 -0
- package/docs/v6/scenarios/log-in.mdx +75 -0
- package/docs/v6/scenarios/pdf-generation.mdx +25 -0
- package/docs/v6/scenarios/spell-check.mdx +22 -0
- package/docs/v6/security/action.mdx +84 -0
- package/docs/v6/security/agent.mdx +73 -0
- package/docs/v6/security/platform.mdx +77 -0
- package/docs/v6/tutorials/advanced-test.mdx +81 -0
- package/docs/v6/tutorials/basic-test.mdx +45 -0
- package/docs/v7/_drafts/agents.mdx +843 -0
- package/docs/v7/_drafts/architecture.mdx +399 -0
- package/docs/v7/_drafts/auto-cache-key.mdx +167 -0
- package/docs/v7/_drafts/awesome-logs-quick-ref.mdx +100 -0
- package/docs/v7/_drafts/best-practices.mdx +486 -0
- package/docs/v7/_drafts/caching-ai.mdx +215 -0
- package/docs/v7/_drafts/caching-selectors.mdx +424 -0
- package/docs/v7/_drafts/caching.mdx +366 -0
- package/docs/v7/_drafts/cli-to-sdk-migration.mdx +425 -0
- package/docs/v7/_drafts/commands/assert.mdx +45 -0
- package/docs/v7/_drafts/commands/exec.mdx +276 -0
- package/docs/v7/_drafts/commands/focus-application.mdx +44 -0
- package/docs/v7/_drafts/commands/hover-image.mdx +69 -0
- package/docs/v7/_drafts/commands/hover-text.mdx +47 -0
- package/docs/v7/_drafts/commands/if.mdx +53 -0
- package/docs/v7/_drafts/commands/match-image.mdx +67 -0
- package/docs/v7/_drafts/commands/press-keys.mdx +87 -0
- package/docs/v7/_drafts/commands/remember.mdx +49 -0
- package/docs/v7/_drafts/commands/run.mdx +44 -0
- package/docs/v7/_drafts/commands/scroll-until-image.mdx +66 -0
- package/docs/v7/_drafts/commands/scroll-until-text.mdx +60 -0
- package/docs/v7/_drafts/commands/scroll.mdx +69 -0
- package/docs/v7/_drafts/commands/type.mdx +45 -0
- package/docs/v7/_drafts/commands/wait-for-image.mdx +54 -0
- package/docs/v7/_drafts/commands/wait-for-text.mdx +48 -0
- package/docs/v7/_drafts/commands/wait.mdx +45 -0
- package/docs/v7/_drafts/configuration.mdx +378 -0
- package/docs/v7/_drafts/contributing.mdx +174 -0
- package/docs/v7/_drafts/core.mdx +458 -0
- package/docs/v7/_drafts/dashcam-title-feature.mdx +89 -0
- package/docs/v7/_drafts/debugging.mdx +349 -0
- package/docs/v7/_drafts/error-handling.mdx +501 -0
- package/docs/v7/_drafts/faq.mdx +393 -0
- package/docs/v7/_drafts/hooks.mdx +360 -0
- package/docs/v7/_drafts/init-command.mdx +95 -0
- package/docs/v7/_drafts/installation.mdx +420 -0
- package/docs/v7/_drafts/migration.mdx +562 -0
- package/docs/v7/_drafts/observable.mdx +604 -0
- package/docs/v7/_drafts/playwright.mdx +342 -0
- package/docs/v7/_drafts/plugin-migration.mdx +220 -0
- package/docs/v7/_drafts/powerful.mdx +419 -0
- package/docs/v7/_drafts/presets.mdx +210 -0
- package/docs/v7/_drafts/progressive-disclosure.mdx +230 -0
- package/docs/v7/_drafts/prompt-cache.mdx +200 -0
- package/docs/v7/_drafts/provision.mdx +390 -0
- package/docs/v7/_drafts/quick-start-test-recording.mdx +214 -0
- package/docs/v7/_drafts/readme.mdx +135 -0
- package/docs/v7/_drafts/reports.mdx +414 -0
- package/docs/v7/_drafts/scalable.mdx +763 -0
- package/docs/v7/_drafts/screenshot.mdx +155 -0
- package/docs/v7/_drafts/sdk-awesome-logs.mdx +468 -0
- package/docs/v7/_drafts/sdk-browser-rendering.mdx +167 -0
- package/docs/v7/_drafts/sdk-migration.mdx +474 -0
- package/docs/v7/_drafts/sdk-v7-complete.mdx +345 -0
- package/docs/v7/_drafts/self-hosting.mdx +369 -0
- package/docs/v7/_drafts/test-recording.mdx +382 -0
- package/docs/v7/_drafts/troubleshooting.mdx +526 -0
- package/docs/v7/_drafts/vitest-plugin.mdx +477 -0
- package/docs/v7/_drafts/vitest.mdx +535 -0
- package/docs/v7/_drafts/writing-tests.mdx +25 -0
- package/docs/v7/ai.mdx +205 -0
- package/docs/v7/assert.mdx +316 -0
- package/docs/v7/aws-setup.mdx +449 -0
- package/docs/v7/cache.mdx +223 -0
- package/docs/v7/caching.mdx +128 -0
- package/docs/v7/captcha.mdx +159 -0
- package/docs/v7/ci-cd.mdx +603 -0
- package/docs/v7/click.mdx +287 -0
- package/docs/v7/client.mdx +478 -0
- package/docs/v7/copilot/auto-healing.mdx +265 -0
- package/docs/v7/copilot/creating-tests.mdx +156 -0
- package/docs/v7/copilot/github.mdx +143 -0
- package/docs/v7/copilot/running-tests.mdx +149 -0
- package/docs/v7/copilot/setup.mdx +143 -0
- package/docs/v7/customizing-devices.mdx +319 -0
- package/docs/v7/dashcam.mdx +419 -0
- package/docs/v7/debugging-with-screenshots.mdx +402 -0
- package/docs/v7/device-config.mdx +317 -0
- package/docs/v7/double-click.mdx +102 -0
- package/docs/v7/elements.mdx +606 -0
- package/docs/v7/enterprise.mdx +9 -0
- package/docs/v7/errors.mdx +248 -0
- package/docs/v7/events.mdx +358 -0
- package/docs/v7/examples/ai.mdx +72 -0
- package/docs/v7/examples/assert.mdx +72 -0
- package/docs/v7/examples/captcha-api.mdx +92 -0
- package/docs/v7/examples/chrome-extension.mdx +132 -0
- package/docs/v7/examples/drag-and-drop.mdx +100 -0
- package/docs/v7/examples/element-not-found.mdx +67 -0
- package/docs/v7/examples/exec-output.mdx +85 -0
- package/docs/v7/examples/exec-pwsh.mdx +83 -0
- package/docs/v7/examples/focus-window.mdx +62 -0
- package/docs/v7/examples/hover-image.mdx +94 -0
- package/docs/v7/examples/hover-text.mdx +69 -0
- package/docs/v7/examples/installer.mdx +91 -0
- package/docs/v7/examples/launch-vscode-linux.mdx +101 -0
- package/docs/v7/examples/match-image.mdx +96 -0
- package/docs/v7/examples/press-keys.mdx +92 -0
- package/docs/v7/examples/scroll-keyboard.mdx +79 -0
- package/docs/v7/examples/scroll-until-image.mdx +81 -0
- package/docs/v7/examples/scroll-until-text.mdx +109 -0
- package/docs/v7/examples/scroll.mdx +81 -0
- package/docs/v7/examples/type.mdx +92 -0
- package/docs/v7/examples/windows-installer.mdx +89 -0
- package/docs/v7/exec.mdx +318 -0
- package/docs/v7/find.mdx +830 -0
- package/docs/v7/focus-application.mdx +294 -0
- package/docs/v7/generating-tests.mdx +36 -0
- package/docs/v7/hosted.mdx +158 -0
- package/docs/v7/hover.mdx +279 -0
- package/docs/v7/locating-elements.mdx +71 -0
- package/docs/v7/making-assertions.mdx +32 -0
- package/docs/v7/mcp.mdx +9 -0
- package/docs/v7/mouse-down.mdx +161 -0
- package/docs/v7/mouse-up.mdx +164 -0
- package/docs/v7/parse.mdx +237 -0
- package/docs/v7/performing-actions.mdx +54 -0
- package/docs/v7/press-keys.mdx +349 -0
- package/docs/v7/provision.mdx +333 -0
- package/docs/v7/quickstart.mdx +173 -0
- package/docs/v7/redraw.mdx +216 -0
- package/docs/v7/reusable-code.mdx +249 -0
- package/docs/v7/right-click.mdx +123 -0
- package/docs/v7/running-tests.mdx +185 -0
- package/docs/v7/screenshot.mdx +249 -0
- package/docs/v7/screenshots.mdx +186 -0
- package/docs/v7/scroll.mdx +336 -0
- package/docs/v7/secrets.mdx +115 -0
- package/docs/v7/self-hosted.mdx +149 -0
- package/docs/v7/type.mdx +358 -0
- package/docs/v7/variables.mdx +111 -0
- package/docs/v7/wait.mdx +52 -0
- package/docs/v7/waiting-for-elements.mdx +90 -0
- package/docs/v7/what-is-testdriver.mdx +54 -0
- package/eslint.config.js +67 -0
- package/examples/ai.test.mjs +31 -0
- package/examples/assert.test.mjs +47 -0
- package/examples/chrome-extension.test.mjs +97 -0
- package/examples/config.mjs +5 -0
- package/examples/element-not-found.test.mjs +27 -0
- package/examples/exec-output.test.mjs +60 -0
- package/examples/exec-pwsh.test.mjs +58 -0
- package/examples/findall-coffee-icons.test.mjs +42 -0
- package/examples/focus-window.test.mjs +37 -0
- package/examples/formatted-logging.test.mjs +27 -0
- package/examples/hover-image.test.mjs +53 -0
- package/examples/hover-text-with-description.test.mjs +57 -0
- package/examples/hover-text.test.mjs +28 -0
- package/examples/installer.test.mjs +50 -0
- package/examples/launch-vscode-linux.test.mjs +55 -0
- package/examples/match-image.test.mjs +55 -0
- package/examples/parse.test.mjs +19 -0
- package/examples/press-keys.test.mjs +44 -0
- package/examples/prompt.test.mjs +34 -0
- package/examples/scroll-keyboard.test.mjs +38 -0
- package/examples/scroll-until-image.test.mjs +40 -0
- package/examples/scroll.test.mjs +42 -0
- package/examples/type.test.mjs +46 -0
- package/examples/windows-installer.test.mjs +54 -0
- package/index.js +2 -0
- package/interfaces/cli/commands/init.js +438 -0
- package/interfaces/cli/commands/setup.js +382 -0
- package/interfaces/cli/lib/base.js +285 -0
- package/interfaces/cli.js +20 -0
- package/interfaces/junit-reporter.js +290 -0
- package/interfaces/logger.js +388 -0
- package/interfaces/readline.js +234 -0
- package/interfaces/shared-test-state.mjs +64 -0
- package/interfaces/vitest-plugin.d.ts +115 -0
- package/interfaces/vitest-plugin.mjs +1698 -0
- package/lib/captcha/solver.js +358 -0
- package/lib/core/Dashcam.js +533 -0
- package/lib/core/index.d.ts +172 -0
- package/lib/core/index.js +12 -0
- package/lib/environments.json +18 -0
- package/lib/github-comment-formatter.js +263 -0
- package/lib/github-comment.mjs +452 -0
- package/lib/init-project.js +575 -0
- package/lib/presets/index.mjs +331 -0
- package/lib/resolve-channel.js +46 -0
- package/lib/sentry.js +417 -0
- package/lib/vitest/hooks.d.ts +57 -0
- package/lib/vitest/hooks.mjs +674 -0
- package/lib/vitest/setup-aws.mjs +247 -0
- package/lib/vitest/setup-self-hosted.mjs +151 -0
- package/lib/vitest/setup.mjs +46 -0
- package/manual/captcha-api.test.mjs +51 -0
- package/manual/drag-and-drop.test.mjs +59 -0
- package/manual/flake-diffthreshold-001.test.mjs +9 -0
- package/manual/flake-diffthreshold-01.test.mjs +9 -0
- package/manual/flake-diffthreshold-05.test.mjs +9 -0
- package/manual/flake-noredraw-cache.test.mjs +9 -0
- package/manual/flake-noredraw-nocache.test.mjs +9 -0
- package/manual/flake-redraw-cache.test.mjs +9 -0
- package/manual/flake-redraw-nocache.test.mjs +9 -0
- package/manual/flake-rocket-match.test.mjs +30 -0
- package/manual/flake-shared.mjs +51 -0
- package/manual/no-provision.test.mjs +31 -0
- package/manual/packer-hover-image.test.mjs +176 -0
- package/manual/scroll-until-text.test.mjs +68 -0
- package/manual/test-init-command.js +223 -0
- package/mcp-server/README.md +322 -0
- package/mcp-server/dist/codegen.d.ts +9 -0
- package/mcp-server/dist/codegen.js +165 -0
- package/mcp-server/dist/mcp-app.html +114 -0
- package/mcp-server/dist/package.json +1 -0
- package/mcp-server/dist/provision-types.d.ts +290 -0
- package/mcp-server/dist/provision-types.js +174 -0
- package/mcp-server/dist/server.d.ts +6 -0
- package/mcp-server/dist/server.mjs +1925 -0
- package/mcp-server/dist/session.d.ts +85 -0
- package/mcp-server/dist/session.js +152 -0
- package/mcp-server/mcp-app.html +28 -0
- package/mcp-server/mcp-config.example.json +19 -0
- package/mcp-server/package-lock.json +4027 -0
- package/mcp-server/package.json +31 -0
- package/mcp-server/src/codegen.ts +189 -0
- package/mcp-server/src/mcp-app.css +360 -0
- package/mcp-server/src/mcp-app.ts +547 -0
- package/mcp-server/src/provision-types.ts +209 -0
- package/mcp-server/src/server.ts +2391 -0
- package/mcp-server/src/session.ts +194 -0
- package/mcp-server/tsconfig.json +16 -0
- package/mcp-server/vite.config.ts +23 -0
- package/package.json +158 -0
- package/schema.json +1046 -0
- package/scripts/generate-skills.js +94 -0
- package/sdk-log-formatter.js +1157 -0
- package/sdk.d.ts +1486 -0
- package/sdk.js +4336 -0
- package/setup/aws/cloudformation.yaml +463 -0
- package/setup/aws/disable-defender.sh +42 -0
- package/setup/aws/install-dev-runner.sh +79 -0
- package/setup/aws/spawn-runner.sh +289 -0
- package/test/captcha-solver.test.mjs +152 -0
- package/test/chrome-remote-debugging.test.mjs +66 -0
- package/test/duckduckgo/experiment.test.mjs +28 -0
- package/test/duckduckgo/setup.test.mjs +29 -0
- package/test/manual/debug-locate-response.js +82 -0
- package/test/manual/reconnect-provision.test.mjs +49 -0
- package/test/manual/test-console-logs.test.mjs +42 -0
- package/test/manual/test-find-api.js +73 -0
- package/test/manual/test-init.sh +54 -0
- package/test/manual/test-prompt-cache.js +97 -0
- package/test/manual/test-provision-auth.mjs +22 -0
- package/test/manual/test-sandbox-render.js +29 -0
- package/test/manual/test-sdk-methods.js +15 -0
- package/test/manual/test-sdk-refactor.js +53 -0
- package/test/manual/test-stack-trace.mjs +57 -0
- package/test/manual/verify-element-api.js +89 -0
- package/test/manual/verify-types.js +0 -0
- package/test/manual-unawaited-promise.test.mjs +31 -0
- package/vitest.config.mjs +58 -0
- package/vitest.runner.config.mjs +33 -0
- package/vscode-extension/.vscodeignore +12 -0
- package/vscode-extension/README.md +94 -0
- package/vscode-extension/media/icon.png +0 -0
- package/vscode-extension/package-lock.json +4126 -0
- package/vscode-extension/package.json +86 -0
- package/vscode-extension/src/extension.ts +829 -0
- package/vscode-extension/testdriverai-0.1.0.vsix +0 -0
- package/vscode-extension/tsconfig.json +16 -0
|
@@ -0,0 +1,333 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "Provision"
|
|
3
|
+
sidebarTitle: "Provision"
|
|
4
|
+
description: "Launch browsers, desktop apps, and extensions in your sandbox"
|
|
5
|
+
icon: "rocket"
|
|
6
|
+
mode: "wide"
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
## Overview
|
|
10
|
+
|
|
11
|
+
The Provision API sets up applications in your sandbox before tests run. It handles downloading, installing, and launching browsers, desktop apps, VS Code, Chrome extensions, and more.
|
|
12
|
+
|
|
13
|
+
Access provision methods via `testdriver.provision.*`:
|
|
14
|
+
|
|
15
|
+
```javascript
|
|
16
|
+
await testdriver.provision.chrome({ url: 'https://example.com' });
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
<Note>
|
|
20
|
+
When `reconnect: true` is set on the client, **all provision methods are skipped** since the application is assumed to already be running.
|
|
21
|
+
</Note>
|
|
22
|
+
|
|
23
|
+
## Methods
|
|
24
|
+
|
|
25
|
+
### chrome()
|
|
26
|
+
|
|
27
|
+
Launch Google Chrome with an optional URL.
|
|
28
|
+
|
|
29
|
+
```javascript
|
|
30
|
+
await testdriver.provision.chrome(options?)
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
<ParamField path="options" type="ProvisionChromeOptions">
|
|
34
|
+
<Expandable title="properties">
|
|
35
|
+
<ParamField path="url" type="string" default="http://testdriver-sandbox.vercel.app/">
|
|
36
|
+
URL to navigate to after launch.
|
|
37
|
+
</ParamField>
|
|
38
|
+
|
|
39
|
+
<ParamField path="maximized" type="boolean" default={true}>
|
|
40
|
+
Launch Chrome in maximized window mode.
|
|
41
|
+
</ParamField>
|
|
42
|
+
|
|
43
|
+
<ParamField path="guest" type="boolean" default={false}>
|
|
44
|
+
Launch Chrome in guest profile mode.
|
|
45
|
+
</ParamField>
|
|
46
|
+
</Expandable>
|
|
47
|
+
</ParamField>
|
|
48
|
+
|
|
49
|
+
```javascript
|
|
50
|
+
// Basic
|
|
51
|
+
await testdriver.provision.chrome({ url: 'https://example.com' });
|
|
52
|
+
|
|
53
|
+
// With guest mode
|
|
54
|
+
await testdriver.provision.chrome({
|
|
55
|
+
url: 'https://example.com',
|
|
56
|
+
guest: true,
|
|
57
|
+
maximized: true,
|
|
58
|
+
});
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
### chromeExtension()
|
|
62
|
+
|
|
63
|
+
Install and launch a Chrome extension. You can install from a local unpacked directory or from the Chrome Web Store by extension ID.
|
|
64
|
+
|
|
65
|
+
```javascript
|
|
66
|
+
await testdriver.provision.chromeExtension(options)
|
|
67
|
+
```
|
|
68
|
+
|
|
69
|
+
<ParamField path="options" type="ProvisionChromeExtensionOptions" required>
|
|
70
|
+
One of `extensionPath` or `extensionId` is required.
|
|
71
|
+
|
|
72
|
+
<Expandable title="properties">
|
|
73
|
+
<ParamField path="extensionPath" type="string">
|
|
74
|
+
Local path to an unpacked extension directory. The extension files are uploaded to the sandbox.
|
|
75
|
+
</ParamField>
|
|
76
|
+
|
|
77
|
+
<ParamField path="extensionId" type="string">
|
|
78
|
+
Chrome Web Store extension ID to install.
|
|
79
|
+
</ParamField>
|
|
80
|
+
|
|
81
|
+
<ParamField path="maximized" type="boolean" default={true}>
|
|
82
|
+
Launch Chrome in maximized window mode.
|
|
83
|
+
</ParamField>
|
|
84
|
+
</Expandable>
|
|
85
|
+
</ParamField>
|
|
86
|
+
|
|
87
|
+
```javascript
|
|
88
|
+
// From local directory
|
|
89
|
+
await testdriver.provision.chromeExtension({
|
|
90
|
+
extensionPath: './my-extension',
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
// From Chrome Web Store
|
|
94
|
+
await testdriver.provision.chromeExtension({
|
|
95
|
+
extensionId: 'abcdefghijklmnop',
|
|
96
|
+
});
|
|
97
|
+
```
|
|
98
|
+
|
|
99
|
+
### vscode()
|
|
100
|
+
|
|
101
|
+
Launch Visual Studio Code with an optional workspace and extensions.
|
|
102
|
+
|
|
103
|
+
```javascript
|
|
104
|
+
await testdriver.provision.vscode(options?)
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
<ParamField path="options" type="ProvisionVSCodeOptions">
|
|
108
|
+
<Expandable title="properties">
|
|
109
|
+
<ParamField path="workspace" type="string">
|
|
110
|
+
Path to a workspace folder or `.code-workspace` file to open.
|
|
111
|
+
</ParamField>
|
|
112
|
+
|
|
113
|
+
<ParamField path="extensions" type="string[]" default={[]}>
|
|
114
|
+
Array of VS Code extension IDs to install before launching.
|
|
115
|
+
</ParamField>
|
|
116
|
+
</Expandable>
|
|
117
|
+
</ParamField>
|
|
118
|
+
|
|
119
|
+
```javascript
|
|
120
|
+
await testdriver.provision.vscode({
|
|
121
|
+
workspace: '/home/testdriver/project',
|
|
122
|
+
extensions: ['ms-python.python', 'esbenp.prettier-vscode'],
|
|
123
|
+
});
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
### installer()
|
|
127
|
+
|
|
128
|
+
Download and run an application installer. Supports `.msi`, `.exe`, `.deb`, `.rpm`, `.appimage`, `.sh`, `.dmg`, and `.pkg` formats.
|
|
129
|
+
|
|
130
|
+
```javascript
|
|
131
|
+
await testdriver.provision.installer(options)
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
<ParamField path="options" type="ProvisionInstallerOptions" required>
|
|
135
|
+
<Expandable title="properties">
|
|
136
|
+
<ParamField path="url" type="string" required>
|
|
137
|
+
Download URL for the installer.
|
|
138
|
+
</ParamField>
|
|
139
|
+
|
|
140
|
+
<ParamField path="filename" type="string">
|
|
141
|
+
Override the auto-detected filename from the URL.
|
|
142
|
+
</ParamField>
|
|
143
|
+
|
|
144
|
+
<ParamField path="appName" type="string">
|
|
145
|
+
Application name to focus after installation completes.
|
|
146
|
+
</ParamField>
|
|
147
|
+
|
|
148
|
+
<ParamField path="launch" type="boolean" default={true}>
|
|
149
|
+
Whether to focus/launch the app after installation.
|
|
150
|
+
</ParamField>
|
|
151
|
+
</Expandable>
|
|
152
|
+
</ParamField>
|
|
153
|
+
|
|
154
|
+
**Behavior:**
|
|
155
|
+
- Downloads the installer from the URL
|
|
156
|
+
- Auto-detects the install method based on file extension
|
|
157
|
+
- Runs the appropriate install command (e.g., `msiexec` for `.msi`, `dpkg` for `.deb`)
|
|
158
|
+
- Optionally focuses the installed application
|
|
159
|
+
|
|
160
|
+
```javascript
|
|
161
|
+
// Windows MSI installer
|
|
162
|
+
await testdriver.provision.installer({
|
|
163
|
+
url: 'https://example.com/app-setup.msi',
|
|
164
|
+
appName: 'MyApp',
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
// Linux DEB package
|
|
168
|
+
await testdriver.provision.installer({
|
|
169
|
+
url: 'https://example.com/app.deb',
|
|
170
|
+
appName: 'MyApp',
|
|
171
|
+
launch: true,
|
|
172
|
+
});
|
|
173
|
+
```
|
|
174
|
+
|
|
175
|
+
### electron()
|
|
176
|
+
|
|
177
|
+
Launch an Electron application.
|
|
178
|
+
|
|
179
|
+
```javascript
|
|
180
|
+
await testdriver.provision.electron(options)
|
|
181
|
+
```
|
|
182
|
+
|
|
183
|
+
<ParamField path="options" type="ProvisionElectronOptions" required>
|
|
184
|
+
<Expandable title="properties">
|
|
185
|
+
<ParamField path="appPath" type="string" required>
|
|
186
|
+
Path to the Electron application directory or executable.
|
|
187
|
+
</ParamField>
|
|
188
|
+
|
|
189
|
+
<ParamField path="args" type="string[]" default={[]}>
|
|
190
|
+
Additional command-line arguments to pass to the Electron app.
|
|
191
|
+
</ParamField>
|
|
192
|
+
</Expandable>
|
|
193
|
+
</ParamField>
|
|
194
|
+
|
|
195
|
+
```javascript
|
|
196
|
+
await testdriver.provision.electron({
|
|
197
|
+
appPath: '/home/testdriver/my-electron-app',
|
|
198
|
+
args: ['--no-sandbox'],
|
|
199
|
+
});
|
|
200
|
+
```
|
|
201
|
+
|
|
202
|
+
### dashcam()
|
|
203
|
+
|
|
204
|
+
Start Dashcam recording with custom options. Usually called automatically by other provision methods, but can be called directly for custom configurations.
|
|
205
|
+
|
|
206
|
+
```javascript
|
|
207
|
+
await testdriver.provision.dashcam(options?)
|
|
208
|
+
```
|
|
209
|
+
|
|
210
|
+
<ParamField path="options" type="ProvisionDashcamOptions">
|
|
211
|
+
<Expandable title="properties">
|
|
212
|
+
<ParamField path="logPath" type="string">
|
|
213
|
+
Path to the TestDriver log file. Defaults to `/tmp/testdriver.log` (Linux) or `C:\Users\testdriver\testdriver.log` (Windows).
|
|
214
|
+
</ParamField>
|
|
215
|
+
|
|
216
|
+
<ParamField path="logName" type="string" default="TestDriver Log">
|
|
217
|
+
Display name for the log file in the Dashcam replay.
|
|
218
|
+
</ParamField>
|
|
219
|
+
|
|
220
|
+
<ParamField path="webLogs" type="boolean" default={true}>
|
|
221
|
+
Enable web traffic log capture.
|
|
222
|
+
</ParamField>
|
|
223
|
+
|
|
224
|
+
<ParamField path="title" type="string">
|
|
225
|
+
Recording title for the Dashcam session.
|
|
226
|
+
</ParamField>
|
|
227
|
+
</Expandable>
|
|
228
|
+
</ParamField>
|
|
229
|
+
|
|
230
|
+
```javascript
|
|
231
|
+
await testdriver.provision.dashcam({
|
|
232
|
+
title: 'Login Flow Test',
|
|
233
|
+
logPath: '/tmp/my-app.log',
|
|
234
|
+
logName: 'Application Log',
|
|
235
|
+
webLogs: true,
|
|
236
|
+
});
|
|
237
|
+
```
|
|
238
|
+
|
|
239
|
+
## Reconnect Behavior
|
|
240
|
+
|
|
241
|
+
When `reconnect: true` is set on the client, all provision methods are wrapped in a Proxy that intercepts calls and skips them silently. This is because when reconnecting to an existing sandbox, the applications are already running.
|
|
242
|
+
|
|
243
|
+
```javascript
|
|
244
|
+
const testdriver = new TestDriver({
|
|
245
|
+
reconnect: true,
|
|
246
|
+
});
|
|
247
|
+
|
|
248
|
+
await testdriver.ready();
|
|
249
|
+
|
|
250
|
+
// These calls are silently skipped:
|
|
251
|
+
await testdriver.provision.chrome({ url: 'https://example.com' });
|
|
252
|
+
await testdriver.provision.dashcam();
|
|
253
|
+
```
|
|
254
|
+
|
|
255
|
+
## Types
|
|
256
|
+
|
|
257
|
+
```typescript
|
|
258
|
+
interface ProvisionChromeOptions {
|
|
259
|
+
url?: string; // Default: "http://testdriver-sandbox.vercel.app/"
|
|
260
|
+
maximized?: boolean; // Default: true
|
|
261
|
+
guest?: boolean; // Default: false
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
interface ProvisionChromeExtensionOptions {
|
|
265
|
+
extensionPath?: string; // Local unpacked extension path
|
|
266
|
+
extensionId?: string; // Chrome Web Store ID
|
|
267
|
+
maximized?: boolean; // Default: true
|
|
268
|
+
}
|
|
269
|
+
|
|
270
|
+
interface ProvisionVSCodeOptions {
|
|
271
|
+
workspace?: string; // Workspace path
|
|
272
|
+
extensions?: string[]; // Extension IDs to install
|
|
273
|
+
}
|
|
274
|
+
|
|
275
|
+
interface ProvisionInstallerOptions {
|
|
276
|
+
url: string; // Download URL (required)
|
|
277
|
+
filename?: string; // Override filename
|
|
278
|
+
appName?: string; // App name to focus
|
|
279
|
+
launch?: boolean; // Default: true
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
interface ProvisionElectronOptions {
|
|
283
|
+
appPath: string; // Path to Electron app (required)
|
|
284
|
+
args?: string[]; // Additional args
|
|
285
|
+
}
|
|
286
|
+
|
|
287
|
+
interface ProvisionDashcamOptions {
|
|
288
|
+
logPath?: string; // Log file path
|
|
289
|
+
logName?: string; // Default: "TestDriver Log"
|
|
290
|
+
webLogs?: boolean; // Default: true
|
|
291
|
+
title?: string; // Recording title
|
|
292
|
+
}
|
|
293
|
+
```
|
|
294
|
+
|
|
295
|
+
## Complete Example
|
|
296
|
+
|
|
297
|
+
```javascript
|
|
298
|
+
import { describe, it, beforeAll, afterAll } from 'vitest';
|
|
299
|
+
import TestDriver from 'testdriverai';
|
|
300
|
+
|
|
301
|
+
describe('Chrome Extension Test', () => {
|
|
302
|
+
let testdriver;
|
|
303
|
+
|
|
304
|
+
beforeAll(async () => {
|
|
305
|
+
testdriver = new TestDriver({
|
|
306
|
+
os: 'linux',
|
|
307
|
+
resolution: '1920x1080',
|
|
308
|
+
});
|
|
309
|
+
|
|
310
|
+
await testdriver.ready();
|
|
311
|
+
|
|
312
|
+
// Install extension and open Chrome
|
|
313
|
+
await testdriver.provision.chromeExtension({
|
|
314
|
+
extensionPath: './my-extension',
|
|
315
|
+
});
|
|
316
|
+
|
|
317
|
+
// Start Dashcam with custom logs
|
|
318
|
+
await testdriver.provision.dashcam({
|
|
319
|
+
title: 'Extension Test',
|
|
320
|
+
webLogs: true,
|
|
321
|
+
});
|
|
322
|
+
});
|
|
323
|
+
|
|
324
|
+
afterAll(async () => {
|
|
325
|
+
await testdriver.disconnect();
|
|
326
|
+
});
|
|
327
|
+
|
|
328
|
+
it('tests the extension popup', async () => {
|
|
329
|
+
await testdriver.find('extension icon').click();
|
|
330
|
+
await testdriver.find('popup content').click();
|
|
331
|
+
});
|
|
332
|
+
});
|
|
333
|
+
```
|
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "Quick Start"
|
|
3
|
+
sidebarTitle: "Quickstart"
|
|
4
|
+
description: "Run your first computer-use test in minutes."
|
|
5
|
+
icon: "rocket"
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
TestDriver makes it easy to write automated computer-use tests for web browsers, desktop apps, and more. Follow the directions below to run your first TestDriver test.
|
|
9
|
+
|
|
10
|
+
<Tip><a href="https://discord.com/invite/cWDFW8DzPm" target="_blank" rel="noreferrer">Join our Discord</a> if you have any questions or need help getting started!</Tip>
|
|
11
|
+
|
|
12
|
+
<Tabs>
|
|
13
|
+
<Tab title="CLI" icon="terminal">
|
|
14
|
+
|
|
15
|
+
Get started quickly with the TestDriver CLI.
|
|
16
|
+
|
|
17
|
+
<Steps>
|
|
18
|
+
<Step title="Install TestDriver">
|
|
19
|
+
|
|
20
|
+
Use `npx` to quickly set up an example project:
|
|
21
|
+
|
|
22
|
+
```bash
|
|
23
|
+
npx testdriverai init
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
This will walk you through creating a new project folder, installing dependencies, setting up your API key, and configuring MCP for your preferred AI assistant (VS Code, Cursor, Claude Desktop, etc.).
|
|
27
|
+
|
|
28
|
+
</Step>
|
|
29
|
+
|
|
30
|
+
<Step title="Run Your Test">
|
|
31
|
+
|
|
32
|
+
TestDriver uses Vitest as the test runner. To run your test, use:
|
|
33
|
+
|
|
34
|
+
```bash
|
|
35
|
+
vitest run
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
This will spawn a sandbox, launch Chrome, and run the example test!
|
|
39
|
+
|
|
40
|
+
</Step>
|
|
41
|
+
</Steps>
|
|
42
|
+
</Tab>
|
|
43
|
+
<Tab title="GitHub Copilot" icon="github">
|
|
44
|
+
|
|
45
|
+
Use the TestDriver VS Code extension with GitHub Copilot for an AI-powered testing workflow.
|
|
46
|
+
|
|
47
|
+
<Card
|
|
48
|
+
title="Install TestDriver for VS Code"
|
|
49
|
+
icon="/images/content/extension/vscode.svg"
|
|
50
|
+
href="vscode:extension/testdriver.testdriver"
|
|
51
|
+
arrow
|
|
52
|
+
horizontal
|
|
53
|
+
>
|
|
54
|
+
</Card>
|
|
55
|
+
|
|
56
|
+
The extension provides one-click sign-in, project initialization, a live preview panel for watching tests execute, and MCP server configuration for GitHub Copilot.
|
|
57
|
+
|
|
58
|
+
Once installed, follow the full setup guide to configure MCP and start building tests with AI assistance:
|
|
59
|
+
|
|
60
|
+
<Card
|
|
61
|
+
title="VS Code + Copilot Setup Guide"
|
|
62
|
+
icon="arrow-right"
|
|
63
|
+
href="/v7/copilot/setup"
|
|
64
|
+
arrow
|
|
65
|
+
horizontal
|
|
66
|
+
>
|
|
67
|
+
Sign in, initialize your project, and configure MCP for GitHub Copilot.
|
|
68
|
+
</Card>
|
|
69
|
+
|
|
70
|
+
</Tab>
|
|
71
|
+
<Tab title="Manual" icon="wrench">
|
|
72
|
+
|
|
73
|
+
Install TestDriver and manually create the files yourself.
|
|
74
|
+
|
|
75
|
+
<Steps>
|
|
76
|
+
<Step title="Create a TestDriver Account">
|
|
77
|
+
|
|
78
|
+
You will need a TestDriver account to get an API key.
|
|
79
|
+
|
|
80
|
+
<Card
|
|
81
|
+
title="Get an API Key"
|
|
82
|
+
icon="user-plus"
|
|
83
|
+
href="https://console.testdriver.ai/team"
|
|
84
|
+
arrow
|
|
85
|
+
horizontal
|
|
86
|
+
>
|
|
87
|
+
Start with 60 free device minutes, no credit-card required!
|
|
88
|
+
</Card>
|
|
89
|
+
|
|
90
|
+
</Step>
|
|
91
|
+
<Step title="Install Dependencies">
|
|
92
|
+
|
|
93
|
+
Install Vitest and TestDriver as dev dependencies:
|
|
94
|
+
|
|
95
|
+
```bash
|
|
96
|
+
npm install --save-dev vitest testdriverai
|
|
97
|
+
```
|
|
98
|
+
|
|
99
|
+
</Step>
|
|
100
|
+
<Step title="Create a vitest.config.js File">
|
|
101
|
+
|
|
102
|
+
In your project root, create a `vitest.config.js` file with the following content:
|
|
103
|
+
|
|
104
|
+
```js vitest.config.js
|
|
105
|
+
import TestDriver from 'testdriverai/vitest';
|
|
106
|
+
import { defineConfig } from 'vitest/config';
|
|
107
|
+
|
|
108
|
+
export default defineConfig({
|
|
109
|
+
test: {
|
|
110
|
+
testTimeout: 900000,
|
|
111
|
+
hookTimeout: 900000,
|
|
112
|
+
reporters: [
|
|
113
|
+
'default',
|
|
114
|
+
TestDriver()
|
|
115
|
+
],
|
|
116
|
+
setupFiles: ['testdriverai/vitest/setup'],
|
|
117
|
+
},
|
|
118
|
+
});
|
|
119
|
+
```
|
|
120
|
+
|
|
121
|
+
</Step>
|
|
122
|
+
<Step title="Create an Example Test File">
|
|
123
|
+
|
|
124
|
+
Add your API key to the example test file below and save it as `test.mjs` in your project root.
|
|
125
|
+
|
|
126
|
+
```js test.mjs highlight={9}
|
|
127
|
+
import { describe, expect, it } from "vitest";
|
|
128
|
+
// Import TestDriver from the vitest hooks
|
|
129
|
+
import { TestDriver } from "testdriverai/vitest/hooks";
|
|
130
|
+
|
|
131
|
+
describe("Google Search Example", () => {
|
|
132
|
+
it("should search for TestDriver", async (context) => {
|
|
133
|
+
// Create TestDriver instance - automatically connects to sandbox
|
|
134
|
+
const testdriver = TestDriver(context, {
|
|
135
|
+
apiKey: 'YOUR_API_KEY_HERE' // supply your API key here
|
|
136
|
+
});
|
|
137
|
+
|
|
138
|
+
// Provision Chrome browser with a URL
|
|
139
|
+
// This also starts dashcam recording automatically
|
|
140
|
+
await testdriver.provision.chrome({ url: "https://duckduckgo.com" });
|
|
141
|
+
|
|
142
|
+
// Find and interact with elements using natural language
|
|
143
|
+
const searchBox = await testdriver.find("DuckDuckGo search input field");
|
|
144
|
+
await searchBox.click();
|
|
145
|
+
|
|
146
|
+
// Type into the focused element
|
|
147
|
+
await testdriver.type("testdriver.ai");
|
|
148
|
+
|
|
149
|
+
// Press Enter to search
|
|
150
|
+
await testdriver.pressKeys(["enter"]);
|
|
151
|
+
|
|
152
|
+
// Assert something is visible on the page
|
|
153
|
+
const result = await testdriver.assert("search results are displayed");
|
|
154
|
+
expect(result).toBeTruthy();
|
|
155
|
+
});
|
|
156
|
+
});
|
|
157
|
+
```
|
|
158
|
+
|
|
159
|
+
</Step>
|
|
160
|
+
<Step title="Run Your Test">
|
|
161
|
+
|
|
162
|
+
TestDriver uses Vitest as the test runner. To run your test, use:
|
|
163
|
+
|
|
164
|
+
```bash
|
|
165
|
+
vitest run
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
This will spawn a sandbox, launch Chrome, and run the example test!
|
|
169
|
+
|
|
170
|
+
</Step>
|
|
171
|
+
</Steps>
|
|
172
|
+
</Tab>
|
|
173
|
+
</Tabs>
|