Skip to content

Commit

Permalink
ci: 👷 add binaries build in ci/cd
Browse files Browse the repository at this point in the history
  • Loading branch information
this-is-tobi committed Aug 3, 2024
1 parent 4838bff commit ac456a2
Show file tree
Hide file tree
Showing 7 changed files with 102 additions and 14 deletions.
56 changes: 53 additions & 3 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,9 @@ name: Build
on:
workflow_call:
inputs:
GO_VERSION:
required: true
type: string
REGISTRY:
required: true
type: string
Expand All @@ -26,6 +29,11 @@ on:
type: string
workflow_dispatch:
inputs:
GO_VERSION:
description: Go version to use
required: true
type: string
default: 1.22.4
REGISTRY:
description: Target registry to push images
required: true
Expand All @@ -42,21 +50,63 @@ on:
type: string
default: linux/amd64,linux/arm64

permissions:
packages: write
contents: write

jobs:
vars:
name: Generate variables
runs-on: ubuntu-latest
outputs:
lower-branch: ${{ steps.infos.outputs.LOWER_BRANCH }}
short-sha: ${{ steps.infos.outputs.SHORT_SHA }}
platforms-json: ${{ steps.infos.outputs.PLATFORMS_JSON }}
steps:
- name: Get variables
id: infos
run: |
echo "SHORT_SHA=sha-$(git rev-parse --short HEAD)" >> $GITHUB_OUTPUT
echo "PLATFORMS_JSON=$(echo "$PLATFORMS"| jq -c 'split(",")')" >> $GITHUB_OUTPUT
build-binaries:
name: Build application binaries
runs-on: ubuntu-latest
needs:
- vars
strategy:
matrix:
platforms: ${{ needs.vars.outputs.platforms-json }}
steps:
- name: Checks-out repository
uses: actions/checkout@v4

- name: Setup Go
uses: actions/setup-go@v5
with:
go-version: ${{ inputs.GO_VERSION }}

- name: Install dependencies
run: go mod download

- name: Run vet command
run: go vet .

- name: Run build
run: |
BUILD_OS=$(echo ${{ matrix.platforms }} | cut -d '/' -f 1)
BUILD_ARCH=$(echo ${{ matrix.platforms }} | cut -d '/' -f 2,3)
CGO_ENABLED=0 GOOS=${BUILD_OS} GOARCH=${BUILD_ARCH} \
go build -o ./binaries/external-dns-midaas-webhook_${BUILD_OS}-${BUILD_ARCH} .
- name: Upload test results
uses: actions/upload-artifact@v4
with:
name: external-dns-midaas-webhook_${BUILD_OS}-${BUILD_ARCH}
path: ./binaries/external-dns-midaas-webhook_${BUILD_OS}-${BUILD_ARCH}

build:
name: Build application
build-docker:
name: Build application image
runs-on: ubuntu-latest
needs:
- vars
Expand Down
7 changes: 5 additions & 2 deletions .github/workflows/cache.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,9 @@ on:
required: false
type: string

permissions:
packages: write

jobs:
cleanup-cache:
name: Delete gituhb cache
Expand Down Expand Up @@ -64,6 +67,6 @@ jobs:
run: |
./ci/scripts/delete-image.sh \
-o "${{ steps.image-infos.outputs.ORG_NAME }}" \
-i "${{ steps.image-infos.outputs.REPO_NAME }}/external-dns-midaas-webhook" \
-t "pr-${{ github.event.pull_request.number || github.event.number }}" \
-i "${{ steps.image-infos.outputs.REPO_NAME }}" \
-t "pr-${{ inputs.PR_NUMBER || github.event.pull_request.number || github.event.number }}" \
-g "${{ secrets.GITHUB_TOKEN }}"
26 changes: 26 additions & 0 deletions .github/workflows/cd.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ on:
workflow_dispatch:

env:
GO_VERSION: 1.22.4
REGISTRY: "ghcr.io"
NAMESPACE: "${{ github.repository }}"
PLATFORMS: linux/amd64,linux/arm64
Expand All @@ -15,6 +16,7 @@ jobs:
expose-vars:
runs-on: ubuntu-latest
outputs:
GO_VERSION: ${{ env.GO_VERSION }}
REGISTRY: ${{ env.REGISTRY }}
NAMESPACE: ${{ env.NAMESPACE }}
PLATFORMS: ${{ env.PLATFORMS }}
Expand All @@ -36,11 +38,35 @@ jobs:
- release
permissions:
packages: write
contents: write
with:
GO_VERSION: ${{ needs.expose-vars.outputs.GO_VERSION }}
REGISTRY: ${{ needs.expose-vars.outputs.REGISTRY }}
NAMESPACE: ${{ needs.expose-vars.outputs.NAMESPACE }}
PLATFORMS: ${{ needs.expose-vars.outputs.PLATFORMS }}
TAG: ${{ needs.release.outputs.major-tag }}.${{ needs.release.outputs.minor-tag }}.${{ needs.release.outputs.patch-tag }}
MAJOR_TAG: ${{ needs.release.outputs.major-tag }}
MINOR_TAG: ${{ needs.release.outputs.minor-tag }}
PATCH_TAG: ${{ needs.release.outputs.patch-tag }}

artifacts:
runs-on: ubuntu-latest
if: ${{ needs.release.outputs.release-created == 'true' }}
needs:
- expose-vars
- release
- build
permissions:
contents: write
steps:
- name: Download artifact
uses: actions/download-artifact@v4
with:
pattern: external-dns-midaas-webhook_*
path: ./binaries
merge-multiple: true

