]> git.stg.codes - stg.git/blobdiff - .github/workflows/buildtest.yml
Fix compilation.
[stg.git] / .github / workflows / buildtest.yml
index 0f6342298cea852bf5da634d1d793111827a215c..e0b210790fde7fbaa6bf793f6b14cd7d80c82d22 100644 (file)
@@ -2,10 +2,6 @@ name: Build and test
 
 on: [push]
 
 
 on: [push]
 
-env:
-  # Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.)
-  BUILD_TYPE: Release
-
 jobs:
   build:
     # The CMake configure and build commands are platform agnostic and should work equally
 jobs:
   build:
     # The CMake configure and build commands are platform agnostic and should work equally
@@ -14,8 +10,20 @@ jobs:
     # See: https://docs.github.com/en/free-pro-team@latest/actions/learn-github-actions/managing-complex-workflows#using-a-build-matrix
     runs-on: ubuntu-latest
 
     # See: https://docs.github.com/en/free-pro-team@latest/actions/learn-github-actions/managing-complex-workflows#using-a-build-matrix
     runs-on: ubuntu-latest
 
+    strategy:
+      matrix:
+        build_type:
+          - Debug
+          - Release
+        compiler:
+          - { CC: gcc, CXX: g++ }
+          - { CC: clang, CXX: clang++ }
+
     steps:
     steps:
-    - uses: actions/checkout@v2
+    - name: Checkout repository and submodules
+      uses: actions/checkout@v2
+      with:
+        submodules: recursive
 
     - name: Create Build Environment
       # Some projects don't allow in-source building, so create a separate build directory
 
     - name: Create Build Environment
       # Some projects don't allow in-source building, so create a separate build directory
@@ -30,20 +38,23 @@ jobs:
       # access regardless of the host operating system
       shell: bash
       working-directory: ${{runner.workspace}}/build
       # access regardless of the host operating system
       shell: bash
       working-directory: ${{runner.workspace}}/build
+      env:
+        CC: ${{ matrix.compiler.CC }}
+        CXX: ${{ matrix.compiler.CXX }}
       # Note the current convention is to use the -S and -B options here to specify source
       # and build directories, but this is only available with CMake 3.13 and higher.
       # The CMake binaries on the Github Actions machines are (as of this writing) 3.12
       # Note the current convention is to use the -S and -B options here to specify source
       # and build directories, but this is only available with CMake 3.13 and higher.
       # The CMake binaries on the Github Actions machines are (as of this writing) 3.12
-      run: cmake $GITHUB_WORKSPACE -DCMAKE_BUILD_TYPE=$BUILD_TYPE -DBUILD_TESTS=ON -DBUILD_LIB_CONFFILES=ON -DBUILD_LIB_CRYPTO=ON -DBUILD_LIB_COMMON=ON -DBUILD_LIB_LOGGER=ON -DBUILD_LIB_SCRIPTEXECUTER=ON
+      run: cmake $GITHUB_WORKSPACE -DCMAKE_BUILD_TYPE=${{ matrix.build_type }} -DBUILD_TESTS=ON -DBUILD_LIB_CONFFILES=ON -DBUILD_LIB_CRYPTO=ON -DBUILD_LIB_COMMON=ON -DBUILD_LIB_LOGGER=ON -DBUILD_LIB_SCRIPTEXECUTER=ON -DBUILD_STG=ON -DBUILD_SGCONF=ON -DBUILD_RSCRIPTD=ON -DBUILD_SGAUTH=ON -DBUILD_MOD_AO=ON -DBUILD_MOD_IA=ON -DBUILD_MOD_SGCONFIG=ON -DBUILD_MOD_PING=ON -DBUILD_MOD_RSCRYPT=ON -DBUILD_MOD_SMUX=ON -DBUILD_MOD_STORE_FILES=ON -DBUILD_MOD_CAP_NF=ON
 
     - name: Build
       working-directory: ${{runner.workspace}}/build
       shell: bash
       # Execute the build.  You can specify a specific target with "--target <NAME>"
 
     - name: Build
       working-directory: ${{runner.workspace}}/build
       shell: bash
       # Execute the build.  You can specify a specific target with "--target <NAME>"
-      run: cmake --build . --config $BUILD_TYPE
+      run: cmake --build . --config ${{ matrix.build_type }}
 
     - name: Test
       working-directory: ${{runner.workspace}}/build
       shell: bash
       # Execute tests defined by the CMake configuration.
       # See https://cmake.org/cmake/help/latest/manual/ctest.1.html for more detail
 
     - name: Test
       working-directory: ${{runner.workspace}}/build
       shell: bash
       # Execute tests defined by the CMake configuration.
       # See https://cmake.org/cmake/help/latest/manual/ctest.1.html for more detail
-      run: ctest -C $BUILD_TYPE
+      run: ctest -C ${{ matrix.build_type }} --rerun-failed --output-on-failure