Skip to content

Update to Kotlin 2.0 (#100) #252

Update to Kotlin 2.0 (#100)

Update to Kotlin 2.0 (#100) #252

Workflow file for this run

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 17
uses: actions/setup-java@v3
with:
distribution: 'temurin'
java-version: '17.0.10+7'
- name: Select XCode 15.2
run: |
sudo xcode-select -s /Applications/Xcode_15.2.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: Upload kim-linuxArm64.kexe
uses: actions/upload-artifact@v3
with:
if-no-files-found: error
name: kim-linuxArm64.kexe
path: build/bin/linuxArm64/releaseExecutable/kim.kexe
- name: Upload kim-linuxX64-lib.zip
uses: actions/upload-artifact@v3
with:
if-no-files-found: error
name: kim-linuxX64-lib.zip
path: build/bin/linuxX64/releaseStatic
- name: Upload kim-linuxX64.kexe
uses: actions/upload-artifact@v3
with:
if-no-files-found: error
name: kim-linuxX64.kexe
path: build/bin/linuxX64/releaseExecutable/kim.kexe
- name: Upload kim-linuxArm64-lib.zip
uses: actions/upload-artifact@v3
with:
if-no-files-found: error
name: kim-linuxArm64-lib.zip
path: build/bin/linuxArm64/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