fix(ci): detect existing container SDK before installing, set ANDROID_HOME via GITHUB_ENV
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -12,8 +12,6 @@ on:
|
|||||||
- '**.md'
|
- '**.md'
|
||||||
|
|
||||||
env:
|
env:
|
||||||
ANDROID_HOME: /opt/android-sdk
|
|
||||||
ANDROID_NDK_HOME: /opt/android-sdk/ndk/25.2.9519653
|
|
||||||
NDK_VERSION: "25.2.9519653"
|
NDK_VERSION: "25.2.9519653"
|
||||||
BUILD_TOOLS_VERSION: "34.0.0"
|
BUILD_TOOLS_VERSION: "34.0.0"
|
||||||
|
|
||||||
@@ -29,36 +27,59 @@ jobs:
|
|||||||
id: meta
|
id: meta
|
||||||
run: echo "sha=${GITHUB_SHA::8}" >> "$GITHUB_OUTPUT"
|
run: echo "sha=${GITHUB_SHA::8}" >> "$GITHUB_OUTPUT"
|
||||||
|
|
||||||
# ── Android SDK + NDK ──────────────────────────────────────────────
|
# ── Probe the container's existing Android SDK ─────────────────────
|
||||||
# Cache the entire SDK root so subsequent runs skip the ~2 GB download.
|
- name: Detect Android SDK
|
||||||
- name: Cache Android SDK
|
id: sdk
|
||||||
uses: actions/cache@v4
|
run: |
|
||||||
id: sdk-cache
|
# Gitea/GitHub ubuntu-latest runners may already have an Android
|
||||||
with:
|
# SDK at /usr/local/lib/android/sdk. If it has the platform and
|
||||||
path: ${{ env.ANDROID_HOME }}
|
# NDK we need we use it directly; otherwise we install our own.
|
||||||
key: v2-android-sdk-ndk${{ env.NDK_VERSION }}-bt${{ env.BUILD_TOOLS_VERSION }}
|
DEFAULT="${ANDROID_HOME:-/usr/local/lib/android/sdk}"
|
||||||
|
echo "container default ANDROID_HOME: $DEFAULT"
|
||||||
|
echo "sdk_path=$DEFAULT" >> "$GITHUB_OUTPUT"
|
||||||
|
ls "$DEFAULT/platforms/" 2>/dev/null || echo "(no platforms/ in default)"
|
||||||
|
ls "$DEFAULT/ndk/" 2>/dev/null || echo "(no ndk/ in default)"
|
||||||
|
|
||||||
|
# ── System dependencies (always needed for build tools + signing) ──
|
||||||
- name: Install system dependencies
|
- name: Install system dependencies
|
||||||
run: |
|
run: |
|
||||||
sudo apt-get update -y
|
sudo apt-get update -y
|
||||||
sudo apt-get install -y openjdk-17-jdk-headless unzip
|
sudo apt-get install -y openjdk-17-jdk-headless unzip jq
|
||||||
|
|
||||||
- name: Install Android SDK + NDK
|
# ── Install missing SDK components if needed ───────────────────────
|
||||||
if: steps.sdk-cache.outputs.cache-hit != 'true'
|
- name: Install SDK platform and NDK
|
||||||
|
env:
|
||||||
|
ANDROID_SDK: ${{ steps.sdk.outputs.sdk_path }}
|
||||||
run: |
|
run: |
|
||||||
mkdir -p "$ANDROID_HOME/cmdline-tools"
|
# Ensure sdkmanager is on PATH
|
||||||
|
SDKMAN="$ANDROID_SDK/cmdline-tools/latest/bin/sdkmanager"
|
||||||
|
if [ ! -f "$SDKMAN" ]; then
|
||||||
|
echo "sdkmanager not found — installing cmdline-tools"
|
||||||
|
mkdir -p "$ANDROID_SDK/cmdline-tools"
|
||||||
curl -sL \
|
curl -sL \
|
||||||
"https://dl.google.com/android/repository/commandlinetools-linux-11076708_latest.zip" \
|
"https://dl.google.com/android/repository/commandlinetools-linux-11076708_latest.zip" \
|
||||||
-o /tmp/cmdtools.zip
|
-o /tmp/cmdtools.zip
|
||||||
unzip -q /tmp/cmdtools.zip -d /tmp/cmdtools
|
unzip -q /tmp/cmdtools.zip -d /tmp/cmdtools
|
||||||
mv /tmp/cmdtools/cmdline-tools "$ANDROID_HOME/cmdline-tools/latest"
|
sudo mv /tmp/cmdtools/cmdline-tools "$ANDROID_SDK/cmdline-tools/latest"
|
||||||
# Accept all SDK licences non-interactively.
|
fi
|
||||||
yes | "$ANDROID_HOME/cmdline-tools/latest/bin/sdkmanager" --sdk_root="$ANDROID_HOME" --licenses \
|
|
||||||
|
yes | sudo "$SDKMAN" --sdk_root="$ANDROID_SDK" --licenses \
|
||||||
> /dev/null 2>&1 || true
|
> /dev/null 2>&1 || true
|
||||||
"$ANDROID_HOME/cmdline-tools/latest/bin/sdkmanager" --sdk_root="$ANDROID_HOME" \
|
|
||||||
"build-tools;$BUILD_TOOLS_VERSION" \
|
NEEDS=""
|
||||||
"platforms;android-34" \
|
[ ! -f "$ANDROID_SDK/platforms/android-34/android.jar" ] && NEEDS="$NEEDS platforms;android-34"
|
||||||
"ndk;$NDK_VERSION"
|
[ ! -d "$ANDROID_SDK/ndk/$NDK_VERSION" ] && NEEDS="$NEEDS ndk;$NDK_VERSION"
|
||||||
|
[ ! -d "$ANDROID_SDK/build-tools/$BUILD_TOOLS_VERSION" ] && NEEDS="$NEEDS build-tools;$BUILD_TOOLS_VERSION"
|
||||||
|
|
||||||
|
if [ -n "$NEEDS" ]; then
|
||||||
|
echo "Installing:$NEEDS"
|
||||||
|
sudo "$SDKMAN" --sdk_root="$ANDROID_SDK" $NEEDS
|
||||||
|
else
|
||||||
|
echo "All SDK components already present"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "ANDROID_HOME=$ANDROID_SDK" >> "$GITHUB_ENV"
|
||||||
|
echo "ANDROID_NDK_HOME=$ANDROID_SDK/ndk/$NDK_VERSION" >> "$GITHUB_ENV"
|
||||||
|
|
||||||
# ── Rust toolchain ─────────────────────────────────────────────────
|
# ── Rust toolchain ─────────────────────────────────────────────────
|
||||||
- name: Install Rust stable
|
- name: Install Rust stable
|
||||||
@@ -99,32 +120,13 @@ jobs:
|
|||||||
key: android-target-${{ hashFiles('**/Cargo.lock') }}-${{ github.sha }}
|
key: android-target-${{ hashFiles('**/Cargo.lock') }}-${{ github.sha }}
|
||||||
restore-keys: android-target-${{ hashFiles('**/Cargo.lock') }}-
|
restore-keys: android-target-${{ hashFiles('**/Cargo.lock') }}-
|
||||||
|
|
||||||
# ── Debug: verify SDK layout ───────────────────────────────────────
|
|
||||||
- name: Verify SDK layout
|
|
||||||
run: |
|
|
||||||
echo "ANDROID_HOME=$ANDROID_HOME"
|
|
||||||
echo "ANDROID_SDK_ROOT=$ANDROID_SDK_ROOT"
|
|
||||||
echo "ANDROID_NDK_HOME=$ANDROID_NDK_HOME"
|
|
||||||
ls "$ANDROID_HOME/" 2>/dev/null || echo "ANDROID_HOME dir missing"
|
|
||||||
ls "$ANDROID_HOME/platforms/" 2>/dev/null || echo "platforms/ missing"
|
|
||||||
ls "$ANDROID_HOME/ndk/" 2>/dev/null || echo "ndk/ missing"
|
|
||||||
|
|
||||||
# ── Build ──────────────────────────────────────────────────────────
|
# ── Build ──────────────────────────────────────────────────────────
|
||||||
- name: Install cargo-apk
|
- name: Install cargo-apk
|
||||||
if: steps.apk-tool-cache.outputs.cache-hit != 'true'
|
if: steps.apk-tool-cache.outputs.cache-hit != 'true'
|
||||||
run: cargo install cargo-apk --locked
|
run: cargo install cargo-apk --locked
|
||||||
|
|
||||||
- name: Build debug APK
|
- name: Build debug APK
|
||||||
run: |
|
run: cargo apk build --package solitaire_app --lib
|
||||||
echo "=== env at build time ==="
|
|
||||||
echo "ANDROID_HOME=$ANDROID_HOME"
|
|
||||||
echo "ANDROID_SDK_ROOT=$ANDROID_SDK_ROOT"
|
|
||||||
printenv | grep -i android || true
|
|
||||||
ls "$ANDROID_HOME/platforms/" || echo "platforms dir missing"
|
|
||||||
ls "$ANDROID_HOME/platforms/android-34/" | head -10 || echo "android-34 dir missing"
|
|
||||||
ls "$ANDROID_HOME/platforms/android-34/android.jar" && echo "android.jar OK" || echo "android.jar MISSING"
|
|
||||||
echo "========================="
|
|
||||||
cargo apk build --package solitaire_app --lib
|
|
||||||
|
|
||||||
# ── Artifact ───────────────────────────────────────────────────────
|
# ── Artifact ───────────────────────────────────────────────────────
|
||||||
- name: Upload APK
|
- name: Upload APK
|
||||||
|
|||||||
Reference in New Issue
Block a user