Skip to content

Merge pull request #405 from fidelity/dependabot/go_modules/github.co… #628

Merge pull request #405 from fidelity/dependabot/go_modules/github.co…

Merge pull request #405 from fidelity/dependabot/go_modules/github.co… #628

Workflow file for this run

name: CI
on:
# Triggers the workflow on push or pull request events but only for the master branch
push:
branches: [master]
paths-ignore: ["**.md"]
pull_request:
branches: [master]
paths-ignore: ["**.md"]
jobs:
validate:
runs-on: ubuntu-20.04
steps:
- uses: actions/checkout@v2
with:
fetch-depth: 0
- name: Validate
run: |
if [ "${{ github.event_name }}" == "pull_request" ]
then
make validate-versions
else
echo "push to master, skipping validation"
fi
docker-build:
needs: validate
runs-on: ubuntu-20.04
steps:
- uses: actions/checkout@v2
- name: Determine Tag
run: |
[ "${{ github.event_name }}" == "pull_request" ] && export VERSION=$(cat VERSION)-dev || export VERSION=$(cat VERSION)
echo "VERSION=$VERSION" >> $GITHUB_ENV
echo "REPO=kraan" >> $GITHUB_ENV
echo "using $VERSION as the release version"
- name: Setup Go environment
uses: actions/setup-go@v2
with:
# The Go version to download (if necessary) and use. Supports semver spec and ranges.
go-version: 1.21.5
- name: Setup dependencies
run: |
[ -z "${GOPATH}" ] && export GOPATH=$HOME/go
PATH="${GOPATH}/bin:${PATH}"
./bin/setup.sh --skip-kind
# - uses: satackey/action-docker-layer-caching@v0
# # Ignore the failure of a step and avoid terminating the job.
# continue-on-error: true
- name: Prerelease - Lint, Test, Build
if: github.event_name == 'pull_request'
run: |
make clean
make dev-build
- name: Prerelease - Store docker image as artifact
if: github.event_name == 'pull_request'
uses: actions/upload-artifact@v2
with:
name: image
path: build/*.tar
if-no-files-found: error
- name: Login to GitHub Packages Docker Registry
if: github.event_name == 'push'
uses: docker/login-action@v1
with:
username: ${{ secrets.DOCKER_USER }}
password: ${{ secrets.DOCKER_TOKEN }}
- name: Prepare
id: prep
if: github.event_name == 'push'
run: |
VERSION=$(cat VERSION)
TAGS=kraan/kraan-controller:${VERSION}
echo ::set-output name=tags::${TAGS}
- name: Set up QEMU
if: github.event_name == 'push'
uses: docker/setup-qemu-action@master
with:
platforms: all
- name: Set up Docker Buildx
id: buildx
if: github.event_name == 'push'
uses: docker/setup-buildx-action@master
- name: Build image and Push
if: github.event_name == 'push'
uses: docker/build-push-action@v4
with:
builder: ${{ steps.buildx.outputs.name }}
context: .
file: ./Dockerfile
platforms: linux/arm64,linux/amd64
tags: ${{ steps.prep.outputs.tags }}
push: true
integration-test:
needs: docker-build
runs-on: ubuntu-20.04
steps:
- uses: actions/checkout@v2
- name: Create kind cluster
run: |
[ -z "${GOPATH}" ] && export GOPATH=$HOME/go
PATH="${GOPATH}/bin:${PATH}"
kind create cluster --image kindest/node:v1.27.3
echo "sleep 60s to wait node ready"
sleep 60s
kubectl get node
- name: Prerelease - pull image from artifact
if: github.event_name == 'pull_request'
uses: actions/download-artifact@v2
with:
name: image
- name: Prerelease - load image
if: github.event_name == 'pull_request'
run: |
export VERSION=$(cat VERSION)-dev
docker load -i *.tar
kind load docker-image kraan/kraan-controller-prerelease:$VERSION
- name: Integration Test
env:
GITREPO: ${{ github.event.pull_request.head.repo.full_name }}
run: |
[ "${{ github.event_name }}" == "pull_request" ] && export DOCKER_IMG='kraan-controller-prerelease' || export DOCKER_IMG='kraan-controller'
[ "${{ github.event_name }}" == "pull_request" ] && export VERSION=$(cat VERSION)-dev || export VERSION=$(cat VERSION)
[ "${{ github.event_name }}" != "pull_request" ] && export GITREPO='fidelity/kraan'
export CHART_VERSION=$VERSION
export REPO=kraan
kubectl cluster-info
kubectl version
echo "installing kraan..."
helm install kraan --set kraan.kraanController.image.name=$DOCKER_IMG --set kraan.kraanController.image.tag=${VERSION} --set kraan.kraanController.resources=null --set gotk.sourceController.resources=null --set gotk.helmController.resources=null --wait --timeout=2m --create-namespace --namespace gotk-system chart || (kubectl describe deploy -n gotk-system && kubectl describe po -n gotk-system && false)
echo "setting up test..."
kubectl apply -f ./testdata/namespaces.yaml
kubectl apply -f ./testdata/addons/addons-source.yaml
kubectl patch gitrepository addons-config -n gotk-system -p "{\"spec\": {\"ref\": {\"branch\": \"$GITHUB_HEAD_REF\"},\"url\": \"$GITHUB_SERVER_URL/$GITREPO.git\"}}" --type=merge
kubectl apply -f ./testdata/addons/addons-repo.yaml
kubectl apply -f ./testdata/addons/addons.yaml
echo "waiting 5m for test to pass..."
kubectl wait al --for=condition=Deployed --all --timeout=5m || (kubectl get po -A && kubectl describe al -A && false)
- name: Orphan Integration Test
env:
GITREPO: ${{ github.event.pull_request.head.repo.full_name }}
run: |
[ "${{ github.event_name }}" != "pull_request" ] && export GITREPO='fidelity/kraan'
echo "setting up test..."
kubectl apply -f ./testdata/addons-orphan/addons-source.yaml
kubectl patch gitrepository addons-config -n gotk-system -p "{\"spec\": {\"ref\": {\"branch\": \"$GITHUB_HEAD_REF\"},\"url\": \"$GITHUB_SERVER_URL/$GITREPO.git\"}}" --type=merge
kubectl apply -f ./testdata/addons-orphan/addons-repo.yaml
kubectl apply -f ./testdata/addons-orphan/addons.yaml
echo "waiting 5m for test to pass..."
kubectl wait al --for=condition=Deployed --all --timeout=5m || (kubectl get po -A && false)
helm-publish:
if: github.event_name == 'push'
needs: integration-test
runs-on: ubuntu-20.04
steps:
- uses: actions/checkout@v2
with:
fetch-depth: 0
- name: Setup dependencies
run: |
[ -z "${GOPATH}" ] && export GOPATH=$HOME/go
PATH="${GOPATH}/bin:${PATH}"
./bin/setup.sh
- name: Publish Helm Chart
run: |
export VERSION=$(cat VERSION)
unset CHART_VERSION
git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com"
git config --global user.name "github-actions"
git checkout go.mod go.sum
make release
tag-repo:
if: github.event_name == 'push'
needs: helm-publish
runs-on: ubuntu-20.04
steps:
- uses: actions/checkout@v2
with:
fetch-depth: 0
- name: tag repository
run: |
export VERSION=$(cat VERSION)
git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com"
git config --global user.name "github-actions"
git tag -a $VERSION -m "tag version $VERSION"
git push origin --tags