मुख्य सामग्री पर जाएं

API Reference

This document provides a complete reference for all browser.electron.* methods and exported utility functions provided by the service.

Table of Contents


Utility Functions

These functions are exported directly from the package and can be used independently of the WDIO test runner.

createElectronCapabilities()

Creates an Electron capabilities object for use with startWdioSession() or in WDIO configuration. Builds the correct capability structure including goog:chromeOptions and wdio:electronServiceOptions.

Signature:

import { createElectronCapabilities } from '@wdio/electron-service';

createElectronCapabilities(options: ElectronServiceOptions): ElectronStandaloneCapability

Parameters:

ParameterTypeDescription
optionsElectronServiceOptionsService options. Must include at least appBinaryPath or appEntryPoint.

Common fields:

FieldTypeDescription
appBinaryPathstringPath to the compiled Electron app binary
appEntryPointstringPath to the unpackaged app entry point (e.g., main.js)
appArgsstring[]Command-line arguments passed to the app
captureMainProcessLogsbooleanEnable main process log capture
captureRendererLogsbooleanEnable renderer process log capture
logDirstringDirectory for standalone mode logs

See Configuration for the full list of ElectronServiceOptions fields.

Returns:

ElectronStandaloneCapability - A single capabilities object

Throws:

ErrorCondition
ErrorIf neither appBinaryPath nor appEntryPoint is provided

Example:

import { startWdioSession, createElectronCapabilities } from '@wdio/electron-service';

const caps = createElectronCapabilities({
appBinaryPath: './dist/mac/MyApp.app/Contents/MacOS/MyApp',
appArgs: ['--disable-gpu', '--headless'],
captureMainProcessLogs: true,
logDir: './test-logs',
});

const browser = await startWdioSession([caps]);

See Also:


getElectronBinaryPath()

Resolves the path to the Electron binary for a given app directory. Uses the same detection logic as the service (reading package.json, checking Electron Forge/Builder configs) without starting a session.

Signature:

import { getElectronBinaryPath } from '@wdio/electron-service';

getElectronBinaryPath(appDir: string): Promise<string>

Parameters:

ParameterTypeDescription
appDirstringPath to the Electron app directory (must contain a package.json)

Returns:

Promise<string> - The resolved path to the Electron binary

Throws:

ErrorCondition
ErrorIf no package.json is found in appDir
ErrorIf the binary path cannot be resolved

Example:

import { getElectronBinaryPath } from '@wdio/electron-service';

const binaryPath = await getElectronBinaryPath('/path/to/my-electron-app');
console.log(binaryPath);
// e.g. '/path/to/my-electron-app/dist/mac-arm64/MyApp.app/Contents/MacOS/MyApp'

See Also:


startWdioSession()

Starts a WebdriverIO session in standalone mode (without the WDIO test runner). Performs the same launcher setup the runner does — binary detection, capability mutation, log writer initialization — and returns a browser instance.

Signature:

import { startWdioSession } from '@wdio/electron-service';

startWdioSession(
capabilities: ElectronServiceCapabilities,
globalOptions?: ElectronServiceGlobalOptions,
): Promise<WebdriverIO.Browser>

Parameters:

ParameterTypeDescription
capabilitiesElectronServiceCapabilitiesAn array of standalone capability objects (typically one, built with createElectronCapabilities()), or a multiremote capabilities object.
globalOptionsElectronServiceGlobalOptionsOptional. Service-level options applied to all capabilities (e.g., rootDir).

Returns:

Promise<WebdriverIO.Browser> - The browser instance, with browser.electron.* available.

Example:

import { startWdioSession, cleanupWdioSession, createElectronCapabilities } from '@wdio/electron-service';

const caps = createElectronCapabilities({
appBinaryPath: '/path/to/MyApp',
captureMainProcessLogs: true,
logDir: './logs',
});

const browser = await startWdioSession([caps]);

try {
const name = await browser.electron.execute((electron) => electron.app.getName());
console.log(name);
} finally {
await cleanupWdioSession(browser);
}

See Also:


cleanupWdioSession()

Tears down a standalone session started with startWdioSession(). Calls browser.deleteSession() and runs the launcher's onComplete cleanup so the Electron process and any spawned drivers are released.

Signature:

import { cleanupWdioSession } from '@wdio/electron-service';

cleanupWdioSession(browser: WebdriverIO.Browser): Promise<void>

