Puppeteer - 设备模拟


我们可以在 Puppeteer 中使用移动配置运行测试并检查网页的响应属性。Puppeteer 支持的设备列表可以从 Chrome DevTools 获取。右键单击在 Chrome 浏览器中打开的页面,然后选择“检查”。

选择检查

然后,单击“切换设备工具栏”。

切换设备工具栏

单击下拉菜单 - 响应式以获取设备列表。

反应灵敏

要模拟设备,我们必须使用 emulate() 方法,并将要模拟的设备作为参数传递给该方法。该方法的语法如下 -

const m = puppeteer.devices['iPhone X']
//emulate iPhoneX
await page.emulate(m)

让我们使用 Puppeteer 中的模拟功能来模拟设备 iPhone X。

首先,请按照《Puppeteer 基本测试》一章中的步骤 1 至 2 进行操作,如下所示 -

步骤 1 - 在创建 node_modules 文件夹的目录中创建一个新文件(Puppeteer 和 Puppeteer 核心的安装位置)。

Puppeteer 安装的详细信息将在 Puppeteer 安装章节中讨论。

右键单击创建 node_modules 文件夹的文件夹,然后单击“新建文件”按钮。

节点模块

步骤 2 - 输入文件名,例如 testcase1.js。

测试用例1.JS

步骤 3 - 在创建的 testcase1.js 文件中添加以下代码。

//Puppeteer library
const puppeteer = require('puppeteer')
//launch browser in headed mode
puppeteer.launch({headless:false}).then(async browser => {
   //browser new page
   const page = await browser.newPage()
   //set device to iPhone X
   const m = puppeteer.devices['iPhone X']
   //emulate iPhoneX
   await page.emulate(m)
   //launch URL
   await page.goto('https://www.tutorialspoint.com/index.htm')
   //capture screenshot of emulated device
   await page.screenshot({ path: 'iPhoneDevice.png'})
   //browser close
   await browser.close()
})

步骤 4 - 使用下面给出的命令执行代码 -

node <filename>

因此,在我们的示例中,我们将运行以下命令 -

node testcase1.js
苹果手机设备

成功执行命令后,会在页面目录中创建一个名为 iPhoneDevice.png 的新文件。它包含为 iPhone X 设备捕获的模拟网页的屏幕截图。