Skip to content

CI improvements

CI improvements #31

Workflow file for this run

name: CI
on:
merge_group:
pull_request:
branches:
- "main"
- "v**"
workflow_dispatch:
jobs:
lint:
name: Lint
runs-on: ubuntu-20.04
steps:
- name: Cancel Previous Runs
uses: styfle/[email protected]
with:
access_token: ${{ github.token }}
- name: Check out code
uses: actions/checkout@v2
- name: Verify
uses: golangci/golangci-lint-action@v2
with:
version: v1.51.2
args: --timeout=15m0s --verbose
unit:
runs-on: ubuntu-20.04
name: Unit and Integration tests
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Setup
uses: ./.github/workflows/composite/setup
- name: Verify manifests
run: |
make manifests
git diff --exit-code
- name: Verify bin dir
run: |
BIN_FILE="metallb-operator.yaml" make bin
git diff --exit-code bin/
- name: Unit and Integration Tests
run: |
export KUBECONFIG=${HOME}/.kube/config
METALLB_BGP_TYPE=native make test
METALLB_BGP_TYPE=frr DEPLOY_KUBE_RBAC_PROXIES=true make test
e2e:
runs-on: ubuntu-20.04
env:
built_image: "metallb-operator:ci" # Arbitrary name
needs:
- lint
- unit
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Setup
uses: ./.github/workflows/composite/setup
- name: Build image
run: |
IMG=${built_image} make docker-build
- name: Create K8s Kind Cluster
run: |
./hack/kind-cluster-without-registry.sh
kind load docker-image ${built_image}
- name: Deploy Metal LB Operator
run: |
IMG=${built_image} KUSTOMIZE_DEPLOY_DIR="config/kind-ci/" make deploy
- name: E2E Tests
shell: bash
run: |
export KUBECONFIG=${HOME}/.kube/config
make test-validation
make test-e2e
- name: Collect Logs
uses: ./.github/workflows/composite/collectlogs
olm:
runs-on: ubuntu-20.04
needs:
- lint
- unit
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Setup
uses: ./.github/workflows/composite/setup
- name: Verify release bundle manifests
run: |
working-directory: metallboperator
make bundle-release
git diff --exit-code -I'^ createdAt: ' bundle
- name: Create and set up K8s Kind Cluster
run: |
working-directory: metallboperator
./hack/kind-cluster-with-registry.sh
make deploy-olm
- name: Build bundle image
run: |
working-directory: metallboperator
make build-and-push-bundle-images REPO=localhost:5000
- name: Deploy Metal LB Operator with OLM
run: |
working-directory: metallboperator
make deploy-with-olm REPO=localhost:5000
- name: E2E Tests
shell: bash
run: |
working-directory: metallboperator
export KUBECONFIG=${HOME}/.kube/config
make test-validation
make test-e2e
- name: Collect Logs
uses: ./.github/workflows/composite/collectlogs
upgrade_version:
runs-on: ubuntu-20.04
env:
built_image_prev_release: "metallb-operator-prev-rel:ci" # Arbitrary name
built_image: "metallb-operator:ci" # Arbitrary name
name: Go 1.17 -> Go 1.20
needs:
- lint
- unit
steps:
- name: Cancel Previous Runs
uses: styfle/[email protected]
with:
access_token: ${{ github.token }}
- name: Checkout Previous Release Metal LB Operator
uses: actions/checkout@v2
with:
path: metallboperator
ref: v0.12 # previous release version
fetch-depth: 0 # Fetch all history for all tags and branches
- uses: actions/setup-go@v2
with:
go-version: '1.17'
- name: Build image
run: |
working-directory: metallboperator
IMG=${built_image_prev_release} make docker-build
- name: Create K8s Kind Cluster
run: |
working-directory: metallboperator
./hack/kind-cluster-without-registry.sh
kind load docker-image ${built_image_prev_release}
- name: Deploy Previous Release Metal LB Operator
run: |
working-directory: metallboperator
make deploy-cert-manager
IMG=${built_image_prev_release} KUSTOMIZE_DEPLOY_DIR="config/kind-ci/" ENABLE_OPERATOR_WEBHOOK="true" make deploy
- name: E2E Tests
shell: bash
run: |
working-directory: metallboperator
export KUBECONFIG=${HOME}/.kube/config
make test-validation
make test-e2e
- name: Collect Logs
uses: ./.github/workflows/composite/collectlogs
- name: Checkout Latest Metal LB Operator
uses: actions/checkout@v2
with:
path: metallboperator-latest
fetch-depth: 0 # Fetch all history for all tags and branches
- uses: actions/setup-go@v2
with:
go-version: '1.20'
- name: Delete old controller-gen
run: |
working-directory: metallboperator
rm $(which controller-gen)
- name: Build image
run: |
working-directory: metallboperator
cd ${GITHUB_WORKSPACE}/metallboperator-latest
IMG=${built_image} make docker-build
kind load docker-image ${built_image}
- name: Deploy Metal LB Operator
run: |
working-directory: metallboperator
cd ${GITHUB_WORKSPACE}/metallboperator-latest
IMG=${built_image} KUSTOMIZE_DEPLOY_DIR="config/kind-ci/" make deploy
- name: Ensure MetalLB operator is ready
run: |
working-directory: metallboperator
sleep 5
while [ "$(kubectl get pods -n metallb-system -l control-plane='controller-manager' -o jsonpath='{.items[*].status.containerStatuses[0].ready}')" != "true" ]; do
sleep 5
echo "Waiting for operator pod to be ready."
done
- name: E2E Tests
shell: bash
run: |
working-directory: metallboperator
export KUBECONFIG=${HOME}/.kube/config
make test-validation
make test-e2e
- name: Collect Logs
uses: ./.github/workflows/composite/collectlogs
metallb_e2e:
runs-on: ubuntu-20.04
env:
built_image: "metallb-operator:ci" # Arbitrary name
needs:
- lint
- unit
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Setup
uses: ./.github/workflows/composite/setup
- name: Read metallb ref
id: metallb_ref
run: |
working-directory: metallboperator
echo "content=$(cat ./hack/metallb_ref.txt)" >> $GITHUB_OUTPUT
- name: Checkout MetalLB
uses: actions/checkout@v2
with:
repository: metallb/metallb
path: metallb
ref: "${{ steps.metallb_ref.outputs.content }}"
- name: Checkout MetalLB v0.12
uses: actions/checkout@v2
with:
repository: metallb/metallb
path: metallb-0.12
ref: v0.12
- name: Install Dependencies
run: |
working-directory: metallboperator
sudo apt-get update
sudo apt-get install linux-modules-extra-$(uname -r) python3-pip arping ndisc6
sudo pip3 install -r ${GITHUB_WORKSPACE}/metallb/dev-env/requirements.txt
go install github.com/onsi/ginkgo/v2/[email protected]
- name: Build image
run: |
working-directory: metallboperator
IMG=${built_image} make docker-build
- name: Create multi-node K8s Kind Cluster
run: |
working-directory: metallboperator
./hack/kind-multi-node-cluster-without-registry.sh
kind load docker-image ${built_image}
./hack/create_second_interface.sh
- name: Deploy Prometheus
run: |
working-directory: metallboperator
make deploy-prometheus
- name: Deploy Metal LB Operator
run: |
working-directory: metallboperator
IMG=${built_image} KUSTOMIZE_DEPLOY_DIR="config/frr-on-ci/" make deploy
- name: Ensure MetalLB operator is ready
run: |
working-directory: metallboperator
while [ "$(kubectl get pods -n metallb-system -l control-plane='controller-manager' -o jsonpath='{.items[*].status.containerStatuses[0].ready}')" != "true" ]; do
sleep 5
echo "Waiting for operator pod to be ready."
done
- name: Enable MetalLB
run: |
working-directory: metallboperator
export KUBECONFIG=${HOME}/.kube/config
kubectl apply -f config/samples/metallb.yaml
- name: MetalLB E2E Tests
run: |
working-directory: metallboperator
cd ${GITHUB_WORKSPACE}/metallb
sudo -E env "PATH=$PATH" inv e2etest --skip "IPV6|DUALSTACK" -e /tmp/kind_logs
- name: MetalLB E2E Tests - backward compatible
run: |
working-directory: metallboperator
patch ${GITHUB_WORKSPACE}/metallb-0.12/e2etest/pkg/config/update.go < ${GITHUB_WORKSPACE}/metallb/e2etest/backwardcompatible/patchfile
cat <<EOF | kubectl apply -f -
apiVersion: v1
kind: ConfigMap
metadata:
namespace: metallb-system
name: config
EOF
cd ${GITHUB_WORKSPACE}/metallb-0.12
FOCUS="L2.*should work for ExternalTrafficPolicy=Cluster|BGP.*A service of protocol load balancer should work with.*IPV4 - ExternalTrafficPolicyCluster$|BGP.*should work with the given bfd profile.*IPV4 - default"
sudo -E env "PATH=$PATH" inv e2etest --use-operator --focus "$FOCUS" -e /tmp/kind_logs
- name: Change permissions for kind logs
if: ${{ failure() }}
run: |
working-directory: metallboperator
sudo chmod -R o+r /tmp/kind_logs
- name: Archive kind logs
if: ${{ failure() }}
uses: actions/upload-artifact@v2
with:
name: kind_logs
path: /tmp/kind_logs