Parameters:

ParameterTypeDescription
browserWebdriverIO.BrowserThe browser instance returned from startWdioSession().

Returns:

Promise<void>

See Also:


Execution Methods

execute()

Executes arbitrary JavaScript code in the Electron main process context.

Signature:

browser.electron.execute<T>(
script: (electron, ...args) => T | Promise<T>,
...args: any[]
): Promise<T>

Parameters:

ParameterTypeDescription
script(electron, ...args) => T | Promise<T>Function to execute in main process. First arg is always the electron module.
...argsany[]Additional arguments passed to the script function

Returns:

Promise<T> - Resolves with the return value of the script

Example:

// Simple execution
const appName = await browser.electron.execute((electron) => {
return electron.app.getName();
});

// With parameters
const result = await browser.electron.execute(
(electron, param1, param2) => {
return param1 + param2;
},
5,
10
);

// With async code
const fileIcon = await browser.electron.execute(async (electron) => {
return await electron.app.getFileIcon('/path/to/file');
});

See Also:


Triggers a deeplink to the Electron application for testing protocol handlers.

On Windows and Linux, this automatically appends the test instance's userData directory to ensure the deeplink reaches the correct instance. On macOS, it works transparently without modification.

Signature:

browser.electron.triggerDeeplink(url: string): Promise<void>

Parameters:

ParameterTypeDescription
urlstringThe deeplink URL to trigger (e.g., 'myapp://open?path=/test'). Must use a custom protocol scheme (not http/https/file).

Returns:

Promise<void> - Resolves when the deeplink has been triggered.

Throws:

ErrorCondition
ErrorIf appBinaryPath is not configured (Windows/Linux only)
ErrorIf the URL is invalid or malformed
ErrorIf the URL uses http/https/file protocols
ErrorIf the platform is unsupported
ErrorIf the command to trigger the deeplink fails

Example:

// Basic usage
await browser.electron.triggerDeeplink('myapp://open?file=test.txt');

// With complex parameters
await browser.electron.triggerDeeplink('myapp://action?id=123&type=user&tags[]=a&tags[]=b');

// In a test with verification
it('should handle deeplinks', async () => {
await browser.electron.triggerDeeplink('myapp://navigate?to=/settings');

await browser.waitUntil(async () => {
const currentPath = await browser.electron.execute(() => {
return globalThis.currentPath;
});
return currentPath === '/settings';
}, {
timeout: 5000,
timeoutMsg: 'App did not process the deeplink'
});
});

Platform-Specific Behavior:

  • Windows: Cannot use appEntryPoint (must use packaged binary). Automatically appends userData parameter to URL.
  • macOS: Works with both packaged binaries and script-based apps. No URL modification.
  • Linux: Cannot use appEntryPoint (must use packaged binary). Automatically appends userData parameter to URL.

See Also:


Mocking Methods

mock()

Mocks an Electron API function when provided with an API name and function name. Returns a mock object.

When called with only an API name (no function name), mocks an entire Electron class (e.g., 'Tray', 'BrowserWindow'). Returns an Electron class mock object.

Signature:

// Mock a specific function
browser.electron.mock(apiName: string, funcName: string): Promise<ElectronMock>

// Mock an entire class
browser.electron.mock(className: string): Promise<ElectronClassMock>

Parameters:

ParameterTypeDescription
apiNamestringThe Electron API module name (e.g., 'dialog', 'app', 'clipboard') or class name (e.g., 'Tray', 'BrowserWindow')
funcNamestringOptional. The function name to mock (e.g., 'showOpenDialog', 'getName'). If omitted, mocks the entire class.

Returns:

Promise<ElectronMock> - An Electron mock object (function mock or class mock) with methods for controlling and inspecting the mock

Example:

const mockedShowOpenDialog = await browser.electron.mock('dialog', 'showOpenDialog');
await browser.electron.execute(
async (electron) =>
await electron.dialog.showOpenDialog({
properties: ['openFile', 'openDirectory'],
}),
);

expect(mockedShowOpenDialog).toHaveBeenCalledTimes(1);
expect(mockedShowOpenDialog).toHaveBeenCalledWith({
properties: ['openFile', 'openDirectory'],
});

// Class mocking
const mockTray = await browser.electron.mock('Tray');
await mockTray.setTitle.mockReturnValue(undefined);

