Skip to content

Merge pull request #105 from RHEcosystemAppEng/test-osh-collection #49

Merge pull request #105 from RHEcosystemAppEng/test-osh-collection

Merge pull request #105 from RHEcosystemAppEng/test-osh-collection #49

name: Build Dev Image
on:
push:
branches: [ main ]
workflow_run:
workflows: ["CodeQL"]
types:
- completed
branches: [ main ]
env:
REGISTRY: quay.io
IMAGE_NAME: ecosystem-appeng/sast-ai-orchestrator
jobs:
build-and-publish-dev:
runs-on: ubuntu-latest
if: ${{ github.event_name == 'push' || (github.event_name == 'workflow_run' && github.event.workflow_run.conclusion == 'success') }}
permissions:
contents: write
packages: write
steps:
- name: Checkout code
uses: actions/checkout@v5
- name: Set up JDK 21
uses: actions/setup-java@v5
with:
java-version: '21'
distribution: 'temurin'
- name: Cache Maven dependencies
uses: actions/cache@v4
with:
path: ~/.m2
key: ${{ runner.os }}-m2-${{ hashFiles('**/pom.xml') }}
restore-keys: ${{ runner.os }}-m2
- name: Build JVM application
run: |
./mvnw clean package -DskipTests
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Log in to Quay.io
uses: docker/login-action@v3
with:
registry: quay.io
username: ${{ secrets.QUAY_USERNAME }}
password: ${{ secrets.QUAY_PASSWORD }}
- name: Extract metadata
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
tags: |
type=raw,value=latest-dev,enable={{is_default_branch}}
type=sha,prefix={{branch}}-
- name: Build and push Docker image
id: build
uses: docker/build-push-action@v6
with:
context: .
file: ./src/main/docker/Dockerfile.jvm
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
cache-from: type=gha
cache-to: type=gha,mode=max
platforms: linux/amd64
- name: Image digest
run: echo ${{ steps.build.outputs.digest }}