spring-petclinic/.github/workflows/main.yml
nirpel-sys 9bdb5dd9dc
Update main.yml
Signed-off-by: nirpel-sys <nirpel@jfrog.com>
2026-01-20 12:50:49 +02:00

74 lines
2.3 KiB
YAML

name: PetClinic to Artifactory
on:
push:
branches: [ "main" ]
workflow_dispatch:
jobs:
build-and-publish:
runs-on: ubuntu-latest
permissions:
contents: read
id-token: write
steps:
- name: Checkout Code
uses: actions/checkout@v4
- name: Set up JDK 17
uses: actions/setup-java@v4
with:
java-version: '17'
distribution: 'temurin'
cache: 'maven'
# Setup JFrog CLI using OIDC
- name: Set up JFrog CLI
uses: jfrog/setup-jfrog-cli@v4
env:
JF_URL: ${{ secrets.JF_URL }}
with:
version: latest
oidc-provider-name: github-oidc-provider
oidc-audience: jfrog-github
# 1 & 2: Compile and Run Tests
- name: Compile and Test
run: ./mvnw clean test
# 3: Package as Docker image
- name: Build Docker Image
run: |
./mvnw spring-boot:build-image \
-Dspring-boot.build-image.imageName=petclinic-app:${{ github.run_number }}
- name: Publish to Artifactory
run: |
# 1. Capture the URL from secrets into a local shell variable
# We use a fallback to 'MISSING' to catch empty secrets
RAW_URL="${{ secrets.JF_URL }}"
# 2. Extract the hostname (remove https:// and any trailing slashes)
JF_HOST=$(echo "$RAW_URL" | sed 's|https://||' | sed 's|/||g')
# 3. SAFETY CHECK: Stop the build if the hostname is missing
if [ -z "$JF_HOST" ]; then
echo "::error::JF_URL is empty! Check your GitHub Repository Secrets."
exit 1
fi
echo "Targeting JFrog Host: $JF_HOST"
DOCKER_REPO="docker-local"
IMAGE_TAG="petclinic-app:${{ github.run_number }}"
REMOTE_TAG="$JF_HOST/$DOCKER_REPO/$IMAGE_TAG"
# 4. Perform the Tag and Push
docker tag "petclinic-app:${{ github.run_number }}" "$REMOTE_TAG"
# Use the 'jf' command which handles OIDC authentication automatically
jf docker push "$REMOTE_TAG" --build-name=petclinic --build-number=${{ github.run_number }}
# 5. Publish Build Info for full traceability
jf rt bp petclinic ${{ github.run_number }}