// Track constructor calls
const tray = await browser.electron.execute((electron) => new electron.Tray('/path/to/icon.png'));
expect(mockTray.__constructor).toHaveBeenCalledWith('/path/to/icon.png');

// Mock instance methods
await browser.electron.execute((electron) => {
const tray = new electron.Tray('/path/to/icon.png');
tray.setTitle('My App');
});
expect(mockTray.setTitle).toHaveBeenCalledWith('My App');

See Also:


mockAll()

Mocks all functions on an Electron API module simultaneously. Returns an object containing all mocks.

Signature:

browser.electron.mockAll(apiName: string): Promise<Record<string, ElectronMock>>

Parameters:

ParameterTypeDescription
apiNamestringThe Electron API module name (e.g., 'dialog', 'app')

Returns:

Promise<Record<string, ElectronMock>> - Object with function names as keys and mock objects as values

Example:

const { showOpenDialog, showMessageBox } = await browser.electron.mockAll('dialog');
await showOpenDialog.mockReturnValue('I opened a dialog!');
await showMessageBox.mockReturnValue('I opened a message box!');

See Also:


clearAllMocks()

Calls mockClear() on all active mocks, or on mocks of a specific API if apiName is provided.

Signature:

browser.electron.clearAllMocks(apiName?: string): Promise<void>

Parameters:

ParameterTypeDescription
apiNamestringOptional. If provided, only clears mocks of this specific API

Returns:

Promise<void>

Example:

// Clear all mocks
const mockSetName = await browser.electron.mock('app', 'setName');
const mockWriteText = await browser.electron.mock('clipboard', 'writeText');

await browser.electron.execute((electron) => electron.app.setName('new app name'));
await browser.electron.execute((electron) => electron.clipboard.writeText('text to be written'));

await browser.electron.clearAllMocks();

expect(mockSetName.mock.calls).toStrictEqual([]);
expect(mockWriteText.mock.calls).toStrictEqual([]);

// Clear mocks of specific API
await browser.electron.clearAllMocks('app');
expect(mockSetName.mock.calls).toStrictEqual([]);
expect(mockWriteText.mock.calls).toStrictEqual([['text to be written']]);

resetAllMocks()

Calls mockReset() on all active mocks, or on mocks of a specific API if apiName is provided.

Signature:

browser.electron.resetAllMocks(apiName?: string): Promise<void>

Parameters:

ParameterTypeDescription
apiNamestringOptional. If provided, only resets mocks of this specific API

Returns:

Promise<void>

Example:

const mockGetName = await browser.electron.mock('app', 'getName');
const mockReadText = await browser.electron.mock('clipboard', 'readText');
await mockGetName.mockReturnValue('mocked appName');
await mockReadText.mockReturnValue('mocked clipboardText');

await browser.electron.resetAllMocks();

const appName = await browser.electron.execute((electron) => electron.app.getName());
const clipboardText = await browser.electron.execute((electron) => electron.clipboard.readText());
expect(appName).toBeUndefined();
expect(clipboardText).toBeUndefined();

restoreAllMocks()

Calls mockRestore() on all active mocks, or on mocks of a specific API if apiName is provided.

Signature:

browser.electron.restoreAllMocks(apiName?: string): Promise<void>

Parameters:

ParameterTypeDescription
apiNamestringOptional. If provided, only restores mocks of this specific API

Returns:

Promise<void>

Example:

const mockGetName = await browser.electron.mock('app', 'getName');
const mockReadText = await browser.electron.mock('clipboard', 'readText');
await mockGetName.mockReturnValue('mocked appName');
await mockReadText.mockReturnValue('mocked clipboardText');

await browser.electron.restoreAllMocks();

const appName = await browser.electron.execute((electron) => electron.app.getName());
const clipboardText = await browser.electron.execute((electron) => electron.clipboard.readText());
expect(appName).toBe('my real app name');
expect(clipboardText).toBe('some real clipboard text');

isMockFunction()

Checks if a given parameter is an Electron mock function. If using TypeScript, narrows down the type.

Signature:

browser.electron.isMockFunction(fn: any): fn is ElectronMock

Parameters:

ParameterTypeDescription
fnanyThe value to check

Returns:

boolean - true if the value is a mock function, false otherwise

Example:

const mockGetName = await browser.electron.mock('app', 'getName');

expect(browser.electron.isMockFunction(mockGetName)).toBe(true);
expect(browser.electron.isMockFunction(() => {})).toBe(false);

