Update user-agent #26
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
# Copyright 2021 Google LLC | |
# | |
# Licensed under the Apache License, Version 2.0 (the "License"); | |
# you may not use this file except in compliance with the License. | |
# You may obtain a copy of the License at | |
# | |
# http://www.apache.org/licenses/LICENSE-2.0 | |
# | |
# Unless required by applicable law or agreed to in writing, software | |
# distributed under the License is distributed on an "AS IS" BASIS, | |
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
# See the License for the specific language governing permissions and | |
# limitations under the License. | |
name: Release | |
on: | |
push: | |
tags: | |
- "v[0-9]+.[0-9]+.[0-9]+-rc[0-9]+" | |
paths-ignore: | |
- "**.md" | |
- "docs/**" | |
jobs: | |
release: | |
runs-on: ubuntu-latest | |
env: | |
CGO_ENABLED: "0" | |
COSIGN_VERSION: v2.4.0 | |
GGCR_VERSION: v0.20.2 | |
KUBEBUILDER_VERSION: "2.3.2" | |
KUBECTL_VERSION: v1.30.3 | |
REGISTRY: ghcr.io | |
SKAFFOLD_VERSION: v2.13.1 | |
SKAFFOLD_CACHE_ARTIFACTS: "false" | |
SKAFFOLD_DETECT_MINIKUBE: "false" | |
SKAFFOLD_INTERACTIVE: "false" | |
SKAFFOLD_OFFLINE: "true" | |
SKAFFOLD_UPDATE_CHECK: "false" | |
permissions: | |
contents: write | |
id-token: write | |
packages: write | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
- name: Setup Go | |
uses: actions/setup-go@v4 | |
with: | |
go-version-file: go.mod | |
- name: Set image env vars | |
run: | | |
echo IMAGE_REPO=$(echo $GITHUB_REPOSITORY | tr '[:upper:]' '[:lower:]') >> $GITHUB_ENV | |
RC_VERSION=${GITHUB_REF#refs/tags/} | |
echo VERSION=${RC_VERSION%-rc*} >> $GITHUB_ENV | |
- name: Print go env | |
run: | | |
echo HOME=$HOME | |
echo PATH=$PATH | |
go version | |
go env | |
- name: Run unit tests | |
run: | | |
go test -v -count=1 -short -timeout=5m -vet=asmdecl,assign,atomic,bools,buildtag,cgocall,composites,copylocks,errorsas,httpresponse,loopclosure,lostcancel,nilfunc,printf,shift,stdmethods,structtag,tests,unmarshal,unreachable,unsafeptr,unusedresult ./... | |
- name: Install kube-apiserver and etcd | |
run: | | |
mkdir -p ${HOME}/.local/bin | |
curl -sSL "https://github.com/kubernetes-sigs/kubebuilder/releases/download/v${KUBEBUILDER_VERSION}/kubebuilder_${KUBEBUILDER_VERSION}_linux_amd64.tar.gz" | tar --strip-components 2 -xzC ${HOME}/.local/bin kubebuilder_${KUBEBUILDER_VERSION}_linux_amd64/bin/etcd kubebuilder_${KUBEBUILDER_VERSION}_linux_amd64/bin/kube-apiserver kubebuilder_${KUBEBUILDER_VERSION}_linux_amd64/bin/kubebuilder | |
echo "KUBEBUILDER_ASSETS=${HOME}/.local/bin" >> $GITHUB_ENV | |
- name: Run integration tests | |
run: | | |
go test -v -timeout=10m ./cmd/webhook/... | |
env: | |
KUBEBUILDER_CONTROLPLANE_START_TIMEOUT: 180s | |
- name: Create release branch | |
run: | | |
git checkout -B release-$VERSION | |
- name: Populate version number in embedded file | |
run: | | |
echo "$VERSION" > pkg/version/version.txt | |
- name: Commit and push to release branch with new version number | |
run: | | |
git add pkg/version/version.txt | |
git config user.name github-actions | |
git config user.email [email protected] | |
git commit -m "Update binary version to $VERSION" | |
git push --force origin release-$VERSION | |
- name: Set image label env vars | |
run: | | |
echo REVISION=$(git rev-parse HEAD) >> $GITHUB_ENV | |
echo SOURCE=${{ github.server_url }}/${{ github.repository }}.git >> $GITHUB_ENV | |
echo URL=${{ github.server_url }}/${{ github.repository }} >> $GITHUB_ENV | |
- name: Build binaries | |
run: | | |
GOOS=darwin GOARCH=amd64 go build -v -trimpath -ldflags="-s -w" -o digester_Darwin_x86_64 . | |
GOOS=darwin GOARCH=arm64 go build -v -trimpath -ldflags="-s -w" -o digester_Darwin_arm64 . | |
GOOS=linux GOARCH=amd64 go build -v -trimpath -ldflags="-s -w" -o digester_Linux_x86_64 . | |
GOOS=linux GOARCH=arm64 go build -v -trimpath -ldflags="-s -w" -o digester_Linux_aarch64 . | |
- name: Install Skaffold | |
run: | | |
mkdir -p $HOME/.local/bin | |
curl -sSLo $HOME/.local/bin/skaffold "https://storage.googleapis.com/skaffold/releases/${SKAFFOLD_VERSION}/skaffold-$(go env GOOS)-$(go env GOARCH)" | |
chmod +x $HOME/.local/bin/skaffold | |
- name: Build and push container images | |
run: | | |
skaffold build \ | |
--default-repo ${{ env.REGISTRY }}/${{ github.repository_owner }} \ | |
--file-output ${{ runner.temp }}/skaffold-artifacts.json \ | |
--profile release \ | |
--push \ | |
--tag $VERSION | |
env: | |
GITHUB_TOKEN: ${{ github.token }} | |
- name: Render release manifest | |
run: | | |
skaffold render \ | |
--build-artifacts ${{ runner.temp }}/skaffold-artifacts.json \ | |
--digest-source none \ | |
--output digester_manifest.yaml \ | |
--profile release | |
- name: Create checksums file | |
run: shasum -a 256 digester_* > SHA256SUMS | |
- name: Get image name with digest | |
run: | | |
echo -n IMAGE_NAME= >> $GITHUB_ENV | |
echo $(jq -r '.builds[] | select(.imageName=="k8s-digester") | .tag' ${{ runner.temp }}/skaffold-artifacts.json) >> $GITHUB_ENV | |
- name: Install krane | |
run: | | |
mkdir -p $HOME/.local/bin | |
curl -sSL "https://github.com/google/go-containerregistry/releases/download/${GGCR_VERSION}/go-containerregistry_$(uname -s)_$(uname -m).tar.gz" | tar -xzC $HOME/.local/bin krane | |
- name: Update latest tag | |
run: krane tag $IMAGE_NAME latest | |
env: | |
GITHUB_TOKEN: ${{ github.token }} | |
- name: Install Cosign | |
uses: sigstore/cosign-installer@main | |
with: | |
cosign-release: ${{ env.COSIGN_VERSION }} | |
- name: Sign the images with GitHub OIDC Token | |
run: cosign sign --k8s-keychain --recursive --upload --yes $IMAGE_NAME | |
env: | |
GITHUB_TOKEN: ${{ github.token }} | |
- name: Create release body file | |
run: | | |
cat << EOF > ${{ runner.temp }}/body.md | |
## Images | |
GitHub Container Registry: | |
$IMAGE_NAME | |
EOF | |
- name: Install kubectl | |
uses: azure/setup-kubectl@v3 | |
with: | |
version: ${{ env.KUBECTL_VERSION }} | |
- name: Set image name in deployment manifest | |
run: | | |
tmpfile=$(mktemp) | |
kubectl patch \ | |
--dry-run=client \ | |
--filename deployment.yaml \ | |
--local \ | |
--output yaml \ | |
--patch '{"spec":{"template":{"spec":{"containers":[{"name":"manager","image":"${{ env.IMAGE_NAME }}"}]}}}}' \ | |
> $tmpfile | |
mv $tmpfile deployment.yaml | |
working-directory: manifests | |
- name: Update version in readme | |
run: | | |
sed -i "s/VERSION=.*/VERSION=$VERSION/" README.md manifests/README.md docs/authentication.md | |
- name: Commit and push to release branch with new version and image ref | |
run: | | |
git add README.md manifests docs/authentication.md | |
git config user.name github-actions | |
git config user.email [email protected] | |
git commit -m "Update version in readme and manifest to $VERSION" | |
git push --force origin release-$VERSION | |
- name: Set release env vars | |
run: | | |
echo COMMITISH=$(git rev-parse HEAD) >> $GITHUB_ENV | |
- name: Create release | |
id: create_release | |
uses: actions/create-release@v1 | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
with: | |
tag_name: ${{ env.VERSION }} | |
release_name: ${{ env.VERSION }} | |
body_path: ${{ runner.temp }}/body.md | |
commitish: ${{ env.COMMITISH }} | |
- name: Upload binary darwin amd64 | |
uses: actions/upload-release-asset@v1 | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
with: | |
upload_url: ${{ steps.create_release.outputs.upload_url }} | |
asset_path: digester_Darwin_x86_64 | |
asset_name: digester_Darwin_x86_64 | |
asset_content_type: application/octet-stream | |
- name: Upload binary darwin arm64 | |
uses: actions/upload-release-asset@v1 | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
with: | |
upload_url: ${{ steps.create_release.outputs.upload_url }} | |
asset_path: digester_Darwin_arm64 | |
asset_name: digester_Darwin_arm64 | |
asset_content_type: application/octet-stream | |
- name: Upload binary linux amd64 | |
uses: actions/upload-release-asset@v1 | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
with: | |
upload_url: ${{ steps.create_release.outputs.upload_url }} | |
asset_path: digester_Linux_x86_64 | |
asset_name: digester_Linux_x86_64 | |
asset_content_type: application/octet-stream | |
- name: Upload binary linux arm64 | |
uses: actions/upload-release-asset@v1 | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
with: | |
upload_url: ${{ steps.create_release.outputs.upload_url }} | |
asset_path: digester_Linux_aarch64 | |
asset_name: digester_Linux_aarch64 | |
asset_content_type: application/octet-stream | |
- name: Upload manifest file | |
uses: actions/upload-release-asset@v1 | |
env: | |
GITHUB_TOKEN: ${{ github.token }} | |
with: | |
upload_url: ${{ steps.create_release.outputs.upload_url }} | |
asset_path: digester_manifest.yaml | |
asset_name: digester_manifest.yaml | |
asset_content_type: application/x-yaml | |
- name: Upload checksum file | |
uses: actions/upload-release-asset@v1 | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
with: | |
upload_url: ${{ steps.create_release.outputs.upload_url }} | |
asset_path: SHA256SUMS | |
asset_name: SHA256SUMS | |
asset_content_type: text/plain | |
- name: Update version in readme on main branch | |
run: | | |
git config user.name github-actions | |
git config user.email [email protected] | |
git reset --hard | |
git remote update | |
git checkout main | |
git pull --no-edit --no-rebase --strategy-option=theirs origin | |
sed -i "s/VERSION=.*/VERSION=$VERSION/" README.md manifests/README.md docs/authentication.md | |
git add README.md manifests/README.md docs/authentication.md | |
git commit -m "Update version in docs to $VERSION" | |
git pull --no-edit --no-rebase --strategy-option=ours origin | |
git push origin main |