Skip to content

Add CI Workflow for Building and Deploying Operator #7

Add CI Workflow for Building and Deploying Operator

Add CI Workflow for Building and Deploying Operator #7

Workflow file for this run

name: Build and Deploy
on: [push, pull_request]
jobs:
build-and-deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Install dependencies
run: |
# Install kind
curl -sLo kind "$(curl -sL https://github.com/gitapi/repos/kubernetes-sigs/kind/releases/latest | jq -r '[.assets[] | select(.name == "kind-linux-amd64")] | first | .browser_download_url')"
chmod +x kind
sudo mv kind /bin/
# Install kubectl
curl -LO "https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl"
chmod +x kubectl
sudo mv kubectl /bin/
# Remove existing containerd
sudo apt-get remove -y containerd
# Install docker
sudo apt-get update
sudo apt-get install -y docker.io
# Install Go 1.21
curl -LO https://go.dev/dl/go1.21.0.linux-amd64.tar.gz
sudo tar -C /usr/local -xzf go1.21.0.linux-amd64.tar.gz
echo 'export PATH=$PATH:/usr/local/go/bin' >> ~/.profile
source ~/.profile
go version
- name: Build Docker image
run: |
sudo -E docker build -t checkpoint-restore-operator:ci .
- name: Delete existing Kubernetes cluster (if any)
run: |
kind delete cluster || true
- name: Create Kubernetes cluster
run: |
kind create cluster
kind export kubeconfig
- name: Load Docker image into kind cluster
run: |
kind load docker-image checkpoint-restore-operator:ci
- name: Deploy to Kubernetes
run: |
export PATH=$PATH:/usr/local/go/bin
make install
make deploy IMG=checkpoint-restore-operator:ci
- name: Wait for deployments to be ready
run: |
wait_for_deployment() {
local deployment_name=$1
timeout=60
i=1
echo "Checking if the ${deployment_name} deployment is ready"
until kubectl -n checkpoint-restore-operator-system get deployment ${deployment_name} -o jsonpath='{.status.conditions[?(@.status=="True")].type}' | grep "Available" 2>/dev/null; do
((i++))
if [[ ${i} -gt ${timeout} ]]; then
echo "The ${deployment_name} deployment has not become ready before the timeout period"
echo "Fetching deployment status and describing pods for debugging:"
kubectl -n checkpoint-restore-operator-system get deployment ${deployment_name}
kubectl -n checkpoint-restore-operator-system describe deployment ${deployment_name}
kubectl -n checkpoint-restore-operator-system get pods
kubectl -n checkpoint-restore-operator-system describe pods
exit 1
fi
echo "Waiting for ${deployment_name} deployment to report a ready status"
sleep 5
done
echo "The ${deployment_name} deployment is ready"
}
wait_for_deployment checkpoint-restore-operator-controller-manager
- name: Check resources
run: kubectl get all -n checkpoint-restore-operator-system