Awesome
<img src="./assets/VirtualBuddyIcon.png" width="128" />VirtualBuddy
VirtualBuddy can virtualize macOS 12 and later on Apple Silicon, with the goal of offering features that are useful to developers who need to test their apps on multiple versions of macOS, especially betas.
System Requirements
- Apple Silicon Mac
- macOS 13 or later
Installing macOS
To install a macOS virtual machine, you can select from a list of macOS versions provided by VirtualBuddy, which will automatically download and install the selected version. You may also provide your own IPSW link or select from an IPSW you have already downloaded.
Installing macOS Betas
If you’d like to run a virtual machine with a macOS beta that’s more recent than the one you’re currently running, such as a macOS 15 virtual machine running in a macOS 14 host, then you’ll need the latest device support package from Apple.
Device support packages are sometimes made available by Apple directly, but they’re always included and installed automatically with the latest Xcode beta. These can be obtained from the Apple Developer portal.
Download
VirtualBuddy is free and open-source. If you’d like to support its development, you may purchase it on Gumroad or sponsor my work on GitHub.
If you’d just like to download the latest version, go to GitHub releases.
Feature Checklist
- Ability to boot any version of macOS 12 or macOS 13, including betas
- Ability to boot some ARM-based Linux distros (tested with Ubuntu Server and Ubuntu Desktop)
- Built-in installation wizard
- Select from a collection of restore images available on Apple’s servers
- Install the latest stable version of macOS
- Local restore image IPSW file
- Custom restore image URL
- Install a Linux distro from a local .iso file
- Select from a collection of Linux distros
- Install Linux from URL
- Boot into recovery mode (in order to disable SIP, for example)
- Networking and file sharing support
- Clipboard sharing
- Customize virtual machine hardware configuration
- Save and restore macOS virtual machine state
Tips and Tricks
VirtualBuddyGuest app
VirtualBuddy automatically mounts a disk image with the VirtualBuddyGuest app when you boot up a virtual machine running macOS. To install the VirtualBuddyGuest app, just select the “Guest” disk on Finder’s side bar then double-click the “VirtualBuddyGuest” app icon.
VirtualBuddyGuest enables clipboard sharing between host and guest and automatic mounting of the shared folders configured for the virtual machine.
Taking Advantage of APFS
Sometimes when trying things out in the OS installed in one of the virtual machines, things might break, requiring a full install of the guest operating system again, which is a pain.
Thanks to APFS cloning though, you can just duplicate a virtual machine within your library folder (using Command + D in Finder), and the copy will take almost no additional disk space. This way you can have a “clean” copy of your VM, do whatever you want with a duplicate of it, and then throw the copy away and re-duplicate the clean version if things break.
Sharing Folders Between Host and Virtual Machine
You can share folders from your Mac to the Virtual Machine and vice-versa using regular macOS file sharing that can be configured in System Preferences/Settings.
When both the Virtual Machine and the host are running macOS 13 or later, it’s possible to share folders directly by configuring them in the VM settings within VirtualBuddy before booting up the VM.
To mount shared folders in the VM, run the following command in the VM’s Terminal:
mkdir -p ~/Desktop/VirtualBuddyShared && mount -t virtiofs VirtualBuddyShared ~/Desktop/VirtualBuddyShared
Building
Xcode 16 is required for building on main
.
- Open the
VirtualBuddy/Config/Signing.xcconfig
file - Set the
VB_BUNDLE_ID_PREFIX
variable to something unique likecom.yourname.
- Select the VirtualBuddy project in the Xcode sidebar
- Under "Targets", select "VirtualBuddy"
- Go to the Signing & Capabilities tab and select your development team under Signing > Team
- Repeat the same process for the "VirtualBuddyGuest" target
- Build the
VirtualBuddy
scheme (the one that doesn't have(Managed)
in its name)