Move buildscript to plugins DSL #40
Workflow file for this run
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 & test | |
on: | |
push: | |
branches: | |
- main | |
paths-ignore: | |
- '**.md' | |
pull_request: | |
paths-ignore: | |
- '**.md' | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
timeout-minutes: 45 | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Copy CI gradle.properties | |
run: mkdir -p ~/.gradle ; cp .github/ci-gradle.properties ~/.gradle/gradle.properties | |
- name: Setup java | |
uses: actions/setup-java@v3 | |
with: | |
distribution: temurin | |
java-version: 17 | |
- name: Decrypt secrets | |
run: release/signing-setup.sh ${{ secrets.ENCRYPT_KEY }} | |
- name: Setup Gradle | |
uses: gradle/gradle-build-action@v2 | |
with: | |
gradle-home-cache-cleanup: true | |
- name: Check spotless | |
run: ./gradlew spotlessCheck --init-script gradle/init.gradle.kts --stacktrace | |
- name: Check metalava | |
run: ./gradlew metalavaCheckCompatibilityRelease --stacktrace | |
- name: Check lint | |
run: ./gradlew lintDebug --stacktrace | |
- name: Build all build type and flavor permutations | |
run: ./gradlew assemble --stacktrace | |
- name: Clean secrets | |
if: always() | |
run: release/signing-cleanup.sh | |
test: | |
needs: build | |
runs-on: ubuntu-latest | |
timeout-minutes: 70 | |
strategy: | |
# Allow tests to continue on other devices if they fail on one device. | |
fail-fast: false | |
matrix: | |
api-level: [ 22, 26, 29 ] | |
env: | |
TERM: dumb | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Copy CI gradle.properties | |
run: mkdir -p ~/.gradle ; cp .github/ci-gradle.properties ~/.gradle/gradle.properties | |
- name: Setup java | |
uses: actions/setup-java@v3 | |
with: | |
distribution: temurin | |
java-version: 17 | |
- name: Decrypt secrets | |
run: release/signing-setup.sh ${{ secrets.ENCRYPT_KEY }} | |
- name: Setup Gradle | |
uses: gradle/gradle-build-action@v2 | |
with: | |
gradle-home-cache-cleanup: true | |
# Determine what emulator image to use. We run all API 28+ emulators using | |
# the google_apis image | |
- name: Determine emulator target | |
id: determine-target | |
env: | |
API_LEVEL: ${{ matrix.api-level }} | |
run: | | |
TARGET="default" | |
if [ "$API_LEVEL" -ge "28" ]; then | |
TARGET="google_apis" | |
fi | |
echo "TARGET=$TARGET" >> $GITHUB_OUTPUT | |
- name: Determine emulator arch | |
id: determine-arch | |
env: | |
API_LEVEL: ${{ matrix.api-level }} | |
run: | | |
ARCH="x86" | |
if [ "$API_LEVEL" -ge "31" ]; then | |
ARCH="x86_64" | |
fi | |
echo "ARCH=$ARCH" >> $GITHUB_OUTPUT | |
- name: Build tests | |
run: ./gradlew assembleDebugAndroidTest --scan | |
- name: Run tests | |
uses: reactivecircus/android-emulator-runner@v2 | |
with: | |
api-level: ${{ matrix.api-level }} | |
arch: ${{ steps.determine-arch.outputs.ARCH }} | |
target: ${{ steps.determine-target.outputs.TARGET }} | |
profile: Galaxy Nexus | |
script: | | |
adb logcat > logcat.txt & | |
./gradlew --scan connectedCheck | |
- name: Clean secrets | |
if: always() | |
run: release/signing-cleanup.sh | |
- name: Upload logs | |
if: always() | |
uses: actions/upload-artifact@v2 | |
with: | |
name: logs-${{ matrix.api-level }}-${{ steps.determine-target.outputs.TARGET }} | |
path: logcat.txt | |
- name: Upload test results | |
if: always() | |
uses: actions/upload-artifact@v2 | |
with: | |
name: test-results-${{ matrix.api-level }}-${{ steps.determine-target.outputs.TARGET }} | |
path: | | |
**/build/reports/* | |
**/build/outputs/*/connected/* | |
deploy: | |
if: github.event_name == 'push' | |
runs-on: ubuntu-latest | |
needs: [ build, test ] | |
timeout-minutes: 30 | |
env: | |
TERM: dumb | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Copy CI gradle.properties | |
run: mkdir -p ~/.gradle ; cp .github/ci-gradle.properties ~/.gradle/gradle.properties | |
- name: Setup java | |
uses: actions/setup-java@v3 | |
with: | |
distribution: temurin | |
java-version: 17 | |
- name: Decrypt secrets | |
run: release/signing-setup.sh ${{ secrets.ENCRYPT_KEY }} | |
- name: Setup Gradle | |
uses: gradle/gradle-build-action@v2 | |
with: | |
gradle-home-cache-cleanup: true | |
- name: Deploy to Sonatype | |
run: ./gradlew publish --no-parallel --stacktrace --no-configuration-cache | |
env: | |
ORG_GRADLE_PROJECT_mavenCentralUsername: ${{ secrets.SONATYPE_NEXUS_USERNAME }} | |
ORG_GRADLE_PROJECT_mavenCentralPassword: ${{ secrets.SONATYPE_NEXUS_PASSWORD }} | |
- name: Clean secrets | |
if: always() | |
run: release/signing-cleanup.sh |