CI #138
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 ] | |
tags: | |
- "*" | |
pull_request: | |
schedule: | |
- cron: '0 0 * * *' | |
workflow_dispatch: | |
env: | |
NVIDIA_VERSION: 535.104.05 | |
jobs: | |
container: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v2 | |
- name: Build container | |
uses: docker/build-push-action@v4 | |
lint: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- name: ShellCheck | |
uses: ludeeus/[email protected] | |
compile-docker: | |
strategy: | |
matrix: | |
include: | |
- module: nvidia | |
version: 535.104.05 | |
group: stable | |
- module: nvidia | |
version: 535.104.05 | |
group: beta | |
- module: nvidia | |
version: 535.104.05 | |
group: alpha | |
- module: nvidia | |
version: 470.103.01 | |
group: stable | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v2 | |
- name: Build container | |
uses: docker/build-push-action@v4 | |
with: | |
tags: modulus | |
load: true | |
- env: | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
MODULUS_S3_BUCKET: ${{ secrets.MODULUS_S3_BUCKET }} | |
run: | | |
export MODULE=${{ matrix.module }} | |
export VERSION=${{ matrix.version }} | |
export MODULUS_GROUP=${{ matrix.group }} | |
export MODULUS_COREOS_RELEASE_VERSION="$(curl https://"$MODULUS_GROUP".release.flatcar-linux.net/amd64-usr/current/version.txt --silent | grep FLATCAR_VERSION= | tr '=' ' ' | awk '{print $2}')" | |
OPTS= | |
if [ -n "$MODULUS_S3_BUCKET" ]; then OPTS=-u; fi | |
docker run --rm -v "$PWD"/out:/out --env-file <(env | grep "MODULUS\|AWS") --privileged modulus -C -d /out -b amd64-usr $OPTS compile "$MODULE" "$VERSION" | |
ls -al out/"$MODULE"/"$VERSION"/lib/modules/*/"$MODULE".ko | |
compile: | |
strategy: | |
matrix: | |
include: | |
- module: nvidia | |
version: 535.104.05 | |
group: stable | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- run: | | |
sudo apt-get update && sudo apt-get install -y gnupg2 gdisk | |
export MODULE=${{ matrix.module }} | |
export VERSION=${{ matrix.version }} | |
export MODULUS_GROUP=${{ matrix.group }} | |
export MODULUS_COREOS_RELEASE_VERSION="$(curl https://"$MODULUS_GROUP".release.flatcar-linux.net/amd64-usr/current/version.txt --silent | grep FLATCAR_VERSION= | tr '=' ' ' | awk '{print $2}')" | |
export MODULUS_BIN_DIR=$PWD | |
sudo -E ./modulus -D -d "$PWD"/out -b amd64-usr compile "$MODULE" "$VERSION" | |
ls -al out/"$MODULE"/"$VERSION"/lib/modules/*/"$MODULE".ko | |
compile-chroot: | |
strategy: | |
matrix: | |
include: | |
- module: nvidia | |
version: 535.104.05 | |
group: stable | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- run: | | |
export MODULE=${{ matrix.module }} | |
export VERSION=${{ matrix.version }} | |
export MODULUS_GROUP=${{ matrix.group }} | |
export MODULUS_COREOS_RELEASE_VERSION="$(curl https://"$MODULUS_GROUP".release.flatcar-linux.net/amd64-usr/current/version.txt --silent | grep FLATCAR_VERSION= | tr '=' ' ' | awk '{print $2}')" | |
export MODULUS_BIN_DIR=$PWD | |
sudo -E ./modulus -CD -d "$PWD"/out -b amd64-usr compile "$MODULE" "$VERSION" | |
ls -al out/"$MODULE"/"$VERSION"/lib/modules/*/"$MODULE".ko | |
push: | |
if: github.event_name != 'pull_request' && github.event_name != 'schedule' | |
needs: | |
- container | |
- lint | |
- compile-docker | |
- compile | |
- compile-chroot | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v2 | |
- name: Login to DockerHub | |
uses: docker/login-action@v2 | |
with: | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
- name: Login to GitHub Container Registry | |
uses: docker/login-action@v2 | |
with: | |
registry: ghcr.io | |
username: ${{ github.repository_owner }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Determine SHA | |
id: sha | |
run: echo "::set-output name=sha::$(git describe --always --tags --dirty)" | |
- name: Build and push | |
id: push | |
uses: docker/build-push-action@v4 | |
with: | |
push: true | |
platforms: linux/amd64 | |
tags: ghcr.io/squat/modulus:latest, ghcr.io/squat/modulus:${{ steps.sha.outputs.sha }}, squat/modulus:latest, squat/modulus:${{ steps.sha.outputs.sha }} | |
- name: Determine digest | |
run: echo ${{ steps.push.outputs.digest }} |