Mock Object Methods

Each mock object returned by mock() or mockAll() has the following methods:

mockImplementation()

Accepts a function that will be used as the implementation of the mock.

Signature:

mockImplementation(fn: (...args: any[]) => any): Promise<ElectronFunctionMock>

Parameters:

ParameterTypeDescription
fn(...args: any[]) => anyFunction to use as mock implementation

Returns:

Promise<ElectronFunctionMock> - Resolves with the mock object for chaining

Example:

const mockGetName = await browser.electron.mock('app', 'getName');
let callsCount = 0;
await mockGetName.mockImplementation(() => {
if (typeof callsCount !== 'undefined') {
callsCount++;
}
return 'mocked value';
});

const result = await browser.electron.execute(async (electron) => await electron.app.getName());
expect(callsCount).toBe(1);
expect(result).toBe('mocked value');

mockImplementationOnce()

Accepts a function that will be used as mock's implementation during the next call. If chained, every consecutive call will produce different results. When the queued implementations run out, the mock falls back to whatever was set via mockImplementation(); if no default has been set, calls return undefined (or null when the original API returns null).

Signature:

mockImplementationOnce(fn: (...args: any[]) => any): Promise<ElectronFunctionMock>

Parameters:

ParameterTypeDescription
fn(...args: any[]) => anyFunction to use for the next call

Returns:

Promise<ElectronFunctionMock> - Resolves with the mock object for chaining

Example:

const mockGetName = await browser.electron.mock('app', 'getName');
await mockGetName.mockImplementationOnce(() => 'first mock');
await mockGetName.mockImplementationOnce(() => 'second mock');

let name = await browser.electron.execute((electron) => electron.app.getName());
expect(name).toBe('first mock');
name = await browser.electron.execute((electron) => electron.app.getName());
expect(name).toBe('second mock');
name = await browser.electron.execute((electron) => electron.app.getName());
expect(name).toBeNull();

mockReturnValue()

Accepts a value that will be returned whenever the mock function is called.

Signature:

mockReturnValue(value: any): Promise<ElectronFunctionMock>

Parameters:

ParameterTypeDescription
valueanyValue to return from the mock

Returns:

Promise<ElectronFunctionMock> - Resolves with the mock object for chaining

Example:

const mockGetName = await browser.electron.mock('app', 'getName');
await mockGetName.mockReturnValue('mocked name');

const name = await browser.electron.execute((electron) => electron.app.getName());
expect(name).toBe('mocked name');

mockReturnValueOnce()

Accepts a value that will be returned during the next function call. If chained, every consecutive call will return the specified value. When values run out, falls back to the previously defined implementation.

Signature:

mockReturnValueOnce(value: any): Promise<ElectronFunctionMock>

Parameters:

ParameterTypeDescription
valueanyValue to return for the next call

Returns:

Promise<ElectronFunctionMock> - Resolves with the mock object for chaining

Example:

const mockGetName = await browser.electron.mock('app', 'getName');
await mockGetName.mockReturnValueOnce('first mock');
await mockGetName.mockReturnValueOnce('second mock');

let name = await browser.electron.execute((electron) => electron.app.getName());
expect(name).toBe('first mock');
name = await browser.electron.execute((electron) => electron.app.getName());
expect(name).toBe('second mock');
name = await browser.electron.execute((electron) => electron.app.getName());
expect(name).toBeNull();

mockResolvedValue()

Accepts a value that will be resolved (for async functions) whenever the mock is called.

Signature:

mockResolvedValue(value: any): Promise<ElectronFunctionMock>

Parameters:

ParameterTypeDescription
valueanyValue to resolve from the mock

Returns:

Promise<ElectronFunctionMock> - Resolves with the mock object for chaining

Example:

const mockGetFileIcon = await browser.electron.mock('app', 'getFileIcon');
await mockGetFileIcon.mockResolvedValue('This is a mock');

const fileIcon = await browser.electron.execute(async (electron) => await electron.app.getFileIcon('/path/to/icon'));

expect(fileIcon).toBe('This is a mock');

mockResolvedValueOnce()

Accepts a value that will be resolved during the next function call. If chained, every consecutive call will resolve the specified value. When values run out, falls back to the previously defined implementation.

Signature:

mockResolvedValueOnce(value: any): Promise<ElectronFunctionMock>

