etaerst
This commit is contained in:
@@ -31,9 +31,6 @@ concurrency:
|
|||||||
jobs:
|
jobs:
|
||||||
check:
|
check:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
outputs:
|
|
||||||
artifact_exists: ${{ steps.check.outputs.artifact_exists }}
|
|
||||||
next_version: ${{ steps.check.outputs.next_version }}
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
@@ -43,7 +40,6 @@ jobs:
|
|||||||
bash scripts/report-status.sh pending "Checking version..." ci-check
|
bash scripts/report-status.sh pending "Checking version..." ci-check
|
||||||
|
|
||||||
- name: Check existing artifact and calculate version
|
- name: Check existing artifact and calculate version
|
||||||
id: check
|
|
||||||
run: |
|
run: |
|
||||||
RAW_VERSION=$(jq -r '.version' package.json)
|
RAW_VERSION=$(jq -r '.version' package.json)
|
||||||
BASE_VERSION=$(echo "$RAW_VERSION" | cut -d'.' -f1-2)
|
BASE_VERSION=$(echo "$RAW_VERSION" | cut -d'.' -f1-2)
|
||||||
@@ -54,12 +50,14 @@ jobs:
|
|||||||
|
|
||||||
TAG=$(echo "$TAGS_JSON" | jq -r 'if type == "array" then .[] | select(.commit.sha == "${{ github.sha }}") | .name else empty end' | head -1)
|
TAG=$(echo "$TAGS_JSON" | jq -r 'if type == "array" then .[] | select(.commit.sha == "${{ github.sha }}") | .name else empty end' | head -1)
|
||||||
|
|
||||||
|
mkdir -p /tmp/build-ctx
|
||||||
|
|
||||||
if [ -n "$TAG" ]; then
|
if [ -n "$TAG" ]; then
|
||||||
echo "artifact_exists=true" >> "$GITHUB_OUTPUT"
|
echo "ARTIFACT_EXISTS=true" > /tmp/build-ctx/build.env
|
||||||
echo "next_version=$TAG" >> "$GITHUB_OUTPUT"
|
echo "NEXT_VERSION=$TAG" >> /tmp/build-ctx/build.env
|
||||||
echo "gitea-ci-library - Artefakti löytyi jo tagilla: $TAG."
|
echo "gitea-ci-library - Artefakti löytyi jo tagilla: $TAG."
|
||||||
else
|
else
|
||||||
echo "artifact_exists=false" >> "$GITHUB_OUTPUT"
|
echo "ARTIFACT_EXISTS=false" > /tmp/build-ctx/build.env
|
||||||
|
|
||||||
HIGHEST_PATCH=$(echo "$TAGS_JSON" | jq -r --arg bv "$BASE_VERSION." '
|
HIGHEST_PATCH=$(echo "$TAGS_JSON" | jq -r --arg bv "$BASE_VERSION." '
|
||||||
if type == "array" then .[] | .name | select(startswith($bv)) | sub($bv; "") | tonumber else empty end' | sort -rn | head -1)
|
if type == "array" then .[] | .name | select(startswith($bv)) | sub($bv; "") | tonumber else empty end' | sort -rn | head -1)
|
||||||
@@ -67,21 +65,24 @@ jobs:
|
|||||||
if [ -z "$HIGHEST_PATCH" ]; then NEXT_PATCH=0; else NEXT_PATCH=$((HIGHEST_PATCH + 1)); fi
|
if [ -z "$HIGHEST_PATCH" ]; then NEXT_PATCH=0; else NEXT_PATCH=$((HIGHEST_PATCH + 1)); fi
|
||||||
FULL_VERSION="${BASE_VERSION}.${NEXT_PATCH}"
|
FULL_VERSION="${BASE_VERSION}.${NEXT_PATCH}"
|
||||||
|
|
||||||
echo "next_version=$FULL_VERSION" >> "$GITHUB_OUTPUT"
|
echo "NEXT_VERSION=$FULL_VERSION" >> /tmp/build-ctx/build.env
|
||||||
echo "gitea-ci-library - Uusi vapaa versio: $FULL_VERSION"
|
echo "gitea-ci-library - Uusi vapaa versio: $FULL_VERSION"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
- name: Upload build env artifact
|
||||||
|
uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: build-context
|
||||||
|
path: /tmp/build-ctx/build.env
|
||||||
|
|
||||||
- name: Set Gitea status to SUCCESS
|
- name: Set Gitea status to SUCCESS
|
||||||
if: success()
|
if: success()
|
||||||
env:
|
|
||||||
EXISTS: ${{ steps.check.outputs.artifact_exists }}
|
|
||||||
VERSION: ${{ steps.check.outputs.next_version }}
|
|
||||||
run: |
|
run: |
|
||||||
echo "===== gitea-ci-library - Check existing artifact | success ====="
|
source /tmp/build-ctx/build.env
|
||||||
if [ "${EXISTS}" = "true" ]; then
|
if [ "${ARTIFACT_EXISTS}" = "true" ]; then
|
||||||
bash scripts/report-status.sh success "Skip build: version $VERSION exists" ci-check
|
bash scripts/report-status.sh success "Skip build: version $NEXT_VERSION exists" ci-check
|
||||||
else
|
else
|
||||||
bash scripts/report-status.sh success "Build version $VERSION required" ci-check
|
bash scripts/report-status.sh success "Build version $NEXT_VERSION required" ci-check
|
||||||
fi
|
fi
|
||||||
|
|
||||||
- name: Set Gitea status to FAILURE
|
- name: Set Gitea status to FAILURE
|
||||||
@@ -90,55 +91,99 @@ jobs:
|
|||||||
|
|
||||||
quality-gate:
|
quality-gate:
|
||||||
needs: [check]
|
needs: [check]
|
||||||
if: needs.check.outputs.artifact_exists == 'false'
|
|
||||||
uses: niko/gitea-ci-library/.gitea/workflows/quality-gate.yml@main
|
uses: niko/gitea-ci-library/.gitea/workflows/quality-gate.yml@main
|
||||||
secrets: inherit
|
secrets: inherit
|
||||||
with:
|
with:
|
||||||
env_json: ${{ inputs.env_json }}
|
env_json: ${{ inputs.env_json }}
|
||||||
bats-image: ${{ inputs.bats-image }}
|
bats-image: ${{ inputs.bats-image }}
|
||||||
cucumber-node-image: ${{ inputs.cucumber-node-image }}
|
cucumber-node-image: ${{ inputs.cucumber-node-image }}
|
||||||
|
|
||||||
build:
|
build:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
needs: [check, quality-gate]
|
needs: [check, quality-gate]
|
||||||
if: needs.quality-gate.result == 'success' && needs.check.outputs.artifact_exists == 'false'
|
# PAKOTETAAN KÄYNTIIN: always() ohittaa Gitean dynaamisen skippausbugin
|
||||||
|
if: always()
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: DIAGNOSTICS - Inspect Gitea State and Variables
|
||||||
|
run: |
|
||||||
|
echo "=================================================="
|
||||||
|
echo " GITEA ACTIONS STATE INSPECTION "
|
||||||
|
echo "=================================================="
|
||||||
|
echo "needs.check.result: ${{ needs.check.result }}"
|
||||||
|
echo "needs.quality-gate.result: ${{ needs.quality-gate.result }}"
|
||||||
|
echo "job.status: ${{ job.status }}"
|
||||||
|
echo "=================================================="
|
||||||
|
|
||||||
|
- name: Download build env
|
||||||
|
uses: actions/download-artifact@v3
|
||||||
|
with:
|
||||||
|
name: build-context
|
||||||
|
path: /tmp/build-ctx
|
||||||
|
|
||||||
|
# TÄMÄ STEPPI VARMISTAA LAADUN JA RÄJÄYTTÄÄ PUTKEN JOS LAATUTESTIT EIVÄT OLLEET SUCCESS
|
||||||
|
- name: Verify Quality Gate and Context
|
||||||
|
id: gatekeeper
|
||||||
|
run: |
|
||||||
|
QG_RESULT="${{ needs.quality-gate.result }}"
|
||||||
|
source /tmp/build-ctx/build.env
|
||||||
|
|
||||||
|
echo "gitea-ci-library - Quality gate tilaksi luettu: $QG_RESULT"
|
||||||
|
echo "gitea-ci-library - Levyltä luettu ARTIFACT_EXISTS: $ARTIFACT_EXISTS"
|
||||||
|
|
||||||
|
# 1. RÄJÄYTETÄÄN PUTKI jos testit feilasivat tai ne peruttiin
|
||||||
|
if [ "$QG_RESULT" != "success" ]; then
|
||||||
|
echo "gitea-ci-library - ERROR: Quality gate pitää läpäistä! Tila oli: $QG_RESULT" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 2. Päätetään skipataanko build koska kontti on jo tehty
|
||||||
|
if [ "$ARTIFACT_EXISTS" = "true" ]; then
|
||||||
|
echo "gitea-ci-library - Kontti valmiina. Ohitetaan build-vaiheet."
|
||||||
|
echo "skip=true" >> "$GITHUB_OUTPUT"
|
||||||
|
else
|
||||||
|
echo "skip=false" >> "$GITHUB_OUTPUT"
|
||||||
|
fi
|
||||||
|
|
||||||
- name: Set Gitea status to PENDING
|
- name: Set Gitea status to PENDING
|
||||||
|
if: steps.gatekeeper.outputs.skip == 'false'
|
||||||
run: |
|
run: |
|
||||||
echo "===== gitea-ci-library - Docker Build | begin ====="
|
echo "===== gitea-ci-library - Docker Build | begin ====="
|
||||||
bash scripts/report-status.sh pending "Building Docker image..." ci-docker-build
|
bash scripts/report-status.sh pending "Building Docker image..." ci-docker-build
|
||||||
|
|
||||||
- name: Build container
|
- name: Build container
|
||||||
id: build
|
if: steps.gatekeeper.outputs.skip == 'false'
|
||||||
env:
|
|
||||||
VERSION: ${{ needs.check.outputs.next_version }}
|
|
||||||
run: |
|
run: |
|
||||||
|
source /tmp/build-ctx/build.env
|
||||||
NOW=$(date -u +%Y-%m-%dT%H:%M:%SZ)
|
NOW=$(date -u +%Y-%m-%dT%H:%M:%SZ)
|
||||||
docker build \
|
docker build \
|
||||||
--label "git.commit=${{ github.sha }}" \
|
--label "git.commit=${{ github.sha }}" \
|
||||||
--label "git.commitBy=${{ github.actor }}" \
|
--label "git.commitBy=${{ github.actor }}" \
|
||||||
--label "build.date=${NOW}" \
|
--label "build.date=${NOW}" \
|
||||||
-t "minimal:${VERSION}" .
|
-t "minimal:${NEXT_VERSION}" .
|
||||||
|
|
||||||
- name: Report status SUCCESS
|
- name: Report status SUCCESS
|
||||||
if: success()
|
if: steps.gatekeeper.outputs.skip == 'false' && success()
|
||||||
env:
|
run: |
|
||||||
VERSION: ${{ needs.check.outputs.next_version }}
|
source /tmp/build-ctx/build.env
|
||||||
run: bash scripts/report-status.sh success "Docker build $VERSION OK" ci-docker-build
|
bash scripts/report-status.sh success "Docker build $NEXT_VERSION OK" ci-docker-build
|
||||||
|
|
||||||
- name: Report status FAILURE
|
- name: Report status FAILURE
|
||||||
if: failure()
|
if: steps.gatekeeper.outputs.skip == 'false' && failure()
|
||||||
env:
|
run: |
|
||||||
VERSION: ${{ needs.check.outputs.next_version }}
|
source /tmp/build-ctx/build.env
|
||||||
run: bash scripts/report-status.sh failure "Docker build $VERSION FAILED" ci-docker-build
|
bash scripts/report-status.sh failure "Docker build $NEXT_VERSION FAILED" ci-docker-build
|
||||||
|
|
||||||
- name: Save Docker image
|
- name: Save Docker image
|
||||||
|
if: steps.gatekeeper.outputs.skip == 'false' && success()
|
||||||
run: |
|
run: |
|
||||||
|
source /tmp/build-ctx/build.env
|
||||||
mkdir -p /tmp/image
|
mkdir -p /tmp/image
|
||||||
docker save "minimal:${{ needs.check.outputs.next_version }}" -o /tmp/image/artifact.tar
|
docker save "minimal:${NEXT_VERSION}" -o /tmp/image/artifact.tar
|
||||||
|
|
||||||
- name: Upload Docker image artifact
|
- name: Upload Docker image artifact
|
||||||
|
if: steps.gatekeeper.outputs.skip == 'false' && success()
|
||||||
uses: actions/upload-artifact@v3
|
uses: actions/upload-artifact@v3
|
||||||
with:
|
with:
|
||||||
name: docker-image
|
name: docker-image
|
||||||
@@ -147,72 +192,119 @@ jobs:
|
|||||||
push:
|
push:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
needs: [check, build]
|
needs: [check, build]
|
||||||
if: needs.build.result == 'success' && needs.check.outputs.artifact_exists == 'false'
|
if: always()
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Download build env
|
||||||
|
uses: actions/download-artifact@v3
|
||||||
|
with:
|
||||||
|
name: build-context
|
||||||
|
path: /tmp/build-ctx
|
||||||
|
|
||||||
|
- name: Verify Build Status
|
||||||
|
id: gatekeeper
|
||||||
|
run: |
|
||||||
|
BUILD_RESULT="${{ needs.build.result }}"
|
||||||
|
source /tmp/build-ctx/build.env
|
||||||
|
if [ "$BUILD_RESULT" != "success" ]; then
|
||||||
|
echo "gitea-ci-library - Edellinen vaihe epäonnistui. Keskeytetään." >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
if [ "${ARTIFACT_EXISTS}" = "true" ]; then
|
||||||
|
echo "skip=true" >> "$GITHUB_OUTPUT"
|
||||||
|
else
|
||||||
|
echo "skip=false" >> "$GITHUB_OUTPUT"
|
||||||
|
fi
|
||||||
|
|
||||||
- name: Load saved Docker image
|
- name: Load saved Docker image
|
||||||
|
if: steps.gatekeeper.outputs.skip == 'false'
|
||||||
uses: actions/download-artifact@v3
|
uses: actions/download-artifact@v3
|
||||||
with:
|
with:
|
||||||
name: docker-image
|
name: docker-image
|
||||||
path: /tmp/image
|
path: /tmp/image
|
||||||
|
|
||||||
- name: Set Gitea status to PENDING
|
- name: Set Gitea status to PENDING
|
||||||
|
if: steps.gatekeeper.outputs.skip == 'false'
|
||||||
run: |
|
run: |
|
||||||
echo "===== gitea-ci-library - Docker Push | begin ====="
|
echo "===== gitea-ci-library - Docker Push | begin ====="
|
||||||
bash scripts/report-status.sh pending "Pushing to registry..." ci-docker-push
|
bash scripts/report-status.sh pending "Pushing to registry..." ci-docker-push
|
||||||
|
|
||||||
- name: Push to Gitea Packages
|
- name: Push to Gitea Packages
|
||||||
|
if: steps.gatekeeper.outputs.skip == 'false'
|
||||||
env:
|
env:
|
||||||
GITEA_TOKEN: ${{ secrets.GITEA_TOKEN }}
|
GITEA_TOKEN: ${{ secrets.GITEA_TOKEN }}
|
||||||
VERSION: ${{ needs.check.outputs.next_version }}
|
|
||||||
run: |
|
run: |
|
||||||
|
source /tmp/build-ctx/build.env
|
||||||
docker load -i /tmp/image/artifact.tar
|
docker load -i /tmp/image/artifact.tar
|
||||||
REGISTRY=$(echo "${{ gitea.server_url }}" | sed -e 's|^https://||' -e 's|^http://||')
|
REGISTRY=$(echo "${{ gitea.server_url }}" | sed -e 's|^https://||' -e 's|^http://||')
|
||||||
IMAGE="$REGISTRY/${{ gitea.repository }}:$VERSION"
|
IMAGE="$REGISTRY/${{ gitea.repository }}:${NEXT_VERSION}"
|
||||||
docker tag "minimal:$VERSION" "$IMAGE"
|
docker tag "minimal:$NEXT_VERSION" "$IMAGE"
|
||||||
echo "$GITEA_TOKEN" | docker login "$REGISTRY" -u "${{ github.actor }}" --password-stdin
|
echo "$GITEA_TOKEN" | docker login "$REGISTRY" -u "${{ github.actor }}" --password-stdin
|
||||||
docker push "$IMAGE"
|
docker push "$IMAGE"
|
||||||
docker logout "$REGISTRY"
|
docker logout "$REGISTRY"
|
||||||
|
|
||||||
- name: Report status SUCCESS
|
- name: Report status SUCCESS
|
||||||
if: success()
|
if: steps.gatekeeper.outputs.skip == 'false' && success()
|
||||||
env:
|
run: |
|
||||||
VERSION: ${{ needs.check.outputs.next_version }}
|
source /tmp/build-ctx/build.env
|
||||||
run: bash scripts/report-status.sh success "Docker push $VERSION OK" ci-docker-push
|
bash scripts/report-status.sh success "Docker push $NEXT_VERSION OK" ci-docker-push
|
||||||
|
|
||||||
- name: Report status FAILURE
|
- name: Report status FAILURE
|
||||||
if: failure()
|
if: steps.gatekeeper.outputs.skip == 'false' && failure()
|
||||||
env:
|
run: |
|
||||||
VERSION: ${{ needs.check.outputs.next_version }}
|
source /tmp/build-ctx/build.env
|
||||||
run: bash scripts/report-status.sh failure "Docker push $VERSION FAILED" ci-docker-push
|
bash scripts/report-status.sh failure "Docker push $NEXT_VERSION FAILED" ci-docker-push
|
||||||
|
|
||||||
tag-commit:
|
tag-commit:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
needs: [check, push]
|
needs: [check, push]
|
||||||
if: needs.push.result == 'success' && needs.check.outputs.artifact_exists == 'false'
|
if: always()
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Download build env
|
||||||
|
uses: actions/download-artifact@v3
|
||||||
|
with:
|
||||||
|
name: build-context
|
||||||
|
path: /tmp/build-ctx
|
||||||
|
|
||||||
|
- name: Verify Push Status
|
||||||
|
id: gatekeeper
|
||||||
|
run: |
|
||||||
|
PUSH_RESULT="${{ needs.push.result }}"
|
||||||
|
source /tmp/build-ctx/build.env
|
||||||
|
if [ "$PUSH_RESULT" != "success" ]; then
|
||||||
|
echo "gitea-ci-library - Push vaihe epäonnistui. Keskeytetään." >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
if [ "${ARTIFACT_EXISTS}" = "true" ]; then
|
||||||
|
echo "skip=true" >> "$GITHUB_OUTPUT"
|
||||||
|
else
|
||||||
|
echo "skip=false" >> "$GITHUB_OUTPUT"
|
||||||
|
fi
|
||||||
|
|
||||||
- name: Set Gitea status to PENDING
|
- name: Set Gitea status to PENDING
|
||||||
|
if: steps.gatekeeper.outputs.skip == 'false'
|
||||||
run: |
|
run: |
|
||||||
echo "===== gitea-ci-library - Create Tag | begin ====="
|
echo "===== gitea-ci-library - Create Tag | begin ====="
|
||||||
bash scripts/report-status.sh pending "Creating tag..." ci-docker-tag
|
bash scripts/report-status.sh pending "Creating tag..." ci-docker-tag
|
||||||
|
|
||||||
- name: Create git tag
|
- name: Create git tag
|
||||||
|
if: steps.gatekeeper.outputs.skip == 'false'
|
||||||
env:
|
env:
|
||||||
GITEA_TOKEN: ${{ secrets.GITEA_TOKEN }}
|
GITEA_TOKEN: ${{ secrets.GITEA_TOKEN }}
|
||||||
REPO: ${{ github.repository }}
|
REPO: ${{ github.repository }}
|
||||||
SERVER_URL: ${{ gitea.server_url }}
|
SERVER_URL: ${{ gitea.server_url }}
|
||||||
RUN_NUMBER: ${{ github.run_number }}
|
RUN_NUMBER: ${{ github.run_number }}
|
||||||
SHA: ${{ github.sha }}
|
SHA: ${{ github.sha }}
|
||||||
VERSION: ${{ needs.check.outputs.next_version }}
|
|
||||||
run: |
|
run: |
|
||||||
|
source /tmp/build-ctx/build.env
|
||||||
HTTP_CODE=$(curl -s -o /dev/null -w "%{http_code}" -X POST \
|
HTTP_CODE=$(curl -s -o /dev/null -w "%{http_code}" -X POST \
|
||||||
"$SERVER_URL/api/v1/repos/$REPO/tags" \
|
"$SERVER_URL/api/v1/repos/$REPO/tags" \
|
||||||
-H "Authorization: token $GITEA_TOKEN" \
|
-H "Authorization: token $GITEA_TOKEN" \
|
||||||
-H "Content-Type: application/json" \
|
-H "Content-Type: application/json" \
|
||||||
-d "{\"tag_name\": \"$VERSION\", \"message\": \"Build #$RUN_NUMBER\", \"target\": \"$SHA\"}")
|
-d "{\"tag_name\": \"$NEXT_VERSION\", \"message\": \"Build #$RUN_NUMBER\", \"target\": \"$SHA\"}")
|
||||||
|
|
||||||
if [ "$HTTP_CODE" = "201" ] || [ "$HTTP_CODE" = "409" ]; then
|
if [ "$HTTP_CODE" = "201" ] || [ "$HTTP_CODE" = "409" ]; then
|
||||||
exit 0
|
exit 0
|
||||||
@@ -221,13 +313,13 @@ jobs:
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
- name: Report status SUCCESS
|
- name: Report status SUCCESS
|
||||||
if: success()
|
if: steps.gatekeeper.outputs.skip == 'false' && success()
|
||||||
env:
|
run: |
|
||||||
VERSION: ${{ needs.check.outputs.next_version }}
|
source /tmp/build-ctx/build.env
|
||||||
run: bash scripts/report-status.sh success "Tag $VERSION OK" ci-docker-tag
|
bash scripts/report-status.sh success "Tag $NEXT_VERSION OK" ci-docker-tag
|
||||||
|
|
||||||
- name: Report status FAILURE
|
- name: Report status FAILURE
|
||||||
if: failure()
|
if: steps.gatekeeper.outputs.skip == 'false' && failure()
|
||||||
env:
|
run: |
|
||||||
VERSION: ${{ needs.check.outputs.next_version }}
|
source /tmp/build-ctx/build.env
|
||||||
run: bash scripts/report-status.sh failure "Tag $VERSION FAILED" ci-docker-tag
|
bash scripts/report-status.sh failure "Tag $NEXT_VERSION FAILED" ci-docker-tag
|
||||||
|
|||||||
Reference in New Issue
Block a user