Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Issue #3880 - Feature Request: Add release management workflow to Anax #3881

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 5 additions & 4 deletions .github/scripts/configure_versions_script.sh
Original file line number Diff line number Diff line change
Expand Up @@ -18,12 +18,13 @@ ESS_IMAGE_VERSION="${ORIG_ESS_IMAGE_VERSION}-${BUILD_NUMBER}"
# ESS_IMAGE_VERSION="${ORIG_ESS_IMAGE_VERSION}-${UNIQUE_VERSION_HASH}"

# Output configured versions for viewing
echo "***Anax Version, No Build Number: ${ORIG_ANAX_IMAGE_VERSION}"
echo "***Anax Version: ${ANAX_IMAGE_VERSION}"
echo "***CSS Version: ${CSS_IMAGE_VERSION}"
echo "***ESS Version: ${ESS_IMAGE_VERSION}"

# Put script variables into workflow env. variables
echo "VERSION_NO_BUILD_NUMBER=$ORIG_ANAX_IMAGE_VERSION" >> $GITHUB_ENV
echo "ANAX_IMAGE_VERSION=$ANAX_IMAGE_VERSION" >> $GITHUB_ENV
echo "CSS_IMAGE_VERSION=$CSS_IMAGE_VERSION" >> $GITHUB_ENV
echo "ESS_IMAGE_VERSION=$ESS_IMAGE_VERSION" >> $GITHUB_ENV
echo "VERSION_NO_BUILD_NUMBER=$ORIG_ANAX_IMAGE_VERSION" >> "$GITHUB_OUTPUT"
echo "ANAX_IMAGE_VERSION=$ANAX_IMAGE_VERSION" >> "$GITHUB_OUTPUT"
echo "CSS_IMAGE_VERSION=$CSS_IMAGE_VERSION" >> "$GITHUB_OUTPUT"
echo "ESS_IMAGE_VERSION=$ESS_IMAGE_VERSION" >> "$GITHUB_OUTPUT"
41 changes: 41 additions & 0 deletions .github/scripts/docker_save_script.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
#!/bin/bash

if [[ -z "$ANAX_IMAGE_VERSION" ]]; then
echo "::error file=docker_save_script.sh::Anax Image Version is unset, check the 'Configure Version Variables' step"
exit 1
fi
if [[ -z "$CSS_IMAGE_VERSION" ]]; then
echo "::error file=docker_save_script.sh::CSS Image Version is unset, check the 'Configure Version Variables' step"
exit 1
fi
if [[ -z "$ESS_IMAGE_VERSION" ]]; then
echo "::error file=docker_save_script.sh::ESS Image Version is unset, check the 'Configure Version Variables' step"
exit 1
fi

# Names of the images created for each architecture
if [[ ${arch} == 'amd64' ]]; then
images=('amd64_agbot' 'amd64_anax' 'amd64_anax_k8s' 'amd64_auto-upgrade-cronjob_k8s' 'amd64_cloud-sync-service' 'amd64_edge-sync-service')
elif [[ ${arch} == 'ppc64el' ]]; then
images=('ppc64el_anax' 'ppc64el_anax_k8s' 'ppc64el_auto-upgrade-cronjob_k8s' 'ppc64el_edge-sync-service')
elif [[ ${arch} == 'arm64' ]]; then
images=('arm64_anax' 'arm64_anax_k8s' 'arm64_auto-upgrade-cronjob_k8s' 'arm64_edge-sync-service')
elif [[ ${arch} == 's390x' ]]; then
images=('s390x_anax' 's390x_anax_k8s' 's390x_auto-upgrade-cronjob_k8s' 's390x_edge-sync-service')
fi

# Save those images
for image in "${images[@]}"; do

if [[ ${image} == *"cloud-sync-service"* ]]; then
VERSION=${CSS_IMAGE_VERSION}
elif [[ ${image} == *"edge-sync-service"* ]]; then
VERSION=${ESS_IMAGE_VERSION}
else
VERSION=${ANAX_IMAGE_VERSION}
fi

docker tag ${IMAGE_REPO}/${image}:testing ${IMAGE_REPO}/${image}:${VERSION}
docker save ${IMAGE_REPO}/${image}:${VERSION} | gzip > ${image}.tar.gz

