mirror of
https://github.com/microsoft/vcpkg.git
synced 2024-12-17 05:37:50 +08:00
decc96c149
Co-authored-by: Billy Robert O'Neal III <bion@microsoft.com>
212 lines
6.9 KiB
Markdown
212 lines
6.9 KiB
Markdown
# `vcpkg-eg-mac` VMs
|
|
|
|
## Table of Contents
|
|
|
|
- [`vcpkg-eg-mac` VMs](#vcpkg-eg-mac-vms)
|
|
- [Table of Contents](#table-of-contents)
|
|
- [Basic Usage](#basic-usage)
|
|
- [Setting up a new macOS machine](#setting-up-a-new-macos-machine)
|
|
|
|
## Basic Usage
|
|
|
|
The simplest usage, and one which should be used for when spinning up
|
|
new VMs, and when restarting old ones, is a simple:
|
|
|
|
```
|
|
$ cd ~/vagrant/vcpkg-eg-mac
|
|
$ vagrant up
|
|
```
|
|
|
|
Any modifications to the machines should be made in `configuration/Vagrantfile`
|
|
and `Setup-VagrantMachines.ps1`, and make sure to push any changes!
|
|
|
|
## Setting up a new macOS machine
|
|
|
|
Before anything else, one must download `brew` and `powershell`.
|
|
|
|
```sh
|
|
$ /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"
|
|
$ brew cask install powershell
|
|
```
|
|
|
|
Then, we need to download the `vcpkg` repository:
|
|
|
|
```sh
|
|
$ git clone https://github.com/microsoft/vcpkg
|
|
```
|
|
|
|
Then, we need to mint an SSH key:
|
|
|
|
```sh
|
|
$ ssh-keygen
|
|
$ cat .ssh/id_rsa.pub
|
|
```
|
|
|
|
Add that SSH key to `authorized_keys` on the file share machine with the base box.
|
|
|
|
Next, install prerequisites and grab the current base box with:
|
|
```sh
|
|
$ cd vcpkg/scripts/azure-pipelines/osx
|
|
$ ./Install-Prerequisites.ps1 -Force
|
|
$ ./Get-InternalBaseBox.ps1 -FileshareMachine vcpkgmm-01.guest.corp.microsoft.com
|
|
```
|
|
|
|
Getting the base box will fail due to missing kernel modules for sshfs and VirtualBox. Log in to the
|
|
machine, open System Preferences > Security & Privacy > General, and allow the kernel extensions for
|
|
VirtualBox and sshfs to load. Then, again:
|
|
|
|
```sh
|
|
$ ./Get-InternalBaseBox.ps1 -FileshareMachine vcpkgmm-01.guest.corp.microsoft.com
|
|
```
|
|
|
|
Replace `XX` with the number of
|
|
the virtual machine. Generally, that should be the same as the number
|
|
for the physical machine; i.e., vcpkgmm-04 would use 04.
|
|
|
|
```sh
|
|
# NOTE: you may get an error about CoreCLR; see the following paragraph if you do
|
|
$ ./Setup-VagrantMachines.ps1 \
|
|
-MachineId XX \
|
|
-DevopsPat '<get this from azure devops; it needs agent pool read and manage access>' \
|
|
-Date <this is the date of the pool; 2020-09-28 at time of writing> \
|
|
-ArchivesMachine 'vcpkgmm-01.guest.corp.microsoft.com'
|
|
$ cd ~/vagrant/vcpkg-eg-mac
|
|
$ vagrant up
|
|
```
|
|
|
|
If you see the following error:
|
|
|
|
```
|
|
Failed to initialize CoreCLR, HRESULT: 0x8007001F
|
|
```
|
|
|
|
You have to reboot the machine; run
|
|
|
|
```sh
|
|
$ sudo shutdown -r now
|
|
```
|
|
|
|
and wait for the machine to start back up. Then, start again from where the error was emitted.
|
|
|
|
## Creating a new Vagrant box
|
|
|
|
Whenever we want to install updated versions of the command line tools,
|
|
or of macOS, we need to create a new vagrant box.
|
|
This is pretty easy, but the results of the creation are not public,
|
|
since we're concerned about licensing.
|
|
However, if you're sure you're following Apple's licensing,
|
|
you can set up your own vagrant boxes that are the same as ours by doing the following:
|
|
|
|
You'll need some prerequisites:
|
|
|
|
- macinbox - installable via `sudo gem install macinbox`
|
|
- vagrant - found at <https://www.vagrantup.com/>
|
|
- VirtualBox - found at <https://www.virtualbox.org/>
|
|
- A macOS installer application - you can get this from the App Store (although I believe only the latest is available)
|
|
- An Xcode Command Line Tools installer - you can get this from Apple's developer website,
|
|
although you'll need to sign in first: <https://developer.apple.com/downloads>
|
|
|
|
First, you'll need to create a base box;
|
|
this is where you determine what version of macOS is installed.
|
|
|
|
```
|
|
> sudo macinbox \
|
|
--box-format virtualbox \
|
|
--name macos-ci-base \
|
|
--installer <path to macOS installer> \
|
|
--no-gui
|
|
```
|
|
|
|
Once you've done that, create a Vagrantfile that looks like the following:
|
|
|
|
```rb
|
|
Vagrant.configure('2') do |config|
|
|
config.vm.box = 'macos-ci-base'
|
|
config.vm.boot_timeout = 600
|
|
config.vm.synced_folder ".", "/vagrant", disabled: true
|
|
end
|
|
```
|
|
|
|
then, run the following in that vagrant directory:
|
|
|
|
```sh
|
|
$ vagrant up
|
|
$ vagrant scp <path to Command Line Tools for Xcode installer> :clt.dmg
|
|
$ vagrant ssh -c 'hdiutil attach clt.dmg -mountpoint /Volumes/setup-installer'
|
|
$ vagrant ssh -c 'sudo installer -pkg "/Volumes/setup-installer/Command Line Tools.pkg" -target /'
|
|
$ vagrant ssh -c 'hdiutil detach /Volumes/setup-installer'
|
|
$ vagrant ssh -c 'rm clt.dmg'
|
|
$ vagrant ssh -c '/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"'
|
|
$ vagrant ssh -c 'ssh-keygen -t rsa -b 4096 -c "Fileshare Key: <date>" -N "" -f "~/.ssh/id_rsa"'
|
|
$ vagrant ssh -c 'cat ~/.ssh/id_rsa.pub'
|
|
$ vagrant ssh -c 'brew cask install osxfuse && brew install sshfs'
|
|
$ vagrant reload
|
|
```
|
|
|
|
After this, you should add the printed ssh public key to the archives share's `.ssh/authorized_keys` file.
|
|
Then, we also now need to make sure that osxfuse is set up correctly;
|
|
macOS requires the user to accept that this signed binary is "okay to be loaded" by the kernel.
|
|
We can get `sshfs` to try to start the `osxfuse` kernel module by attempting to start it:
|
|
|
|
```sh
|
|
$ vagrant ssh -c 'mkdir testmnt && sshfs <fileshare ssh>:/Users/fileshare/share testmnt'
|
|
```
|
|
|
|
Then, you'll need to open the VM in VirtualBox, go to System Preferences,
|
|
go to Security & Privacy, General, unlock the settings,
|
|
and allow system extensions from the osxfuse developer to run.
|
|
|
|
Then, retry the above, and see if it works:
|
|
|
|
```sh
|
|
$ vagrant ssh -c 'sshfs <fileshare ssh>:/Users/fileshare/share testmnt'
|
|
```
|
|
|
|
if that works, you can now package the box:
|
|
|
|
```sh
|
|
$ vagrant ssh -c 'umount testmnt && rmdir testmnt'
|
|
$ vagrant package
|
|
```
|
|
|
|
This will create a `package.box`, which is the box file for the base VM.
|
|
Then, you can `vagrant box add <package.box> --name <name for the box>`,
|
|
and you'll have the base vcpkg box added for purposes of `Setup-VagrantMachines.ps1`!
|
|
|
|
Once you've created the base box, if you're making it the new base box for the CI,
|
|
upload it to the fileshare, under `share/vcpkg-boxes`.
|
|
Then, add the metadata about the box (the name and version) to the JSON file there.
|
|
Once you've done that, add the software versions under [VM Software Versions](#vm-software-versions).
|
|
|
|
### VM Software Versions
|
|
|
|
* 2020-09-28:
|
|
* macOS: 10.15.6
|
|
* Xcode CLTs: 12
|
|
|
|
### (Internal) Accessing the macOS fileshare
|
|
|
|
The fileshare is located on `vcpkgmm-01`, under the `fileshare` user, in the `share` directory.
|
|
In order to get `sshfs` working on the physical machine,
|
|
you'll need to do the same thing one needs to do for building the base box.
|
|
You can run `Install-Prerequisites.ps1` to grab the right software, then either:
|
|
|
|
```sh
|
|
$ mkdir vagrant/share
|
|
$ sshfs fileshare@<vcpkgmm-01 URN>:/Users/fileshare/share vagrant/share
|
|
```
|
|
|
|
or you can just run
|
|
|
|
```sh
|
|
$ ./Get-InternalBaseBox.ps1
|
|
```
|
|
|
|
which will do the thing automatically.
|
|
|
|
If you get an error, that means that gatekeeper has prevented the kernel extension from loading,
|
|
so you'll need to access the GUI of the machine, go to System Preferences,
|
|
Security & Privacy, General, unlock the settings,
|
|
and allow system extensions from the osxfuse developer to run.
|
|
Then, you'll be able to add the fileshare as an sshfs.
|