Build a package using GitHub Actions #19
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: CI | |
on: | |
push: | |
branches: | |
- main | |
- release-* | |
pull_request: {} | |
workflow_dispatch: {} | |
env: | |
# Common versions | |
GO_VERSION: '1.21.3' | |
GOLANGCI_VERSION: 'v1.54.2' | |
DOCKER_BUILDX_VERSION: 'v0.11.2' | |
# Common users. We can't run a step 'if secrets.AWS_USR != ""' but we can run | |
# a step 'if env.AWS_USR' != ""', so we copy these to succinctly test whether | |
# credentials have been provided before trying to run steps that need them. | |
XPKG_PUSH_ROBOT_USR: ${{ secrets.XPKG_PUSH_ROBOT_USR }} | |
jobs: | |
lint: | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Setup Go | |
uses: actions/setup-go@v4 | |
with: | |
go-version: ${{ env.GO_VERSION }} | |
cache: false # The golangci-lint action does its own caching. | |
- name: Lint | |
uses: golangci/golangci-lint-action@v3 | |
with: | |
version: ${{ env.GOLANGCI_VERSION }} | |
unit-tests: | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Setup Go | |
uses: actions/setup-go@v4 | |
with: | |
go-version: ${{ env.GO_VERSION }} | |
- name: Run Unit Tests | |
run: go test -v -cover ./... | |
push-package: | |
runs-on: ubuntu-22.04 | |
strategy: | |
fail-fast: true | |
matrix: | |
platform: | |
- linux/amd64 | |
- linux/arm64 | |
steps: | |
- name: Setup QEMU | |
uses: docker/setup-qemu-action@v3 | |
with: | |
platforms: all | |
- name: Setup Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
with: | |
version: ${{ env.DOCKER_BUILDX_VERSION }} | |
install: true | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Build Runtime | |
id: image | |
uses: docker/build-push-action@v5 | |
with: | |
context: . | |
platforms: ${{ matrix.platform }} | |
cache-from: type=gha | |
cache-to: type=gha,mode=max | |
target: image | |
build-args: | |
GO_VERSION=${{ env.GO_VERSION }} | |
outputs: type=docker,dest=runtime.tar | |
# TODO(negz): Use the crossplane-contrib/xpkg-action for this? It doesn't | |
# currently do anything other than download the CLI and run a command. | |
- name: Setup the Crossplane CLI | |
run: "curl -sL https://raw.githubusercontent.com/crossplane/crossplane/master/install.sh | sh" | |
env: | |
XP_CHANNEL: master | |
XP_VERSION: current | |
- name: Build Package | |
run: ./crossplane xpkg build \ | |
--package-root=package/ \ | |
--embed-runtime-image-tarball=runtime.tar | |
- name: Login to Upbound | |
uses: docker/login-action@v3 | |
if: env.XPKG_PUSH_ROBOT_USR != '' | |
with: | |
registry: xpkg.upbound.io | |
username: ${{ secrets.XPKG_PUSH_ROBOT_USR }} | |
password: ${{ secrets.XPKG_PUSH_ROBOT_PSW }} |