Refactor ci

This commit is contained in:
2025-09-07 20:26:28 +03:00
parent e8b9261775
commit 035137148c
3 changed files with 106 additions and 59 deletions

33
.github/workflows/ci.yaml vendored Normal file
View File

@@ -0,0 +1,33 @@
name: CI Verification
on:
push:
branches: [ main ]
pull_request:
branches: [ main ]
# Cancel redundant, in-progress runs for the same branch or PR
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
jobs:
verify:
name: Build & Test
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up JDK 21
uses: actions/setup-java@v4
with:
distribution: 'temurin'
java-version: '21'
cache: 'gradle'
- name: Verify with Gradle
# The 'build' command will compile, run tests, and package the app.
# If any step fails, the workflow will fail, protecting your main branch.
run: ./gradlew build

View File

@@ -1,59 +0,0 @@
name: CI
on:
push:
branches:
- main
pull_request:
jobs:
verify:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v5
- uses: actions/setup-java@v4
with:
distribution: 'temurin'
java-version: '21'
cache: 'gradle'
- name: Build with Gradle
run: ./gradlew build
publish:
runs-on: ubuntu-latest
needs: verify
if: github.event_name == 'push' && github.ref == 'refs/heads/main'
permissions:
contents: read
packages: write
attestations: write
id-token: write
steps:
- uses: actions/checkout@v5
- uses: actions/setup-java@v4
with:
distribution: 'temurin'
java-version: '21'
cache: 'gradle'
- name: Build with Gradle
run: ./gradlew build
- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Build and push Docker image
uses: docker/build-push-action@v6
with:
context: .
push: true
tags: ghcr.io/${{ github.repository_owner }}/memevizor:latest
cache-from: type=gha
cache-to: type=gha,mode=max

73
.github/workflows/release.yaml vendored Normal file
View File

@@ -0,0 +1,73 @@
name: Publish Release
# This workflow is triggered ONLY when a new release is created in GitHub
on:
release:
types: [ created ]
jobs:
build:
name: Build Release Artifact
runs-on: ubuntu-latest
steps:
- name: Checkout code
# Checks out the specific Git tag associated with the release
uses: actions/checkout@v4
- name: Set up JDK 21
uses: actions/setup-java@v4
with:
distribution: 'temurin'
java-version: '21'
cache: 'gradle'
- name: Build with Gradle
run: ./gradlew build
- name: Upload JAR artifact for publisher job
uses: actions/upload-artifact@v4
with:
name: app-jar
path: build/libs/*.jar # Adjust path if needed
retention-days: 1
publish:
name: Publish to GitHub Container Registry
runs-on: ubuntu-latest
needs: build # This job waits for the 'build' job to succeed
permissions:
contents: read
packages: write
steps:
- name: Download JAR artifact from build job
uses: actions/download-artifact@v4
with:
name: app-jar
path: build/libs
- name: Log in to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Extract metadata for Docker
id: meta
uses: docker/metadata-action@v5
with:
images: ghcr.io/${{ github.repository }}
tags: |
# Tag with the release version (e.g., v1.2.3)
type=raw,value=${{ github.ref_name }}
# Also tag as 'latest'
type=raw,value=latest
- name: Build and push Docker image
uses: docker/build-push-action@v6
with:
context: .
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}