Upgrade to Kotlin 2.x and Compose 1.6.10 #173
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
# Thanks to https://github.com/coil-kt/coil/blob/master/.github/workflows/ci.yml | |
name: CI | |
on: | |
push: | |
tags: | |
- '*' | |
pull_request: | |
jobs: | |
build: | |
name: Build | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 100 | |
- uses: actions/setup-java@v3 | |
with: | |
distribution: 'zulu' | |
java-version: '17' | |
java-package: jdk | |
- name: Validate gradle wrapper | |
uses: gradle/wrapper-validation-action@v1 | |
- name: Copy CI gradle.properties | |
run: mkdir -p ~/.gradle ; cp .github/ci-gradle.properties ~/.gradle/gradle.properties | |
- name: Checkout Gradle Build Cache | |
if: ${{ steps.self_hosted.outputs.FLAG != 'self-hosted' }} | |
uses: actions/cache@v3 | |
with: | |
path: | | |
~/.gradle/caches | |
~/.gradle/wrapper | |
!~/.gradle/wrapper/dists/**/gradle*.zip | |
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*') }} | |
restore-keys: | | |
gradle-${{ runner.os }}- | |
- name: Build Debug | |
run: ./gradlew clean app:assembleDebug | |
- name: Run Lint | |
if: github.event_name == 'pull_request' | |
run: ./gradlew lintDebug | |
- name: Detekt | |
if: github.event_name == 'pull_request' | |
run: ./gradlew detekt | |
- name: Setup Ruby | |
if: github.event_name == 'pull_request' | |
uses: ruby/setup-ruby@v1 | |
with: | |
ruby-version: '3.0' | |
bundler-cache: true | |
- name: Run Danger | |
if: github.event_name == 'pull_request' | |
run: | | |
gem install danger | |
bundle exec danger --dangerfile=Dangerfile --danger_id=danger-pr | |
env: | |
DANGER_GITHUB_API_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
- name: Prepare Keystore and Local. | |
if: startsWith(github.ref, 'refs/tags/') | |
run: | | |
echo "${{ secrets.KEYSTORE }}" > opensource.jks.asc | |
gpg -d --passphrase "${{ secrets.KEYSTORE_PASSPHRASE }}" --batch "opensource.jks.asc" > "app/opensource.jks" | |
echo "${{ secrets.SIGNING_GRADLE }}" > signing.gradle.asc | |
gpg -d --passphrase "${{ secrets.KEYSTORE_PASSPHRASE }}" --batch "signing.gradle.asc" > "app/signing.gradle" | |
echo "openSource.signing.file=signing.gradle" >> local.properties | |
- name: Build Release App | |
if: startsWith(github.ref, 'refs/tags/') | |
run: ./gradlew app:assembleRelease app:bundleRelease | |
- name: Prepare Sonatype Gradle properties | |
if: startsWith(github.ref, 'refs/tags/') | |
run: | | |
echo "${{ secrets.SONATYPE_GPG_FILE }}" > opensource.gpg.asc | |
gpg -d --passphrase "${{ secrets.KEYSTORE_PASSPHRASE }}" --batch "opensource.gpg.asc" > "$HOME/.gradle/opensource.gpg" | |
echo "sonatype.gpg.key=${{ secrets.SONATYPE_GPG_KEY }}" >> ~/.gradle/gradle.properties | |
echo "sonatype.gpg.password=${{ secrets.SONATYPE_GPG_PASS }}" >> ~/.gradle/gradle.properties | |
echo "sonatype.gpg.secretKeyRingFile=$HOME/.gradle/opensource.gpg" >> ~/.gradle/gradle.properties | |
- name: Relase Sonatype | |
if: startsWith(github.ref, 'refs/tags/') | |
run: | | |
./gradlew build -x test -x lint | |
./gradlew publishReleasePublicationToSonatypeRepository -x test -x lint -Plibrarytypefaceonly --no-configure-on-demand --no-parallel | |
./gradlew publishReleasePublicationToSonatypeRepository -x test -x lint -Plibrarycoreonly --no-configure-on-demand --no-parallel | |
./gradlew publishReleasePublicationToSonatypeRepository -x test -x lint -Plibraryviewsonly --no-configure-on-demand --no-parallel | |
./gradlew publishReleasePublicationToSonatypeRepository -x test -x lint -Plibrarycomposeonly --no-configure-on-demand --no-parallel | |
env: | |
NEXUS_USERNAME: ${{ secrets.NEXUS_USERNAME }} | |
NEXUS_PASSWORD: ${{ secrets.NEXUS_PASSWORD }} | |
- name: Collect artifacts | |
run: | | |
COLLECT_PWD=${PWD} | |
mkdir -p "artifacts" | |
find . -name "*.apk" -type f -exec cp {} "artifacts" \; | |
find . -name "*.aab" -type f -exec cp {} "artifacts" \; | |
- name: Archive Artifacts | |
uses: actions/upload-artifact@v3 | |
with: | |
name: "App-Artifacts" | |
path: artifacts/* | |
- name: Build Changelog | |
id: github_release | |
uses: mikepenz/release-changelog-builder-action@v1 | |
if: startsWith(github.ref, 'refs/tags/') | |
with: | |
configuration: ".github/config/configuration.json" | |
ignorePreReleases: ${{ !contains(github.ref, '-') }} | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
- name: Release | |
uses: softprops/action-gh-release@91409e712cf565ce9eff10c87a8d1b11b81757ae | |
if: startsWith(github.ref, 'refs/tags/') | |
with: | |
body: ${{steps.github_release.outputs.changelog}} | |
prerelease: ${{ contains(github.event.inputs.version, '-rc') || contains(github.event.inputs.version, '-b') || contains(github.event.inputs.version, '-a') }} | |
files: artifacts/* | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |