Skip to content

CI improvements

CI improvements #2

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
strategy:
matrix:
go: [ '1.18.3' ]
name: Unit and Integration tests
steps:
- 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
verify_branch:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v2
with:
fetch-depth: 0
- name: Verify Version Bump
run: |
make bump_versions
make check_generated
main:
runs-on: ubuntu-20.04
env:
built_image: "metallb-operator:ci" # Arbitrary name
strategy:
matrix:
go: [ '1.19.5' ]
name: Go ${{ matrix.go }}
needs:
- lint
- verify_branch
- unit
steps:
- name: Setup
uses: ./.github/workflows/composite/setup
- name: Verify manifests
run: |
make manifests
git diff --exit-code
- 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: Collectlogs
uses: ./.github/workflows/composite/collectlogs
mainolm:
runs-on: ubuntu-20.04
strategy:
matrix:
go: [ '1.19.5' ]
name: Go ${{ matrix.go }}
needs:
- lint
- verify_branch
- unit
steps:
- name: Setup
uses: ./.github/workflows/composite/setup
- name: Verify release bundle manifests
run: |
make bundle-release
git diff --exit-code -I'^ createdAt: ' bundle
- name: Create and set up K8s Kind Cluster
run: |
./hack/kind-cluster-with-registry.sh
make deploy-olm
- name: Build bundle image
run: |
make build-and-push-bundle-images REPO=localhost:5000
- name: Deploy Metal LB Operator with OLM
run: |
make deploy-with-olm REPO=localhost:5000
- name: Collectlogs
uses: ./.github/workflows/composite/collectlogs
mainupgrade:
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.18
needs:
- lint
- verify_branch
- 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' # this need to stay to 1.17 as long as the previous release is v0.12
- name: Build image
run: |
IMG=${built_image_prev_release} make docker-build
- name: Create K8s Kind Cluster
run: |
./hack/kind-cluster-without-registry.sh
kind load docker-image ${built_image_prev_release}
- name: Deploy Previous Release Metal LB Operator
run: |
make deploy-cert-manager
IMG=${built_image_prev_release} KUSTOMIZE_DEPLOY_DIR="config/kind-ci/" ENABLE_OPERATOR_WEBHOOK="true" make deploy
- name: Collectlogs
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.18'
- name: Build image
run: |
cd ${GITHUB_WORKSPACE}/metallboperator-latest
IMG=${built_image} make docker-build
kind load docker-image ${built_image}
- name: Deploy Metal LB Operator
run: |
cd ${GITHUB_WORKSPACE}/metallboperator-latest
IMG=${built_image} KUSTOMIZE_DEPLOY_DIR="config/kind-ci/" make deploy
- name: Ensure MetalLB operator is ready
run: |
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: Collectlogs
uses: ./.github/workflows/composite/collectlogs
maine2e:
runs-on: ubuntu-20.04
env:
built_image: "metallb-operator:ci" # Arbitrary name
strategy:
matrix:
go: ["1.19.5"]
name: Go ${{ matrix.go }}
needs:
- lint
- verify_branch
- unit
steps:
- name: Setup
uses: ./.github/workflows/composite/setup
- name: Verify manifests
run: |
make manifests
git diff --exit-code
- name: Read metallb ref
id: metallb_ref
run: 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: |
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: |
IMG=${built_image} make docker-build
- name: Create multi-node K8s Kind Cluster
run: |
./hack/kind-multi-node-cluster-without-registry.sh
kind load docker-image ${built_image}
./hack/create_second_interface.sh
- name: Deploy Prometheus
run: |
make deploy-prometheus
- name: Deploy Metal LB Operator
run: |
IMG=${built_image} KUSTOMIZE_DEPLOY_DIR="config/frr-on-ci/" make deploy
- name: Ensure MetalLB operator is ready
run: |
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: |
export KUBECONFIG=${HOME}/.kube/config
kubectl apply -f config/samples/metallb.yaml
- name: MetalLB E2E Tests
run: |
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: |
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: |
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