From 710d006cc170ae1301134754dd0673cdaf994d8f Mon Sep 17 00:00:00 2001 From: Tian Feng Date: Fri, 9 Aug 2024 09:39:50 -0700 Subject: [PATCH] feat: Support takeScreenshot (#11) * feat: Support take screenshot * add fullPage check * add comments --- src/driver.ts | 10 ++++++++++ src/index.ts | 29 +++++++++++++++++++++++------ 2 files changed, 33 insertions(+), 6 deletions(-) diff --git a/src/driver.ts b/src/driver.ts index 41791e9..3dc1fbf 100644 --- a/src/driver.ts +++ b/src/driver.ts @@ -1,4 +1,5 @@ import wd, { Client } from 'webdriver'; +import * as fs from 'fs'; import { isDevice, isSimulator } from './device'; import { CreateSessionError } from './errors'; @@ -139,4 +140,13 @@ export class SauceDriver { newWindowSize.height, ); } + + async takeScreenshot(browserId: string, filepath: string) { + const browser = this.sessions.get(browserId); + if (!browser) { + return; + } + const screenBuffer = await browser.takeScreenshot(); + fs.writeFileSync(filepath, Buffer.from(screenBuffer, 'base64')); + } } diff --git a/src/index.ts b/src/index.ts index e29cc1d..af64159 100644 --- a/src/index.ts +++ b/src/index.ts @@ -1,8 +1,8 @@ -import { SauceDriver } from './driver.js'; +import { SauceDriver } from './driver'; import { AuthError, TunnelNameError, WindowSizeRangeError } from './errors'; import { getPlatforms } from './api'; import { rcompareOses, rcompareVersions } from './sort'; -import { isDevice } from './device.js'; +import { isDevice } from './device'; type Browser = string; type Version = string; @@ -230,10 +230,27 @@ module.exports = { * Called by TestCafe to take a screenshot. * * https://github.com/DevExpress/testcafe/blob/4a30f1c3b8769ca68c9b7912911f1dd8aa91d62c/src/browser/provider/plugin-host.js#L134 + * + * @param {string} browserId - The ID of the browser session. + * @param {string} screenshotPath - The absolute path with .png extension where the screenshot will be saved. + * It also supports path pattern. + * @param {number} pageWidth - The width of the page to capture, currently no use. + * @param {number} pageHeight - The height of the page to capture, currently no use. + * @param {boolean} fullPage - A flag indicating whether to capture a full-page screenshot. + * Currently, full-page screenshots are not supported. */ - async takeScreenshot(/* id, screenshotPath, pageWidth, pageHeight */) { - this.reportWarning( - 'The screenshot functionality is not supported by the Sauce Labs browser provider plugin.', - ); + async takeScreenshot( + browserId: string, + screenshotPath: string, + pageWidth: number, + pageHeight: number, + fullPage: boolean, + ) { + if (fullPage) { + console.warn( + 'Taking a full-page screenshot on the remote browser is not supported.', + ); + } + await sauceDriver.takeScreenshot(browserId, screenshotPath); }, };