Parameters:

ParameterTypeDescription
valueanyValue to resolve for the next call

Returns:

Promise<ElectronFunctionMock> - Resolves with the mock object for chaining

Example:

const mockGetFileIcon = await browser.electron.mock('app', 'getFileIcon');

await mockGetFileIcon.mockResolvedValue('default mocked icon');
await mockGetFileIcon.mockResolvedValueOnce('first mocked icon');
await mockGetFileIcon.mockResolvedValueOnce('second mocked icon');

let fileIcon = await browser.electron.execute(async (electron) => await electron.app.getFileIcon('/path/to/icon'));
expect(fileIcon).toBe('first mocked icon');
fileIcon = await browser.electron.execute(async (electron) => await electron.app.getFileIcon('/path/to/icon'));
expect(fileIcon).toBe('second mocked icon');
fileIcon = await browser.electron.execute(async (electron) => await electron.app.getFileIcon('/path/to/icon'));
expect(fileIcon).toBe('default mocked icon');

mockRejectedValue()

Accepts a value that will be rejected (for async functions) whenever the mock is called.

Signature:

mockRejectedValue(value: any): Promise<ElectronFunctionMock>

Parameters:

ParameterTypeDescription
valueanyValue to reject from the mock

Returns:

Promise<ElectronFunctionMock> - Resolves with the mock object for chaining

Example:

const mockGetFileIcon = await browser.electron.mock('app', 'getFileIcon');
await mockGetFileIcon.mockRejectedValue('This is a mock error');

const fileIconError = await browser.electron.execute(async (electron) => {
try {
await electron.app.getFileIcon('/path/to/icon');
} catch (e) {
return e;
}
});

expect(fileIconError).toBe('This is a mock error');

mockRejectedValueOnce()

Accepts a value that will be rejected during the next function call. If chained, every consecutive call will reject the specified value. When values run out, falls back to the previously defined implementation.

Signature:

mockRejectedValueOnce(value: any): Promise<ElectronFunctionMock>

Parameters:

ParameterTypeDescription
valueanyValue to reject for the next call

Returns:

Promise<ElectronFunctionMock> - Resolves with the mock object for chaining

Example:

const mockGetFileIcon = await browser.electron.mock('app', 'getFileIcon');

await mockGetFileIcon.mockRejectedValue('default mocked icon error');
await mockGetFileIcon.mockRejectedValueOnce('first mocked icon error');
await mockGetFileIcon.mockRejectedValueOnce('second mocked icon error');

const getFileIcon = async () =>
await browser.electron.execute(async (electron) => {
try {
await electron.app.getFileIcon('/path/to/icon');
} catch (e) {
return e;
}
});

let fileIcon = await getFileIcon();
expect(fileIcon).toBe('first mocked icon error');
fileIcon = await getFileIcon();
expect(fileIcon).toBe('second mocked icon error');
fileIcon = await getFileIcon();
expect(fileIcon).toBe('default mocked icon error');

mockClear()

Clears the history of the mocked function. The mock implementation will not be reset.

Signature:

mockClear(): Promise<void>

Returns:

Promise<void>

Example:

const mockGetName = await browser.electron.mock('app', 'getName');
await browser.electron.execute((electron) => electron.app.getName());

await mockGetName.mockClear();

await browser.electron.execute((electron) => electron.app.getName());
expect(mockGetName).toHaveBeenCalledTimes(1);

mockReset()

Resets the mocked function. The mock history will be cleared and the implementation will be reset to an empty function (returning undefined). Also resets all "once" implementations.

Signature:

mockReset(): Promise<void>

Returns:

Promise<void>

Example:

const mockGetName = await browser.electron.mock('app', 'getName');
await mockGetName.mockReturnValue('mocked name');
await browser.electron.execute((electron) => electron.app.getName());

await mockGetName.mockReset();

const name = await browser.electron.execute((electron) => electron.app.getName());
expect(name).toBeUndefined();
expect(mockGetName).toHaveBeenCalledTimes(1);

mockRestore()

Restores the original implementation to the Electron API function.

Signature:

mockRestore(): Promise<void>

Returns:

Promise<void>

Example:

const appName = await browser.electron.execute((electron) => electron.app.getName());
const mockGetName = await browser.electron.mock('app', 'getName');
await mockGetName.mockReturnValue('mocked name');

await mockGetName.mockRestore();

