运行和调试测试
简介
使用 Playwright,您可以运行单个测试、一组测试或所有测试。测试可以在一个或多个浏览器上运行,通过使用 --project
标志。默认情况下,测试并行运行,并以无头模式运行,这意味着在运行测试时不会打开浏览器窗口,结果将在终端中看到。但是,您可以使用 --headed
CLI 参数以有头模式运行测试,或者您可以使用 --ui
标志在 UI 模式下运行测试。查看您的测试的完整追踪,包括监视模式、时间旅行调试等。
您将学习
运行测试
命令行
您可以使用 playwright test
命令运行测试。这将在 playwright.config
文件中配置的所有浏览器上运行您的测试。默认情况下,测试以无头模式运行,这意味着在运行测试时不会打开浏览器窗口,结果将在终端中看到。
npx playwright test
在 UI 模式下运行测试
我们强烈建议您使用 UI 模式运行测试,以获得更好的开发者体验,您可以在其中轻松地逐步浏览测试的每个步骤,并直观地查看每个步骤之前、期间和之后发生的事情。UI 模式还具有许多其他功能,例如定位器选择器、监视模式等。
npx playwright test --ui
查看我们的 UI 模式详细指南,以了解有关其功能的更多信息。
在有头模式下运行测试
要在有头模式下运行测试,请使用 --headed
标志。这将使您能够直观地看到 Playwright 如何与网站交互。
npx playwright test --headed
在不同浏览器上运行测试
要指定要在哪个浏览器上运行测试,请使用 --project
标志,后跟浏览器名称。
npx playwright test --project webkit
要指定要在多个浏览器上运行测试,请多次使用 --project
标志,后跟每个浏览器的名称。
npx playwright test --project webkit --project firefox
运行特定测试
要运行单个测试文件,请传入要运行的测试文件的名称。
npx playwright test landing-page.spec.ts
要从不同目录运行一组测试文件,请传入要运行测试的目录的名称。
npx playwright test tests/todo-page/ tests/landing-page/
要运行文件名中包含 landing
或 login
的文件,只需将这些关键字传递给 CLI。
npx playwright test landing login
要运行具有特定标题的测试,请使用 -g
标志,后跟测试的标题。
npx playwright test -g "add a todo item"
运行上次失败的测试
要仅运行上次测试运行中失败的测试,请首先运行测试,然后使用 --last-failed
标志再次运行它们。
npx playwright test --last-failed
在 VS Code 中运行测试
测试可以直接从 VS Code 中运行,使用 VS Code 扩展。安装后,您可以简单地单击要运行的测试旁边的绿色三角形,或从测试侧边栏运行所有测试。查看我们的 VS Code 入门指南以获取更多详细信息。
调试测试
由于 Playwright 在 Node.js 中运行,您可以使用您选择的调试器对其进行调试,例如使用 console.log
或在 IDE 中,或直接在 VS Code 中使用 VS Code 扩展。Playwright 带有 UI 模式,您可以在其中轻松地逐步浏览测试的每个步骤,查看日志、错误、网络请求、检查 DOM 快照等。您还可以使用 Playwright Inspector,它允许您逐步执行 Playwright API 调用,查看其调试日志并探索定位器。
在 UI 模式下调试测试
我们强烈建议您使用 UI 模式调试测试,以获得更好的开发者体验,您可以在其中轻松地逐步浏览测试的每个步骤,并直观地查看每个步骤之前、期间和之后发生的事情。UI 模式还具有许多其他功能,例如定位器选择器、监视模式等。
npx playwright test --ui
在调试时,您可以使用“选择定位器”按钮来选择页面上的元素,并查看 Playwright 将用于查找该元素的定位器。您还可以在定位器 playground 中编辑定位器,并查看它在浏览器窗口中实时突出显示。使用“复制定位器”按钮将定位器复制到剪贴板,然后将其粘贴到您的测试中。
查看我们的 UI 模式详细指南,以了解有关其功能的更多信息。
使用 Playwright Inspector 调试测试
要调试所有测试,请运行 Playwright test 命令,后跟 --debug
标志。
npx playwright test --debug
此命令将打开一个浏览器窗口以及 Playwright Inspector。您可以使用 inspector 顶部的“单步跳过”按钮来单步执行您的测试。或者,按“播放”按钮从头到尾运行您的测试。测试完成后,浏览器窗口将关闭。
要调试一个测试文件,请运行 Playwright test 命令,后跟要调试的测试文件的名称,以及 --debug
标志。
npx playwright test example.spec.ts --debug
要从定义 test(..
的行号调试特定测试,请在测试文件名末尾添加冒号,后跟行号,然后是 --debug
标志。
npx playwright test example.spec.ts:10 --debug
在调试时,您可以使用“选择定位器”按钮来选择页面上的元素,并查看 Playwright 将用于查找该元素的定位器。您还可以编辑定位器,并查看它在浏览器窗口中实时突出显示。使用“复制定位器”按钮将定位器复制到剪贴板,然后将其粘贴到您的测试中。
查看我们的 调试指南,以了解有关使用 VS Code 调试器、UI 模式和 Playwright Inspector 进行调试,以及使用 浏览器开发者工具进行调试的更多信息。
测试报告
HTML 报告器向您显示完整的测试报告,允许您按浏览器、通过的测试、失败的测试、跳过的测试和不稳定的测试来过滤报告。默认情况下,如果某些测试失败,则会自动打开 HTML 报告,否则您可以使用以下命令打开它。
npx playwright show-report
您可以过滤和搜索测试,以及单击每个测试以查看测试错误并探索测试的每个步骤。