playwright/docs/src/api/class-electron.md

4.2 KiB

class: Electron

  • since: v1.9
  • langs: js

Playwright has experimental support for Electron automation. You can access electron namespace via:

const { _electron } = require('playwright');

An example of the Electron automation script would be:

const { _electron: electron } = require('playwright');

(async () => {
  // Launch Electron app.
  const electronApp = await electron.launch({ args: ['main.js'] });

  // Evaluation expression in the Electron context.
  const appPath = await electronApp.evaluate(async ({ app }) => {
    // This runs in the main Electron process, parameter here is always
    // the result of the require('electron') in the main app script.
    return app.getAppPath();
  });
  console.log(appPath);

  // Get the first window that the app opens, wait if necessary.
  const window = await electronApp.firstWindow();
  // Print the title.
  console.log(await window.title());
  // Capture a screenshot.
  await window.screenshot({ path: 'intro.png' });
  // Direct Electron console to Node terminal.
  window.on('console', console.log);
  // Click button.
  await window.click('text=Click me');
  // Exit app.
  await electronApp.close();
})();

Supported Electron versions are:

  • v12.2.0+
  • v13.4.0+
  • v14+

Known issues:

If you are not able to launch Electron and it will end up in timeouts during launch, try the following:

async method: Electron.launch

  • since: v1.9
  • returns: <[ElectronApplication]>

Launches electron application specified with the [option: executablePath].

option: Electron.launch.executablePath

  • since: v1.9
  • executablePath <[string]>

Launches given Electron application. If not specified, launches the default Electron executable installed in this package, located at node_modules/.bin/electron.

option: Electron.launch.args

  • since: v1.9
  • args <[Array]<[string]>>

Additional arguments to pass to the application when launching. You typically pass the main script name here.

option: Electron.launch.cwd

  • since: v1.9
  • cwd <[string]>

Current working directory to launch application from.

option: Electron.launch.env

  • since: v1.9
  • env <[Object]<[string], [string]>>

Specifies environment variables that will be visible to Electron. Defaults to process.env.

option: Electron.launch.timeout

  • since: v1.15
  • timeout <[float]>

Maximum time in milliseconds to wait for the application to start. Defaults to 30000 (30 seconds). Pass 0 to disable timeout.

option: Electron.launch.acceptdownloads = %%-context-option-acceptdownloads-%%

  • since: v1.12

option: Electron.launch.bypassCSP = %%-context-option-bypasscsp-%%

  • since: v1.12

option: Electron.launch.colorScheme = %%-context-option-colorscheme-%%

  • since: v1.12

option: Electron.launch.extraHTTPHeaders = %%-context-option-extrahttpheaders-%%

  • since: v1.12

option: Electron.launch.geolocation = %%-context-option-geolocation-%%

  • since: v1.12

option: Electron.launch.httpcredentials = %%-context-option-httpcredentials-%%

  • since: v1.12

option: Electron.launch.ignoreHTTPSErrors = %%-context-option-ignorehttpserrors-%%

  • since: v1.12

option: Electron.launch.locale = %%-context-option-locale-%%

  • since: v1.12

option: Electron.launch.offline = %%-context-option-offline-%%

  • since: v1.12

option: Electron.launch.recordhar = %%-context-option-recordhar-%%

  • since: v1.12

option: Electron.launch.recordharpath = %%-context-option-recordhar-path-%%

  • since: v1.12

option: Electron.launch.recordHarOmitContent = %%-context-option-recordhar-omit-content-%%

  • since: v1.12

option: Electron.launch.recordvideo = %%-context-option-recordvideo-%%

  • since: v1.12

option: Electron.launch.recordvideodir = %%-context-option-recordvideo-dir-%%

  • since: v1.12

option: Electron.launch.recordvideosize = %%-context-option-recordvideo-size-%%

  • since: v1.12

option: Electron.launch.timezoneId = %%-context-option-timezoneid-%%

  • since: v1.12

option: Electron.launch.tracesDir = %%-browser-option-tracesdir-%%

  • since: v1.36