const name = await browser.electron.execute((electron) => electron.app.getName());
expect(name).toBe(appName);

withImplementation()

Overrides the original mock implementation temporarily while the callback is being executed. The electron object is passed into the callback in the same way as for execute().

Signature:

withImplementation(
implementation: (...args: any[]) => any,
callback: (electron) => any
): Promise<any>

Parameters:

ParameterTypeDescription
implementation(...args: any[]) => anyTemporary implementation to use
callback(electron) => anyCallback function to execute with temporary implementation

Returns:

Promise<any> - Returns the result of the callback

Example:

const mockGetName = await browser.electron.mock('app', 'getName');
const withImplementationResult = await mockGetName.withImplementation(
() => 'temporary mock name',
(electron) => electron.app.getName(),
);

expect(withImplementationResult).toBe('temporary mock name');

// Async callback
const mockGetFileIcon = await browser.electron.mock('app', 'getFileIcon');
const result = await mockGetFileIcon.withImplementation(
() => Promise.resolve('temporary mock icon'),
async (electron) => await electron.app.getFileIcon('/path/to/icon'),
);

expect(result).toBe('temporary mock icon');

getMockImplementation()

Returns the current mock implementation if there is one. This call is synchronous — unlike most mock methods, it doesn't cross the CDP/WebDriver boundary because the implementation function is cached on the outer mock object in the test process.

Signature:

getMockImplementation(): Function | undefined

Returns:

Function | undefined - The current mock implementation function, or undefined if none is set

Example:

const mockGetName = await browser.electron.mock('app', 'getName');
await mockGetName.mockImplementation(() => 'mocked name');
const mockImpl = mockGetName.getMockImplementation();

expect(mockImpl()).toBe('mocked name');

getMockName()

Returns the assigned name of the mock. Defaults to electron.<apiName>.<funcName>.

Signature:

getMockName(): string

Returns:

string - The mock name

Example:

const mockGetName = await browser.electron.mock('app', 'getName');

expect(mockGetName.getMockName()).toBe('electron.app.getName');

mockName()

Assigns a name to the mock. The name can be retrieved via getMockName().

Signature:

mockName(name: string): ElectronFunctionMock

Parameters:

ParameterTypeDescription
namestringName to assign to the mock

Returns:

ElectronFunctionMock - Returns the mock object for chaining

Example:

const mockGetName = await browser.electron.mock('app', 'getName');

mockGetName.mockName('test mock');

expect(mockGetName.getMockName()).toBe('test mock');

mockReturnThis()

Useful if you need to return the this context from the method without invoking the original implementation. Shorthand for mockImplementation(function () { return this; }). Useful for builder-style APIs that chain calls on the same object.

Signature:

mockReturnThis(): Promise<ElectronFunctionMock>

Returns:

Promise<ElectronFunctionMock> - Resolves with the mock object for chaining

Example:

// `BrowserWindow.setMenuBarVisibility` is a void method. After mockReturnThis()
// it returns the BrowserWindow instance, allowing it to be chained.
const mockSetMenuBarVisibility = await browser.electron.mock('BrowserWindow', 'setMenuBarVisibility');
await mockSetMenuBarVisibility.mockReturnThis();

await browser.electron.execute((electron) => {
const win = electron.BrowserWindow.getFocusedWindow();
// setMenuBarVisibility now returns `win`, enabling the chained focus() call
win.setMenuBarVisibility(false).focus();
});

expect(mockSetMenuBarVisibility).toHaveBeenCalledWith(false);

Mock Object Properties

mock.calls

An array containing all arguments for each call. Each item of the array is the arguments of that call.

Type:

Array<Array<any>>

Example:

const mockGetFileIcon = await browser.electron.mock('app', 'getFileIcon');

await browser.electron.execute((electron) => electron.app.getFileIcon('/path/to/icon'));
await browser.electron.execute((electron) => electron.app.getFileIcon('/path/to/another/icon', { size: 'small' }));

expect(mockGetFileIcon.mock.calls).toStrictEqual([
['/path/to/icon'], // first call
['/path/to/another/icon', { size: 'small' }], // second call
]);

mock.lastCall

Contains the arguments of the last call. Returns undefined if the mock wasn't called.

Type:

Array<any> | undefined

Example:

const mockSetName = await browser.electron.mock('app', 'setName');

