2021-02-01 11:43:26 -08:00
# class: Electron
* langs: js
Playwright has **experimental** support for Electron automation. You can access electron namespace via:
```js
const { _electron } = require('playwright');
```
An example of the Electron automation script would be:
```js
const { _electron: electron } = require('playwright');
(async () => {
// Launch Electron app.
const electronApp = await electron.launch({ args: ['main.js'] });
// Evaluation expression in the Electron context.
2021-04-04 14:06:30 -07:00
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();
2021-02-01 11:43:26 -08:00
});
2021-04-04 14:06:30 -07:00
console.log(appPath);
2021-02-01 11:43:26 -08:00
// 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');
2021-04-04 14:06:30 -07:00
// Exit app.
await electronApp.close();
2021-02-01 11:43:26 -08:00
})();
```
Note that since you don't need Playwright to install web browsers when testing Electron, you can omit browser download via setting the following environment variable when installing Playwright:
```sh js
2021-05-11 20:47:48 +02:00
PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD=1 npm i -D playwright
2021-02-01 11:43:26 -08:00
```
## async method: Electron.launch
- returns: < [ElectronApplication]>
Launches electron application specified with the [`option: executablePath` ].
### option: Electron.launch.executablePath
- `executablePath` < [string]>
Launches given Electron application. If not specified, launches the default Electron
executable inst alled in this package, located at `node_modules/.bin/electron` .
### option: Electron.launch.args
- `args` < [Array]< [string]>>
Additional arguments to pass to the application when launching. You typically pass the main
script name here.
### option: Electron.launch.cwd
- `cwd` < [string]>
Current working directory to launch application from.
### option: Electron.launch.env
- `env` < [Object]< [string], [string]>>
Specifies environment variables that will be visible to Electron. Defaults to `process.env` .
#### option: Electron.launch.timeout
- `timeout` < [float]>
Maximum time in milliseconds to wait for the application to start. Defaults to `30000` (30 seconds). Pass `0` to disable timeout.