Buildkite Test Agent Setup¶
We are using Buildkite for Windows and macOS testing. The build machines and buildkite-agent
must be set up before use.
Windows Test Agent Setup¶
- Create the user “testbot” on the machine. Use the password for
ddevtestbot@gmail.com
, available in 1Password. - In admin PowerShell,
wsl --install
. - (WSL2/Docker Desktop and traditional Windows only): Install either Docker Desktop for Windows (from the release notes page, which is best maintained) or Rancher Desktop. With Rancher Desktop, turn off Kubernetes. (Rancher Desktop on Windows appears to be too unreliable to use at this point in its history.)
- In admin PowerShell,
Set-ExecutionPolicy -Scope "CurrentUser" -ExecutionPolicy "Unrestricted"
. - In admin PowerShell, download and run windows_buildkite_start.ps1 with
curl <url> -O windows_buildkite_start.ps1
. - Install items as needed;
git
,jq
,mysql-cli
,golang
,make
are only required for a traditional Windows test machine.choco install -y git jq mysql-cli golang make mkcert netcat zip
. - After restart, in administrative Git Bash window,
Rename-Computer <testbot-win10(home|pro)-<description>-1
and thenexport BUILDKITE_AGENT_TOKEN=<token>
. - (Traditional Windows test runner only): Download and run windows_buildkite_setup.sh.
- If using Rancher Desktop, adjust the /c/buildkite-agent/buildkite-agent.cfg file to set
rancher-desktop=true
in the tags instead ofdocker-desktop
. If using Docker Desktop, setdocker-desktop=true
. - (Traditional Windows test runner only): Download and run windows_postinstall.sh.
- (Traditional Windows or Docker Desktop WSL2 Only) Launch Docker. It may require you to take further actions.
- Check “Start Docker Desktop when you sign in” or the equivalent with Rancher Desktop.
- Check “Add the *.docker.internal names to the host’s /etc/hosts file”
- Uncheck “SBOM Indexing”
- Under “Resources” uncheck “Resource Saver”
- After starting Docker Desktop or Rancher Desktop, set the correct Docker context in the Git Bash window with
docker context use desktop-linux
(Docker Desktop) ordocker context use default
(Rancher Desktop). - Log into Chrome with the user
ddevtestbot@gmail.com
and enable Chrome Remote Desktop. - (Traditional Windows test runner only): Enable gd, fileinfo, and curl extensions in
/c/tools/php*/php.ini
. - Set the “Sleep after time” setting in settings to never.
- Install winaero tweaker and “Enable user autologin checkbox”. Set up the machine to automatically log in on boot. Then run netplwiz, provide the password for the main user, uncheck “require a password to log in”.
- (Traditional Windows test runner only): Set the
buildkite-agent
service to run as the testbot user and use delayed start: Choose “Automatic, delayed start” and on the “Log On” tab in the services widget it must be set up to log in as the testbot user, so it inherits environment variables and home directory (and can access NFS, has testbot Git config, etc). - (Traditional Windows test runner only):
git config --global --add safe.directory '*'
. - (Traditional Windows test runner only): Manually run
testbot_maintenance.sh
,curl -sL -O https://raw.githubusercontent.com/ddev/ddev/main/.buildkite/testbot_maintenance.sh && bash testbot_maintenance.sh
. - (Traditional Windows test runner only): Run
.buildkite/sanetestbot.sh
to check your work. - (Traditional Windows test runner only): Reboot the machine and do a test run. (On Windows, the machine name only takes effect on reboot.)
- (Traditional Windows test runner only): Verify that
go
,ddev
,git-bash
are in the path. - In “Advanced Windows Update Settings” enable “Receive updates for other Microsoft products” to make sure you get WSL2 kernel upgrades. Make sure to run Windows Update to get the latest kernel.
- Turn off the settings that cause the “windows experience” prompts after new upgrades:
- In PowerShell:
wsl.exe --update
. Watch for the escalation to complete, it may require escalation.
Both Docker Desktop/WSL2 and Docker-ce/WSL2¶
- The Ubuntu distro should be set up with the user
buildkite-agent
and the password used forddevtestbot@gmail.com
. - Stop Docker Desktop if it is running.
-
(Optionally if hostname is not same as appropriate hostname for WSL2) set the hostname in
/etc/wsl.conf
in the network section, for example: -
Log into Chrome with the user
ddevtestbot@gmail.com
and enable Chrome Remote Desktop. - Windows Terminal should be installed. Set “Ubuntu” (or this distro) as the default and have it start on Windows startup. Enable “copy on select” in behaviors.
nc.exe -L -p 9003
on Windows to trigger and allow Windows Defender.-
Optionally edit the
~/.wslconfig
on Windows to add appropriate WSL2 memory allocation andautoMemoryReclaim
-
In the Ubuntu distro:
export BUILDKITE_AGENT_TOKEN=<token>
with the token from 1PasswordBUILDKITE_AGENT_TOKEN
.export BUILDKITE_DOCKER_TYPE=dockerforwindows
orexport BUILDKITE_DOCKER_TYPE=wsl2
- Optionally
export NGROK_TOKEN=<token>
with theNGROK_TOKEN
from 1Password ngrok.comnopaid
account. - Run the script wsl2-test-runner-setup.sh in the Ubuntu distro.
- Restart the distro with
wsl.exe -t Ubuntu
and then restart it by opening the Ubuntu window. - If using Docker Desktop, start Docker Desktop.
- In
~/workspace/ddev/.buildkite
, run./testbot_maintenance.sh
. - In
~/workspace/ddev/.buildkite
, run./sanetestbot.sh
to check your work.
Icinga2 monitoring setup for WSL2 instances¶
- Icinga Director web UI, configure the host on
newmonitor.thefays.us
, normally making a copy of an existing identical item. - Deploy the new host using Icinga Director.
sudo icinga2 node wizard
to configure the agent, see docs- Restart
sudo systemctl restart icinga2
- On
newmonitor.thefays.us
edit/usr/local/bin/check_buildkite_agents.sh
to include the hostname of the new instance.
macOS Docker Desktop Test Agent Setup (Intel and Apple Silicon)¶
- Create the user “testbot” on the machine. Use the password for
ddevtestbot@gmail.com
, available in 1Password. - Change the name of the machine to something in keeping with current style, perhaps
testbot-macos-arm64-8
. This is done in Settings → General → About → Name and in Sharing → Computer Name and in Sharing → Local Hostname. - Download and install Chrome and log the browser into the account used for test runners. It will pick up the Chrome Remote Desktop setup as a result. Configure Chrome Remote Desktop to serve. When this is done, the machine will be available for remote access and most other tasks can be done using Chrome Remote Desktop.
- The machine should be on the correct network and have a static IP handed out by DHCP. IP addresses are listed in /etc/hosts on
pi.ddev.site
, so this one should be added. - Power should be set up as in
.
- Auto login should be set up as in
, see automatically log in on boot.
- Remote login should be enabled as in
.
- Automatic updates should be set to mostly security only as in
.
- Set the time zone to US MT (nearest city: Denver, Colorado).
sudo mkdir -p /usr/local/bin && sudo chown -R testbot /usr/local/bin
- Install Homebrew
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
- After installing Homebrew follow the instructions it gives you at the end to add brew to your PATH.
- Install everything you’ll need with
brew install buildkite/buildkite/buildkite-agent bats-core composer ddev/ddev/ddev git golang jq mysql-client@8.0 mkcert netcat p7zip && brew install --cask docker iterm2 ngrok && brew link --force mysql-client
. - Run
ngrok authtoken <token>
with token for free account from 1Password. - Run
mkcert -install
. - If Docker Desktop will be deployed, run Docker manually and go through its configuration routine.
- If OrbStack will be deployed, install it from orbstack.dev.
- Install with Docker only.
- Click “Sign in” in the lower left to sign in with OrbStack credentials (normal test runner gmail address; it will receive an email with a login code).
- Configure it to automatically start and download updates, see
.
- If Rancher Desktop will be deployed, install it.
- Turn off kubernetes.
- Set virtualization to VZ
- Set mount type to VirtioFS
- Run iTerm. You may need to allow full disk access permissions.
- Run
mkdir ~/workspace && cd ~/workspace && git clone https://github.com/ddev/ddev
. - Set up
nfsd
by runningbash ~/workspace/ddev/scripts/macos_ddev_nfs_setup.sh
. git config --global --add safe.directory '*'
.- Edit
/usr/local/etc/buildkite-agent/buildkite-agent.cfg
or/opt/homebrew/etc/buildkite-agent/buildkite-agent.cfg
to add- the agent
token
(from agents tab, “Reveal Agent Token”). - the agent
name
(the name of the machine). tags
, like"os=macos,architecture=arm64,osvariant=sonoma,dockertype=dockerformac,rancher-desktop=true,orbstack=true,docker-desktop=true"
build-path="~/tmp/buildkite-agent/builds"
- the agent
- Run
brew services start buildkite-agent
. - Run
bash ~/workspace/ddev/.buildkite/testbot_maintenance.sh
. - Run
bash ~/workspace/ddev/.buildkite/sanetestbot.sh
to check your work. - The
testbot
user’s SSH account is used for monitoring, sossh-keygen
and then add the public keyid_testbot
from 1Password to~/.ssh/authorized_keys
andchmod 600 ~/.ssh/authorized_keys
. - Add the new machine to Icinga by copying an existing Icinga service to the new one. This is done in Icinga Director → Services → Single Services → Select a Service → Clone → Deploy. The new service has to have
by-ssh-address
set to the name of the test runner, and that address needs to be added topi.ddev.site
’s/etc/hosts
file. -
If
zsh
is the shell configured, add/etc/zshenv
so that/usr/local/bin/docker
will be picked up: -
In macOS Settings visit “full disk access” and grant access to
buildkite-agent
,docker
,iterm
,orbstack
. This may prevent startup modal dialogs that preventbuildkite-agent
ordocker
from continuing properly.
Additional Colima macOS setup¶
brew install colima
colima start vz --cpu 4 --memory 6 --disk 60 --vm-type=vz --mount-type=virtiofs --dns=1.1.1.1
colima stop vz
Then the Buildkite agent must be configured with tags colima_vz=true
.
Additional Lima macOS setup¶
limactl create --name=lima-vz --vm-type=vz --mount-type=virtiofs --mount-writable --mount="~/:w" --memory=6 --cpus=4 --disk=60 template://docker
limactl start lima-vz
docker context use lima-lima-vz
Then the Buildkite agent must be configured with tags lima=true
.