done
195 changes: 148 additions & 47 deletions .github/workflows/build-push.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ on:
- master
- v2.30
- v2.29
workflow_dispatch:

env:
IMAGE_REPO: ${{ vars.DOCKERHUB_REPO }}
Expand All @@ -21,10 +22,15 @@ env:
jobs:

# Migrating workflow causes run number to be reset to 1, offset so our versions don't go back in time.
offset-build-number:
prepare-workflow:
if: github.repository_owner == 'open-horizon'
runs-on: ubuntu-20.04
outputs:
BUILD_NUMBER: ${{ steps.offset.outputs.BUILD_NUMBER }}
ANAX_IMAGE_VERSION: ${{ steps.version.outputs.ANAX_IMAGE_VERSION }}
CSS_IMAGE_VERSION: ${{ steps.version.outputs.CSS_IMAGE_VERSION }}
ESS_IMAGE_VERSION: ${{ steps.version.outputs.ESS_IMAGE_VERSION }}
VERSION_NO_BUILD_NUMBER: ${{ steps.version.outputs.VERSION_NO_BUILD_NUMBER }}
steps:
# Ensure that the repo variables and secrets are set before running any other steps
- name: Check User Set Variables
Expand Down Expand Up @@ -75,9 +81,39 @@ jobs:
run: |
echo "BUILD_NUMBER=$(($RUN_NUMBER + $RUN_NUMBER_OFFSET))" >> "$GITHUB_OUTPUT"
# Checkout our Github repo
- name: Checkout Github Repo
uses: actions/checkout@v3

# Configure version variables for later steps, stored in our workflow env. variables
- name: Config Version Variables
id: version
run: |
cd $GITHUB_WORKSPACE
./.github/scripts/configure_versions_script.sh
env:
BUILD_NUMBER: ${{ steps.offset.outputs.BUILD_NUMBER }}

