npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

node-simctl

v7.6.2

Published

Wrapper around Apple's simctl binary

Downloads

1,335,169

Readme

node-simctl

NPM version Downloads

Release

ES6/7 Node wrapper around Apple's simctl binary, the "Command line utility to control the iOS Simulator". simctl is run as a sub-command of xcrun

Installation

Install through npm.

npm install node-simctl

API

The module exports single class Simctl. This class contains methods which wrap the following simctl subcommands:

create (Create a new device)

  • createDevice *

clone (Clone an existing device)

None

upgrade (Upgrade a device to a newer runtime)

None

delete (Delete specified devices, unavailable devices, or all devices)

  • deleteDevice

pair (Create a new watch and phone pair)

None

unpair (Unpair a watch and phone pair)

None

pair_activate (Set a given pair as active)

None

erase (Erase a device's contents and settings)

  • eraseDevice

boot (Boot a device)

  • bootDevice

shutdown (Shutdown a device)

  • shutdownDevice

rename (Rename a device)

None

getenv (Print an environment variable from a running device)

  • getEnv

openurl (Open a URL in a device)

  • openUrl

addmedia (Add photos, live photos, videos, or contacts to the library of a device)

  • addMedia

install (Install an app on a device)

  • installApp

uninstall (Uninstall an app from a device)

  • uninstallApp

get_app_container (Print the path of the installed app's container)

  • getAppContainer

launch (Launch an application by identifier on a device)

  • launchApp

terminate (Terminate an application by identifier on a device)

  • terminateApp

spawn (Spawn a process by executing a given executable on a device)

  • spawnProcess
  • spawnSubProcess

list (List available devices, device types, runtimes, or device pairs)

  • getDevicesByParsing *
  • getDevices *
  • getRuntimeForPlatformVersionViaJson *
  • getRuntimeForPlatformVersion *
  • getDeviceTypes *
  • list *

icloud_sync (Trigger iCloud sync on a device)

None

pbsync (Sync the pasteboard content from one pasteboard to another)

None

pbcopy (Copy standard input onto the device pasteboard)

  • setPasteboard

pbpaste (Print the contents of the device's pasteboard to standard output)

  • getPasteboard

help (Prints the usage for a given subcommand)

None

io (Set up a device IO operation)

  • getScreeenshot

diagnose (Collect diagnostic information and logs)

None

logverbose (enable or disable verbose logging for a device)

None

status_bar (Set or clear status bar overrides)

None

ui (Get or Set UI options)

  • getAppearance
  • setAppearance

push (Send a simulated push notification)

  • pushNotification

privacy (Grant, revoke, or reset privacy and permissions)

  • grantPermission
  • revokePermission
  • resetPermission

keychain (Manipulate a device's keychain)

  • addRootCertificate
  • addCertificate
  • resetKeychain

appinfo (Undocumented)

  • appInfo

bootstatus (Undocumented)

  • startBootMonitor

Methods marked with the star (*) character do not require the udid property to be set on the Simctl instance upon their invocation. All other methods will throw an error if the udid property is unset while they are being invoked.

All public methods are supplied with docstrings that describe their arguments and returned values.

The Simctl class constructor supports the following options:

  • xcrun (Object): The xcrun properties. Currently only one property is supported, which is path and it by default contains null, which enforces the instance to automatically detect the full path to xcrun tool and to throw an exception if it cannot be detected. If the path is set upon instance creation then it is going to be used by exec and no autodetection will happen.
  • execTimeout (number[600000]): The maximum number of milliseconds to wait for a single synchronous xcrun command.
  • logErrors (boolean[true]): Whether to write xcrun error messages into the debug log before throwing them as errors.
  • udid (string[null]): The unique identifier of the current device, which is going to be implicitly passed to all methods, which require it (see above). It can either be set upon instance creation if it is already known or later when/if needed via the corresponding setter.
  • devicesSetPath (string[null]): Full path to the set of devices that you want to manage. By default this path usually equals to ~/Library/Developer/CoreSimulator/Devices. This option has a getter and a setter which allows to switch between multiple device sets during the Simctl instance life cycle.

Advanced Usage

Any simctl subcommand could be called via exec method, which accepts the subcommand itself as the first argument and the set of options, which may contain additional command args, environment variables, encoding, etc. For example:

import Simctl from 'node-simctl';

const simctl = new Simctl();
const name = 'My Device Name';
simctl.udid = await simctl.createDevice(name, 'iPhone X', '13.3');
await simctl.bootDevice();
await simctl.startBootMonitor({timeout: 120000});
await simctl.exec('pbsync');
console.log(`Pasteboard content: ${await simctl.getPasteboard()}`);
const {stdout} = await simctl.exec('status_bar', {
  args: [simctl.udid, 'list']
});
console.log(output);
simctl.udid = void(await simctl.deleteDevice());

See specs for examples of usage.

Running Multiple Simulator SDKs On a Single Computer

It is possible to run multiple simulators using different Xcode SDKs on a single machine. Simply set a proper value to DEVELOPER_DIR environment variable for each process.

Read this MacOps article for more details.