- name: Upload Release Artifact
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: gh release upload ${{ needs.release.outputs.tag-name }} $(ls ./binaries)
8 changes: 5 additions & 3 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,10 +12,10 @@ on:
workflow_dispatch:

env:
GO_VERSION: 1.22.4
REGISTRY: "ghcr.io"
NAMESPACE: "${{ github.repository }}"
PLATFORMS: linux/amd64,linux/arm64
GO_VERSION: 1.22.4

jobs:
path-filter:
Expand Down Expand Up @@ -43,10 +43,10 @@ jobs:
runs-on: ubuntu-latest
if: ${{ !github.event.pull_request.draft }}
outputs:
GO_VERSION: ${{ env.GO_VERSION }}
REGISTRY: ${{ env.REGISTRY }}
NAMESPACE: ${{ env.NAMESPACE }}
PLATFORMS: ${{ env.PLATFORMS }}
GO_VERSION: ${{ env.GO_VERSION }}
steps:
- name: Exposing env vars
run: echo "Exposing env vars"
Expand All @@ -58,7 +58,7 @@ jobs:
- path-filter
- expose-vars
permissions:
packages: write
contents: write
with:
GO_VERSION: ${{ needs.expose-vars.outputs.GO_VERSION }}

Expand All @@ -70,7 +70,9 @@ jobs:
- expose-vars
permissions:
packages: write
contents: write
with:
GO_VERSION: ${{ needs.expose-vars.outputs.GO_VERSION }}
REGISTRY: ${{ needs.expose-vars.outputs.REGISTRY }}
NAMESPACE: ${{ needs.expose-vars.outputs.NAMESPACE }}
PLATFORMS: ${{ needs.expose-vars.outputs.PLATFORMS }}
Expand Down
6 changes: 5 additions & 1 deletion .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,9 @@ on:
release-created:
description: "Has the releease been created"
value: ${{ jobs.release.outputs.release-created }}
tag-name:
description: "Release tag name"
value: ${{ jobs.release.outputs.tag-name }}
major-tag:
description: "Major version tag"
value: ${{ jobs.release.outputs.major-tag }}
Expand All @@ -22,14 +25,15 @@ jobs:
runs-on: ubuntu-latest
outputs:
release-created: ${{ steps.release.outputs.release_created }}
tag-name: ${{ steps.release.outputs.tag_name }}
major-tag: ${{ steps.release.outputs.major }}
minor-tag: ${{ steps.release.outputs.minor }}
patch-tag: ${{ steps.release.outputs.patch }}
steps:
- name: Checks-out repository
uses: actions/checkout@v4

- name: Pre release new version
- name: Release new version
uses: googleapis/release-please-action@v4
id: release
with:
Expand Down
3 changes: 3 additions & 0 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,9 @@ on:
type: string
default: 1.22.4

permissions:
contents: read

jobs:
test:
name: Test application
Expand Down
10 changes: 5 additions & 5 deletions ci/scripts/delete-image.sh
Original file line number Diff line number Diff line change
Expand Up @@ -75,19 +75,19 @@ fi
IMAGE_NAME_URL_ENCODED="$(jq -rn --arg x ${IMAGE_NAME} '$x | @uri')"
IMAGES=$(curl -s \
-H "Authorization: Bearer ${GITHUB_TOKEN}" \
"https://api.github.com/orgs/${ORG}/packages/container/${IMAGE_NAME_URL_ENCODED}/versions?per_page=100")
MAIN_IMAGE_ID=$(echo "$IMAGES" | jq -r --arg t "$TAG" '.[] | select(.metadata.container.tags[] | contains($t)) | .id')
"https://api.github.com/users/${ORG}/packages/container/${IMAGE_NAME_URL_ENCODED}/versions?per_page=100")
MAIN_IMAGE_ID=$(echo "$IMAGES" | jq -r --arg t "$TAG" '.[] | select(.labels["org.opencontainers.image.version"] == $t) | .id')

# Delete subsequent images
while read -r SHA; do
IMAGE_ID=$(echo "$IMAGES" | jq -r --arg s "$SHA" '.[] | select(.name==$s) | .id')
IMAGE_ID=$(echo "$IMAGES" | jq -r --arg s "$SHA" '.[] | select(.name == $s) | .id')

printf "\n${red}[Delete ghcr image].${no_color} Deleting subsequent image '$ORG/$IMAGE_NAME@$SHA'\n"

curl -s \
-X DELETE \
-H "Authorization: Bearer ${GITHUB_TOKEN}" \
"https://api.github.com/orgs/${ORG}/packages/container/${IMAGE_NAME_URL_ENCODED}/versions/${IMAGE_ID}"
"https://api.github.com/user/${ORG}/packages/container/${IMAGE_NAME_URL_ENCODED}/versions/${IMAGE_ID}"
done <<< "$(docker buildx imagetools inspect ghcr.io/${ORG}/${IMAGE_NAME}:${TAG} --raw | jq -r '.manifests[] | .digest')"

# Delete main image
Expand All @@ -96,4 +96,4 @@ printf "\n${red}[Delete ghcr image].${no_color} Deleting image '$ORG/$IMAGE_NAME
curl -s \
-X DELETE \
-H "Authorization: Bearer ${GITHUB_TOKEN}" \
"https://api.github.com/orgs/${ORG}/packages/container/${IMAGE_NAME_URL_ENCODED}/versions/${MAIN_IMAGE_ID}"
"https://api.github.com/user/${ORG}/packages/container/${IMAGE_NAME_URL_ENCODED}/versions/${MAIN_IMAGE_ID}"

0 comments on commit ac456a2

Please sign in to comment.