ci: add gitea image publishing workflows
This commit is contained in:
130
.gitea/workflows/build-push.yaml
Normal file
130
.gitea/workflows/build-push.yaml
Normal file
@@ -0,0 +1,130 @@
|
|||||||
|
name: Release Docker Image Build
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- master
|
||||||
|
paths:
|
||||||
|
- 'VERSION'
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
verify-and-package:
|
||||||
|
if: github.repository != 'templates/mono-app-with-db'
|
||||||
|
runs-on: java-node-24
|
||||||
|
env:
|
||||||
|
GRADLE_USER_HOME: /opt/hostedtoolcache/gradle/${{ github.repository }}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: 1. Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: 2. Prepare Gradle cache and Docker access
|
||||||
|
run: |
|
||||||
|
sudo install -d -m 0755 -o "$(id -u)" -g "$(id -g)" "$GRADLE_USER_HOME"
|
||||||
|
sudo chgrp "$(id -g)" /var/run/docker.sock
|
||||||
|
sudo chmod g+rw /var/run/docker.sock
|
||||||
|
|
||||||
|
- name: 3. Verify and stage with Gradle
|
||||||
|
run: |
|
||||||
|
./gradlew --no-daemon --console=plain check stageFatJar
|
||||||
|
|
||||||
|
- name: 4. Upload test reports
|
||||||
|
if: always()
|
||||||
|
id: upload-test-reports
|
||||||
|
uses: christopherhx/gitea-upload-artifact@v4
|
||||||
|
with:
|
||||||
|
name: test-reports
|
||||||
|
path: |
|
||||||
|
build/reports/tests/test/**
|
||||||
|
build/test-results/test/**/*.xml
|
||||||
|
if-no-files-found: warn
|
||||||
|
retention-days: 7
|
||||||
|
|
||||||
|
- name: 5. Output test report artifact URL
|
||||||
|
if: always()
|
||||||
|
run: |
|
||||||
|
echo "Test reports: ${{ steps.upload-test-reports.outputs.artifact-url }}"
|
||||||
|
|
||||||
|
- name: 6. Upload staged fat jar
|
||||||
|
uses: christopherhx/gitea-upload-artifact@v4
|
||||||
|
with:
|
||||||
|
name: application-fat-jar
|
||||||
|
path: build/ci/server.jar
|
||||||
|
retention-days: 1
|
||||||
|
compression-level: 0
|
||||||
|
|
||||||
|
build-and-publish:
|
||||||
|
if: github.repository != 'templates/mono-app-with-db'
|
||||||
|
runs-on: java-node-24
|
||||||
|
needs: verify-and-package
|
||||||
|
env:
|
||||||
|
REGISTRY: git.dslan.at
|
||||||
|
REPOSITORY: ${{ github.repository }}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: 1. Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
|
||||||
|
- name: 2. Download staged fat jar
|
||||||
|
uses: christopherhx/gitea-download-artifact@v4
|
||||||
|
with:
|
||||||
|
name: application-fat-jar
|
||||||
|
path: ./build/ci
|
||||||
|
|
||||||
|
- name: 3. Prepare Docker access
|
||||||
|
run: |
|
||||||
|
sudo chgrp "$(id -g)" /var/run/docker.sock
|
||||||
|
sudo chmod g+rw /var/run/docker.sock
|
||||||
|
|
||||||
|
- name: 4. Set up Docker Buildx
|
||||||
|
uses: docker/setup-buildx-action@v3.11.0
|
||||||
|
with:
|
||||||
|
driver: docker-container
|
||||||
|
driver-opts: network=host
|
||||||
|
|
||||||
|
- name: 5. Read version and set image tags
|
||||||
|
id: meta
|
||||||
|
run: |
|
||||||
|
VERSION_TAG=$(cat VERSION)
|
||||||
|
echo "tag_version=$VERSION_TAG" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- name: 6. Log in to the Gitea Container Registry
|
||||||
|
uses: docker/login-action@v3.6.0
|
||||||
|
with:
|
||||||
|
registry: ${{ env.REGISTRY }}
|
||||||
|
username: ${{ secrets.PR_USER }}
|
||||||
|
password: ${{ secrets.PR_PASSWORD }}
|
||||||
|
|
||||||
|
- name: 7. Build and push the Docker image
|
||||||
|
uses: docker/build-push-action@v5
|
||||||
|
with:
|
||||||
|
context: ./build/ci
|
||||||
|
file: ./Dockerfile
|
||||||
|
push: true
|
||||||
|
tags: |
|
||||||
|
${{ env.REGISTRY }}/${{ env.REPOSITORY }}:${{ steps.meta.outputs.tag_version }}
|
||||||
|
${{ env.REGISTRY }}/${{ env.REPOSITORY }}:latest
|
||||||
|
cache-from: type=registry,ref=${{ env.REGISTRY }}/${{ env.REPOSITORY }}:buildcache-release
|
||||||
|
cache-to: type=registry,ref=${{ env.REGISTRY }}/${{ env.REPOSITORY }}:buildcache-release,mode=max
|
||||||
|
|
||||||
|
- name: 8. Create and push Git tag
|
||||||
|
run: |
|
||||||
|
git config user.name "${{ secrets.PR_USER }}"
|
||||||
|
git config user.email "gitea-actions@${{ env.REGISTRY }}"
|
||||||
|
TAG_NAME="${{ steps.meta.outputs.tag_version }}"
|
||||||
|
git fetch --tags
|
||||||
|
if git rev-parse "$TAG_NAME" >/dev/null 2>&1; then
|
||||||
|
echo "Tag $TAG_NAME already exists, skipping."
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
git tag $TAG_NAME
|
||||||
|
git push https://${{ secrets.PR_USER }}:${{ secrets.PR_PASSWORD }}@${{ env.REGISTRY }}/${{ env.REPOSITORY }}.git $TAG_NAME
|
||||||
|
|
||||||
|
- name: 9. Output image names
|
||||||
|
run: |
|
||||||
|
echo "Successfully pushed:"
|
||||||
|
echo "${{ env.REGISTRY }}/${{ env.REPOSITORY }}:${{ steps.meta.outputs.tag_version }}"
|
||||||
|
echo "${{ env.REGISTRY }}/${{ env.REPOSITORY }}:latest"
|
||||||
111
.gitea/workflows/build-snapshot.yaml
Normal file
111
.gitea/workflows/build-snapshot.yaml
Normal file
@@ -0,0 +1,111 @@
|
|||||||
|
name: Snapshot Docker Image Build
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- master
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
verify-and-package:
|
||||||
|
if: github.repository != 'templates/mono-app-with-db'
|
||||||
|
runs-on: java-node-24
|
||||||
|
env:
|
||||||
|
GRADLE_USER_HOME: /opt/hostedtoolcache/gradle/${{ github.repository }}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: 1. Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: 2. Prepare Gradle cache and Docker access
|
||||||
|
run: |
|
||||||
|
sudo install -d -m 0755 -o "$(id -u)" -g "$(id -g)" "$GRADLE_USER_HOME"
|
||||||
|
sudo chgrp "$(id -g)" /var/run/docker.sock
|
||||||
|
sudo chmod g+rw /var/run/docker.sock
|
||||||
|
|
||||||
|
- name: 3. Verify and stage with Gradle
|
||||||
|
run: |
|
||||||
|
./gradlew --no-daemon --console=plain check stageFatJar
|
||||||
|
|
||||||
|
- name: 4. Upload test reports
|
||||||
|
if: always()
|
||||||
|
id: upload-test-reports
|
||||||
|
uses: christopherhx/gitea-upload-artifact@v4
|
||||||
|
with:
|
||||||
|
name: test-reports
|
||||||
|
path: |
|
||||||
|
build/reports/tests/test/**
|
||||||
|
build/test-results/test/**/*.xml
|
||||||
|
if-no-files-found: warn
|
||||||
|
retention-days: 7
|
||||||
|
|
||||||
|
- name: 5. Output test report artifact URL
|
||||||
|
if: always()
|
||||||
|
run: |
|
||||||
|
echo "Test reports: ${{ steps.upload-test-reports.outputs.artifact-url }}"
|
||||||
|
|
||||||
|
- name: 6. Upload staged fat jar
|
||||||
|
uses: christopherhx/gitea-upload-artifact@v4
|
||||||
|
with:
|
||||||
|
name: application-fat-jar
|
||||||
|
path: build/ci/server.jar
|
||||||
|
retention-days: 1
|
||||||
|
compression-level: 0
|
||||||
|
|
||||||
|
build-and-publish-snapshot:
|
||||||
|
if: github.repository != 'templates/mono-app-with-db'
|
||||||
|
runs-on: java-node-24
|
||||||
|
needs: verify-and-package
|
||||||
|
env:
|
||||||
|
REGISTRY: git.dslan.at
|
||||||
|
REPOSITORY: ${{ github.repository }}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: 1. Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
|
||||||
|
- name: 2. Download staged fat jar
|
||||||
|
uses: christopherhx/gitea-download-artifact@v4
|
||||||
|
with:
|
||||||
|
name: application-fat-jar
|
||||||
|
path: ./build/ci
|
||||||
|
|
||||||
|
- name: 3. Prepare Docker access
|
||||||
|
run: |
|
||||||
|
sudo chgrp "$(id -g)" /var/run/docker.sock
|
||||||
|
sudo chmod g+rw /var/run/docker.sock
|
||||||
|
|
||||||
|
- name: 4. Set up Docker Buildx
|
||||||
|
uses: docker/setup-buildx-action@v3.11.0
|
||||||
|
with:
|
||||||
|
driver: docker-container
|
||||||
|
driver-opts: network=host
|
||||||
|
|
||||||
|
- name: 5. Read version and set snapshot tag
|
||||||
|
id: meta
|
||||||
|
run: |
|
||||||
|
VERSION_BASE=$(cat VERSION)
|
||||||
|
LAST_CHANGED=$(git log -1 --format=%H VERSION)
|
||||||
|
COUNT=$(git rev-list ${LAST_CHANGED}..HEAD --count)
|
||||||
|
SNAPSHOT_TAG="${VERSION_BASE}-SNAPSHOT-$((COUNT + 1))"
|
||||||
|
echo "tag_version=$SNAPSHOT_TAG" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- name: 6. Log in to the Gitea Container Registry
|
||||||
|
uses: docker/login-action@v3.6.0
|
||||||
|
with:
|
||||||
|
registry: ${{ env.REGISTRY }}
|
||||||
|
username: ${{ secrets.PR_USER }}
|
||||||
|
password: ${{ secrets.PR_PASSWORD }}
|
||||||
|
|
||||||
|
- name: 7. Build and push the Docker image
|
||||||
|
uses: docker/build-push-action@v5
|
||||||
|
with:
|
||||||
|
context: ./build/ci
|
||||||
|
file: ./Dockerfile
|
||||||
|
push: true
|
||||||
|
tags: |
|
||||||
|
${{ env.REGISTRY }}/${{ env.REPOSITORY }}:${{ steps.meta.outputs.tag_version }}
|
||||||
|
${{ env.REGISTRY }}/${{ env.REPOSITORY }}:snapshot-latest
|
||||||
|
cache-from: type=registry,ref=${{ env.REGISTRY }}/${{ env.REPOSITORY }}:buildcache-snapshot
|
||||||
|
cache-to: type=registry,ref=${{ env.REGISTRY }}/${{ env.REPOSITORY }}:buildcache-snapshot,mode=max
|
||||||
10
Dockerfile
10
Dockerfile
@@ -1,8 +1,12 @@
|
|||||||
FROM eclipse-temurin:21-jre
|
FROM eclipse-temurin:24-jre-noble
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
|
||||||
COPY build/libs/*.jar app.jar
|
RUN useradd -m -s /bin/bash codenames
|
||||||
|
|
||||||
|
COPY --chown=codenames:codenames server.jar /app/server.jar
|
||||||
|
|
||||||
|
USER codenames
|
||||||
|
|
||||||
EXPOSE 8080
|
EXPOSE 8080
|
||||||
|
|
||||||
ENTRYPOINT ["java", "-jar", "/app/app.jar"]
|
ENTRYPOINT ["java", "-jar", "/app/server.jar"]
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ plugins {
|
|||||||
apply(plugin = "org.springframework.boot")
|
apply(plugin = "org.springframework.boot")
|
||||||
|
|
||||||
group = "at.dslan"
|
group = "at.dslan"
|
||||||
version = "0.1.0"
|
version = file("VERSION").readText().trim()
|
||||||
|
|
||||||
java {
|
java {
|
||||||
toolchain {
|
toolchain {
|
||||||
@@ -40,3 +40,14 @@ dependencies {
|
|||||||
tasks.withType<Test> {
|
tasks.withType<Test> {
|
||||||
useJUnitPlatform()
|
useJUnitPlatform()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tasks.register<Copy>("stageFatJar") {
|
||||||
|
group = "build"
|
||||||
|
description = "Copies the boot jar to a stable location for CI image assembly."
|
||||||
|
dependsOn("bootJar")
|
||||||
|
from(layout.buildDirectory.dir("libs")) {
|
||||||
|
include("*.jar")
|
||||||
|
}
|
||||||
|
into(layout.buildDirectory.dir("ci"))
|
||||||
|
rename { "server.jar" }
|
||||||
|
}
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ spec:
|
|||||||
- name: codenames-registry
|
- name: codenames-registry
|
||||||
containers:
|
containers:
|
||||||
- name: codenames
|
- name: codenames
|
||||||
image: git.dslan.at/zeugs/codenames:master
|
image: git.dslan.at/zeugs/codenames:snapshot-latest
|
||||||
imagePullPolicy: Always
|
imagePullPolicy: Always
|
||||||
ports:
|
ports:
|
||||||
- containerPort: 8080
|
- containerPort: 8080
|
||||||
|
|||||||
Reference in New Issue
Block a user