Build containers for amd64 and arm64 #131
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: build | |
on: | |
pull_request: | |
branches: | |
- main | |
schedule: | |
- cron: '0 0 * * *' | |
workflow_dispatch: | |
env: | |
REGISTRY: ghcr.io | |
IMAGE_NAME: ${{ github.repository }} | |
jobs: | |
coverage: | |
name: Check test coverage with tarpaulin | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Create k8s Kind Cluster | |
uses: helm/[email protected] | |
with: | |
cluster_name: "kind" | |
- name: "Apply RBAC resources" | |
run: kubectl apply -k rbac | |
- name: Install stable toolchain | |
uses: actions-rs/toolchain@v1 | |
with: | |
toolchain: stable | |
override: true | |
# - uses: actions-rs/[email protected] | |
# with: | |
# crate: cargo-tarpaulin | |
# version: latest | |
# - run: cargo tarpaulin --timeout 300 -o Xml | |
# - name: Upload to codecov.io | |
# uses: codecov/[email protected] | |
# with: | |
# token: ${{secrets.CODECOV_TOKEN}} | |
# - name: Archive code coverage results | |
# uses: actions/upload-artifact@v3 | |
# with: | |
# name: code-coverage-report | |
# path: cobertura.xml | |
build: | |
name: Build a nightly version of runo | |
runs-on: ubuntu-latest | |
needs: coverage | |
strategy: | |
fail-fast: false | |
matrix: | |
recipe: | |
- { target: aarch64-unknown-linux-gnu, platform: linux/arm64 } | |
- { target: x86_64-unknown-linux-gnu, platform: linux/amd64 } | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Install stable toolchain | |
uses: actions-rs/toolchain@v1 | |
with: | |
toolchain: stable | |
target: ${{ matrix.recipe.target }} | |
override: true | |
- uses: actions-rs/cargo@v1 | |
with: | |
use-cross: true | |
command: build | |
args: --target ${{ matrix.recipe.target }} | |
- name: Archive artifacts | |
uses: actions/upload-artifact@v3 | |
with: | |
name: ${{ matrix.recipe.target }} | |
path: target/${{ matrix.recipe.target }}/debug/runo | |
retention-days: 30 | |
image: | |
name: Build and push image | |
runs-on: ubuntu-latest | |
needs: build | |
strategy: | |
fail-fast: false | |
matrix: | |
recipe: | |
- { target: aarch64-unknown-linux-gnu, platform: linux/arm64 } | |
- { target: x86_64-unknown-linux-gnu, platform: linux/amd64 } | |
permissions: | |
contents: read | |
packages: write | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Debug | |
run: | | |
echo "github.ref -> {{ github.ref }}" | |
- name: Log in to the Container registry | |
uses: docker/login-action@v3 | |
with: | |
registry: ${{ env.REGISTRY }} | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Set metadata | |
id: metadata | |
uses: docker/metadata-action@v5 | |
with: | |
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} | |
tags: | | |
type=raw,value={{sha}} | |
- name: Download a single artifact | |
uses: actions/download-artifact@v3 | |
with: | |
name: ${{ matrix.recipe.target }} | |
- name: Build and push image | |
uses: docker/build-push-action@v5 | |
with: | |
context: . | |
platforms: ${{ matrix.recipe.platform }} | |
push: true | |
tags: ${{ steps.metadata.outputs.tags }} | |
labels: ${{ steps.metadata.outputs.labels }} | |