跳到主要内容

隔离

简介

使用 Playwright 编写的测试在称为浏览器上下文的独立全新环境中执行。这种隔离模式提高了可重现性并防止了级联测试失败。

什么是测试隔离?

测试隔离是指每个测试都与其他测试完全隔离。每个测试独立于任何其他测试运行。这意味着每个测试都有自己的本地存储 (local storage)、会话存储 (session storage)、Cookie 等。Playwright 通过使用 BrowserContext 来实现这一点,它相当于无痕浏览 (incognito) 式的配置文件。它们创建速度快且成本低,并且完全隔离,即使在单个浏览器中运行也是如此。Playwright 为每个测试创建一个上下文,并在该上下文中提供一个默认的 Page

为什么测试隔离很重要?

  • 没有失败的传递。如果一个测试失败,它不会影响其他测试。
  • 易于调试错误或不稳定性,因为您可以根据需要多次运行单个测试。
  • 在并行、分片等运行时,无需考虑顺序。

测试隔离的两种方式

测试隔离有两种不同的策略:从头开始或在测试之间进行清理。在测试之间进行清理的问题在于很容易忘记清理,而且有些东西是无法清理的,例如“已访问链接”。一个测试的状态可能会泄露到下一个测试中,这可能导致您的测试失败并使调试更加困难,因为问题源自另一个测试。从头开始意味着一切都是新的,因此如果测试失败,您只需要在该测试内部查找即可进行调试。

Playwright 如何实现测试隔离

Playwright 使用浏览器上下文来实现测试隔离。每个测试都有自己的浏览器上下文。每次运行测试时都会创建一个新的浏览器上下文。将 Playwright 用作测试运行器时,默认会创建浏览器上下文。否则,您可以手动创建浏览器上下文。

Browser browser = chromium.launch();
BrowserContext context = browser.newContext();
Page page = context.newPage();

浏览器上下文还可用于模拟涉及移动设备、权限、区域设置和颜色方案的多页面场景。有关更多详细信息,请查看我们的模拟指南。

单个测试中的多个上下文

Playwright 可以在单个场景中创建多个浏览器上下文。这在您想要测试多用户功能(例如聊天)时非常有用。

import com.microsoft.playwright.*;

public class Example {
public static void main(String[] args) {
try (Playwright playwright = Playwright.create()) {
BrowserType chromium = playwright.chromium();
// Create a Chromium browser instance
Browser browser = chromium.launch();
// Create two isolated browser contexts
BrowserContext userContext = browser.newContext();
BrowserContext adminContext = browser.newContext();
// Create pages and interact with contexts independently
}
}
}