Mastering iOS Simulator Control with simctl (Part 1)

July 16, 20234 min read#ios, #simulator, #simrecorder, #swift

iOS Simulator

Introduction:

As an iOS developer, the iOS Simulator is an indispensable tool in your toolkit. It allows you to test and debug your applications on a variety of iOS devices without the need for physical devices. One powerful command-line tool that helps you control the iOS Simulator is simctl. In this blog post, we will explore the most common and useful simctl commands to efficiently manage and manipulate iOS simulators.

Listing Available Devices:

Before diving into simulator control, it’s helpful to know the available devices. Use the following command to list all the available iOS simulators:

xcrun simctl list devices

Creating a New Simulator:

To create a new iOS simulator, use the following command:

xcrun simctl create <name> <device_type> <runtime>

Here, <name> is the desired name for the simulator, <device_type> represents the device type (e.g., “iPhone 12 Pro”), and <runtime> specifies the iOS runtime version (e.g., “14.5”).

Booting and Shutting Down Simulators:

To boot a simulator, use the following command:

xcrun simctl boot <device>

To shut down a simulator, replace boot with shutdown.

Installing an App:

To install an app on a simulator, you need to provide the app’s bundle path. Use the following command:

xcrun simctl install <device> <path_to_app_bundle>

Replace <device> with the desired simulator and <path_to_app_bundle> with the location of the app’s .app bundle.

Launching an App:

Once the app is installed, you can launch it on a simulator using:

xcrun simctl launch <device> <bundle_identifier>

Replace <device> with the target simulator and <bundle_identifier> with the app’s bundle identifier.

Uninstalling an App:

To remove an app from a simulator, use the following command:

xcrun simctl uninstall <device> <bundle_identifier>

Replace <device> with the desired simulator and <bundle_identifier> with the app’s bundle identifier.

Simulating Location:

Simulating location on a simulator can be useful for testing location-based features. Use the following command to set a specific location:

xcrun simctl location <device> <latitude> <longitude>

Replace <device> with the target simulator, <latitude> with the desired latitude, and <longitude> with the desired longitude.

Device Management:

simctl also offers various device management commands:

  • To erase a simulator’s contents and settings, use xcrun simctl erase <device>.
  • To rename a simulator, use xcrun simctl rename <device> <new_name>.
  • To delete a simulator, use xcrun simctl delete <device>.

These commands allow you to manage your simulators efficiently.

Conclusion:

The simctl command-line tool is an essential asset for iOS developers when working with iOS simulators. It provides a wide range of capabilities, from creating and managing simulators to installing and launching apps. With the commands outlined in this blog post, you can streamline your iOS development workflow and ensure efficient testing and debugging processes.

Remember, practice is key to mastering simctl. Experiment with different commands and explore additional options to enhance your familiarity with this powerful tool. Happy simulating!

Quick Drop logo

Profile picture

Personal blog by An Tran. I'm focusing on creating useful apps.
#Swift #Kotlin #Mobile #MachineLearning #Minimalist


© An Tran - 2025