This commit is contained in:
Kris Lamoureux 2024-05-02 01:54:14 -04:00
parent 4d3faf3617
commit 9d48725c38
2 changed files with 64 additions and 47 deletions

View File

@ -21,6 +21,9 @@ jobs:
restore-keys: |
${{ runner.os }}-vagrant-
- name: Install Tools
run: brew install nmap tree
- name: Install VirtualBox
run: brew install --cask virtualbox
@ -36,51 +39,5 @@ jobs:
vagrant --version
ansible --version
- name: Install debugging tools
run: brew install nmap tree
- name: Vagrant Up with Dockerbox Playbook
env:
SSH_AUTH_SOCK: ''
run: |
PLAYBOOK=dockerbox vagrant up --debug &
VAGRANT_UP_PID=$!
DEBUG_ID="[homelab-ci]"
echo "$DEBUG_ID Waiting for VM to start..."
sleep 60
TIMEOUT=600
ELAPSED=0
SLEEP_DURATION=30
SSH_AVAILABLE=0
while [[ $ELAPSED -lt $TIMEOUT ]]; do
vagrant ssh-config
PRIVATE_KEY="$(vagrant ssh-config | grep -E 'IdentityFile.*\.rsa$' | awk '{print $2}')"
HOST_IP="$(vagrant ssh-config | grep HostName | awk '{print $2}')"
echo "$DEBUG_ID Checking SSH connection availability..."
echo "$DEBUG_ID Private Key: $PRIVATE_KEY"
echo "$DEBUG_ID Host IP: $HOST_IP"
echo "$DEBUG_ID 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 "$DEBUG_ID SSH port is open, attempting connection..."
set -x
ssh -vvv -i "$PRIVATE_KEY" \
-o UserKnownHostsFile=/dev/null \
-o StrictHostKeyChecking=no \
-o IdentitiesOnly=yes \
-o PreferredAuthentications=publickey \
-o PubkeyAuthentication=yes \
-o PasswordAuthentication=no \
-o KbdInteractiveAuthentication=no \
-v vagrant@"$HOST_IP" cat /etc/os-release && break || echo "$DEBUG_ID SSH connection failed, retrying..."
set +x
else
echo "$DEBUG_ID SSH port not open, retrying in $SLEEP_DURATION seconds..."
fi
sleep $SLEEP_DURATION
((ELAPSED+=SLEEP_DURATION))
done
if [[ $SSH_AVAILABLE -ne 1 ]]; then
echo "$DEBUG_ID Timeout reached without successful SSH connection."
fi
wait $VAGRANT_UP_PID # Ensure the Vagrant up process completes
run: ./scripts/github-vagrant.sh

60
scripts/github-vagrant.sh Executable file
View File

@ -0,0 +1,60 @@
#!/bin/bash
# Defaults
TIMEOUT=600
ELAPSED=0
INITIAL_SLEEP=60
SLEEP_DURATION=30
SSH_AVAILABLE=0
DEBUG_ID="[homelab-ci]"
# Run Vagrant Up in the background
PLAYBOOK=dockerbox vagrant up --debug &
VAGRANT_UP_PID=$!
# Initial delay
echo "$DEBUG_ID Waiting for VM to start..."
sleep $INITIAL_SLEEP
# Loop until timeout or breaks
while [[ $ELAPSED -lt $TIMEOUT ]]; do
vagrant ssh-config
PRIVATE_KEY="$(vagrant ssh-config | grep -E 'IdentityFile.*\.rsa$' | awk '{print $2}')"
HOST_IP="$(vagrant ssh-config | grep HostName | awk '{print $2}')"
echo "$DEBUG_ID Checking SSH connection availability..."
echo "$DEBUG_ID Private Key: $PRIVATE_KEY"
echo "$DEBUG_ID Host IP: $HOST_IP"
echo "$DEBUG_ID Running nmap to check open ports..."
# Check if SSH is open
nmap -p 22 "$HOST_IP" | grep "22/tcp open" && SSH_AVAILABLE=1 || SSH_AVAILABLE=0
if [[ $SSH_AVAILABLE -eq 1 ]]; then
echo "$DEBUG_ID SSH port is open, attempting connection..."
set -x
ssh -vvv -i "$PRIVATE_KEY" \
-o UserKnownHostsFile=/dev/null \
-o StrictHostKeyChecking=no \
-o IdentitiesOnly=yes \
-o PreferredAuthentications=publickey \
-o PubkeyAuthentication=yes \
-o PasswordAuthentication=no \
-o KbdInteractiveAuthentication=no \
vagrant@"$HOST_IP" cat /etc/os-release && break || echo "$DEBUG_ID SSH connection failed, retrying..."
set +x
else
echo "$DEBUG_ID SSH port not open, retrying in $SLEEP_DURATION seconds..."
fi
# Sleep and start again
sleep $SLEEP_DURATION
((ELAPSED+=SLEEP_DURATION))
done
# Success?
if [[ $SSH_AVAILABLE -ne 1 ]]; then
echo "$DEBUG_ID Timeout reached without successful SSH connection."
fi
# Ensure the Vagrant up process completes
wait $VAGRANT_UP_PID