Build and Upload GCP CCM container image #139
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 and Upload GCP CCM container image | |
on: | |
push: | |
branches: | |
- 'main' | |
paths: | |
- '.github/workflows/build-ccm-gcp.yml' | |
- '.github/actions/gcpccm_vers_to_build/**' | |
schedule: | |
- cron: "0 4 * * 3" # Every Wednesday at 4am UTC | |
workflow_dispatch: | |
jobs: | |
find-ccm-versions: | |
runs-on: ubuntu-24.04 | |
outputs: | |
versions: ${{ steps.find-versions.outputs.versions }} | |
latest: ${{ steps.find-latest.outputs.latest }} | |
steps: | |
- name: Checkout Constellation | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | |
- name: Checkout kubernetes/cloud-provider-gcp | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | |
with: | |
repository: "kubernetes/cloud-provider-gcp" | |
path: "cloud-provider-gcp" | |
fetch-depth: 0 | |
- name: Setup Go environment | |
uses: actions/setup-go@0a12ed9d6a96ab950c8f026ed9f722fe0da7ef32 # v5.0.2 | |
with: | |
go-version: "1.23.2" | |
cache: false | |
- name: Install Crane | |
run: | | |
go install github.com/google/go-containerregistry/cmd/crane@latest | |
- name: Find versions | |
id: find-versions | |
uses: ./.github/actions/gcpccm_vers_to_build | |
with: | |
path: "cloud-provider-gcp" | |
- name: Find latest | |
id: find-latest | |
run: | | |
rawList=$(jq -r '.[]' <<< '${{ steps.find-versions.outputs.versions }}') | |
lastest=$(echo "${rawList}" | sort -V | tail -n 1) | |
echo "latest=${lastest}" | tee -a "$GITHUB_OUTPUT" | |
build-ccm-gcp: | |
# matrix cannot handle empty lists | |
if: needs.find-ccm-versions.outputs.versions != '[]' | |
runs-on: ubuntu-24.04 | |
permissions: | |
contents: read | |
packages: write | |
needs: find-ccm-versions | |
strategy: | |
fail-fast: false | |
matrix: | |
version: ${{ fromJson(needs.find-ccm-versions.outputs.versions) }} | |
steps: | |
- name: Checkout Constellation | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | |
- name: Checkout kubernetes/cloud-provider-gcp | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | |
with: | |
repository: "kubernetes/cloud-provider-gcp" | |
path: "cloud-provider-gcp" | |
ref: refs/tags/ccm/${{ matrix.version }} | |
- name: Docker meta | |
id: meta | |
uses: docker/metadata-action@8e5442c4ef9f78752691e2d8f8d19755c6f78e81 # v5.5.1 | |
with: | |
images: | | |
ghcr.io/edgelesssys/cloud-provider-gcp | |
flavor: | | |
latest=${{ matrix.version == needs.find-ccm-versions.outputs.latest }} | |
tags: | | |
type=semver,pattern=v{{version}},value=${{ matrix.version }} | |
- name: Log in to the Container registry | |
id: docker-login | |
uses: ./.github/actions/container_registry_login | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Build CCM | |
working-directory: cloud-provider-gcp | |
run: | | |
bazel build //cmd/cloud-controller-manager:cloud-controller-manager | |
- name: Copy CCM | |
working-directory: cloud-provider-gcp | |
run: | | |
cp ./bazel-bin/cmd/cloud-controller-manager/cloud-controller-manager_/cloud-controller-manager ./cloud-controller-manager | |
- name: Prepare Dockerfile | |
working-directory: cloud-provider-gcp | |
run: | | |
cat > Dockerfile <<EOF | |
FROM scratch | |
COPY ./cloud-controller-manager /cloud-controller-manager | |
EOF | |
- name: Build and push container image | |
id: build | |
uses: docker/build-push-action@5176d81f87c23d6fc96624dfdbcd9f3830bbe445 # v6.5.0 | |
with: | |
context: ./cloud-provider-gcp | |
push: ${{ github.ref_name == 'main' }} | |
tags: ${{ steps.meta.outputs.tags }} | |
labels: ${{ steps.meta.outputs.labels }} |