päivitettu runner image 1.0.4 -> 1.0.8
CI / Load gitea-env.conf to pipeline env (push) Successful in 2m8s
ci-check Build version 0.1.0 required
ci-cucumber Cucumber tests
ci-bats Bats tests
CI / Build & Push Artifact (push) Failing after 2m13s

This commit is contained in:
moilanik
2026-06-15 08:50:54 +03:00
parent 52601104b0
commit 16b25970ff
2 changed files with 54 additions and 145 deletions
+53 -145
View File
@@ -31,6 +31,9 @@ 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
@@ -40,6 +43,7 @@ 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)
@@ -50,14 +54,12 @@ 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" > /tmp/build-ctx/build.env echo "artifact_exists=true" >> "$GITHUB_OUTPUT"
echo "NEXT_VERSION=$TAG" >> /tmp/build-ctx/build.env echo "next_version=$TAG" >> "$GITHUB_OUTPUT"
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" > /tmp/build-ctx/build.env echo "artifact_exists=false" >> "$GITHUB_OUTPUT"
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)
@@ -65,24 +67,21 @@ 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" >> /tmp/build-ctx/build.env echo "next_version=$FULL_VERSION" >> "$GITHUB_OUTPUT"
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: |
source /tmp/build-ctx/build.env echo "===== gitea-ci-library - Check existing artifact | success ====="
if [ "${ARTIFACT_EXISTS}" = "true" ]; then if [ "${EXISTS}" = "true" ]; then
bash scripts/report-status.sh success "Skip build: version $NEXT_VERSION exists" ci-check bash scripts/report-status.sh success "Skip build: version $VERSION exists" ci-check
else else
bash scripts/report-status.sh success "Build version $NEXT_VERSION required" ci-check bash scripts/report-status.sh success "Build version $VERSION required" ci-check
fi fi
- name: Set Gitea status to FAILURE - name: Set Gitea status to FAILURE
@@ -91,99 +90,55 @@ 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]
# PAKOTETAAN KÄYNTIIN: always() ohittaa Gitean dynaamisen skippausbugin if: needs.quality-gate.result == 'success' && needs.check.outputs.artifact_exists == 'false'
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
if: steps.gatekeeper.outputs.skip == 'false' id: build
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:${NEXT_VERSION}" . -t "minimal:${VERSION}" .
- name: Report status SUCCESS - name: Report status SUCCESS
if: steps.gatekeeper.outputs.skip == 'false' && success() if: success()
run: | env:
source /tmp/build-ctx/build.env VERSION: ${{ needs.check.outputs.next_version }}
bash scripts/report-status.sh success "Docker build $NEXT_VERSION OK" ci-docker-build run: bash scripts/report-status.sh success "Docker build $VERSION OK" ci-docker-build
- name: Report status FAILURE - name: Report status FAILURE
if: steps.gatekeeper.outputs.skip == 'false' && failure() if: failure()
run: | env:
source /tmp/build-ctx/build.env VERSION: ${{ needs.check.outputs.next_version }}
bash scripts/report-status.sh failure "Docker build $NEXT_VERSION FAILED" ci-docker-build run: bash scripts/report-status.sh failure "Docker build $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:${NEXT_VERSION}" -o /tmp/image/artifact.tar docker save "minimal:${{ needs.check.outputs.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
@@ -192,119 +147,72 @@ jobs:
push: push:
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: [check, build] needs: [check, build]
if: always() if: needs.build.result == 'success' && needs.check.outputs.artifact_exists == 'false'
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 }}:${NEXT_VERSION}" IMAGE="$REGISTRY/${{ gitea.repository }}:$VERSION"
docker tag "minimal:$NEXT_VERSION" "$IMAGE" docker tag "minimal:$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: steps.gatekeeper.outputs.skip == 'false' && success() if: success()
run: | env:
source /tmp/build-ctx/build.env VERSION: ${{ needs.check.outputs.next_version }}
bash scripts/report-status.sh success "Docker push $NEXT_VERSION OK" ci-docker-push run: bash scripts/report-status.sh success "Docker push $VERSION OK" ci-docker-push
- name: Report status FAILURE - name: Report status FAILURE
if: steps.gatekeeper.outputs.skip == 'false' && failure() if: failure()
run: | env:
source /tmp/build-ctx/build.env VERSION: ${{ needs.check.outputs.next_version }}
bash scripts/report-status.sh failure "Docker push $NEXT_VERSION FAILED" ci-docker-push run: bash scripts/report-status.sh failure "Docker push $VERSION FAILED" ci-docker-push
tag-commit: tag-commit:
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: [check, push] needs: [check, push]
if: always() if: needs.push.result == 'success' && needs.check.outputs.artifact_exists == 'false'
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\": \"$NEXT_VERSION\", \"message\": \"Build #$RUN_NUMBER\", \"target\": \"$SHA\"}") -d "{\"tag_name\": \"$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
@@ -313,13 +221,13 @@ jobs:
fi fi
- name: Report status SUCCESS - name: Report status SUCCESS
if: steps.gatekeeper.outputs.skip == 'false' && success() if: success()
run: | env:
source /tmp/build-ctx/build.env VERSION: ${{ needs.check.outputs.next_version }}
bash scripts/report-status.sh success "Tag $NEXT_VERSION OK" ci-docker-tag run: bash scripts/report-status.sh success "Tag $VERSION OK" ci-docker-tag
- name: Report status FAILURE - name: Report status FAILURE
if: steps.gatekeeper.outputs.skip == 'false' && failure() if: failure()
run: | env:
source /tmp/build-ctx/build.env VERSION: ${{ needs.check.outputs.next_version }}
bash scripts/report-status.sh failure "Tag $NEXT_VERSION FAILED" ci-docker-tag run: bash scripts/report-status.sh failure "Tag $VERSION FAILED" ci-docker-tag
+1
View File
@@ -130,6 +130,7 @@ helm upgrade --install act-runner gitea/actions \
--set giteaRootURL="$GITEA_URL" \ --set giteaRootURL="$GITEA_URL" \
--set existingSecret=act-runner-token \ --set existingSecret=act-runner-token \
--set existingSecretKey=token \ --set existingSecretKey=token \
--set statefulset.runner.tag=1.0.8 \
--set statefulset.dind.tag=29.5.2-dind \ --set statefulset.dind.tag=29.5.2-dind \
--set-string 'statefulset.runner.config=log: --set-string 'statefulset.runner.config=log:
level: info level: info