Playwright中修改接口返回的5种方法

前言:

在使用Playwright做自动化测试过程中,拦截接口并修改返回数据是一个非常常见的场景,今天我们就来总结下,都有哪些方法可以让我们实现这个功能。

方法1:使用 page.route() 方法

page.route() 是 Playwright 中常用的拦截和修改网络请求的方法。你可以拦截请求并返回自定义的响应。

dart 复制代码
```
(async () => {
  const browser = await chromium.launch();
  const page = await browser.newPage();

  // 拦截请求并修改响应
  await page.route('**/api/some-endpoint', async (route) => {
    // 获取原始响应
    const response = await route.fetch();
    const originalBody = await response.json();

    // 修改响应内容
    originalBody.someField = 'modified value';

    // 返回修改后的响应
    await route.fulfill({
      status: response.status(),
      headers: response.headers(),
      body: JSON.stringify(originalBody),
    });
  });

  // 导航到页面
  await page.goto('https://example.com');

  // 等待页面加载完成
  await page.waitForTimeout(5000); // 仅用于演示,实际使用时建议使用更可靠的等待方式

  await browser.close();
})();
```

方法2:使用 page.setRequestInterception(true) 拦截并直接返回自定义内容

通过 page.setRequestInterception(true) 启用请求拦截,然后使用 request.respond() 直接返回自定义内容。

dart 复制代码
const { chromium } = require('playwright');

(async () => {
  const browser = await chromium.launch();
  const page = await browser.newPage();

  // 启用请求拦截
  await page.setRequestInterception(true);

  // 监听请求事件
  page.on('request', async (request) => {
    if (request.url().includes('api/some-endpoint')) {
      // 直接返回自定义响应
      await request.respond({
        status: 200,
        contentType: 'application/json',
        body: JSON.stringify({ someField: 'modified value' }),
      });
    } else {
      // 继续其他请求
      request.continue();
    }
  });

  // 导航到页面
  await page.goto('https://example.com');

  // 等待页面加载完成
  await page.waitForTimeout(5000); // 仅用于演示,实际使用时建议使用更可靠的等待方式

  await browser.close();
})();

方法3:使用 browserContext.route() 拦截并修改返回内容

browserContext.route()page.route() 类似,但作用范围是整个浏览器上下文(即所有页面)。

javascript 复制代码
const { chromium } = require('playwright');

(async () => {
  const browser = await chromium.launch();
  const context = await browser.newContext();

  // 拦截请求并修改响应
  await context.route('**/api/some-endpoint', async (route) => {
    // 获取原始响应
    const response = await route.fetch();
    const originalBody = await response.json();

    // 修改响应内容
    originalBody.someField = 'modified value';

    // 返回修改后的响应
    await route.fulfill({
      status: response.status(),
      headers: response.headers(),
      body: JSON.stringify(originalBody),
    });
  });

  const page = await context.newPage();
  await page.goto('https://example.com');

  // 等待页面加载完成
  await page.waitForTimeout(5000); // 仅用于演示,实际使用时建议使用更可靠的等待方式

  await browser.close();
})();

方法 4:使用 page.evaluate() 在页面上下文中修改返回内容

如果需要在页面上下文中动态修改返回内容,可以使用 page.evaluate()

javascript 复制代码
const { chromium } = require('playwright');

(async () => {
  const browser = await chromium.launch();
  const page = await browser.newPage();

  // 导航到页面
  await page.goto('https://example.com');

  // 在页面上下文中修改返回内容
  await page.evaluate(async () => {
    const originalResponse = await fetch('/api/some-endpoint');
    const originalData = await originalResponse.json();

    // 修改返回内容
    originalData.someField = 'modified value';

    // 覆盖 fetch 方法以返回修改后的内容
    window.fetch = new Proxy(window.fetch, {
      apply: async (target, thisArg, args) => {
        if (args[0].includes('/api/some-endpoint')) {
          return Promise.resolve({
            ok: true,
            status: 200,
            json: () => Promise.resolve(originalData),
          });
        }
        return target.apply(thisArg, args);
      },
    });
  });

  // 等待页面加载完成
  await page.waitForTimeout(5000); // 仅用于演示,实际使用时建议使用更可靠的等待方式

  await browser.close();
})();

方法 5:使用 route.fulfill() 直接返回静态内容

如果不需要依赖原始响应,可以直接使用 route.fulfill() 返回静态内容。

javascript 复制代码
const { chromium } = require('playwright');

(async () => {
  const browser = await chromium.launch();
  const page = await browser.newPage();

  // 拦截请求并返回静态内容
  await page.route('**/api/some-endpoint', async (route) => {
    await route.fulfill({
      status: 200,
      contentType: 'application/json',
      body: JSON.stringify({ someField: 'modified value' }),
    });
  });

  // 导航到页面
  await page.goto('https://example.com');

  // 等待页面加载完成
  await page.waitForTimeout(5000); // 仅用于演示,实际使用时建议使用更可靠的等待方式

  await browser.close();
})();

以上,就是所有的方法了,大家可以在项目中实践看看效果。

相关推荐
jiayong234 分钟前
前端面试题库 - JavaScript核心基础篇
前端·javascript·面试
软件技术NINI18 分钟前
泉州html+css 4页
前端·javascript·css·html
再吃一根胡萝卜19 分钟前
OpenScreen:免费开源的录屏神器,做出专业级演示视频
前端
Cloud_Shy61820 分钟前
Python 数据分析基础入门:《Excel Python:飞速搞定数据分析与处理》学习笔记系列(第十一章 Python 包跟踪器 下篇)
前端·后端·python·数据分析·excel
kyriewen22 分钟前
我用AI把公司10万行代码屎山重构了,CTO看了代码后说:你提前转正
前端·javascript·ai编程
ttwuai25 分钟前
XYGo Admin 菜单与路由:Vue3 动态路由 + GoFrame 权限菜单的完整实现方案
前端·vue·后台框架
程序员码歌33 分钟前
OpenSpec 到 Superpowers:AI 编码从说清到做对
android·前端·人工智能
爱编程的小新☆33 分钟前
LangGraph4j工作流框架
前端·数据库·ai·langchain·langgraph4j
@PHARAOH1 小时前
HOW - 构建一个轻量前后端一体服务
前端·微服务·服务端