summaryrefslogtreecommitdiff
path: root/.github/workflows/build_release.yml
diff options
context:
space:
mode:
authorFabio Alessandrelli <fabio.alessandrelli@gmail.com>2021-07-06 16:27:59 +0200
committerGitHub <noreply@github.com>2021-07-06 16:27:59 +0200
commite44c42fde859ccf828f0e1beaec6a6229e991f9a (patch)
treea780f6e900e81cfbe87ffc7f807a554368d9c9a7 /.github/workflows/build_release.yml
parent673a4c1a1c1bc4518aee8062a89537e31a8050ef (diff)
parent524fdde8f2c280cdf7677253ac545d615e698941 (diff)
downloadfork-godot-webrtc-native-e44c42fde859ccf828f0e1beaec6a6229e991f9a.tar.gz
fork-godot-webrtc-native-e44c42fde859ccf828f0e1beaec6a6229e991f9a.tar.bz2
fork-godot-webrtc-native-e44c42fde859ccf828f0e1beaec6a6229e991f9a.zip
Merge pull request #36 from Faless/ci/single
Setup CI for Android, iOS, Linux, macOS, Windows.
Diffstat (limited to '.github/workflows/build_release.yml')
-rw-r--r--.github/workflows/build_release.yml180
1 files changed, 180 insertions, 0 deletions
diff --git a/.github/workflows/build_release.yml b/.github/workflows/build_release.yml
new file mode 100644
index 0000000..0205afa
--- /dev/null
+++ b/.github/workflows/build_release.yml
@@ -0,0 +1,180 @@
+name: 🔧 Build -> Package 📦
+on: [push, pull_request]
+
+jobs:
+ build:
+ runs-on: ${{ matrix.os }}
+ name: 🔧 Build
+ strategy:
+ matrix:
+ include:
+ # Android
+ - platform: android
+ arch: 'x86'
+ sconsflags: 'android_arch=x86'
+ os: 'ubuntu-20.04'
+ - platform: android
+ arch: 'x64'
+ sconsflags: 'android_arch=x86_64'
+ os: 'ubuntu-20.04'
+ - platform: android
+ arch: 'arm'
+ sconsflags: 'android_arch=armv7'
+ os: 'ubuntu-20.04'
+ - platform: android
+ arch: 'arm64'
+ sconsflags: 'android_arch=arm64v8'
+ os: 'ubuntu-20.04'
+
+ # iOS
+ - platform: ios
+ arch: 'x64'
+ sconsflags: 'ios_arch=x86_64 ios_simulator=true'
+ os: 'macos-latest'
+ - platform: ios
+ arch: 'arm'
+ sconsflags: 'ios_arch=armv7'
+ os: 'macos-latest'
+ - platform: ios
+ arch: 'arm64'
+ sconsflags: 'ios_arch=arm64'
+ os: 'macos-latest'
+
+ # Linux
+ - platform: linux
+ arch: 'x86'
+ sconsflags: 'bits=32'
+ os: 'ubuntu-20.04'
+ - platform: linux
+ arch: 'x64'
+ sconsflags: 'bits=64'
+ os: 'ubuntu-20.04'
+
+ # macOS
+ - platform: osx
+ arch: 'x64'
+ sconsflags: 'bits=64'
+ os: 'macos-latest'
+
+ # Windows
+ - platform: windows
+ arch: 'x86'
+ sconsflags: 'bits=32'
+ os: 'windows-latest'
+ msvc_arch: amd64_x86
+ - platform: windows
+ arch: 'x64'
+ sconsflags: 'bits=64'
+ os: 'windows-latest'
+ msvc_arch: amd64
+
+ env:
+ SCONSFLAGS: ${{ matrix.sconsflags }} platform=${{ matrix.platform }} --jobs=2
+ NDK_VERSION: 22b
+ ANDROID_NDK_ROOT: ${{github.workspace}}/android-ndk-r22b
+ MSVC_VARS: 'C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\VC\Auxiliary\Build\vcvarsall.bat'
+
+ defaults:
+ run:
+ shell: bash
+
+ steps:
+ - uses: actions/checkout@v2
+ with:
+ submodules: recursive
+
+ - name: Cache NDK
+ id: cache-ndk
+ if: ${{ matrix.platform == 'android' }}
+ uses: actions/cache@v2
+ with:
+ path: ${{ env.ANDROID_NDK_ROOT }}
+ key: ndk-${{ env.NDK_VERSION }}
+
+ - name: Download NDK
+ if: ${{ matrix.platform == 'android' && steps.cache-ndk.outputs.cache-hit != 'true' }}
+ id: setup-ndk
+ run: |
+ cd ${{ github.workspace }}
+ curl -L https://dl.google.com/android/repository/android-ndk-r${{ env.NDK_VERSION }}-linux-x86_64.zip -o ndk.zip
+ unzip ndk.zip
+ ls
+
+ - name: Setup MSVC build environment for ${{ matrix.msvc_arch }}
+ if: ${{ matrix.platform == 'windows' }}
+ run: "'${{ env.MSVC_VARS }}' ${{ matrix.msvc_arch }}"
+
+ - name: Install Linux build dependencies
+ if: ${{ matrix.platform == 'linux' }}
+ run: |
+ sudo apt-get install build-essential gcc-multilib wget g++-multilib
+
+ - name: Set up Python 3.x
+ uses: actions/setup-python@v2
+ with:
+ python-version: '3.x'
+ architecture: 'x64'
+
+ - name: Configuring Python packages
+ run: |
+ python -c "import sys; print(sys.version)"
+ python -m pip install scons
+ python --version
+ scons --version
+
+ - name: Get WebRTC package for ${{ matrix.platform }} - ${{ matrix.arch }}
+ uses: ./.github/actions/webrtc-download
+ with:
+ platform: ${{ matrix.platform }}
+ archs: ${{ matrix.arch }}
+
+ - name: Compilation ${{ matrix.platform }} - ${{ matrix.arch }} - godot-cpp
+ run: |
+ scons -C godot-cpp target=debug generate_bindings=yes
+ scons -C godot-cpp target=release
+
+ - name: Compilation ${{ matrix.platform }} - ${{ matrix.arch }} - webrtc-native
+ run: |
+ scons target=debug
+ scons target=release
+
+ - uses: actions/upload-artifact@v2
+ with:
+ name: ${{ github.job }}-${{ matrix.platform }}-${{ matrix.arch }}
+ path: bin/*
+
+ package:
+ name: 📦 Package
+ needs: build
+ runs-on: "ubuntu-latest"
+ steps:
+ - uses: actions/checkout@v2
+
+ - uses: actions/download-artifact@v2
+ with:
+ path: artifacts
+
+ - name: Package artifacts for release
+ run: |
+ mkdir release
+ cd release
+ for name in webrtc webrtc_debug
+ do
+ mkdir -p ${name}/lib/
+ find ../artifacts -wholename "*/${name}/lib/*" | xargs cp -t ${name}/lib/
+ find ../artifacts -wholename "*/${name}/${name}.tres" | head -n 1 | xargs cp -t ${name}/
+ done
+
+ zip -r godot-webrtc-native-release.zip webrtc
+ zip -r godot-webrtc-native-debug.zip webrtc_debug
+ ls -R
+
+ - uses: actions/upload-artifact@v2
+ with:
+ name: godot-webrtc-native-debug.zip
+ path: release/godot-webrtc-native-debug.zip
+
+ - uses: actions/upload-artifact@v2
+ with:
+ name: godot-webrtc-native-release.zip
+ path: release/godot-webrtc-native-release.zip