fix: update check ignores non-semver tags + GitHub Actions builds versioned releases
This commit is contained in:
@@ -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)
|
||||||
|
|||||||
Reference in New Issue
Block a user