fix: update check ignores non-semver tags + GitHub Actions builds versioned releases

This commit is contained in:
dadaloop82
2026-05-06 14:41:36 +00:00
parent cbb3f6b288
commit 8535f4d4b9
3 changed files with 41 additions and 26 deletions
+32 -23
View File
@@ -2,9 +2,7 @@ name: Build & Release Kiosk APK
on: on:
push: push:
branches: branches: [main]
- main
- develop
paths: paths:
- 'evershelf-kiosk/**' - 'evershelf-kiosk/**'
workflow_dispatch: workflow_dispatch:
@@ -30,7 +28,14 @@ jobs:
- name: Set up Gradle - name: Set up Gradle
uses: gradle/actions/setup-gradle@v3 uses: gradle/actions/setup-gradle@v3
with: with:
gradle-version: '8.4' gradle-version: '8.6'
- name: Get version name
id: version
run: |
VERSION=$(grep 'versionName' evershelf-kiosk/app/build.gradle.kts | grep -oP '"\K[^"]+')
echo "name=$VERSION" >> "$GITHUB_OUTPUT"
echo "Kiosk version: $VERSION"
- name: Build debug APK - name: Build debug APK
run: gradle assembleDebug --no-daemon run: gradle assembleDebug --no-daemon
@@ -41,29 +46,33 @@ jobs:
mkdir -p artifacts mkdir -p artifacts
cp evershelf-kiosk/app/build/outputs/apk/debug/app-debug.apk artifacts/evershelf-kiosk.apk cp evershelf-kiosk/app/build/outputs/apk/debug/app-debug.apk artifacts/evershelf-kiosk.apk
- name: Get version name # Publish with a semver-compatible tag so the in-app update check can
id: version # compare versions numerically (tag "kiosk-1.7.0" → norm → "1.7.0").
run: | # Also update the "kiosk-latest" tag so the hardcoded download URL still works.
VERSION=$(grep 'versionName' evershelf-kiosk/app/build.gradle.kts | grep -oP '"\K[^"]+') - name: Create versioned release
echo "name=$VERSION" >> "$GITHUB_OUTPUT"
- name: Delete existing kiosk release
env: env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: | run: |
gh release delete kiosk-latest --yes || true TAG="kiosk-${{ steps.version.outputs.name }}"
sleep 5 # Delete old release with same tag if it exists (e.g. re-run on same version)
gh release delete "$TAG" --yes 2>/dev/null || true
git push --delete origin "$TAG" 2>/dev/null || true
gh release create "$TAG" \
--title "EverShelf Kiosk v${{ steps.version.outputs.name }}" \
--notes "Kiosk mode app. Scarica e installa su Android 7.0+. L'aggiornamento OTA è automatico." \
--latest \
artifacts/evershelf-kiosk.apk
- name: Create GitHub Release and upload APK - name: Update kiosk-latest tag (for hardcoded download URL)
env: env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: | run: |
for i in 1 2 3; do gh release delete kiosk-latest --yes 2>/dev/null || true
gh release create kiosk-latest \ git push --delete origin kiosk-latest 2>/dev/null || true
--title "EverShelf Kiosk v${{ steps.version.outputs.name }}" \ sleep 3
--notes "Kiosk mode app with embedded BLE scale gateway. Install on your Android device (7.0+)." \ gh release create kiosk-latest \
--prerelease \ --title "EverShelf Kiosk Latest" \
artifacts/evershelf-kiosk.apk && break --notes "Alias automatico → kiosk-${{ steps.version.outputs.name }}" \
echo "Attempt $i failed, retrying in 10s..." --prerelease \
sleep 10 artifacts/evershelf-kiosk.apk
done
Binary file not shown.
@@ -555,8 +555,10 @@ class KioskActivity : AppCompatActivity() {
packageManager.getPackageInfo(packageName, 0).versionName ?: "" packageManager.getPackageInfo(packageName, 0).versionName ?: ""
} catch (_: Exception) { "" } } catch (_: Exception) { "" }
val norm = { v: String -> v.trimStart('v') } // Strip any non-numeric prefix so "kiosk-1.7.0", "v1.7.0", "kiosk-v1.7.1"
val isSemver = latestTag.trimStart('v').matches(Regex("\\d+\\.\\d+.*")) // all normalise to "1.7.0" / "1.7.1" for comparison.
val norm = { v: String -> v.replace(Regex("^[^0-9]*"), "") }
val isSemver = norm(latestTag).matches(Regex("\\d+\\.\\d+.*"))
// Compare semver: returns true if `remote` is strictly greater than `local` // Compare semver: returns true if `remote` is strictly greater than `local`
fun semverNewer(remote: String, local: String): Boolean { fun semverNewer(remote: String, local: String): Boolean {
@@ -583,8 +585,12 @@ class KioskActivity : AppCompatActivity() {
} }
if (kioskApkUrl.isEmpty()) kioskApkUrl = KIOSK_DOWNLOAD_URL if (kioskApkUrl.isEmpty()) kioskApkUrl = KIOSK_DOWNLOAD_URL
// Only flag an update when the remote tag is parseable as semver AND
// the remote version is strictly greater than the installed version.
// Non-semver tags (e.g. "kiosk-latest", "rolling") cannot be compared
// numerically → treat as "no update" to avoid false positives.
val kioskNeedsUpdate = currentKiosk.isNotEmpty() && val kioskNeedsUpdate = currentKiosk.isNotEmpty() &&
(!isSemver || semverNewer(norm(latestTag), norm(currentKiosk))) isSemver && semverNewer(norm(latestTag), norm(currentKiosk))
val result = JSONObject() val result = JSONObject()
.put("has_update", kioskNeedsUpdate) .put("has_update", kioskNeedsUpdate)