Skip to content

Add support for Github Actions #579

Add support for Github Actions

Add support for Github Actions #579

Workflow file for this run

name: PR Build
on:
pull_request:
paths-ignore:
- '**.md'
env:
REALM_DISABLE_ANALYTICS: true
# CMAKE_C_COMPILER: /usr/local/opt/ccache/libexec/clang
# CMAKE_CXX_COMPILER: /usr/local/opt/ccache/libexec/clang++
CMAKE_C_COMPILER: /usr/local/bin/ccache-clang
CMAKE_CXX_COMPILER: /usr/local/bin/ccache-clang++
RELEASE_BRANCHES: "[ 'master', 'releases', 'feature/github-actions' ]"
jobs:
static-analysis:
uses: ./.github/workflows/include-static-analysis.yml
check-cache:
uses: ./.github/workflows/include-check-cache.yml
# TODO The actual build takes 45 seconds. Is there a reason we do this? Is it because swig doesn't work on Windows?
build-jni-swig-stub:
runs-on: ubuntu-latest
needs: check-cache
if: always() && !cancelled() && needs.check-cache.outputs.jni-swig-stub-cache-hit != 'true'
steps:
- name: Checkout code
uses: actions/checkout@v3
with:
submodules: "recursive"
- name: Setup Java 11
uses: actions/setup-java@v3
with:
distribution: zulu
java-version: 11
- name: Setup Gradle and task/dependency caching
uses: gradle/gradle-build-action@v2
with:
cache-read-only: false
- name: Load build cache
uses: actions/cache@v3
with:
path: ./packages/jni-swig-stub/build/generated/sources/jni
key: jni-swig-stubs-${{ needs.check-cache.outputs.packages-sha }}
# Manually install SWIG 4.1.0 as only 4.0.2 is pre-installed
# 4.1.0 is not available in apt-get, so use brew instead
# https://github.com/actions/runner-images/blob/main/images/linux/Ubuntu2204-Readme.md#ubuntu-22041-lts
# It seems to be required to manually add brew dirs to the PATH. This does not happen automatically.
- name: Install SWIG
run: |
test -d ~/.linuxbrew && eval "$(~/.linuxbrew/bin/brew shellenv)"
test -d /home/linuxbrew/.linuxbrew && eval "$(/home/linuxbrew/.linuxbrew/bin/brew shellenv)"
test -r ~/.bash_profile && echo "eval \"\$($(brew --prefix)/bin/brew shellenv)\"" >> ~/.bash_profile
echo "eval \"\$($(brew --prefix)/bin/brew shellenv)\"" >> ~/.profile
brew install swig
echo "/home/linuxbrew/.linuxbrew/sbin" >> $GITHUB_PATH
echo "/home/linuxbrew/.linuxbrew/bin" >> $GITHUB_PATH
- name: Build JNI Stub
working-directory: ./packages
run: ./gradlew :jni-swig-stub:assemble -PignoreNativeLibs=true -Prealm.kotlin.mainHost=false
# TODO Do we need to cache something or just built it every time?
- name: Upload artifacts
uses: actions/upload-artifact@v3
with:
name: jni-stub-${{ needs.check-cache.outputs.version-label }}
path: ./packages/jni-swig-stub/build/generated/sources/jni/*
retention-days: 1
build-jvm-linux-native-lib:
runs-on: ubuntu-latest
needs: [check-cache, build-jni-swig-stub]
if: |
always() &&
!cancelled() &&
!contains(needs.*.result, 'failure') &&
!contains(needs.*.result, 'cancelled') &&
needs.check-cache.outputs.jni-linux-lib-cache-hit != 'true'
steps:
- name: Checkout code
uses: actions/checkout@v3
with:
submodules: "recursive"
- name: Setup build cache
uses: actions/cache@v3
with:
path: ./packages/cinterop/src/jvmMain/linux-build-dir
key: jni-linux-lib-${{ needs.check-cache.outputs.packages-sha }}
- name: Restore JNI Swig Stubs
uses: actions/download-artifact@v3
with:
name: jni-stub-${{ needs.check-cache.outputs.version-label }}
path: ./packages/jni-swig-stub/build/generated/sources/jni
- name: Build Docker image
uses: docker/build-push-action@v3
with:
tags: jvm-native-lib-linux:latest
file: ./packages/cinterop/src/jvmMain/generic.Dockerfile
push: false
- name: Build native lib
uses: addnab/docker-run-action@v3
with:
image: jvm-native-lib-linux:latest
shell: bash
options: -v ${{ github.workspace }}:/work
run: |
cd /work/packages/cinterop
mkdir build
cd build
rm -rf realmLinuxBuild
mkdir realmLinuxBuild
cd realmLinuxBuild
cmake ../../src/jvm
make -j8
- name: Upload artifacts
uses: actions/upload-artifact@v3
with:
name: jni-linux-lib-${{ needs.check-cache.outputs.version-label }}
path: ./packages/cinterop/build/realmLinuxBuild/librealmc.so
retention-days: 1
# TODO Is the `if` check enough? Should we also compare the swig stub?
build-jvm-windows-native-lib:
runs-on: windows-latest
needs: [check-cache, build-jni-swig-stub]
if: |
always() &&
!cancelled() &&
!contains(needs.*.result, 'failure') &&
!contains(needs.*.result, 'cancelled') &&
needs.check-cache.outputs.jni-windows-lib-cache-hit != 'true'
steps:
- name: Checkout code
uses: actions/checkout@v3
with:
# TODO See https://github.com/microsoft/vcpkg/issues/25349 which might describe the error here https://github.com/realm/realm-kotlin/runs/8099890473?check_suite_focus=true
# -- Building for: Visual Studio 17 2022
# -- Running vcpkg install
# Error: while checking out port openssl with git tree 7e4d802e3bde4154c227c0dd1da75c719be9f07a
# Error: Failed to tar port directory
# error: tar failed with exit code: (128).
# fatal: not a tree object: 7e4d802e3bde4154c227c0dd1da75c719be9f07a
# TODO Implement better work-around here: https://mongodb.slack.com/archives/C017MBM0A30/p1661889411467029?thread_ts=1661888738.117769&cid=C017MBM0A30
fetch-depth: 0
submodules: "recursive"
- name: Setup build cache
uses: actions/cache@v3
with:
path: ./packages/cinterop/src/jvmMain/windows-build-dir
key: jni-windows-lib-${{ needs.check-cache.outputs.packages-sha }}
enableCrossOsArchive: true
- name: Restore JNI Swig Stubs
uses: actions/download-artifact@v3
with:
name: jni-stub-${{ needs.check-cache.outputs.version-label }}
path: ${{ github.workspace }}/packages/jni-swig-stub/build/generated/sources/jni
- name: Build native lib
shell: powershell
working-directory: packages
run: |
cd cinterop
mkdir build
cd build
Remove-Item -Path realmWindowsBuild -Force -Recurse -ErrorAction Ignore
mkdir realmWindowsBuild
cd realmWindowsBuild
cmake `
..\..\src\jvm `
-DCMAKE_GENERATOR_PLATFORM=x64 `
-DCMAKE_BUILD_TYPE=Release `
-DREALM_ENABLE_SYNC=ON `
-DREALM_NO_TESTS=1 `
-DVCPKG_TARGET_TRIPLET=x64-windows-static
cmake --build . --config Release
- name: Upload artifacts
uses: actions/upload-artifact@v3
with:
name: jni-windows-lib-${{ needs.check-cache.outputs.version-label }}
path: ./packages/cinterop/build/realmWindowsBuild/Release/realmc.dll
retention-days: 1
build-jvm-macos-native-lib:
runs-on: macos-latest
needs: [check-cache, build-jni-swig-stub]
if: |
always() &&
!cancelled() &&
!contains(needs.*.result, 'failure') &&
!contains(needs.*.result, 'cancelled') &&
needs.check-cache.outputs.jni-windows-lib-cache-hit != 'true'
steps:
- name: Checkout code
uses: actions/checkout@v3
with:
submodules: "recursive"
# TODO I'm not sure this catches changes to our Config.kt, what is the impact?
# https://github.com/actions/setup-java#caching-packages-dependencies
- name: Setup Java 11
uses: actions/setup-java@v3
with:
distribution: zulu
java-version: 11
# TODO Default behavior is only caching from main/master. Unclear what the best caching strategy is for us.
# TODO What is the rules and limits for caching on Github -> 10 GB limit, automatic evicition
- name: Setup Gradle and task/dependency caching
uses: gradle/gradle-build-action@v2
with:
cache-read-only: false
# TODO This cmake version is not being used by the Android builds. Figure out why.
- name: Setup cmake
uses: jwlawson/actions-setup-cmake@v1.13
with:
cmake-version: '3.25.2'
# TODO This Ninja version is not being used by the Android builds. Figure out why.
- name: Setup ninja
uses: cmelchior/setup-ninja@master
with:
version: '1.11.0'
# TODO This might not work on Windows: https://github.com/hendrikmuhs/ccache-action#notes-on-windows-support
- name: Install ccache
uses: hendrikmuhs/ccache-action@v1.2.2
with:
key: ${{ github.job.name }}
max-size: '2.0G'
- name: Prepend ccache executables to the PATH
run: echo "/usr/lib/ccache:/usr/local/opt/ccache/libexec" >> $GITHUB_PATH
# TODO See https://github.com/hendrikmuhs/ccache-action/issues/94
- name: Configure ccache
run: |
ccache --set-config="compiler_check=content"
ccache --show-config
echo '#!/bin/bash\nccache clang "$@"%"' > /usr/local/bin/ccache-clang
echo '#!/bin/bash\nccache clang++ "$@"%"' > /usr/local/bin/ccache-clang++
- name: Debug environment
run: |
env
type cmake
cmake --version
type ninja
ninja --version
# TODO Figure out naming schema and retention policy
# We cannot use artifacts as they cannot be shared between workflows, so use cache instead.
- name: Setup build cache
uses: actions/cache@v3
with:
path: ./packages/build/m2-buildrepo
key: packages-m2-jvm-sync-${{ needs.check-cache.outputs.packages-sha }}
- name: Restore JNI Swig Stubs
uses: actions/download-artifact@v3
with:
name: jni-stub-${{ needs.check-cache.outputs.version-label }}
path: ${{ github.workspace }}/packages/jni-swig-stub/build/generated/sources/jni
- name: Build packages
working-directory: packages
run: ./gradlew buildJVMSharedLibs -Prealm.kotlin.mainHost=false
- name: Upload artifacts
uses: actions/upload-artifact@v3
with:
name: jni-macos-lib-${{ needs.check-cache.outputs.version-label }}
path: ./packages/cinterop/build/realmMacOsBuild/librealmc.dylib
retention-days: 1
# This task is also responsible for creating the Gradle and Compiler Plugin as well as
# all Kotlin Multiplatform Metadata
build-jvm-packages:
runs-on: macos-latest
needs: [check-cache, build-jvm-linux-native-lib, build-jvm-windows-native-lib, build-jvm-macos-native-lib]
if: |
always() &&
!cancelled() &&
!contains(needs.*.result, 'failure') &&
!contains(needs.*.result, 'cancelled') &&
needs.check-cache.outputs.packages-jvm-cache-hit != 'true'
steps:
- name: Checkout code
uses: actions/checkout@v3
with:
submodules: "recursive"
# TODO I'm not sure this catches changes to our Config.kt, what is the impact?
# https://github.com/actions/setup-java#caching-packages-dependencies
- name: Setup Java 11
uses: actions/setup-java@v3
with:
distribution: zulu
java-version: 11
# TODO Default behavior is only caching from main/master. Unclear what the best caching strategy is for us.
# TODO What is the rules and limits for caching on Github -> 10 GB limit, automatic evicition
- name: Setup Gradle and task/dependency caching
uses: gradle/gradle-build-action@v2
with:
cache-read-only: false
# TODO This cmake version is not being used by the Android builds. Figure out why.
- name: Setup cmake
uses: jwlawson/actions-setup-cmake@v1.13
with:
cmake-version: '3.25.2'
# TODO This Ninja version is not being used by the Android builds. Figure out why.
- name: Setup ninja
uses: cmelchior/setup-ninja@master
with:
version: '1.11.0'
# TODO This might not work on Windows: https://github.com/hendrikmuhs/ccache-action#notes-on-windows-support
- name: Install ccache
uses: hendrikmuhs/ccache-action@v1.2.2
with:
key: ${{ github.job.name }}
max-size: '2.0G'
- name: Prepend ccache executables to the PATH
run: echo "/usr/lib/ccache:/usr/local/opt/ccache/libexec" >> $GITHUB_PATH
# TODO See https://github.com/hendrikmuhs/ccache-action/issues/94
- name: Configure ccache
run: |
ccache --set-config="compiler_check=content"
ccache --show-config
echo '#!/bin/bash\nccache clang "$@"%"' > /usr/local/bin/ccache-clang
echo '#!/bin/bash\nccache clang++ "$@"%"' > /usr/local/bin/ccache-clang++
# TODO This matches 23.2.8568313, but what happens if we a define specific ndk version in our build?
- name: Setup NDK
uses: nttld/setup-ndk@v1
with:
ndk-version: r23c
- name: Debug environment
run: |
env
type cmake
cmake --version
type ninja
ninja --version
# TODO Figure out naming schema and retention policy
# We cannot use artifacts as they cannot be shared between workflows, so use cache instead.
- name: Setup build cache
uses: actions/cache@v3
with:
path: ./packages/build/m2-buildrepo
key: packages-m2-jvm-sync-${{ needs.check-cache.outputs.packages-sha }}
- name: Restore Linux JNI lib
uses: actions/download-artifact@v3
with:
name: jni-linux-lib-${{ needs.check-cache.outputs.version-label }}
path: ./packages/cinterop/build/realmLinuxBuild
- name: Restore Windows JNI lib
uses: actions/download-artifact@v3
with:
name: jni-windows-lib-${{ needs.check-cache.outputs.version-label }}
path: ./packages/cinterop/build/realmWindowsBuild/Release
- name: Restore MacOS JNI lib
uses: actions/download-artifact@v3
with:
name: jni-macos-lib-${{ needs.check-cache.outputs.version-label }}
path: ./packages/cinterop/build/realmMacOsBuild
- name: Build packages
working-directory: packages
run: ./gradlew publishCIPackages -Prealm.kotlin.targets=jvm,gradlePlugin,compilerPlugin -PcopyJvmABIs=true -PignoreNativeLibs=true -Prealm.kotlin.mainHost=true --no-rebuild
- name: Upload artifacts
uses: actions/upload-artifact@v3
with:
name: packages-jvm-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo/**/*
retention-days: 1
build-android-packages:
runs-on: ubuntu-latest
needs: check-cache
# needs: static-analysis
if: always() && !cancelled() && needs.check-cache.outputs.packages-android-cache-hit != 'true'
steps:
- name: Checkout code
uses: actions/checkout@v3
with:
submodules: "recursive"
# TODO I'm not sure this catches changes to our Config.kt, what is the impact?
# https://github.com/actions/setup-java#caching-packages-dependencies
- name: Setup Java 11
uses: actions/setup-java@v3
with:
distribution: zulu
java-version: 11
# TODO Default behavior is only caching from main/master. Unclear what the best caching strategy is for us.
# TODO What is the rules and limits for caching on Github -> 10 GB limit, automatic evicition
- name: Setup Gradle and task/dependency caching
uses: gradle/gradle-build-action@v2
with:
cache-read-only: false
# Manually install SWIG 4.1.0 as only 4.0.2 is pre-installed
# 4.1.0 is not available in apt-get, so use brew instead
# https://github.com/actions/runner-images/blob/main/images/linux/Ubuntu2204-Readme.md#ubuntu-22041-lts
# It seems to be required to manually add brew dirs to the PATH. This does not happen automatically.
- name: Install SWIG
run: |
test -d ~/.linuxbrew && eval "$(~/.linuxbrew/bin/brew shellenv)"
test -d /home/linuxbrew/.linuxbrew && eval "$(/home/linuxbrew/.linuxbrew/bin/brew shellenv)"
test -r ~/.bash_profile && echo "eval \"\$($(brew --prefix)/bin/brew shellenv)\"" >> ~/.bash_profile
echo "eval \"\$($(brew --prefix)/bin/brew shellenv)\"" >> ~/.profile
brew install swig
echo "/home/linuxbrew/.linuxbrew/sbin" >> $GITHUB_PATH
echo "/home/linuxbrew/.linuxbrew/bin" >> $GITHUB_PATH
# TODO This cmake version is not being used by the Android builds. Figure out why.
- name: Setup cmake
uses: jwlawson/actions-setup-cmake@v1.13
with:
cmake-version: '3.25.2'
# TODO This Ninja version is not being used by the Android builds. Figure out why.
- name: Setup ninja
uses: cmelchior/setup-ninja@master
with:
version: '1.11.0'
# TODO This might not work on Windows: https://github.com/hendrikmuhs/ccache-action#notes-on-windows-support
- name: Install ccache
uses: hendrikmuhs/ccache-action@v1.2.2
with:
key: ${{ github.job.name }}
max-size: '2.0G'
- name: Prepend ccache executables to the PATH
run: echo "/usr/lib/ccache:/usr/local/opt/ccache/libexec" >> $GITHUB_PATH
# TODO See https://github.com/hendrikmuhs/ccache-action/issues/94
- name: Configure ccache
run: |
ccache --set-config="compiler_check=content"
ccache --show-config
echo '#!/bin/bash\nccache clang "$@"%"' > /usr/local/bin/ccache-clang
echo '#!/bin/bash\nccache clang++ "$@"%"' > /usr/local/bin/ccache-clang++
# TODO This matches 23.2.8568313, but what happens if we a define specific ndk version in our build?
- name: Setup NDK
uses: nttld/setup-ndk@v1
with:
ndk-version: r23c
- name: Debug environment
run: |
env
type cmake
cmake --version
type ninja
ninja --version
- name: Build Android Test Apk
working-directory: packages
run: ./gradlew :test-base:assembleAndroidTest -PignoreNativeLibs=true
- name: Build packages
working-directory: packages
run: ./gradlew publishCIPackages -Prealm.kotlin.targets=android -PignoreNativeLibs=true -Prealm.kotlin.mainHost=false
- name: APK zipinfo
run: zipinfo ./packages/test-base/build/outputs/apk/androidTest/debug/test-base-debug-androidTest.apk
# TODO Figure out naming schema and retention policy
# We cannot use artifacts as they cannot be shared between workflows, so use cache instead.
- name: Store build cache
uses: actions/cache@v3
with:
path: ./packages/build/m2-buildrepo
key: packages-m2-android-sync-${{ needs.check-cache.outputs.packages-sha }}
- name: Store build cache for Android Test APK
uses: actions/cache@v3
with:
path: ./packages/test-base/build/outputs/apk/androidTest/debug/test-base-debug-androidTest.apk
key: android-base-test-apk-key-${{ needs.check-cache.outputs.packages-sha }}
# TODO Must match naming found in include-check-cache.yml
- name: Upload artifacts
uses: actions/upload-artifact@v3
with:
name: packages-android-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo/**/*
retention-days: 1
- name: Upload Android Test APK
uses: actions/upload-artifact@v3
with:
name: android-base-test-apk-${{ needs.check-cache.outputs.version-label }}
path: ./packages/test-base/build/outputs/apk/androidTest/debug/test-base-debug-androidTest.apk
retention-days: 1
# TODO: ccache is not being used by this build for some reason
build-macos-x64-packages:
runs-on: macos-latest
needs: check-cache
# needs: static-analysis
if: always() && !cancelled() && needs.check-cache.outputs.packages-macos-x64-cache-hit != 'true'
steps:
- name: Checkout code
uses: actions/checkout@v3
with:
submodules: "recursive"
# TODO I'm not sure this catches changes to our Config.kt, what is the impact?
# https://github.com/actions/setup-java#caching-packages-dependencies
- name: Setup Java 11
uses: actions/setup-java@v3
with:
distribution: zulu
java-version: 11
# TODO Default behavior is only caching from main/master. Unclear what the best caching strategy is for us.
# TODO What is the rules and limits for caching on Github -> 10 GB limit, automatic evicition
- name: Setup Gradle and task/dependency caching
uses: gradle/gradle-build-action@v2
with:
cache-read-only: false
# TODO This cmake version is not being used by the Android builds. Figure out why.
- name: Setup cmake
uses: jwlawson/actions-setup-cmake@v1.13
with:
cmake-version: '3.25.2'
# TODO This Ninja version is not being used by the Android builds. Figure out why.
- name: Setup ninja
uses: cmelchior/setup-ninja@master
with:
version: '1.11.0'
# TODO This might not work on Windows: https://github.com/hendrikmuhs/ccache-action#notes-on-windows-support
- name: Install ccache
uses: hendrikmuhs/ccache-action@v1.2.2
with:
key: ${{ github.job.name }}
max-size: '2.0G'
- name: Prepend ccache executables to the PATH
run: echo "/usr/lib/ccache:/usr/local/opt/ccache/libexec" >> $GITHUB_PATH
# TODO See https://github.com/hendrikmuhs/ccache-action/issues/94
- name: Configure ccache
run: |
ccache --set-config="compiler_check=content"
ccache --show-config
echo '#!/bin/bash\nccache clang "$@"%"' > /usr/local/bin/ccache-clang
echo '#!/bin/bash\nccache clang++ "$@"%"' > /usr/local/bin/ccache-clang++
- name: Debug environment
run: |
env
type cmake
cmake --version
type ninja
ninja --version
- name: Build packages
working-directory: packages
run: ./gradlew publishCIPackages -Prealm.kotlin.targets=macosX64 -Prealm.kotlin.mainHost=false
# TODO Figure out naming schema and retention policy
# We cannot use artifacts as they cannot be shared between workflows, so use cache instead.
- name: Store build cache
uses: actions/cache@v3
with:
path: ./packages/build/m2-buildrepo
key: packages-m2-macos-x64-sync-${{ needs.check-cache.outputs.packages-sha }}
# TODO Must match naming found in include-check-cache.yml
- name: Upload artifacts
uses: actions/upload-artifact@v3
with:
name: packages-macos-x64-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo/**/*
retention-days: 1
# TODO: ccache is not being used by this build for some reason
build-macos-arm64-packages:
runs-on: macos-latest
needs: check-cache
# needs: static-analysis
if: always() && !cancelled() && needs.check-cache.outputs.packages-macos-arm64-cache-hit != 'true'
steps:
- name: Checkout code
uses: actions/checkout@v3
with:
submodules: "recursive"
# TODO I'm not sure this catches changes to our Config.kt, what is the impact?
# https://github.com/actions/setup-java#caching-packages-dependencies
- name: Setup Java 11
uses: actions/setup-java@v3
with:
distribution: zulu
java-version: 11
# TODO Default behavior is only caching from main/master. Unclear what the best caching strategy is for us.
# TODO What is the rules and limits for caching on Github -> 10 GB limit, automatic evicition
- name: Setup Gradle and task/dependency caching
uses: gradle/gradle-build-action@v2
with:
cache-read-only: false
# TODO This cmake version is not being used by the Android builds. Figure out why.
- name: Setup cmake
uses: jwlawson/actions-setup-cmake@v1.13
with:
cmake-version: '3.25.2'
# TODO This Ninja version is not being used by the Android builds. Figure out why.
- name: Setup ninja
uses: cmelchior/setup-ninja@master
with:
version: '1.11.0'
# TODO This might not work on Windows: https://github.com/hendrikmuhs/ccache-action#notes-on-windows-support
- name: Install ccache
uses: hendrikmuhs/ccache-action@v1.2.2
with:
key: ${{ github.job.name }}
max-size: '2.0G'
- name: Prepend ccache executables to the PATH
run: echo "/usr/lib/ccache:/usr/local/opt/ccache/libexec" >> $GITHUB_PATH
# TODO See https://github.com/hendrikmuhs/ccache-action/issues/94
- name: Configure ccache
run: |
ccache --set-config="compiler_check=content"
ccache --show-config
echo '#!/bin/bash\nccache clang "$@"%"' > /usr/local/bin/ccache-clang
echo '#!/bin/bash\nccache clang++ "$@"%"' > /usr/local/bin/ccache-clang++
- name: Build packages
working-directory: packages
run: ./gradlew publishCIPackages -Prealm.kotlin.targets=macosArm64 -Prealm.kotlin.mainHost=false
# TODO Figure out naming schema and retention policy
# We cannot use artifacts as they cannot be shared between workflows, so use cache instead.
- name: Store build cache
uses: actions/cache@v3
with:
path: ./packages/build/m2-buildrepo
key: packages-m2-macos-arm64-sync-${{ needs.check-cache.outputs.packages-sha }}
# TODO Must match naming found in include-check-cache.yml
- name: Upload artifacts
uses: actions/upload-artifact@v3
with:
name: packages-macos-arm64-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo/**/*
retention-days: 1
# TODO: ccache is not being used by this build for some reason
build-ios-x64-packages:
runs-on: macos-latest
needs: check-cache
# needs: static-analysis
if: always() && !cancelled() && needs.check-cache.outputs.packages-ios-x64-cache-hit != 'true'
steps:
- name: Checkout code
uses: actions/checkout@v3
with:
submodules: "recursive"
# TODO I'm not sure this catches changes to our Config.kt, what is the impact?
# https://github.com/actions/setup-java#caching-packages-dependencies
- name: Setup Java 11
uses: actions/setup-java@v3
with:
distribution: zulu
java-version: 11
# TODO Default behavior is only caching from main/master. Unclear what the best caching strategy is for us.
# TODO What is the rules and limits for caching on Github -> 10 GB limit, automatic evicition
- name: Setup Gradle and task/dependency caching
uses: gradle/gradle-build-action@v2
with:
cache-read-only: false
# TODO This cmake version is not being used by the Android builds. Figure out why.
- name: Setup cmake
uses: jwlawson/actions-setup-cmake@v1.13
with:
cmake-version: '3.25.2'
# TODO This Ninja version is not being used by the Android builds. Figure out why.
- name: Setup ninja
uses: cmelchior/setup-ninja@master
with:
version: '1.11.0'
# TODO This might not work on Windows: https://github.com/hendrikmuhs/ccache-action#notes-on-windows-support
- name: Install ccache
uses: hendrikmuhs/ccache-action@v1.2.2
with:
key: ${{ github.job.name }}
max-size: '2.0G'
- name: Prepend ccache executables to the PATH
run: echo "/usr/lib/ccache:/usr/local/opt/ccache/libexec" >> $GITHUB_PATH
# TODO See https://github.com/hendrikmuhs/ccache-action/issues/94
- name: Configure ccache
run: |
ccache --set-config="compiler_check=content"
ccache --show-config
echo '#!/bin/bash\nccache clang "$@"%"' > /usr/local/bin/ccache-clang
echo '#!/bin/bash\nccache clang++ "$@"%"' > /usr/local/bin/ccache-clang++
- name: Build packages
working-directory: packages
run: ./gradlew publishCIPackages -Prealm.kotlin.targets=iosX64 -Prealm.kotlin.mainHost=false
# TODO Figure out naming schema and retention policy
# We cannot use artifacts as they cannot be shared between workflows, so use cache instead.
- name: Store build cache
uses: actions/cache@v3
with:
path: ./packages/build/m2-buildrepo
key: packages-m2-ios-x64-sync-${{ needs.check-cache.outputs.packages-sha }}
# TODO Must match naming found in include-check-cache.yml
- name: Upload artifacts
uses: actions/upload-artifact@v3
with:
name: packages-ios-x64-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo/**/*
retention-days: 1
# TODO: ccache is not being used by this build for some reason
build-ios-arm64-packages:
runs-on: macos-latest
needs: check-cache
# needs: static-analysis
if: always() && !cancelled() && needs.check-cache.outputs.packages-ios-arm64-cache-hit != 'true'
steps:
- name: Checkout code
uses: actions/checkout@v3
with:
submodules: "recursive"
# TODO I'm not sure this catches changes to our Config.kt, what is the impact?
# https://github.com/actions/setup-java#caching-packages-dependencies
- name: Setup Java 11
uses: actions/setup-java@v3
with:
distribution: zulu
java-version: 11
# TODO Default behavior is only caching from main/master. Unclear what the best caching strategy is for us.
# TODO What is the rules and limits for caching on Github -> 10 GB limit, automatic evicition
- name: Setup Gradle and task/dependency caching
uses: gradle/gradle-build-action@v2
with:
cache-read-only: false
# TODO This cmake version is not being used by the Android builds. Figure out why.
- name: Setup cmake
uses: jwlawson/actions-setup-cmake@v1.13
with:
cmake-version: '3.25.2'
# TODO This Ninja version is not being used by the Android builds. Figure out why.
- name: Setup ninja
uses: cmelchior/setup-ninja@master
with:
version: '1.11.0'
# TODO This might not work on Windows: https://github.com/hendrikmuhs/ccache-action#notes-on-windows-support
- name: Install ccache
uses: hendrikmuhs/ccache-action@v1.2.2
with:
key: ${{ github.job.name }}
max-size: '2.0G'
- name: Prepend ccache executables to the PATH
run: echo "/usr/lib/ccache:/usr/local/opt/ccache/libexec" >> $GITHUB_PATH
# TODO See https://github.com/hendrikmuhs/ccache-action/issues/94
- name: Configure ccache
run: |
ccache --set-config="compiler_check=content"
ccache --show-config
echo '#!/bin/bash\nccache clang "$@"%"' > /usr/local/bin/ccache-clang
echo '#!/bin/bash\nccache clang++ "$@"%"' > /usr/local/bin/ccache-clang++
- name: Build packages
working-directory: packages
run: ./gradlew publishCIPackages -Prealm.kotlin.targets=iosArm64 -Prealm.kotlin.mainHost=false
# TODO Figure out naming schema and retention policy
# We cannot use artifacts as they cannot be shared between workflows, so use cache instead.
- name: Store build cache
uses: actions/cache@v3
with:
path: ./packages/build/m2-buildrepo
key: packages-m2-ios-arm64-sync-${{ needs.check-cache.outputs.packages-sha }}
# TODO Must match naming found in include-check-cache.yml
- name: Upload artifacts
uses: actions/upload-artifact@v3
with:
name: packages-ios-arm64-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo/**/*
retention-days: 1
# TODO Split into base and sync tests
# TODO If we hook up to Device Farm we can use ubuntu runners instead
# TODO Compare speed between emulator and Device Farm
# TODO We should be able to move this into a reusable work-flow
test-android-packages-emulator:
timeout-minutes: 60
runs-on: macos-latest
needs: [check-cache, build-android-packages, build-jvm-packages]
if: |
always() &&
!cancelled() &&
!contains(needs.*.result, 'failure') &&
!contains(needs.*.result, 'cancelled')
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Setup Java 11
uses: actions/setup-java@v3
with:
distribution: zulu
java-version: 11
- name: Setup Gradle and task/dependency caching
uses: gradle/gradle-build-action@v2
with:
cache-read-only: false
- name: Restore m2-buildrepo (Android)
uses: actions/download-artifact@v3
with:
name: packages-android-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo
- name: Restore m2-buildrepo (JVM)
uses: actions/download-artifact@v3
with:
name: packages-jvm-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo
# - name: AVD cache
# uses: actions/cache@v3
# id: avd-cache
# with:
# path: |
# ~/.android/avd/*
# ~/.android/adb*
# key: android-emulator-avd-33
# - name: create AVD and generate snapshot for caching
# if: steps.avd-cache.outputs.cache-hit != 'true'
# uses: reactivecircus/android-emulator-runner@v2
# with:
# api-level: 33
# target: default
# # target: aosp_atd
# arch: x86_64
# disk-size: 4096M
# ram-size: 2048M
# heap-size: 1024M
# force-avd-creation: false
# emulator-options: -no-window -gpu swiftshader_indirect -noaudio -no-boot-anim -camera-back none
# disable-animations: true
# channel: canary
# script: echo "Generated AVD snapshot for caching."
# TODO Can we read api level from Config.kt
- name: Run Integration Tests
env:
SSH_AUTH_SOCK: /tmp/ssh_agent.sock
uses: reactivecircus/android-emulator-runner@v2
with:
emulator-options: -no-snapshot-save -no-window -gpu swiftshader_indirect -noaudio -no-boot-anim -camera-back none
disable-animations: true
# force-avd-creation: true
api-level: 33 # Must be 30 to support aosp_atd
target: default
# target: aosp_atd
arch: x86_64
# profile: Nexus 6
disk-size: 4096M
ram-size: 2048M
heap-size: 1024M
channel: canary
script: |
adb logcat -c
adb logcat > logcat.txt &
cd packages && ./gradlew :test-base:connectedAndroidTest -PincludeSdkModules=false --info
- name: Archive LogCat data
uses: actions/upload-artifact@v3
if: always() || failure()
with:
name: logcat-base-emulator.txt
path: logcat.txt
retention-days: 1
- name: Publish Unit Test Results
uses: dorny/test-reporter@v1
if: always() || failure()
with:
name: Results - Android Base (Emulator)
path: ./packages/test-base/build/**/TEST-*.xml
reporter: java-junit
list-suites: failed
list-tests: failed
fail-on-error: true
test-android-packages-device-farm:
name: AWS Device Farm
timeout-minutes: 60
runs-on: ubuntu-latest
needs: [ check-cache, build-android-packages, build-jvm-packages ]
if: |
always() &&
!cancelled() &&
!contains(needs.*.result, 'failure') &&
!contains(needs.*.result, 'cancelled')
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Restore Android Test APK
uses: actions/download-artifact@v3
with:
name: android-base-test-apk-${{ needs.check-cache.outputs.version-label }}
path: ./packages/test-base/build/outputs/apk/androidTest/debug/test-base-debug-androidTest.apk
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@v1
with:
aws-access-key-id: ${{ secrets.AWS_DEVICEFARM_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_DEVICEFARM_SECRET_ACCESS_KEY }}
aws-region: us-west-2
- name: Run the tests
uses: ./.github/actions/run-android-device-farm-test
id: run_android_tests
with:
apk-path: ${{ github.workspace }}/packages/test-base/build/outputs/apk/androidTest/debug/test-base-debug-androidTest.apk/test-base-debug-androidTest.apk
app-id: io.realm.testapp.test
project-arn: ${{ secrets.DEVICEFARM_PROJECT_ARN }}
device-pool-arn: ${{ secrets.DEVICEFARM_POOL_ARN }}
test-macos-packages:
timeout-minutes: 30
strategy:
matrix:
os: [macos-latest] # , macos-arm]
include:
- os: macos-latest
package-prefix: macos-x64
test-title: Unit Test Results - MacOS x64 Base
# - os: macos-arm
# package-prefix: macos-arm64
# test-title: Results - MacOS arm64 Base
runs-on: ${{ matrix.os }}
# TODO Do we need to wait for all matrix builds?
# Disable macos-arm for now as the host needs to have the Android SDK installed even though it isn't really using it.
needs: [check-cache, build-macos-x64-packages] #, build-macos-arm64-packages]
if: |
always() &&
!cancelled() &&
!contains(needs.*.result, 'failure') &&
!contains(needs.*.result, 'cancelled')
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Setup Java 11
uses: actions/setup-java@v3
with:
distribution: zulu
java-version: 11
- name: Setup Gradle and task/dependency caching
uses: gradle/gradle-build-action@v2
with:
cache-read-only: false
- name: Restore m2-buildrepo
uses: actions/download-artifact@v3
with:
name: packages-${{ matrix.package-prefix }}-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo
- name: Run tests
run: cd packages && ./gradlew :test-base:macosTest -PincludeSdkModules=false
- name: Publish Unit Test Results
uses: dorny/test-reporter@v1
if: always() || failure()
with:
name: ${{ matrix.test-title }}
path: ./packages/test-base/build/**/TEST-*.xml
reporter: java-junit
list-suites: failed
list-tests: failed
fail-on-error: true
test-ios-packages:
timeout-minutes: 30
strategy:
matrix:
os: [macos-latest] # , macos-arm]
include:
- os: macos-latest
package-prefix: x64
test-title: Unit Test Results - iOS x64 Base
# - os: macos-arm
# package-prefix: macos-arm64
# test-title: Results - MacOS arm64 Base
runs-on: ${{ matrix.os }}
# TODO Do we need to wait for all matrix builds?
# Disable macos-arm for now as the host needs to have the Android SDK installed even though it isn't really using it.
needs: [check-cache, build-macos-x64-packages, build-ios-x64-packages] # , build-ios-arm64-packages]
if: |
always() &&
!cancelled() &&
!contains(needs.*.result, 'failure') &&
!contains(needs.*.result, 'cancelled')
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Setup Java 11
uses: actions/setup-java@v3
with:
distribution: zulu
java-version: 11
- name: Setup Gradle and task/dependency caching
uses: gradle/gradle-build-action@v2
with:
cache-read-only: false
- name: Restore m2-buildrepo (mac)
uses: actions/download-artifact@v3
with:
name: packages-macos-${{ matrix.package-prefix }}-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo
- name: Restore m2-buildrepo (ios)
uses: actions/download-artifact@v3
with:
name: packages-ios-${{ matrix.package-prefix }}-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo
- name: Run tests
run: cd packages && ./gradlew :test-base:iosTest -PincludeSdkModules=false
- name: Publish Unit Test Results
uses: dorny/test-reporter@v1
if: always() || failure()
with:
name: ${{ matrix.test-title }}
path: ./packages/test-base/build/**/TEST-*.xml
reporter: java-junit
list-suites: failed
list-tests: failed
fail-on-error: true
# TODO Investigate why these tests seem to hang for the `run tests` step with no log output. Could it be related to the test failing, but not being picked up?
test-jvm-packages:
timeout-minutes: 30
strategy:
matrix:
os: [macos-latest, ubuntu-latest, windows-latest] # TODO Should we also test om MacOS arm64?
include:
- os: macos-latest
test-title: Unit Test Results - Base JVM MacOS x64
- os: ubuntu-latest
test-title: Unit Test Results - Base JVM Linux
- os: windows-latest
test-title: Unit Test Results - Base JVM Windows
runs-on: ${{ matrix.os }}
needs: [check-cache, build-jvm-packages]
if: |
always() &&
!cancelled() &&
!contains(needs.*.result, 'failure') &&
!contains(needs.*.result, 'cancelled')
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Setup Java 11
uses: actions/setup-java@v3
with:
distribution: zulu
java-version: 11
- name: Setup Gradle and task/dependency caching
uses: gradle/gradle-build-action@v2
with:
cache-read-only: false
- name: Restore m2-buildrepo
uses: actions/download-artifact@v3
with:
name: packages-jvm-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo
- name: Run tests
working-directory: packages
run: ./gradlew :test-base:jvmTest -PincludeSdkModules=false --info --no-daemon
- name: Publish Unit Test Results
uses: dorny/test-reporter@v1
if: always() || failure()
with:
name: ${{ matrix.test-title }}
path: ./packages/test-base/build/**/TEST-*.xml
reporter: java-junit
list-suites: failed
list-tests: failed
fail-on-error: true
package-all-artifacts:
runs-on: ubuntu-latest
needs: [check-cache, build-jvm-packages, build-android-packages, build-macos-x64-packages, build-macos-arm64-packages, build-ios-x64-packages, build-ios-arm64-packages]
if: |
always() &&
!cancelled() &&
!contains(needs.*.result, 'failure') &&
!contains(needs.*.result, 'cancelled')
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Restore Android artifacts
uses: actions/download-artifact@v3
with:
name: packages-android-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo
- name: Restore JVM artifacts
uses: actions/download-artifact@v3
with:
name: packages-jvm-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo
- name: Restore JVM artifacts
uses: actions/download-artifact@v3
with:
name: packages-jvm-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo
- name: Restore MacOS x64 artifacts
uses: actions/download-artifact@v3
with:
name: packages-macos-x64-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo
- name: Restore MacOS arm64 artifacts
uses: actions/download-artifact@v3
with:
name: packages-macos-arm64-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo
- name: Restore iOS x64 artifacts
uses: actions/download-artifact@v3
with:
name: packages-ios-x64-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo
- name: Restore iOS arm64 artifacts
uses: actions/download-artifact@v3
with:
name: packages-ios-arm64-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo
- name: Upload artifacts bundle
uses: actions/upload-artifact@v3
with:
name: all-packages-${{ needs.check-cache.outputs.version-label }}
path: ./packages/build/m2-buildrepo
retention-days: 7
integration-tests:
uses: ./.github/workflows/include-integration-tests.yml
needs: [check-cache, package-all-artifacts]
if: |
always() &&
!cancelled() &&
!contains(needs.*.result, 'failure') &&
!contains(needs.*.result, 'cancelled')
with:
version-label: ${{ needs.check-cache.outputs.version-label }}
# TODO: Should only deploy snapshots from certain branches. For now deploy always until GHA branch is closer to being done.
deploy-snapshot:
uses: ./.github/workflows/include-deploy-snapshot.yml
needs: [
check-cache,
static-analysis,
integration-tests,
test-jvm-packages,
test-macos-packages,
test-ios-packages,
test-android-packages-emulator,
test-android-packages-device-farm,
package-all-artifacts
]
if: |
always() &&
!cancelled() &&
endsWith(needs.check-cache.outputs.version-label, '-SNAPSHOT') &&
!contains(needs.*.result, 'failure') &&
!contains(needs.*.result, 'cancelled')
secrets: inherit
with:
version-label: ${{ needs.check-cache.outputs.version-label }}