Skip to content

Remove second timeout #4363

Remove second timeout

Remove second timeout #4363

Workflow file for this run

name: backend
on:
push:
workflow_dispatch:
env:
DOCKER_IMAGE_NAME: ghcr.io/loculus-project/backend
concurrency:
group: ci-${{ github.ref == 'refs/heads/main' && github.run_id || github.ref }}-backend
cancel-in-progress: true
jobs:
Tests:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up JDK
uses: actions/setup-java@v4
with:
java-version: "21"
distribution: "adopt"
- name: Execute Tests
uses: gradle/gradle-build-action@v3
with:
arguments: test
build-root-directory: ./backend
- name: Check Format And Lint
uses: gradle/gradle-build-action@v3
with:
arguments: ktlintCheck
build-root-directory: ./backend
dockerImage:
name: Build Backend Docker Image
runs-on: ubuntu-latest
permissions:
packages: write
contents: read
checks: read
steps:
- uses: actions/checkout@v4
- name: Generate files hash
id: files-hash
run: |
DIR_HASH=$(echo -n ${{ hashFiles('backend/**', '.github/workflows/backend.yml') }})
echo "DIR_HASH=$DIR_HASH" >> $GITHUB_ENV
- name: Setup Docker metadata
id: dockerMetadata
uses: docker/metadata-action@v5
with:
images: ${{ env.DOCKER_IMAGE_NAME }}
tags: |
type=raw,value=${{ env.DIR_HASH }}
type=raw,value=latest,enable=${{ github.ref == 'refs/heads/main' }}
type=ref,event=branch
type=sha,prefix=commit-
- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Check if image exists
id: check-image
run: |
EXISTS=$(docker manifest inspect ${{ env.DOCKER_IMAGE_NAME }}:${{ env.DIR_HASH }} > /dev/null 2>&1 && echo "true" || echo "false")
echo "CACHE_HIT=$EXISTS" >> $GITHUB_ENV
- name: Set up JDK
if: env.CACHE_HIT == 'false'
uses: actions/setup-java@v4
with:
java-version: "21"
distribution: "adopt"
- name: Extract Docker Tags
if: env.CACHE_HIT == 'false'
id: extractTag
run: |
FIRST_TAG=$(echo "${{ steps.dockerMetadata.outputs.tags }}" | head -n 1)
echo "firstTag=$FIRST_TAG" >> $GITHUB_ENV
- name: Build Docker Image For Branch
if: env.CACHE_HIT == 'false'
uses: gradle/actions/setup-gradle@v3
env:
USER: ${{ github.actor }}
TOKEN: "${{ secrets.GITHUB_TOKEN }}"
with:
arguments: bootBuildImage --imageName=${{ env.DOCKER_IMAGE_NAME }}:${{ env.DIR_HASH }}
build-root-directory: ./backend
- name: Push Docker Image
if: env.CACHE_HIT == 'false'
run: docker push ${{ env.DOCKER_IMAGE_NAME }}:${{ env.DIR_HASH }}
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Tag and push existing images
run: |
TAGS=(${{ steps.dockerMetadata.outputs.tags }})
for TAG in "${TAGS[@]}"; do
docker buildx imagetools create --tag $TAG ${{ env.DOCKER_IMAGE_NAME }}:${{ env.DIR_HASH }}
done