name: homelab-ci on: push: branches: - main - testing jobs: homelab-ci: runs-on: macos-13 steps: - uses: actions/checkout@v3 - name: Cache Vagrant boxes uses: actions/cache@v3 with: path: ~/.vagrant.d/boxes key: ${{ runner.os }}-vagrant-${{ hashFiles('Vagrantfile') }} restore-keys: | ${{ runner.os }}-vagrant- - name: Install VirtualBox run: brew install --cask virtualbox - name: Install Vagrant run: brew install --cask vagrant - name: Install Ansible run: brew install ansible - name: Software Versions run: | printf "VirtualBox "; vboxmanage --version vagrant --version ansible --version - name: Install nmap run: brew install nmap - name: Vagrant Up with Dockerbox Playbook env: SSH_AUTH_SOCK: '' run: | set +x ssh-add -D && echo "[homelab-ci] SSH Agent disabled" PLAYBOOK=dockerbox vagrant up --debug & VAGRANT_UP_PID=$! echo "[homelab-ci] Waiting for VM to start..." TIMEOUT=600 ELAPSED=0 SLEEP_DURATION=10 SSH_AVAILABLE=0 while [[ $ELAPSED -lt $TIMEOUT ]]; do PRIVATE_KEY="$(find .vagrant -name "private_key" 2>/dev/null | sort)" HOST_IP="$(vagrant ssh-config | grep HostName | awk '{print $2}')" echo "[homelab-ci] Checking SSH connection availability..." echo "[homelab-ci] Private Key: $PRIVATE_KEY" echo "[homelab-ci] Host IP: $HOST_IP" echo "[homelab-ci] Running nmap to check open ports..." nmap -p 22 "$HOST_IP" | grep "22/tcp open" && SSH_AVAILABLE=1 || SSH_AVAILABLE=0 if [[ $SSH_AVAILABLE -eq 1 ]]; then echo "[homelab-ci] SSH port is open, attempting connection..." ssh -vvv -i "$PRIVATE_KEY" \ -o UserKnownHostsFile=/dev/null \ -o StrictHostKeyChecking=no \ -v vagrant@"$HOST_IP" && break || echo "[homelab-ci] SSH connection failed, retrying..." else echo "[homelab-ci] SSH port not open, retrying in $SLEEP_DURATION seconds..." fi sleep $SLEEP_DURATION ((ELAPSED+=SLEEP_DURATION)) done if [[ $SSH_AVAILABLE -ne 1 ]]; then echo "[homelab-ci] Timeout reached without successful SSH connection." fi wait $VAGRANT_UP_PID # Ensure the Vagrant up process completes