Merge pull request #10819 from k8s-infra-cherrypick-robot/cherry-pick… #92
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
on: | |
push: | |
branches: | |
- main | |
- "release/**" | |
tags: | |
- "v*" # Push events to matching v*, i.e. v1.0, v20.15.10 | |
pull_request: | |
branches: | |
- main | |
- "release/**" | |
name: Containerd Release | |
env: | |
GO_VERSION: "1.22.8" | |
permissions: # added using https://github.com/step-security/secure-workflows | |
contents: read | |
jobs: | |
check: | |
name: Check Signed Tag | |
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/v') | |
runs-on: ubuntu-20.04 | |
timeout-minutes: 5 | |
outputs: | |
stringver: ${{ steps.contentrel.outputs.stringver }} | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ github.ref }} | |
path: src/github.com/containerd/containerd | |
- name: Check signature | |
run: | | |
releasever=${{ github.ref }} | |
releasever="${releasever#refs/tags/}" | |
TAGCHECK=$(git tag -v ${releasever} 2>&1 >/dev/null) || | |
echo "${TAGCHECK}" | grep -q "error" && { | |
echo "::error::tag ${releasever} is not a signed tag. Failing release process." | |
exit 1 | |
} || { | |
echo "Tag ${releasever} is signed." | |
exit 0 | |
} | |
working-directory: src/github.com/containerd/containerd | |
- name: Release content | |
id: contentrel | |
run: | | |
RELEASEVER=${{ github.ref }} | |
echo "stringver=${RELEASEVER#refs/tags/v}" >> $GITHUB_OUTPUT | |
git tag -l ${RELEASEVER#refs/tags/} -n20000 | tail -n +3 | cut -c 5- >release-notes.md | |
working-directory: src/github.com/containerd/containerd | |
- name: Save release notes | |
uses: actions/upload-artifact@v4 | |
with: | |
name: containerd-release-notes | |
path: src/github.com/containerd/containerd/release-notes.md | |
build: | |
name: Build Release Binaries | |
runs-on: ubuntu-20.04 | |
timeout-minutes: 30 | |
strategy: | |
matrix: | |
include: | |
# Choose an old release of Ubuntu to avoid glibc issue https://github.com/containerd/containerd/issues/7255 | |
- dockerfile-ubuntu: 18.04 | |
dockerfile-platform: linux/amd64 | |
- dockerfile-ubuntu: 18.04 | |
dockerfile-platform: linux/arm64 | |
- dockerfile-ubuntu: 18.04 | |
dockerfile-platform: linux/ppc64le | |
# riscv64 isn't supported by Ubuntu 18.04 | |
- dockerfile-ubuntu: 22.04 | |
dockerfile-platform: linux/riscv64 | |
- dockerfile-ubuntu: 18.04 | |
dockerfile-platform: windows/amd64 | |
steps: | |
- name: Checkout containerd | |
uses: actions/checkout@v4 | |
with: | |
# Intentionally use github.repository instead of containerd/containerd to | |
# make this action runnable on forks. | |
# See https://github.com/containerd/containerd/issues/5098 for the context. | |
repository: ${{ github.repository }} | |
ref: ${{ github.ref }} | |
path: src/github.com/containerd/containerd | |
- uses: ./src/github.com/containerd/containerd/.github/actions/install-go | |
- name: Set RELEASE_VER | |
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/v') | |
shell: bash | |
run: | | |
releasever=${{ github.ref }} | |
releasever="${releasever#refs/tags/}" | |
echo "RELEASE_VER=${releasever}" >> $GITHUB_ENV | |
echo "GOPATH=${{ github.workspace }}" >> $GITHUB_ENV | |
- name: Setup buildx instance | |
uses: docker/setup-buildx-action@v3 | |
with: | |
use: true | |
- uses: crazy-max/ghaction-github-runtime@v3 # sets up needed vars for caching to github | |
- name: Make | |
shell: bash | |
run: | | |
cache="--cache-from=type=gha,scope=containerd-release --cache-to=type=gha,scope=containerd-release" | |
if [[ "${PLATFORM}" =~ "windows" ]]; then | |
# For Windows the cni build script generates a config but shells out to powershell (and also assume it is running on windows) to get a gateway and subnet. | |
# The values provided here are taken from packages that we previously generated. | |
export GATEWAY=172.21.16.1 | |
export PREFIX_LEN=12 | |
BUILD_ARGS="--build-arg GATEWAY --build-arg PREFIX_LEN" | |
fi | |
docker buildx build ${cache} --build-arg RELEASE_VER --build-arg UBUNTU_VERSION=${{ matrix.dockerfile-ubuntu }} --build-arg GO_VERSION ${BUILD_ARGS} -f .github/workflows/release/Dockerfile --platform=${PLATFORM} -o releases/ . | |
echo PLATFORM_CLEAN=${PLATFORM/\//-} >> $GITHUB_ENV | |
# Remove symlinks since we don't want these in the release Artifacts | |
find ./releases/ -maxdepth 1 -type l | xargs rm | |
working-directory: src/github.com/containerd/containerd | |
env: | |
PLATFORM: ${{ matrix.dockerfile-platform }} | |
- name: Save Artifacts | |
uses: actions/upload-artifact@v4 | |
with: | |
name: release-tars-${{env.PLATFORM_CLEAN}} | |
path: src/github.com/containerd/containerd/releases/*.tar.gz* | |
release: | |
name: Create containerd Release | |
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/v') | |
permissions: | |
contents: write | |
runs-on: ubuntu-20.04 | |
timeout-minutes: 10 | |
needs: [build, check] | |
steps: | |
- name: Download builds and release notes | |
uses: actions/download-artifact@v4 | |
with: | |
path: builds | |
- name: Create Release | |
uses: softprops/action-gh-release@v2 | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
fail_on_unmatched_files: true | |
name: containerd ${{ needs.check.outputs.stringver }} | |
draft: false | |
prerelease: ${{ contains(github.ref, 'beta') || contains(github.ref, 'rc') }} | |
body_path: ./builds/containerd-release-notes/release-notes.md | |
files: | | |
builds/release-tars-**/* | |
make_latest: false |