Contribution improvements #486
Workflow file for this run
This file contains hidden or 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: | |
publish_archives: | |
name: Publish Archives | |
if: startsWith(github.ref, 'refs/tags/') | |
strategy: | |
matrix: | |
os: [ macos-latest ] | |
runs-on: ${{matrix.os}} | |
steps: | |
- name: Checkout the repo | |
uses: actions/checkout@v4 | |
- uses: actions/setup-java@v4 | |
with: | |
distribution: 'zulu' | |
java-version: | | |
11 | |
15 | |
17 | |
- name: Copy CI gradle.properties | |
run: mkdir -p ~/.gradle ; cp .github/ci-gradle.properties ~/.gradle/gradle.properties | |
- name: Setup Gradle | |
uses: gradle/actions/setup-gradle@v4 | |
- name: Cache konan | |
uses: actions/cache@v4 | |
with: | |
path: ~/.konan | |
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*') }} | |
restore-keys: | | |
gradle-${{ runner.os }}- | |
- name: Publish the macOS artifacts | |
if: matrix.os == 'macos-latest' | |
env: | |
ORG_GRADLE_PROJECT_mavenCentralUsername: ${{ secrets.NEXUS_USERNAME }} | |
ORG_GRADLE_PROJECT_mavenCentralPassword: ${{ secrets.NEXUS_PASSWORD }} | |
ORG_GRADLE_PROJECT_signingInMemoryKeyId: ${{ secrets.SIGNING_KEY_ID }} | |
ORG_GRADLE_PROJECT_signingInMemoryKey: ${{ secrets.SIGNING_PRIVATE_KEY }} | |
ORG_GRADLE_PROJECT_signingInMemoryKeyPassword: ${{ secrets.SIGNING_PASSWORD }} | |
run: | | |
./gradlew multiplatform-markdown-renderer:publishAllPublicationsToMavenCentralRepository --no-daemon --no-configure-on-demand --no-parallel | |
./gradlew multiplatform-markdown-renderer-m2:publishAllPublicationsToMavenCentralRepository --no-daemon --no-configure-on-demand --no-parallel | |
./gradlew multiplatform-markdown-renderer-m3:publishAllPublicationsToMavenCentralRepository --no-daemon --no-configure-on-demand --no-parallel | |
./gradlew multiplatform-markdown-renderer-coil2:publishAllPublicationsToMavenCentralRepository --no-daemon --no-configure-on-demand --no-parallel | |
./gradlew multiplatform-markdown-renderer-coil3:publishAllPublicationsToMavenCentralRepository --no-daemon --no-configure-on-demand --no-parallel | |
./gradlew multiplatform-markdown-renderer-code:publishAllPublicationsToMavenCentralRepository --no-daemon --no-configure-on-demand --no-parallel | |
build: | |
name: Build | |
runs-on: macos-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 100 | |
- uses: actions/setup-java@v4 | |
with: | |
distribution: 'temurin' | |
java-version: '17' | |
- name: Validate gradle wrapper | |
uses: gradle/actions/wrapper-validation@v4 | |
- name: Copy CI gradle.properties | |
run: mkdir -p ~/.gradle ; cp .github/ci-gradle.properties ~/.gradle/gradle.properties | |
- name: Setup Gradle | |
uses: gradle/actions/setup-gradle@v4 | |
- name: Build Debug | |
run: | | |
./gradlew clean || true | |
./gradlew sample:android:assembleDebug --stacktrace | |
- name: Run Tests | |
run: | | |
./gradlew sample:android:validateDebugScreenshotTest | |
- name: Publish Test Report | |
if: (failure() || success()) && github.event_name == 'pull_request' | |
uses: mikepenz/action-junit-report@v5 | |
with: | |
report_paths: '**/sample/android/build/test-results/validateDebugScreenshotTest/TEST-*.xml' | |
github_token: ${{ secrets.GITHUB_TOKEN }} | |
fail_on_failure: true | |
annotate_only: true | |
detailed_summary: true | |
- name: Archive Test Report | |
uses: actions/upload-artifact@v4 | |
with: | |
name: "Test-Artifacts" | |
path: "sample/android/build/reports/screenshotTest/preview/debug/" | |
- name: Api Check | |
if: github.event_name == 'pull_request' | |
run: ./gradlew apiCheck | |
- name: Run Lint | |
if: github.event_name == 'pull_request' | |
run: ./gradlew lintDebug | |
- 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" > "sample/android/opensource.jks" | |
- name: Build Release App | |
if: startsWith(github.ref, 'refs/tags/') | |
run: ./gradlew sample:android:assembleRelease sample:android:bundleRelease -P"com.mikepenz.android.signing.enabled"="true" -P"com.mikepenz.android.signing.storeFile"="opensource.jks" -P"com.mikepenz.android.signing.storePassword"="${{ secrets.STORE_PASSWORD }}" -P"com.mikepenz.android.signing.keyAlias"="${{ secrets.KEY_ALIAS }}" -P"com.mikepenz.android.signing.keyPassword"="${{ secrets.KEY_PASSWORD }}" | |
- name: Collect artifacts | |
if: startsWith(github.ref, 'refs/tags/') | |
run: | | |
COLLECT_PWD=${PWD} | |
mkdir -p "artifacts" | |
find . -name "*release.apk" -type f -exec cp {} "artifacts" \; | |
find . -name "*release.aab" -type f -exec cp {} "artifacts" \; | |
- name: Archive Artifacts | |
if: startsWith(github.ref, 'refs/tags/') | |
uses: actions/upload-artifact@v4 | |
with: | |
name: "App-Artifacts" | |
path: artifacts/* | |
- name: Build Changelog | |
id: github_release | |
uses: mikepenz/release-changelog-builder-action@v5 | |
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: mikepenz/action-gh-release@v1 | |
if: startsWith(github.ref, 'refs/tags/') | |
with: | |
body: ${{steps.github_release.outputs.changelog}} | |
prerelease: ${{ contains(github.ref, '-rc') || contains(github.ref, '-b') || contains(github.ref, '-a') }} | |
files: artifacts/* | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |