Merge pull request #1131 from lihenggui/fix/move_app_state_test_to_un… #2664
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Build | |
on: | |
push: | |
branches: | |
- main | |
paths-ignore: | |
- '.idea/**' | |
- '.gitattributes' | |
- '.github/**.json' | |
- '.gitignore' | |
- '.gitmodules' | |
- '**.md' | |
- 'LICENSE' | |
- 'NOTICE' | |
pull_request: | |
paths-ignore: | |
- '.idea/**' | |
- '.gitattributes' | |
- '.github/**.json' | |
- '.gitignore' | |
- '.gitmodules' | |
- '**.md' | |
- 'LICENSE' | |
- 'NOTICE' | |
concurrency: | |
group: build-${{ github.ref }} | |
cancel-in-progress: true | |
jobs: | |
test_and_apk: | |
name: "Local tests and APKs" | |
runs-on: ubuntu-latest | |
permissions: | |
contents: write | |
security-events: write | |
pull-requests: write | |
timeout-minutes: 60 | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
submodules: 'true' | |
fetch-depth: 0 | |
- name: Enable KVM group perms | |
run: | | |
echo 'KERNEL=="kvm", GROUP="kvm", MODE="0666", OPTIONS+="static_node=kvm"' | sudo tee /etc/udev/rules.d/99-kvm4all.rules | |
sudo udevadm control --reload-rules | |
sudo udevadm trigger --name-match=kvm | |
ls /dev/kvm | |
- name: Delete unnecessary tools 🔧 | |
uses: jlumbroso/free-disk-space@v1.3.1 | |
with: | |
android: false # Don't remove Android tools | |
tool-cache: true # Remove image tool cache - rm -rf "$AGENT_TOOLSDIRECTORY" | |
dotnet: true # rm -rf /usr/share/dotnet | |
haskell: true # rm -rf /opt/ghc... | |
swap-storage: true # rm -f /mnt/swapfile (4GiB) | |
docker-images: false # Takes 16s, enable if needed in the future | |
large-packages: false # includes google-cloud-sdk and it's slow | |
- name: Write sign info | |
if: github.event_name != 'pull_request' && github.ref == 'refs/heads/main' && github.repository == 'lihenggui/Blocker' | |
run: | | |
if [ ! -z "${{ secrets.KEYSTORE }}" ]; then | |
echo releaseStorePassword='${{ secrets.SIGNING_STORE_PASSWORD }}' >> gradle.properties | |
echo releaseKeyAlias='${{ secrets.SIGNING_KEY_ALIAS }}' >> gradle.properties | |
echo releaseKeyPassword='${{ secrets.SIGNING_KEY_PASSWORD }}' >> gradle.properties | |
echo releaseStoreFile='${{ github.workspace }}/key.jks' >> gradle.properties | |
echo ${{ secrets.KEYSTORE }} | base64 --decode > ${{ github.workspace }}/key.jks | |
fi | |
- name: Copy CI gradle.properties | |
run: mkdir -p ~/.gradle ; cp .github/ci-gradle.properties ~/.gradle/gradle.properties | |
- name: Set up JDK 17 | |
uses: actions/setup-java@v4 | |
with: | |
distribution: 'zulu' | |
java-version: 17 | |
- name: Setup Gradle | |
uses: gradle/actions/setup-gradle@v4 | |
with: | |
cache-encryption-key: ${{ secrets.GRADLE_ENCRYPTION_KEY }} | |
- name: Accept Android licenses | |
run: yes | "$ANDROID_HOME"/cmdline-tools/latest/bin/sdkmanager --licenses || true | |
- name: Check build-logic | |
run: ./gradlew :build-logic:convention:check | |
- name: Check spotless | |
run: ./gradlew spotlessCheck --init-script gradle/init.gradle.kts --no-configuration-cache | |
- name: Check Dependency Guard | |
id: dependencyguard_verify | |
continue-on-error: true | |
run: ./gradlew dependencyGuard | |
- name: Prevent updating Dependency Guard baselines if this is a fork | |
id: checkfork_dependencyguard | |
continue-on-error: false | |
if: steps.dependencyguard_verify.outcome == 'failure' && github.event.pull_request.head.repo.full_name != github.repository | |
run: | | |
echo "::error::Dependency Guard failed, please update baselines with: ./gradlew dependencyGuardBaseline" && exit 1 | |
# Runs if previous job failed | |
- name: Generate new Dependency Guard baselines if verification failed and it's a PR | |
id: dependencyguard_baseline | |
if: steps.dependencyguard_verify.outcome == 'failure' && github.event_name == 'pull_request' | |
run: | | |
./gradlew dependencyGuardBaseline | |
- name: Push new Dependency Guard baselines if available | |
uses: stefanzweifel/git-auto-commit-action@v5 | |
if: steps.dependencyguard_baseline.outcome == 'success' | |
with: | |
file_pattern: '**/dependencies/*.txt' | |
disable_globbing: true | |
commit_message: "🤖 Updates baselines for Dependency Guard" | |
- name: Run all local screenshot tests (Roborazzi) | |
id: screenshotsverify | |
continue-on-error: true | |
run: ./gradlew verifyRoborazziFossDebug | |
- name: Prevent pushing new screenshots if this is a fork | |
id: checkfork_screenshots | |
continue-on-error: false | |
if: steps.screenshotsverify.outcome == 'failure' && github.event.pull_request.head.repo.full_name != github.repository | |
run: | | |
echo "::error::Screenshot tests failed, please create a PR in your fork first." | |
echo "Your fork's CI will take screenshots for your fork." | |
exit 1 | |
# Runs if previous job failed | |
- name: Generate new screenshots if verification failed and it's a PR | |
id: screenshotsrecord | |
if: steps.screenshotsverify.outcome == 'failure' && github.event_name == 'pull_request' | |
run: | | |
./gradlew recordRoborazziFossDebug | |
- name: Push new screenshots if available | |
uses: stefanzweifel/git-auto-commit-action@v5 | |
if: steps.screenshotsrecord.outcome == 'success' | |
with: | |
file_pattern: '*/*.png' | |
disable_globbing: true | |
commit_message: "🤖 Updates screenshots" | |
# Run local tests after screenshot tests to avoid wrong UP-TO-DATE. TODO: Ignore screenshots. | |
- name: Run local tests | |
if: always() | |
run: ./gradlew testFossDebug :lint:test | |
- name: Build all build type and flavor permutations | |
run: ./gradlew :app:assemble | |
- name: Upload Foss apk | |
if: success() && github.event_name != 'pull_request' && github.repository == 'lihenggui/Blocker' | |
uses: actions/upload-artifact@v4 | |
with: | |
name: Foss-APK | |
path: ${{ github.workspace }}/app-compose/build/outputs/apk/foss/release | |
- name: Upload Market apk | |
if: success() && github.event_name != 'pull_request' && github.repository == 'lihenggui/Blocker' | |
uses: actions/upload-artifact@v4 | |
with: | |
name: Market-APK | |
path: ${{ github.workspace }}/app-compose/build/outputs/apk/market/release | |
- name: Upload build outputs (APKs) | |
uses: actions/upload-artifact@v4 | |
with: | |
name: APKs | |
path: '**/build/outputs/apk/**/*.apk' | |
- name: Upload mappings | |
if: success() && github.event_name != 'pull_request' && github.ref == 'refs/heads/main' | |
uses: actions/upload-artifact@v4 | |
with: | |
name: mappings | |
path: "app-compose/build/outputs/mapping/marketRelease" | |
- name: Set apk path | |
id: apk-path | |
run: | | |
foss_path=$(find **/build/outputs/apk/foss -name '*.apk' -type f | head -1) | |
echo "foss_path=$foss_path" >> $GITHUB_OUTPUT | |
market_path=$(find **/build/outputs/apk/market -name '*.apk' -type f | head -1) | |
echo "market_path=$market_path" >> $GITHUB_OUTPUT | |
- name: Get apk info | |
if: success() && github.event_name != 'pull_request' && github.repository == 'lihenggui/Blocker' | |
id: apk-info | |
uses: zhaobozhen/apk-info-action@v1.1.3 | |
with: | |
apk-path: ${{ steps.apk-path.outputs.foss_path }} | |
- name: Upload JVM local results (XML) | |
if: ${{ !cancelled() }} | |
uses: actions/upload-artifact@v4 | |
with: | |
name: local-test-results | |
path: '**/build/test-results/test*UnitTest/**.xml' | |
- name: Check lint | |
run: ./gradlew :app-compose:lintMarketRelease :lint:lint | |
- name: Upload lint reports (HTML) | |
if: ${{ !cancelled() }} | |
uses: actions/upload-artifact@v4 | |
with: | |
name: lint-reports | |
path: '**/build/reports/lint-results-*.html' | |
- name: Upload lint reports (SARIF) | |
if: ${{ !cancelled() }} | |
uses: github/codeql-action/upload-sarif@v3 | |
with: | |
sarif_file: './' | |
- name: Check badging | |
id: check_badging | |
continue-on-error: true | |
run: ./gradlew :app-compose:checkMarketReleaseBadging | |
- name: Prevent updating badging if this is a fork | |
id: checkfork_badging | |
continue-on-error: false | |
if: steps.check_badging.outcome == 'failure' && github.event.pull_request.head.repo.full_name != github.repository | |
run: | | |
echo "::error::Badging check failed, please create a PR in your fork first." && exit 1 | |
- name: Update badging if verification failed and it's a PR | |
id: update_badging | |
if: steps.check_badging.outcome == 'failure' && github.event_name == 'pull_request' | |
run: | | |
./gradlew updateMarketReleaseBadging | |
- name: Push new badging if available | |
uses: stefanzweifel/git-auto-commit-action@v5 | |
if: steps.update_badging.outcome == 'success' | |
with: | |
file_pattern: '*/*-badging.txt' | |
disable_globbing: true | |
commit_message: "🤖 Updates badging" | |
androidTest: | |
runs-on: ubuntu-latest | |
timeout-minutes: 90 | |
strategy: | |
matrix: | |
api-level: [ 26, 35 ] | |
steps: | |
- name: Delete unnecessary tools 🔧 | |
uses: jlumbroso/free-disk-space@v1.3.1 | |
with: | |
android: false # Don't remove Android tools | |
tool-cache: true # Remove image tool cache - rm -rf "$AGENT_TOOLSDIRECTORY" | |
dotnet: true # rm -rf /usr/share/dotnet | |
haskell: true # rm -rf /opt/ghc... | |
swap-storage: true # rm -f /mnt/swapfile (4GiB) | |
docker-images: false # Takes 16s, enable if needed in the future | |
large-packages: false # includes google-cloud-sdk and it's slow | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
submodules: 'true' | |
fetch-depth: 0 | |
- name: Enable KVM group perms | |
run: | | |
echo 'KERNEL=="kvm", GROUP="kvm", MODE="0666", OPTIONS+="static_node=kvm"' | sudo tee /etc/udev/rules.d/99-kvm4all.rules | |
sudo udevadm control --reload-rules | |
sudo udevadm trigger --name-match=kvm | |
ls /dev/kvm | |
- name: Copy CI gradle.properties | |
run: mkdir -p ~/.gradle ; cp .github/ci-gradle.properties ~/.gradle/gradle.properties | |
- name: Set up JDK 17 | |
uses: actions/setup-java@v4 | |
with: | |
distribution: 'zulu' | |
java-version: 17 | |
- name: Setup Gradle | |
uses: gradle/actions/setup-gradle@v4 | |
with: | |
cache-encryption-key: ${{ secrets.GRADLE_ENCRYPTION_KEY }} | |
# Cache AVD. See https://github.com/ReactiveCircus/android-emulator-runner | |
- name: AVD cache | |
uses: actions/cache@v4 | |
id: avdcache | |
with: | |
path: | | |
~/.android/avd/* | |
~/.android/adb* | |
key: avd-${{ matrix.api-level }} | |
- name: create AVD and generate snapshot for caching | |
if: steps.avdcache.outputs.cache-hit != 'true' | |
uses: reactivecircus/android-emulator-runner@v2 | |
with: | |
api-level: ${{ matrix.api-level }} | |
force-avd-creation: false | |
arch: x86_64 | |
target: default # No ATD in API 26 | |
emulator-options: -no-window -gpu swiftshader_indirect -noaudio -no-boot-anim -camera-back none | |
disable-animations: false | |
disk-size: 6000M | |
heap-size: 600M | |
script: echo "Generated AVD snapshot for caching." | |
- name: Build projects and run instrumentation tests | |
uses: reactivecircus/android-emulator-runner@v2 | |
with: | |
api-level: ${{ matrix.api-level }} | |
arch: x86_64 | |
disable-animations: true | |
disk-size: 6000M | |
heap-size: 600M | |
script: ./gradlew connectedMarketDebugAndroidTest --daemon | |
- name: Run local tests (including Roborazzi) for the combined coverage report (only API 30) | |
if: matrix.api-level == 30 | |
# There is no need to verify Roborazzi tests to generate coverage. | |
run: ./gradlew testFossDebugUnitTest -Proborazzi.test.verify=false # Add Prod if we ever add JVM tests for prod | |
# Add `createProdDebugUnitTestCoverageReport` if we ever add JVM tests for prod | |
- name: Generate coverage reports for Debug variants (only API 30) | |
if: matrix.api-level == 30 | |
run: ./gradlew createFossDebugCombinedCoverageReport | |
- name: Upload test reports | |
if: ${{ !cancelled() }} | |
uses: actions/upload-artifact@v4 | |
with: | |
name: test-reports-${{ matrix.api-level }} | |
path: '**/build/reports/androidTests' | |
- name: Display local test coverage (only API 30) | |
if: matrix.api-level == 30 | |
id: jacoco | |
uses: madrapps/jacoco-report@v1.7.1 | |
with: | |
title: Combined test coverage report | |
min-coverage-overall: 40 | |
min-coverage-changed-files: 60 | |
paths: | | |
${{ github.workspace }}/**/build/reports/jacoco/**/*Report.xml | |
token: ${{ secrets.GITHUB_TOKEN }} | |
- name: Upload local coverage reports (XML + HTML) (only API 30) | |
if: matrix.api-level == 30 | |
uses: actions/upload-artifact@v4 | |
with: | |
name: coverage-reports | |
if-no-files-found: error | |
compression-level: 1 | |
overwrite: false | |
path: '**/build/reports/jacoco/' |