Veränderter Release Ablauf, jetzt wieder mit metadata.txt
Some checks failed
Release Plugin / release (push) Failing after 5s
Some checks failed
Release Plugin / release (push) Failing after 5s
This commit is contained in:
@@ -40,8 +40,20 @@ jobs:
|
|||||||
id: releaseinfo
|
id: releaseinfo
|
||||||
run: |
|
run: |
|
||||||
TAG="${{ github.ref_name }}"
|
TAG="${{ github.ref_name }}"
|
||||||
VERSION="${TAG#v}"
|
TAG_VERSION="${TAG#v}"
|
||||||
|
|
||||||
|
# Version aus metadata.txt auslesen
|
||||||
|
VERSION=$(grep -m1 '^version=' repo/metadata.txt | cut -d'=' -f2-)
|
||||||
|
if [ -z "$VERSION" ]; then
|
||||||
|
echo "Fehler: Version in repo/metadata.txt nicht gefunden" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$VERSION" != "$TAG_VERSION" ]; then
|
||||||
|
echo "Fehler: Tag-Version ($TAG_VERSION) stimmt nicht mit metadata.txt-Version ($VERSION) überein" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
case "$TAG" in
|
case "$TAG" in
|
||||||
*-unstable*)
|
*-unstable*)
|
||||||
CHANNEL="unstable"
|
CHANNEL="unstable"
|
||||||
@@ -65,15 +77,34 @@ jobs:
|
|||||||
echo "draft=$DRAFT" >> $GITHUB_OUTPUT
|
echo "draft=$DRAFT" >> $GITHUB_OUTPUT
|
||||||
echo "prerelease=$PRERELEASE" >> $GITHUB_OUTPUT
|
echo "prerelease=$PRERELEASE" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- name: metadata.txt einlesen
|
||||||
|
id: metadata
|
||||||
|
run: |
|
||||||
|
cd repo
|
||||||
|
|
||||||
|
# Hilfsfunktion, um einen Schlüssel aus metadata.txt auszulesen
|
||||||
|
get() {
|
||||||
|
grep -m1 -E "^$1=" metadata.txt | cut -d'=' -f2- || true
|
||||||
|
}
|
||||||
|
|
||||||
|
echo "name=$(get name)" >> $GITHUB_OUTPUT
|
||||||
|
echo "description=$(get description)" >> $GITHUB_OUTPUT
|
||||||
|
echo "author=$(get author)" >> $GITHUB_OUTPUT
|
||||||
|
echo "email=$(get email)" >> $GITHUB_OUTPUT
|
||||||
|
echo "qgisMinimumVersion=$(get qgisMinimumVersion)" >> $GITHUB_OUTPUT
|
||||||
|
echo "qgisMaximumVersion=$(get qgisMaximumVersion)" >> $GITHUB_OUTPUT
|
||||||
|
echo "experimental=$(get experimental)" >> $GITHUB_OUTPUT
|
||||||
|
echo "deprecated=$(get deprecated)" >> $GITHUB_OUTPUT
|
||||||
|
echo "supportsQt6=$(get supportsQt6)" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
- name: plugin.cfg einlesen
|
- name: plugin.cfg einlesen
|
||||||
id: info
|
id: config
|
||||||
run: |
|
run: |
|
||||||
cd repo
|
cd repo
|
||||||
while read -r line || [ -n "$line" ]; do
|
while read -r line || [ -n "$line" ]; do
|
||||||
key="${line%%=*}"
|
key="${line%%=*}"
|
||||||
value="${line#*=}"
|
value="${line#*=}"
|
||||||
echo "$key=$value" >> $GITHUB_OUTPUT
|
echo "$key=$value" >> $GITHUB_OUTPUT
|
||||||
echo "$key=$value"
|
|
||||||
done < plugin.cfg
|
done < plugin.cfg
|
||||||
|
|
||||||
- name: Changelog einlesen
|
- name: Changelog einlesen
|
||||||
@@ -103,45 +134,13 @@ jobs:
|
|||||||
echo "$FULL" >> $GITHUB_OUTPUT
|
echo "$FULL" >> $GITHUB_OUTPUT
|
||||||
echo "EOF" >> $GITHUB_OUTPUT
|
echo "EOF" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
- name: metadata.txt erzeugen
|
|
||||||
run: |
|
|
||||||
cd repo
|
|
||||||
|
|
||||||
# ------------------------ GEÄNDERT ------------------------
|
|
||||||
# Temporär die Vorlage aus dem hidden/templates Branch holen
|
|
||||||
git fetch origin hidden/templates
|
|
||||||
git checkout origin/hidden/templates -- metadata.template
|
|
||||||
TEMPLATE="metadata.template"
|
|
||||||
# -----------------------------------------------------------
|
|
||||||
|
|
||||||
# TEMPLATE="templates/metadata.template"
|
|
||||||
OUT="metadata.txt"
|
|
||||||
|
|
||||||
CONTENT=$(cat "$TEMPLATE")
|
|
||||||
|
|
||||||
CONTENT="${CONTENT//\{\{NAME\}\}/${{ steps.info.outputs.name }}}"
|
|
||||||
CONTENT="${CONTENT//\{\{QGIS_MIN\}\}/${{ steps.info.outputs.qgisMinimumVersion }}}"
|
|
||||||
CONTENT="${CONTENT//\{\{QGIS_MAX\}\}/${{ steps.info.outputs.qgisMaximumVersion }}}"
|
|
||||||
CONTENT="${CONTENT//\{\{DESCRIPTION\}\}/${{ steps.info.outputs.description }}}"
|
|
||||||
CONTENT="${CONTENT//\{\{VERSION\}\}/${{ steps.releaseinfo.outputs.version }}}"
|
|
||||||
CONTENT="${CONTENT//\{\{AUTHOR\}\}/${{ steps.info.outputs.author }}}"
|
|
||||||
CONTENT="${CONTENT//\{\{EMAIL\}\}/${{ steps.info.outputs.email }}}"
|
|
||||||
CONTENT="${CONTENT//\{\{HOMEPAGE\}\}/${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}}"
|
|
||||||
CONTENT="${CONTENT//\{\{TRACKER\}\}/${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}}"
|
|
||||||
CONTENT="${CONTENT//\{\{REPOSITORY\}\}/${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}}"
|
|
||||||
CONTENT="${CONTENT//\{\{EXPERIMENTAL\}\}/${{ steps.info.outputs.experimental }}}"
|
|
||||||
CONTENT="${CONTENT//\{\{DEPRECATED\}\}/${{ steps.info.outputs.deprecated }}}"
|
|
||||||
CONTENT="${CONTENT//\{\{QT6\}\}/${{ steps.info.outputs.supportsQt6 }}}"
|
|
||||||
|
|
||||||
printf "%s\n" "$CONTENT" > "$OUT"
|
|
||||||
rm $TEMPLATE
|
|
||||||
|
|
||||||
- name: ZIP-Datei erstellen
|
- name: ZIP-Datei erstellen
|
||||||
id: zip
|
id: zip
|
||||||
run: |
|
run: |
|
||||||
cd repo
|
cd repo
|
||||||
|
|
||||||
ZIP_FOLDER="${{ steps.info.outputs.zip_folder }}"
|
ZIP_FOLDER="${{ steps.config.outputs.zip_folder }}"
|
||||||
ZIP_FILE="${ZIP_FOLDER}.zip"
|
ZIP_FILE="${ZIP_FOLDER}.zip"
|
||||||
|
|
||||||
echo "ZIP_FOLDER: $ZIP_FOLDER"
|
echo "ZIP_FOLDER: $ZIP_FOLDER"
|
||||||
@@ -233,21 +232,21 @@ jobs:
|
|||||||
DOWNLOAD_URL="https://${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}/releases/download/${{ github.ref_name }}/${ZIP_FILE}"
|
DOWNLOAD_URL="https://${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}/releases/download/${{ github.ref_name }}/${ZIP_FILE}"
|
||||||
|
|
||||||
jq -n \
|
jq -n \
|
||||||
--arg name "${{ steps.info.outputs.name }}" \
|
--arg name "${{ steps.metadata.outputs.name }}" \
|
||||||
--arg version "$VERSION" \
|
--arg version "$VERSION" \
|
||||||
--arg channel "$CHANNEL" \
|
--arg channel "$CHANNEL" \
|
||||||
--arg description "${{ steps.info.outputs.description }}" \
|
--arg description "${{ steps.metadata.outputs.description }}" \
|
||||||
--arg author "${{ steps.info.outputs.author }}" \
|
--arg author "${{ steps.metadata.outputs.author }}" \
|
||||||
--arg email "${{ steps.info.outputs.email }}" \
|
--arg email "${{ steps.metadata.outputs.email }}" \
|
||||||
--arg qgis_min "${{ steps.info.outputs.qgisMinimumVersion }}" \
|
--arg qgis_min "${{ steps.metadata.outputs.qgisMinimumVersion }}" \
|
||||||
--arg qgis_max "${{ steps.info.outputs.qgisMaximumVersion }}" \
|
--arg qgis_max "${{ steps.metadata.outputs.qgisMaximumVersion }}" \
|
||||||
--arg homepage "${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}" \
|
--arg homepage "${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}" \
|
||||||
--arg tracker "${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}" \
|
--arg tracker "${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}" \
|
||||||
--arg repository "${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}" \
|
--arg repository "${{ vars.RELEASE_URL }}/${GITHUB_REPOSITORY}" \
|
||||||
--arg experimental "${{ steps.info.outputs.experimental }}" \
|
--arg experimental "${{ steps.metadata.outputs.experimental }}" \
|
||||||
--arg deprecated "${{ steps.info.outputs.deprecated }}" \
|
--arg deprecated "${{ steps.metadata.outputs.deprecated }}" \
|
||||||
--arg qt6 "${{ steps.info.outputs.supportsQt6 }}" \
|
--arg qt6 "${{ steps.metadata.outputs.supportsQt6 }}" \
|
||||||
--arg id "${{ steps.info.outputs.zip_folder }}" \
|
--arg id "${{ steps.config.outputs.zip_folder }}" \
|
||||||
--arg url "$DOWNLOAD_URL" \
|
--arg url "$DOWNLOAD_URL" \
|
||||||
--arg changelog "${{ steps.changelog.outputs.current }}" \
|
--arg changelog "${{ steps.changelog.outputs.current }}" \
|
||||||
'{
|
'{
|
||||||
@@ -277,7 +276,7 @@ jobs:
|
|||||||
|
|
||||||
PAYLOAD_B64=$(base64 -w0 repo/payload.json)
|
PAYLOAD_B64=$(base64 -w0 repo/payload.json)
|
||||||
|
|
||||||
FULL_NAME="${{ steps.info.outputs.name }}"
|
FULL_NAME="${{ steps.metadata.outputs.name }}"
|
||||||
NAME=$(echo "$FULL_NAME" | awk -F'|' '{gsub(/^ +| +$/,"",$2); print $2}')
|
NAME=$(echo "$FULL_NAME" | awk -F'|' '{gsub(/^ +| +$/,"",$2); print $2}')
|
||||||
TAG="${{ steps.releaseinfo.outputs.version }}"
|
TAG="${{ steps.releaseinfo.outputs.version }}"
|
||||||
|
|
||||||
|
|||||||
3
.gitignore
vendored
3
.gitignore
vendored
@@ -174,5 +174,4 @@ cython_debug/
|
|||||||
# PyPI configuration file
|
# PyPI configuration file
|
||||||
.pypirc
|
.pypirc
|
||||||
|
|
||||||
metadata.txt
|
release.cmd
|
||||||
release.cmd
|
|
||||||
|
|||||||
14
metadata.txt
Normal file
14
metadata.txt
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
[general]
|
||||||
|
name=LNO Sachsen | Plugin Test Action
|
||||||
|
qgisMinimumVersion=3.40
|
||||||
|
qgisMaximumVersion=3.99
|
||||||
|
description=Test plugin for release pipeline
|
||||||
|
version=0
|
||||||
|
author=Daniel Helbig
|
||||||
|
email=daniel.helbig@kreis-meissen.de
|
||||||
|
homepage=https://entwicklung.flurneuordnung-sachsen.de/AG_QGIS/Plugin_Test_Action
|
||||||
|
tracker=https://entwicklung.flurneuordnung-sachsen.de/AG_QGIS/Plugin_Test_Action/issues
|
||||||
|
repository=https://entwicklung.flurneuordnung-sachsen.de/AG_QGIS/Plugin_Test_Action/src/branch/unstable/
|
||||||
|
experimental=true
|
||||||
|
deprecated=false
|
||||||
|
supportsQt6=true
|
||||||
10
plugin.cfg
10
plugin.cfg
@@ -1,11 +1 @@
|
|||||||
name=LNO Sachsen | Plugin Test Action
|
|
||||||
description=Test plugin for release pipeline
|
|
||||||
author=Daniel Helbig
|
|
||||||
email=daniel.helbig@kreis-meissen.de
|
|
||||||
qgisMinimumVersion=3.0
|
|
||||||
qgisMaximumVersion=3.99
|
|
||||||
deprecated=False
|
|
||||||
experimental=True
|
|
||||||
supportsQt6=Yes
|
|
||||||
|
|
||||||
zip_folder=plugin_folder
|
zip_folder=plugin_folder
|
||||||
|
|||||||
Reference in New Issue
Block a user