浏览器
简介
Playwright 的每个版本都需要特定版本的浏览器二进制文件才能运行。您需要使用 Playwright CLI 安装这些浏览器。
Playwright 在每次发布时都会更新其支持的浏览器版本,因此最新版本的 Playwright 将始终支持最新的浏览器。这意味着每次更新 Playwright 时,您可能都需要重新运行 install
CLI 命令。
安装浏览器
Playwright 可以安装支持的浏览器。在没有参数的情况下运行该命令将安装默认浏览器。
pwsh bin/Debug/netX/playwright.ps1 install
您还可以通过提供参数来安装特定浏览器
pwsh bin/Debug/netX/playwright.ps1 install webkit
查看所有支持的浏览器
pwsh bin/Debug/netX/playwright.ps1 install --help
通过 API 安装浏览器
可以通过 .NET API 运行命令行工具命令
var exitCode = Microsoft.Playwright.Program.Main(new[] {"install"});
if (exitCode != 0)
{
throw new Exception($"Playwright exited with code {exitCode}");
}
安装系统依赖项
系统依赖项可以自动安装。这对于 CI 环境非常有用。
pwsh bin/Debug/netX/playwright.ps1 install-deps
您还可以通过将其作为参数传递来安装单个浏览器的依赖项
pwsh bin/Debug/netX/playwright.ps1 install-deps chromium
也可以将 install-deps
与 install
结合使用,以便使用单个命令安装浏览器和操作系统依赖项。
pwsh bin/Debug/netX/playwright.ps1 install --with-deps chromium
查看 系统要求,了解正式支持的操作系统。
配置浏览器
Playwright 可以在 Chromium、WebKit 和 Firefox 浏览器以及 Google Chrome 和 Microsoft Edge 等品牌浏览器上运行测试。它也可以在模拟的平板电脑和移动设备上运行。查看 设备参数注册表,了解所选台式机、平板电脑和移动设备的完整列表。
在不同的浏览器上运行测试
在特定浏览器上运行测试
dotnet test -- Playwright.BrowserName=webkit
要在多个浏览器或配置上运行测试,您需要多次调用 dotnet test
命令。您可以指定 BROWSER
环境变量或通过 runsettings 文件设置 Playwright.BrowserName
dotnet test --settings:chromium.runsettings
dotnet test --settings:firefox.runsettings
dotnet test --settings:webkit.runsettings
<?xml version="1.0" encoding="utf-8"?>
<RunSettings>
<Playwright>
<BrowserName>chromium</BrowserName>
</Playwright>
</RunSettings>
Chromium
对于 Google Chrome、Microsoft Edge 和其他基于 Chromium 的浏览器,Playwright 默认使用开源 Chromium 构建。由于 Chromium 项目领先于品牌浏览器,当全球使用 Google Chrome N 时,Playwright 已经支持 Google Chrome 和 Microsoft Edge 几个星期后将发布的 Chromium N+1。
Google Chrome & Microsoft Edge
虽然 Playwright 可以下载并使用最新的 Chromium 构建,但它可以在机器上可用的品牌 Google Chrome 和 Microsoft Edge 浏览器上运行(请注意,Playwright 默认不安装它们)。特别是,当前版本的 Playwright 将支持这些浏览器的稳定版和测试版渠道。
可用的渠道是 chrome
、msedge
、chrome-beta
、msedge-beta
或 msedge-dev
。
某些企业浏览器策略可能会影响 Playwright 启动和控制 Google Chrome 和 Microsoft Edge 的能力。在使用浏览器策略的环境中运行不在 Playwright 项目的范围内。
<?xml version="1.0" encoding="utf-8"?>
<RunSettings>
<Playwright>
<BrowserName>chromium</BrowserName>
<LaunchOptions>
<Channel>msedge</Channel>
</LaunchOptions>
</Playwright>
</RunSettings>
dotnet test -- Playwright.BrowserName=chromium Playwright.LaunchOptions.Channel=msedge
安装 Google Chrome & Microsoft Edge
如果您的机器上没有 Google Chrome 或 Microsoft Edge,您可以使用 Playwright 命令行工具安装它们
pwsh bin/Debug/netX/playwright.ps1 install msedge
Google Chrome 或 Microsoft Edge 安装将安装在操作系统的默认全局位置,覆盖您当前的浏览器安装。
使用 --help
选项运行以查看可安装浏览器的完整列表。
何时使用 Google Chrome & Microsoft Edge,何时不使用?
默认值
大多数情况下,使用最新的 Chromium 与默认的 Playwright 配置是一个好主意。由于 Playwright 领先于浏览器的稳定版渠道,因此可以放心的是,即将发布的 Google Chrome 或 Microsoft Edge 版本不会破坏您的网站。您可以在官方 Chrome 更新之前及早发现问题并有充足的时间修复它。
回归测试
话虽如此,测试策略通常要求对当前公开可用的浏览器进行回归测试。在这种情况下,您可以选择使用其中一个稳定版渠道,"chrome"
或 "msedge"
。
媒体编解码器
使用官方二进制文件进行测试的另一个原因是测试与媒体编解码器相关的功能。由于各种许可考虑因素和协议,Chromium 不具备 Google Chrome 或 Microsoft Edge 捆绑的所有编解码器。如果您的网站依赖于这种编解码器(很少见),您也需要使用官方渠道。
企业策略
Google Chrome 和 Microsoft Edge 尊重企业策略,其中包括对功能、网络代理、强制性扩展的限制,这些限制会妨碍测试。因此,如果您属于使用此类策略的组织的一部分,最简单的方法是使用捆绑的 Chromium 进行本地测试,您仍然可以在通常不受此类限制影响的机器人上选择使用稳定版渠道。
Firefox
Playwright 的 Firefox 版本与最新的 Firefox 稳定版 构建匹配。Playwright 不适用于品牌版本的 Firefox,因为它依赖于补丁。
请注意,某些功能的可用性(高度依赖于底层平台)可能因操作系统而异。例如,可用的媒体编解码器在 Linux、macOS 和 Windows 之间差异很大。
WebKit
Playwright 的 WebKit 来自最新的 WebKit 主分支源代码,通常是在这些更新被纳入 Apple Safari 和其他基于 WebKit 的浏览器之前。这为应对潜在的浏览器更新问题提供了充足的超前时间。Playwright 不适用于品牌版本的 Safari,因为它依赖于补丁。相反,您可以使用最新的 WebKit 构建进行测试。
请注意,某些功能的可用性(高度依赖于底层平台)可能因操作系统而异。例如,可用的媒体编解码器在 Linux、macOS 和 Windows 之间差异很大。虽然在 Linux CI 上运行 WebKit 通常是最实惠的选择,但为了获得最接近 Safari 的体验,您应该在 Mac 上运行 WebKit,例如,如果您要进行视频播放。
在防火墙或代理后面安装
默认情况下,Playwright 从 Microsoft 的 CDN 下载浏览器。
有时,公司会维护内部代理,阻止对公共资源的直接访问。在这种情况下,可以配置 Playwright 通过代理服务器下载浏览器。
- Bash
- PowerShell
- 批处理
HTTPS_PROXY=https://192.0.2.1 pwsh bin/Debug/netX/playwright.ps1 install
$Env:HTTPS_PROXY="https://192.0.2.1"
pwsh bin/Debug/netX/playwright.ps1 install
set HTTPS_PROXY=https://192.0.2.1
pwsh bin/Debug/netX/playwright.ps1 install
如果代理的请求被自定义不受信任的证书颁发机构 (CA) 拦截,并且在下载浏览器时导致 Error: self signed certificate in certificate chain
,则必须通过 NODE_EXTRA_CA_CERTS
环境变量设置自定义根证书,然后再安装浏览器
- Bash
- PowerShell
- 批处理
export NODE_EXTRA_CA_CERTS="/path/to/cert.pem"
$Env:NODE_EXTRA_CA_CERTS="C:\certs\root.crt"
set NODE_EXTRA_CA_CERTS="C:\certs\root.crt"
如果您的网络连接到 Playwright 浏览器存档的速度很慢,可以使用 PLAYWRIGHT_DOWNLOAD_CONNECTION_TIMEOUT
环境变量以毫秒为单位增加连接超时
- Bash
- PowerShell
- 批处理
PLAYWRIGHT_DOWNLOAD_CONNECTION_TIMEOUT=120000 pwsh bin/Debug/netX/playwright.ps1 install
$Env:PLAYWRIGHT_DOWNLOAD_CONNECTION_TIMEOUT="120000"
pwsh bin/Debug/netX/playwright.ps1 install
set PLAYWRIGHT_DOWNLOAD_CONNECTION_TIMEOUT=120000
pwsh bin/Debug/netX/playwright.ps1 install
如果您正在 安装依赖项 并且需要在 Linux 上使用代理,请确保以 root 用户身份运行该命令。否则,Playwright 将尝试变为 root 并且不会将 HTTPS_PROXY
等环境变量传递给 Linux 包管理器。
sudo HTTPS_PROXY=https://192.0.2.1 pwsh bin/Debug/netX/playwright.ps1 install-deps
从工件存储库下载
默认情况下,Playwright 从 Microsoft 的 CDN 下载浏览器。
有时公司会维护一个内部工件仓库来托管浏览器二进制文件。在这种情况下,可以配置 Playwright 使用 `PLAYWRIGHT_DOWNLOAD_HOST` 环境变量从自定义位置下载。
- Bash
- PowerShell
- 批处理
PLAYWRIGHT_DOWNLOAD_HOST=http://192.0.2.1 pwsh bin/Debug/netX/playwright.ps1 install
$Env:PLAYWRIGHT_DOWNLOAD_HOST="http://192.0.2.1"
pwsh bin/Debug/netX/playwright.ps1 install
set PLAYWRIGHT_DOWNLOAD_HOST=http://192.0.2.1
pwsh bin/Debug/netX/playwright.ps1 install
也可以使用每个浏览器的下载主机,使用 `PLAYWRIGHT_CHROMIUM_DOWNLOAD_HOST`、`PLAYWRIGHT_FIREFOX_DOWNLOAD_HOST` 和 `PLAYWRIGHT_WEBKIT_DOWNLOAD_HOST` 环境变量,它们优先于 `PLAYWRIGHT_DOWNLOAD_HOST`。
- Bash
- PowerShell
- 批处理
PLAYWRIGHT_FIREFOX_DOWNLOAD_HOST=http://203.0.113.3 PLAYWRIGHT_DOWNLOAD_HOST=http://192.0.2.1 pwsh bin/Debug/netX/playwright.ps1 install
$Env:PLAYWRIGHT_DOWNLOAD_HOST="http://192.0.2.1"
$Env:PLAYWRIGHT_FIREFOX_DOWNLOAD_HOST="http://203.0.113.3"
pwsh bin/Debug/netX/playwright.ps1 install
set PLAYWRIGHT_FIREFOX_DOWNLOAD_HOST=http://203.0.113.3
set PLAYWRIGHT_DOWNLOAD_HOST=http://192.0.2.1
pwsh bin/Debug/netX/playwright.ps1 install
管理浏览器二进制文件
Playwright 将 Chromium、WebKit 和 Firefox 浏览器下载到操作系统特定的缓存文件夹。
- Windows 上的 `%USERPROFILE%\AppData\Local\ms-playwright`
- macOS 上的 `~/Library/Caches/ms-playwright`
- Linux 上的 `~/.cache/ms-playwright`
这些浏览器安装后将占用几百兆字节的磁盘空间。
du -hs ~/Library/Caches/ms-playwright/*
281M chromium-XXXXXX
187M firefox-XXXX
180M webkit-XXXX
您可以使用环境变量覆盖默认行为。安装 Playwright 时,要求它将浏览器下载到特定位置。
- Bash
- PowerShell
- 批处理
PLAYWRIGHT_BROWSERS_PATH=$HOME/pw-browsers pwsh bin/Debug/netX/playwright.ps1 install
$Env:PLAYWRIGHT_BROWSERS_PATH="$Env:USERPROFILE\pw-browsers"
pwsh bin/Debug/netX/playwright.ps1 install
set PLAYWRIGHT_BROWSERS_PATH=%USERPROFILE%\pw-browsers
pwsh bin/Debug/netX/playwright.ps1 install
运行 Playwright 脚本时,要求它在共享位置搜索浏览器。
- Bash
- PowerShell
- 批处理
PLAYWRIGHT_BROWSERS_PATH=$HOME/pw-browsers dotnet test
$Env:PLAYWRIGHT_BROWSERS_PATH="$Env:USERPROFILE\pw-browsers"
dotnet test
set PLAYWRIGHT_BROWSERS_PATH=%USERPROFILE%\pw-browsers
dotnet test
Playwright 会跟踪需要这些浏览器的软件包,并在您将 Playwright 更新到较新版本时对其进行垃圾回收。
开发人员可以通过在他们的 `~/.bashrc` 中导出 `PLAYWRIGHT_BROWSERS_PATH=$HOME/pw-browsers` 来选择此模式。
过时浏览器删除
Playwright 会跟踪使用其浏览器的客户端。当不再有客户端需要特定版本的浏览器时,该版本将从系统中删除。这样,您可以安全地使用不同版本的 Playwright 实例,同时不会浪费不再使用的浏览器的磁盘空间。
要选择退出未使用浏览器删除,可以设置 `PLAYWRIGHT_SKIP_BROWSER_GC=1` 环境变量。
卸载浏览器
这将删除当前 Playwright 安装的浏览器(chromium、firefox、webkit)。
pwsh bin/Debug/netX/playwright.ps1 uninstall
要删除其他 Playwright 安装的浏览器,请传递 `--all` 标志。
pwsh bin/Debug/netX/playwright.ps1 uninstall --all