Skip to content

chore(ci): Upgrade to supported actions/cache version (#83226) #19600

chore(ci): Upgrade to supported actions/cache version (#83226)

chore(ci): Upgrade to supported actions/cache version (#83226) #19600

name: Publish Sentry image to DockerHub
on:
push:
branches:
- master
- releases/**
jobs:
publish-sentry:
runs-on: ubuntu-24.04
steps:
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7
- name: Pull the test image
id: image_pull
env:
IMAGE_URL: ghcr.io/getsentry/sentry-self-hosted:${{ github.sha }}
shell: bash
run: |
echo "We poll for the Docker image that the GCB/GHA build produces until it succeeds or this job times out."
echo "Polling for $IMAGE_URL"
timeout 20m bash -c 'until docker pull "$IMAGE_URL" 2>/dev/null; do sleep 10; done'
- name: Get short SHA for docker tag
id: short_sha
shell: bash
run: |
SHORT_SHA=$(git rev-parse --short "$GITHUB_SHA")
if [[ -z "$SHORT_SHA" ]]; then
echo "Short SHA empty? Re-running rev-parse."
git rev-parse --short "$GITHUB_SHA"
else
echo "sha=$SHORT_SHA" >> $GITHUB_OUTPUT
fi
- name: Push built docker image
shell: bash
env:
SHORT_SHA: ${{ steps.short_sha.outputs.sha }}
IMAGE_URL: ghcr.io/getsentry/sentry-self-hosted:${{ github.sha }}
run: |
# only login if the password is set
if [[ "${{ secrets.DOCKER_HUB_RW_TOKEN }}" ]]; then echo "${{ secrets.DOCKER_HUB_RW_TOKEN }}" | docker login --username=sentrybuilder --password-stdin; fi
# We push 3 tags to Dockerhub:
# first, the full sha of the commit
docker tag ${IMAGE_URL} getsentry/sentry:${GITHUB_SHA}
docker push getsentry/sentry:${GITHUB_SHA}
# second, the short sha of the commit
docker tag ${IMAGE_URL} getsentry/sentry:${SHORT_SHA}
docker push getsentry/sentry:${SHORT_SHA}
# finally, nightly
docker tag ${IMAGE_URL} getsentry/sentry:nightly
docker push getsentry/sentry:nightly