await browser.electron.execute((electron) => electron.app.setName('test'));
expect(mockSetName.mock.lastCall).toStrictEqual(['test']);
await browser.electron.execute((electron) => electron.app.setName('test 2'));
expect(mockSetName.mock.lastCall).toStrictEqual(['test 2']);
await browser.electron.execute((electron) => electron.app.setName('test 3'));
expect(mockSetName.mock.lastCall).toStrictEqual(['test 3']);

mock.results

An array containing all values that were returned from the mock. Each item is an object with type and value properties.

Type:

Array<{ type: 'return' | 'throw', value: any }>

Available types:

  • 'return' - the mock returned without throwing
  • 'throw' - the mock threw a value

The value property contains the returned value or thrown error. If the mock returned a promise, the value will be the resolved value, not the Promise itself, unless it was never resolved.

Example:

const mockGetName = await browser.electron.mock('app', 'getName');

await mockGetName.mockImplementationOnce(() => 'result');
await mockGetName.mockImplementation(() => {
throw new Error('thrown error');
});

await expect(browser.electron.execute((electron) => electron.app.getName())).resolves.toBe('result');
await expect(browser.electron.execute((electron) => electron.app.getName())).rejects.toThrow('thrown error');

expect(mockGetName.mock.results).toStrictEqual([
{
type: 'return',
value: 'result',
},
{
type: 'throw',
value: new Error('thrown error'),
},
]);

mock.invocationCallOrder

The order of mock invocation. Returns an array of numbers that are shared between all defined mocks. Returns an empty array if the mock was never invoked.

Type:

Array<number>

Example:

const mockGetName = await browser.electron.mock('app', 'getName');
const mockGetVersion = await browser.electron.mock('app', 'getVersion');

await browser.electron.execute((electron) => electron.app.getName());
await browser.electron.execute((electron) => electron.app.getVersion());
await browser.electron.execute((electron) => electron.app.getName());

expect(mockGetName.mock.invocationCallOrder).toStrictEqual([1, 3]);
expect(mockGetVersion.mock.invocationCallOrder).toStrictEqual([2]);

Electron Class Mock

Electron class mocks are returned when calling browser.electron.mock() with only a class name (no function name). They provide mocking capabilities for Electron classes like Tray, BrowserWindow, Menu, etc.

Class Mock Properties

__constructor

An ElectronFunctionMock object that tracks calls to the class constructor.

Type:

ElectronFunctionMock

Example:

const mockTray = await browser.electron.mock('Tray');

// Track constructor calls
await browser.electron.execute((electron) => {
new electron.Tray('/path/to/icon.png');
new electron.Tray('/path/to/other-icon.png');
});

expect(mockTray.__constructor).toHaveBeenCalledTimes(2);
expect(mockTray.__constructor.mock.calls).toStrictEqual([
['/path/to/icon.png'],
['/path/to/other-icon.png'],
]);

[methodName]

All instance methods of the class are available as ElectronFunctionMock objects.

Type:

ElectronFunctionMock

Example:

const mockTray = await browser.electron.mock('Tray');

// Mock instance methods
await mockTray.setTitle.mockReturnValue(undefined);
await mockTray.setToolTip.mockReturnValue(undefined);

// Use in tests
await browser.electron.execute((electron) => {
const tray = new electron.Tray('/path/to/icon.png');
tray.setTitle('My App');
tray.setToolTip('Click for menu');
});

expect(mockTray.setTitle).toHaveBeenCalledWith('My App');
expect(mockTray.setToolTip).toHaveBeenCalledWith('Click for menu');

Class Mock Methods

getMockName()

Returns the assigned name of the class mock. Defaults to electron.<className>.

Signature:

getMockName(): string

Returns:

string - The mock name

Example:

const mockTray = await browser.electron.mock('Tray');

expect(mockTray.getMockName()).toBe('electron.Tray');

mockRestore()

Restores the original Electron class, removing all mocks.

Signature:

mockRestore(): Promise<void>

Returns:

Promise<void>

Example:

const mockTray = await browser.electron.mock('Tray');

// Mock some behavior
await mockTray.setTitle.mockReturnValue(undefined);

// Restore original class
await mockTray.mockRestore();

// Original Tray class is now available
const tray = await browser.electron.execute((electron) => new electron.Tray('/path/to/icon.png'));
expect(tray).toBeDefined();

Welcome! How can I help?

WebdriverIO AI Copilot