[feat] Allow the job to run for 3 hours (#39) #104
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 someengineering/fix-collect-coordinator Docker image | |
on: | |
push: | |
tags: | |
- '*.*.*' | |
branches: | |
- main | |
pull_request: | |
branches: | |
- main | |
workflow_dispatch: | |
jobs: | |
split-build: | |
name: Build split Docker images | |
runs-on: ubuntu-latest | |
steps: | |
- name: Check out repository | |
uses: actions/checkout@v3 | |
- name: Set build platforms | |
id: platform | |
run: | | |
GITHUB_REF="${{ github.ref }}" | |
GITHUB_TAG=${GITHUB_REF##*/} | |
echo "targets=linux/amd64,linux/arm64" >> $GITHUB_OUTPUT | |
if [ "${{ github.ref_type }}" = tag ]; then | |
if [[ "$GITHUB_TAG" =~ [0-9]([ab]|rc)[0-9]* ]]; then | |
echo "latest=false" >> $GITHUB_OUTPUT | |
else | |
echo "latest=true" >> $GITHUB_OUTPUT | |
fi | |
else | |
echo "latest=false" >> $GITHUB_OUTPUT | |
fi | |
- name: Check short commit SHA and build targets | |
run: | | |
echo ${{ steps.platform.outputs.targets }} | |
echo ${{ steps.platform.outputs.latest }} | |
- name: Docker metadata | |
id: metadata | |
uses: docker/metadata-action@v4 | |
with: | |
images: | | |
someengineering/fix-collect-coordinator | |
ghcr.io/someengineering/fix-collect-coordinator | |
flavor: | | |
latest=${{ steps.platform.outputs.latest }} | |
tags: | | |
type=pep440,pattern={{version}} | |
type=pep440,pattern={{major}}.{{minor}} | |
type=pep440,pattern={{major}} | |
type=sha,prefix= | |
type=edge | |
labels: | | |
org.opencontainers.image.title=fix-collect-coordinator | |
org.opencontainers.image.description=coordinate jobs | |
org.opencontainers.image.vendor=Some Engineering Inc. | |
- name: Set up QEMU | |
id: qemu | |
uses: docker/setup-qemu-action@v2 | |
with: | |
platforms: arm64,amd64 | |
- name: Set up Docker Buildx | |
id: buildx | |
uses: docker/setup-buildx-action@v2 | |
- name: Log in to Docker Hub | |
if: github.event_name != 'pull_request' | |
uses: docker/login-action@v2 | |
with: | |
username: ${{ secrets.DOCKERHUB_USER }} | |
password: ${{ secrets.DOCKERHUB_PASS }} | |
- name: Log in to GitHub Container Registry | |
if: github.event_name != 'pull_request' | |
uses: docker/login-action@v2 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Build and push fix-collect-coordinator Docker image | |
uses: docker/build-push-action@v3 | |
with: | |
context: . | |
file: ./Dockerfile | |
platforms: ${{ steps.platform.outputs.targets }} | |
push: ${{ github.event_name != 'pull_request' }} | |
tags: ${{ steps.metadata.outputs.tags }} | |
labels: ${{ steps.metadata.outputs.labels }} | |
provenance: false # Temporary workaround for https://github.com/docker/buildx/issues/1533 | |
- name: Setup yq | |
uses: mikefarah/yq@master | |
- name: Authenticate with GitHub CLI | |
if: github.event_name != 'pull_request' | |
run: | | |
gh auth login --with-token <<< "${{ secrets.SOME_CI_PAT }}" | |
- name: Bump tag version | |
if: github.event_name != 'pull_request' | |
env: | |
GITHUB_TOKEN: ${{ secrets.SOME_CI_PAT }} | |
run: | | |
git config --global user.email "[email protected]" | |
git config --global user.name "Some CI" | |
git clone "https://[email protected]/someengineering/setup-infra.git" | |
git_sha="${{ github.sha }}" | |
short_sha="${git_sha:0:7}" | |
echo "Use short SHA: $short_sha" | |
# update the tag | |
cd setup-infra | |
yq eval ".images[] |= select(.name == \"someengineering/fix-collect-coordinator\").newTag |= \"${short_sha}\"" -i argocd/envs/dev/fix-collect-coordinator/kustomization.yaml | |
git add . | |
git commit -m "Bump fix-collect-coordinator on dev to ${short_sha}" | |
git push origin main |