inventree-app/.github/workflows/android.yaml
HendrikRauh 51a1c1e6f3
Some checks failed
Android / build (push) Failing after 6m12s
Refactor Android CI workflow to use Nix actions and improve translation file collection
2026-01-27 11:15:09 +01:00

98 lines
3.6 KiB
YAML

# Build Android version of the app
name: Android
on:
push:
pull_request:
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v6
- name: Prepare Nix devshell
uses: ./.github/actions/nix-devshell
with:
prebuild: "true"
- name: Collect Translation Files
uses: ./.github/actions/nix-devshell
with:
commands: |
cd lib/l10n
python3 collect_translations.py
# - name: Build Debug APK
# uses: ./.github/actions/nix-devshell
# with:
# commands: |
# flutter build apk --debug --target-platform android-arm64
# - name: Upload APK artifact
# uses: actions/upload-artifact@v4
# with:
# name: app-debug-apk
# path: build/app/outputs/flutter-apk/*.apk
# # retention-days: 90
- name: Setup Release Keystore
uses: ./.github/actions/nix-devshell
with:
commands: |
# Write keystore into android/app and key.properties into android/
echo "$RELEASE_KEYSTORE_BASE64" | base64 -d > android/app/inventree-release-key.jks
chmod 600 android/app/inventree-release-key.jks
# Write key.properties inside android/ (user preferred)
printf "storePassword=%s\nkeyPassword=%s\nkeyAlias=%s\nstoreFile=%s\n" \
"$STORE_PASSWORD" "$KEY_PASSWORD" "$KEY_ALIAS" "android/app/inventree-release-key.jks" \
> android/key.properties
# Also write a repo-root shim with an absolute path for Gradle to consume reliably
printf "storePassword=%s\nkeyPassword=%s\nkeyAlias=%s\nstoreFile=%s\n" \
"$STORE_PASSWORD" "$KEY_PASSWORD" "$KEY_ALIAS" "${GITHUB_WORKSPACE}/android/app/inventree-release-key.jks" \
> key.properties
# Debug: show only non-secret info so logs aren't masked; confirm storeFile entries and JKS presence
echo "=== root storeFile ==="
grep '^storeFile=' key.properties || true
echo "=== android storeFile ==="
grep '^storeFile=' android/key.properties || true
echo "=== android/app listing ==="
ls -la android/app | sed -n '1,200p'
echo "=== key.properties files ==="
ls -la key.properties android/key.properties || true
env:
RELEASE_KEYSTORE_BASE64: ${{ secrets.INVENTREE_RELEASE_KEY_BASE64 }}
STORE_PASSWORD: ${{ secrets.INVENTREE_STORE_PASSWORD }}
KEY_PASSWORD: ${{ secrets.INVENTREE_KEY_PASSWORD }}
KEY_ALIAS: ${{ secrets.INVENTREE_KEY_ALIAS }}
- name: Debug Gradle signing
uses: ./.github/actions/nix-devshell
with:
commands: |
echo "=== root key.properties ==="
sed -n '1,200p' key.properties | sed -E 's/^(storePassword|keyPassword)=.*/\1=***/' || true
echo "=== android/key.properties ==="
sed -n '1,200p' android/key.properties | sed -E 's/^(storePassword|keyPassword)=.*/\1=***/' || true
echo "=== run gradle printSigning ==="
cd android
./gradlew :app:printSigning --no-daemon --console=plain
- name: Build Release APK
uses: ./.github/actions/nix-devshell
with:
commands: |
flutter build apk --release --no-tree-shake-icons
- name: Upload Release APK artifact
uses: actions/upload-artifact@v4
with:
name: app-release-apk
path: build/app/outputs/flutter-apk/*.apk
# retention-days: 90