wip: add workload demand #29
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: ensemble-operator build-and deploy | |
on: | |
workflow_dispatch: | |
pull_request: [] | |
push: | |
branches: | |
- main | |
jobs: | |
build-api: | |
permissions: | |
packages: write | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
x: [["ghcr.io/converged-computing/ensemble-operator-api:rockylinux9", "docker/Dockerfile.rocky", "9"], | |
["ghcr.io/converged-computing/ensemble-operator-api:rockylinux8", "docker/Dockerfile.rocky", "8"], | |
["ghcr.io/converged-computing/ensemble-operator-api:ubuntu-jammy", "docker/Dockerfile.ubuntu", "22.04"], | |
["ghcr.io/converged-computing/ensemble-operator-api:ubuntu-focal", "docker/Dockerfile.ubuntu", "20.04"]] | |
name: ${{ matrix.x[0] }} | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Build Containers | |
env: | |
container: ${{ matrix.x[0] }} | |
dockerfile: ${{ matrix.x[1] }} | |
tag: ${{ matrix.x[2] }} | |
run: | | |
cd python/ | |
docker build --build-arg tag=${tag} -f ${dockerfile} -t ${container} . | |
- name: GHCR Login | |
if: (github.event_name != 'pull_request') | |
uses: docker/login-action@v2 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Deploy Container | |
if: (github.event_name != 'pull_request') | |
env: | |
container: ${{ matrix.x[0] }} | |
run: docker push ${{ env.container }} | |
# Only build arm image on merge, takes too long otherwise | |
build-arm: | |
if: (github.event_name == 'release') | |
runs-on: ubuntu-latest | |
name: make and build arm | |
steps: | |
- name: Checkout Repository | |
uses: actions/checkout@v4 | |
- uses: actions/setup-go@v3 | |
with: | |
go-version: ^1.20 | |
- name: GHCR Login | |
if: (github.event_name != 'pull_request') | |
uses: docker/login-action@v2 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Add custom buildx ARM builder | |
run: | | |
docker buildx create --name armbuilder | |
docker buildx use armbuilder | |
docker buildx inspect --bootstrap | |
- name: Deploy Container | |
run: | | |
go mod tidy | |
make arm-deploy | |
build: | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
command: [docker] | |
name: make and build ${{ matrix.command }} | |
steps: | |
- name: Checkout Repository | |
uses: actions/checkout@v4 | |
- uses: actions/setup-go@v3 | |
with: | |
go-version: ^1.20 | |
- name: GHCR Login | |
if: (github.event_name != 'pull_request') | |
uses: docker/login-action@v2 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Build Container | |
run: make ${{ matrix.command }}-build | |
- name: Deploy Container | |
if: (github.event_name != 'pull_request') | |
run: make ${{ matrix.command }}-push |