Container Image #8
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
# SPDX-License-Identifier: MIT | |
# (c) Copyright 2023 Advanced Micro Devices, Inc. | |
name: "Container Image" | |
on: | |
workflow_dispatch: | |
inputs: | |
registry-prefix: | |
description: Registry host and org | |
type: string | |
# push: | |
# branches: [ master ] | |
# pull_request: | |
# branches: [ master ] | |
env: | |
registry-prefix: ${{ inputs.registry-prefix || format('ghcr.io/{0}', github.repository_owner) }} | |
permissions: | |
contents: read | |
packages: write | |
jobs: | |
container-build: | |
name: Container Build | |
runs-on: ubuntu-latest | |
timeout-minutes: 20 | |
strategy: | |
matrix: | |
app: [Operator, Device Plugin] | |
include: | |
- app: Operator | |
image-repo: onload-operator | |
- app: Device Plugin | |
image-repo: onload-device-plugin | |
dockerfile_prefix: deviceplugin. | |
outputs: | |
digests: ${{ steps.build.outputs.digest }} | |
env: | |
DOCKER_CONFIG: .docker | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Login to registry | |
uses: docker/login-action@v3 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ github.token }} | |
- name: Metadata - Docker tagging | |
id: meta | |
uses: docker/metadata-action@v5 | |
with: | |
flavor: | | |
latest=false | |
images: | | |
${{ env.registry-prefix }}/${{ matrix.image-repo }} | |
tags: | | |
type=ref,event=branch,suffix=-dev | |
type=ref,event=tag,suffix=-dev | |
type=ref,event=pr,prefix=pr- | |
type=semver,pattern={{version}},suffix=-dev | |
type=sha,prefix=git-,format=short | |
- name: Metadata - summarise | |
env: | |
TITLE: ${{ matrix.image-repo }} | |
run: | | |
{ | |
echo "# $TITLE" | |
echo '## Metadata output' | |
echo '### Tags' | |
echo '```' | |
echo "$DOCKER_METADATA_OUTPUT_TAGS" | |
echo '```' | |
echo '### Labels' | |
echo '```' | |
echo "$DOCKER_METADATA_OUTPUT_LABELS" | |
echo '```' | |
} >> "$GITHUB_STEP_SUMMARY" | |
- name: Build | |
id: build | |
uses: docker/build-push-action@v5 | |
with: | |
file: ${{ matrix.dockerfile_prefix }}Dockerfile | |
tags: ${{ steps.meta.outputs.tags }} | |
labels: ${{ steps.meta.outputs.labels }} | |
push: true | |
- name: Build - summarise | |
env: | |
IMAGE_REPO: ${{ env.registry-prefix }}/${{ matrix.image-repo }} | |
DIGEST: ${{ steps.build.outputs.digest }} | |
IMAGEID: ${{ steps.build.outputs.imageid }} | |
run: | | |
{ | |
echo '## Build output' | |
echo "[\`$IMAGE_REPO\`](https://$IMAGE_REPO)@\`$DIGEST\`" | |
echo "Image ID (Config): \`$IMAGEID\`" | |
} >> "$GITHUB_STEP_SUMMARY" | |
- name: Preflight | |
id: preflight | |
uses: docker://quay.io/opdev/preflight:1.7.0 | |
with: | |
args: check container ${{ env.registry-prefix }}/${{ matrix.image-repo }}@${{ steps.build.outputs.digest }} # --submit | |
continue-on-error: true | |
env: | |
PFLT_DOCKERCONFIG: ${{ github.workspace }}/.docker/config.json | |
PFLT_PYXIS_API_TOKEN: | |
PFLT_CERTIFICATION_PROJECT_ID: | |
PFLT_ARTIFACTS: ${{ github.workspace }}/preflight-artifacts | |
- name: Preflight - summarise | |
env: | |
DOCKERFILE: ${{ matrix.dockerfile_prefix }}Dockerfile | |
run: | | |
{ | |
echo '## Preflight output' | |
echo "For \`$DOCKERFILE\`" | |
echo '### Results' | |
echo '```json' | |
echo """$(cat preflight-artifacts/*/results.json || echo Missing)""" | |
echo '```' | |
echo '### RPM Manifest' | |
echo '```json' | |
echo """$(cat preflight-artifacts/*/rpm-manifest.json || echo Missing)""" | |
echo '```' | |
echo '### Cert Image' | |
echo '```json' | |
echo """$(cat preflight-artifacts/*/cert-image.json || echo Missing)""" | |
echo '```' | |
} >> "$GITHUB_STEP_SUMMARY" | |
if [ "$(jq .passed preflight-artifacts/*/results.json)" == "false" ]; then | |
echo "::error file=$DOCKERFILE::Preflight failed" | |
fi |