Dependency updates (#42) #110
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 | |
tags: | |
- '*' | |
pull_request: | |
branches: | |
- main | |
jobs: | |
build: | |
name: Build & Test | |
runs-on: macos-13 | |
steps: | |
- name: Checkout workspace | |
uses: actions/checkout@v3 | |
timeout-minutes: 5 | |
with: | |
fetch-depth: 0 # no shallow clones for SonarQube | |
- name: Set up Java JDK 18 | |
uses: actions/setup-java@v3 | |
with: | |
distribution: 'temurin' | |
java-version: '18.0.2+9' | |
- name: Select XCode 15.0.1 | |
run: | | |
sudo xcode-select -s /Applications/Xcode_15.0.1.app/Contents/Developer | |
xcodebuild -version | |
- name: Gradle Cache | |
uses: actions/cache@v3 | |
with: | |
path: | | |
~/.gradle/caches | |
~/.gradle/wrapper | |
~/.gradle/native | |
key: ${{ runner.os }}-gradle-${{ hashFiles('gradle/wrapper/gradle-wrapper.properties', 'build.gradle.kts') }} | |
restore-keys: ${{ runner.os }}-gradle- | |
- name: Kotlin Native Cache | |
uses: actions/cache@v3 | |
with: | |
path: ~/.konan | |
key: ${{ runner.os }}-konan-${{ hashFiles('gradle/wrapper/gradle-wrapper.properties', 'build.gradle.kts') }} | |
restore-keys: ${{ runner.os }}-konan- | |
- name: Android Cache | |
uses: actions/cache@v3 | |
with: | |
path: ~/.android | |
key: ${{ runner.os }}-android-${{ hashFiles('gradle/wrapper/gradle-wrapper.properties', 'build.gradle.kts') }} | |
restore-keys: ${{ runner.os }}-android- | |
- name: Cache SonarCloud packages | |
uses: actions/cache@v3 | |
with: | |
path: ~/.sonar/cache | |
key: ${{ runner.os }}-sonar | |
restore-keys: ${{ runner.os }}-sonar | |
- name: Build & Test | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} | |
run: | | |
chmod +x ./gradlew | |
./gradlew build test koverXmlReport detekt sonar assembleXCFramework --parallel | |
- name: Set RELEASE_VERSION variable | |
run: | | |
echo "RELEASE_VERSION=$(cat build/version.txt)" >> $GITHUB_ENV | |
echo ${{ env.RELEASE_VERSION }} | |
- name: Upload reports | |
uses: actions/upload-artifact@v3 | |
if: always() | |
with: | |
name: reports.zip | |
path: build/reports | |
- name: Upload unit test reference files | |
uses: actions/upload-artifact@v3 | |
if: always() | |
with: | |
name: reference_files.zip | |
path: build/*.* | |
- name: List files | |
run: | | |
ls -lah build/bin/*/releaseExecutable build/libs/ build/outputs/aar/ build/XCFrameworks/release/ | |
- name: Upload kim.jar | |
uses: actions/upload-artifact@v3 | |
with: | |
if-no-files-found: error | |
name: kim.jar | |
path: build/libs/kim-jvm-${{ env.RELEASE_VERSION }}.jar | |
- name: Upload kim.aar | |
uses: actions/upload-artifact@v3 | |
with: | |
if-no-files-found: error | |
name: kim.aar | |
path: build/outputs/aar/kim-release.aar | |
- name: Upload kim.xcframework | |
uses: actions/upload-artifact@v3 | |
with: | |
if-no-files-found: error | |
name: kim.xcframework | |
path: build/XCFrameworks/release/kim.xcframework | |
- name: Upload kim.exe | |
uses: actions/upload-artifact@v3 | |
with: | |
if-no-files-found: error | |
name: kim.exe | |
path: build/bin/win/releaseExecutable/kim.exe | |
- name: Upload kim-macosX64.kexe | |
uses: actions/upload-artifact@v3 | |
with: | |
if-no-files-found: error | |
name: kim-macosX64.kexe | |
path: build/bin/macosX64/releaseExecutable/kim.kexe | |
- name: Upload kim-macosArm64.kexe | |
uses: actions/upload-artifact@v3 | |
with: | |
if-no-files-found: error | |
name: kim-macosArm64.kexe | |
path: build/bin/macosArm64/releaseExecutable/kim.kexe | |
- name: Upload kim-win-lib.zip | |
uses: actions/upload-artifact@v3 | |
with: | |
if-no-files-found: error | |
name: kim-win-lib.zip | |
path: build/bin/win/releaseStatic | |
- name: Export secring.pgp | |
if: startsWith(github.ref, 'refs/tags/') # Only for releases | |
run: | | |
echo ${{ secrets.SINGING_SECRET_KEY_RING_FILE_CONTENTS }} | base64 --decode > secring.pgp | |
- name: Publish to Maven Central | |
if: startsWith(github.ref, 'refs/tags/') # Only for releases | |
env: | |
SIGNING_ENABLED: true | |
SIGNING_KEY_ID: ${{ secrets.SIGNING_KEY_ID }} | |
SIGNING_PASSWORD: ${{ secrets.SIGNING_PASSWORD }} | |
OSSRH_USERNAME: ${{ secrets.OSSRH_USERNAME }} | |
OSSRH_PASSWORD: ${{ secrets.OSSRH_PASSWORD }} | |
run: ./gradlew publishAllPublicationsToSonatypeRepository |