Puppeteer - 截屏



在使用 Puppeteer 开发自动化测试时,我们可以使用 screenshot 方法来捕获屏幕截图。通常情况下,如果遇到应用程序错误、测试用例失败等情况,我们会捕获屏幕截图。

语法

在 Puppeteer 中捕获屏幕截图的语法如下:

await page.screenshot({
   path: 'tutorialspoint.png'
})

这里,将屏幕截图保存到的路径作为参数传递给方法。这样,只会捕获网页的可视部分。要捕获全页面屏幕截图,我们必须传递另一个名为 fullPage 的参数,并将其值设置为 true。

语法

语法如下:

await page.screenshot({
   path: 'tutorialspoint.png', fullPage: true
})

让我们捕获以下页面的屏幕截图:

Screenshot

首先,按照 Puppeteer 基本测试章节中的步骤 1 到步骤 2 操作,步骤如下:

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

Puppeteer 的安装细节在 Puppeteer 安装章节中讨论。

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

Node Modules

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

Testcase1.JS

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

//adding Puppeteer library
const pt = require('puppeteer');
pt.launch().then(async browser => {
   //browser new page
   const p = await browser.newPage();
   //set viewpoint of browser page
   await p.setViewport({ width: 1000, height: 500 })
   //launch URL
   await p.goto('https://tutorialspoint.com/index.htm')
   //capture screenshot
   await p.screenshot({
      path: 'tutorialspoint.png'
   });
   //browser close
   await browser.close()
})

步骤 4 - 使用以下命令执行代码:

node <filename>

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

node testcase1.js
Launched in the Browser

命令成功执行后,将在 page 目录中创建一个名为 tutorialspoint.png 的新文件。它包含在浏览器中启动的页面的捕获屏幕截图。

广告
© . All rights reserved.