# Prepare files for upload
- name: Prepare Files for Upload
run: |
mkdir $RUNNER_TEMP/files_to_upload
mkdir $RUNNER_TEMP/files_to_tar && cd $RUNNER_TEMP/files_to_tar
cp $GITHUB_WORKSPACE/agent-install/agent-uninstall.sh .
cp $GITHUB_WORKSPACE/agent-install/k8s/* .
tar -czvf $RUNNER_TEMP/files_to_upload/horizon-agent-edge-cluster-files.tar.gz *.*
cp $GITHUB_WORKSPACE/agent-install/agent-install.sh $RUNNER_TEMP/files_to_upload
# Upload files needed for release management that don't change between runs
- name: Upload Anax Agent Files
uses: actions/upload-artifact@v3
with:
name: anax-agent-files-v${{ steps.version.outputs.ANAX_IMAGE_VERSION }}
path: ${{ runner.temp }}/files_to_upload

# Builds on Linux: Deb Packages, RPM Packages, Docker images, and pushes to Dockerhub
linux-build-push:
needs: offset-build-number
needs: prepare-workflow

# The type of runner that the job will run on
runs-on: ubuntu-20.04
Expand All @@ -92,11 +128,11 @@ jobs:
env:
arch: ${{ matrix.architecture }}
os: ${{ matrix.platform }}
BUILD_NUMBER: ${{ needs.offset-build-number.outputs.BUILD_NUMBER }}
ANAX_IMAGE_VERSION: '' # Updated in 'Config Version Variables' step
CSS_IMAGE_VERSION: '' # Updated in 'Config Version Variables' step
ESS_IMAGE_VERSION: '' # Updated in 'Config Version Variables' step
VERSION_NO_BUILD_NUMBER: '' # Updated in 'Config Version Variables' step
BUILD_NUMBER: ${{ needs.prepare-workflow.outputs.BUILD_NUMBER }}
ANAX_IMAGE_VERSION: ${{ needs.prepare-workflow.outputs.ANAX_IMAGE_VERSION }}
CSS_IMAGE_VERSION: ${{ needs.prepare-workflow.outputs.CSS_IMAGE_VERSION }}
ESS_IMAGE_VERSION: ${{ needs.prepare-workflow.outputs.ESS_IMAGE_VERSION }}
VERSION_NO_BUILD_NUMBER: ${{ needs.prepare-workflow.outputs.VERSION_NO_BUILD_NUMBER }}
GOPATH: /home/runner/work/anax/anax/go

# Steps represent a sequence of tasks that will be executed as part of the job
Expand Down Expand Up @@ -155,12 +191,6 @@ jobs:
run: |
echo "GO_VERSION=$(go version | awk '{print $3}')" >> $GITHUB_OUTPUT
# Configure version variables for later steps, stored in our workflow env. variables
- name: Config Version Variables
run: |
cd ${GOPATH}/src/github.com/${GITHUB_REPOSITORY}
./.github/scripts/configure_versions_script.sh
# Increment version, make translation catalogs, build anax binaries for given ARCH and OS
- name: Build Anax Binaries
run: |
Expand Down Expand Up @@ -298,10 +328,91 @@ jobs:
cd ${GOPATH}/src/github.com/${GITHUB_REPOSITORY}
./.github/scripts/docker_push_script.sh
# Save Docker Images
- name: Save Docker Images
if: (matrix.architecture == 'amd64' || matrix.architecture == 'ppc64el' || matrix.architecture == 'arm64' || matrix.architecture == 's390x')
run: |
mkdir -p $RUNNER_TEMP/images_to_upload && cd $RUNNER_TEMP/images_to_upload
${GOPATH}/src/github.com/${GITHUB_REPOSITORY}/.github/scripts/docker_save_script.sh
# Upload Agbot Docker Images
- name: Upload Agbot Docker Images to Artifacts
if: (matrix.architecture == 'amd64')
uses: actions/upload-artifact@v3
with:
name: anax-${{ matrix.platform }}-${{ matrix.architecture }}_agbot-image-v${{ env.ANAX_IMAGE_VERSION }}
path: ${{ runner.temp }}/images_to_upload/${{ matrix.architecture }}_agbot.tar.gz

# Upload Anax Docker Images
- name: Upload Anax Docker Images to Artifacts
if: (matrix.architecture == 'amd64' || matrix.architecture == 'ppc64el' || matrix.architecture == 'arm64' || matrix.architecture == 's390x')
uses: actions/upload-artifact@v3
with:
name: anax-${{ matrix.platform }}-${{ matrix.architecture }}_anax-image-v${{ env.ANAX_IMAGE_VERSION }}
path: ${{ runner.temp }}/images_to_upload/${{ matrix.architecture }}_anax.tar.gz

# Upload Anax K8s Docker Images
- name: Upload Anax K8s Docker Images to Artifacts
if: (matrix.architecture == 'amd64' || matrix.architecture == 'ppc64el' || matrix.architecture == 'arm64' || matrix.architecture == 's390x')
uses: actions/upload-artifact@v3
with:
name: anax-${{ matrix.platform }}-${{ matrix.architecture }}_anax_k8s-image-v${{ env.ANAX_IMAGE_VERSION }}
path: ${{ runner.temp }}/images_to_upload/${{ matrix.architecture }}_anax_k8s.tar.gz

# Upload Anax K8s Cronjob Docker Images
- name: Upload Anax K8s Cronjob Docker Images to Artifacts
if: (matrix.architecture == 'amd64' || matrix.architecture == 'ppc64el' || matrix.architecture == 'arm64' || matrix.architecture == 's390x')
uses: actions/upload-artifact@v3
with:
name: anax-${{ matrix.platform }}-${{ matrix.architecture }}_auto-upgrade-cronjob_k8s-image-v${{ env.ANAX_IMAGE_VERSION }}
path: ${{ runner.temp }}/images_to_upload/${{ matrix.architecture }}_auto-upgrade-cronjob_k8s.tar.gz

# Upload CSS Docker Images
- name: Upload CSS Docker Images to Artifacts
if: (matrix.architecture == 'amd64')
uses: actions/upload-artifact@v3
with:
name: anax-${{ matrix.platform }}-${{ matrix.architecture }}_cloud-sync-service-image-v${{ env.CSS_IMAGE_VERSION }}
path: ${{ runner.temp }}/images_to_upload/${{ matrix.architecture }}_cloud-sync-service.tar.gz

# Upload ESS Docker Images
- name: Upload ESS Docker Images to Artifacts
if: (matrix.architecture == 'amd64' || matrix.architecture == 'ppc64el' || matrix.architecture == 'arm64' || matrix.architecture == 's390x')
uses: actions/upload-artifact@v3
with:
name: anax-${{ matrix.platform }}-${{ matrix.architecture }}_edge-sync-service-image-v${{ env.ESS_IMAGE_VERSION }}
path: ${{ runner.temp }}/images_to_upload/${{ matrix.architecture }}_edge-sync-service.tar.gz

# Prep to Upload Packages
- name: Prepare to Upload Packages
run: |
mkdir -p $RUNNER_TEMP/rpm_to_upload
if [[ ${arch} == 'amd64' ]]; then \
cp /home/runner/rpmbuild/RPMS/x86_64/*.rpm $RUNNER_TEMP/rpm_to_upload; \
elif [[ ${arch} == 'ppc64el' || ${arch} == 's390x' ]]; then \
cp /home/runner/work/anax/anax/RPMS/*.rpm $RUNNER_TEMP/rpm_to_upload; \
fi
mkdir -p $RUNNER_TEMP/deb_to_upload
cp ${GOPATH}/src/github.com/${GITHUB_REPOSITORY}/pkg/deb/debs/*.deb $RUNNER_TEMP/deb_to_upload
# Upload RPM Packages
- name: Upload RPM Packages to Artifacts
if: (matrix.architecture == 'ppc64el' || matrix.architecture == 'amd64' || matrix.architecture == 's390x')
uses: actions/upload-artifact@v3
with:
name: anax-${{ matrix.platform }}-${{ matrix.architecture }}-rpm-package-v${{ env.ANAX_IMAGE_VERSION }}
path: ${{ runner.temp }}/rpm_to_upload/*.rpm

# Upload DEB Packages
- name: Upload DEB Packages to Artifacts
uses: actions/upload-artifact@v3
with:
name: anax-${{ matrix.platform }}-${{ matrix.architecture }}-deb-package-v${{ env.ANAX_IMAGE_VERSION }}
path: ${{ runner.temp }}/deb_to_upload/*.deb

# Build our mac packages on a macOS runner
mac-build:
needs: offset-build-number
needs: prepare-workflow

# Do not use any 'xl' version of macos or you will pay (literally)
# When mac silicon runner comes out we can update this runs-on to ${{ (matrix.architecture == 'amd64') && 'macos-12' || 'macSiliconVersion' }}
Expand All @@ -315,17 +426,13 @@ jobs:
env:
arch: ${{ matrix.architecture }}
os: ${{ matrix.platform }}
BUILD_NUMBER: ${{ needs.offset-build-number.outputs.BUILD_NUMBER }}
ANAX_IMAGE_VERSION: '' # Updated in 'Config Version Variables' step
CSS_IMAGE_VERSION: '' # Updated in 'Config Version Variables' step
ESS_IMAGE_VERSION: '' # Updated in 'Config Version Variables' step
VERSION_NO_BUILD_NUMBER: '' # Updated in 'Config Version Variables' step
BUILD_NUMBER: ${{ needs.prepare-workflow.outputs.BUILD_NUMBER }}
ANAX_IMAGE_VERSION: ${{ needs.prepare-workflow.outputs.ANAX_IMAGE_VERSION }}
CSS_IMAGE_VERSION: ${{ needs.prepare-workflow.outputs.CSS_IMAGE_VERSION }}
ESS_IMAGE_VERSION: ${{ needs.prepare-workflow.outputs.ESS_IMAGE_VERSION }}
VERSION_NO_BUILD_NUMBER: ${{ needs.prepare-workflow.outputs.VERSION_NO_BUILD_NUMBER }}
GOPATH: /Users/runner/work/anax/anax/go

# Specify outputs to be used in our push-macos job
outputs:
ANAX_VERSION: ${{ env.ANAX_IMAGE_VERSION }}

steps:
# Checkout our Github repo
- name: Checkout Github Repo
Expand All @@ -340,12 +447,6 @@ jobs:
go-version: '1.19'
check-latest: true

# Configure version variables for later steps, stored in our workflow env. variables
- name: Config Version Variables
run: |
cd ${GOPATH}/src/github.com/${GITHUB_REPOSITORY}
./.github/scripts/configure_versions_script.sh
# Configure the certificates for package signing
- name: Configure Certificates
run: |
Expand Down Expand Up @@ -399,18 +500,24 @@ jobs:
env:
VERSION: ${{ env.VERSION_NO_BUILD_NUMBER }}

- name: Add Certificate File to Package Directory
run: |
touch ${GOPATH}/src/github.com/${GITHUB_REPOSITORY}/pkg/mac/build/horizon-cli.crt
echo "$MACPKG_HORIZON_CLI_CRT" >> ${GOPATH}/src/github.com/${GITHUB_REPOSITORY}/pkg/mac/build/horizon-cli.crt
env:
MACPKG_HORIZON_CLI_CRT: ${{ secrets.MACPKG_HORIZON_CLI_CRT }}

# Upload created package to artifacts to be used in next job
- name: Upload MacOS Package to Artifacts
uses: actions/upload-artifact@v3
with:
name: macos-${{ matrix.architecture }}-package
path: ${{ env.GOPATH }}/src/github.com/${{ github.repository }}/pkg/mac/build/*.pkg

name: anax-${{ matrix.platform }}-${{ matrix.architecture }}-mac-package-v${{ env.ANAX_IMAGE_VERSION }}
path: ${{ env.GOPATH }}/src/github.com/${{ github.repository }}/pkg/mac/build/*

# This will push our built mac packages to Dockerhub
mac-push:
# Specify that we wait for mac-build to run and create the packages
needs: mac-build
needs: [prepare-workflow, mac-build]

runs-on: ubuntu-20.04

Expand Down Expand Up @@ -456,22 +563,16 @@ jobs:
password: ${{ secrets.GITHUB_TOKEN }}

# Setup a working directory in the temp folder path
- name: Setup Working Directory and add Certificate File
id: workdir_setup
- name: Setup Working Directory for Mac Package
run: |
mkdir $RUNNER_TEMP/macs
touch $RUNNER_TEMP/macs/horizon-cli.crt
echo "$MACPKG_HORIZON_CLI_CRT" >> $RUNNER_TEMP/macs/horizon-cli.crt
echo "PKG_PATH="${RUNNER_TEMP}/macs"" >> $GITHUB_OUTPUT
env:
MACPKG_HORIZON_CLI_CRT: ${{ secrets.MACPKG_HORIZON_CLI_CRT }}
# Retrieve artifact from previous job
- name: Download our MacOS Package Artifact
uses: actions/download-artifact@v3
with:
name: macos-${{ matrix.architecture }}-package
path: ${{ steps.workdir_setup.outputs.PKG_PATH }}
name: anax-${{ matrix.platform }}-${{ matrix.architecture }}-mac-package-v${{ needs.prepare-workflow.outputs.ANAX_IMAGE_VERSION }}
path: ${{ runner.temp }}/macs

# Push our .crt and .pkg to Dockerhub
- name: Make MacOS Package Tarball and Upload to Dockerhub
Expand All @@ -485,10 +586,10 @@ jobs:
# Build docker image with only mac tarball
docker build \
--no-cache \
-t ${IMAGE_REPO}/${{ matrix.architecture }}_anax_macpkg:testing \
-f Dockerfile.macpkg.tarball \
.
--no-cache \
-t ${IMAGE_REPO}/${{ matrix.architecture }}_anax_macpkg:testing \
-f Dockerfile.macpkg.tarball \
.
if [[ "$GITHUB_REF" == 'refs/heads/master' ]]; then
docker push ${IMAGE_REPO}/${{ matrix.architecture }}_anax_macpkg:testing
Expand All @@ -499,4 +600,4 @@ jobs:
docker push ${IMAGE_REPO}/${{ matrix.architecture }}_anax_macpkg:testing_${GH_BRANCH}
fi
env:
ANAX_IMAGE_VERSION: ${{ needs.mac-build.outputs.ANAX_VERSION }}
ANAX_IMAGE_VERSION: ${{ needs.prepare-workflow.outputs.ANAX_IMAGE_VERSION }}
Loading