Skip to content

Module for interacting with iOS simulators (mainly directory-specific manipulations)

License

Notifications You must be signed in to change notification settings

mykola-mokhnach/appium-ios-simulator

 
 

Repository files navigation

appium-ios-simulator

NPM version Downloads

Appium API for dealing with iOS simulators. The API enables you to use the following features:

  • query locations of Simulator-specific directories and applications
  • read/write access to Simulator settings
  • full control over starting and stopping simulators
  • deal with biometric auth, geolocation settings, application permissions, and others

Usage

async getSimulator(udid)

This is the main entry of this module. This function returns a simulator object (see below) associated with the udid passed in. If an iOS simulator with the given udid does not exist already on this machine, it will throw an error.

If you want to create a new simulator, you can use the createDevice() method of node-simctl.

import { getSimulator } from 'appium-ios-simulator';
import assert from 'node:assert/strict';

const sim = await getSimulator('DAE95172-0788-4A85-8D0D-5C85509109E1');
await sim.run();
assert.equal('Booted', (await sim.stat()).state);
await sim.shutdown();
assert.equal('Shutdown', (await sim.stat()).state);

Third-party tools

The following tools and utilities are not mandatory, but could be used by the appium-ios-simulator, if installed locally, to extend its functionality:

Xcode and iOS versions

Check Xcode wikipedia for more details about Xcode version to iOS version mapping.

Development

Checkout the repository and run

npm install
npm run dev

Use the following commands to run tests:

# unit tests
npm run test
# integration tests
npm run e2e-test

About

Module for interacting with iOS simulators (mainly directory-specific manipulations)

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 92.9%
  • TypeScript 7.1%