From bd1d097a1cc4ac0f85a86cc4e0f1e3407a92d8d0 Mon Sep 17 00:00:00 2001 From: benedekkupper Date: Thu, 16 Nov 2023 11:21:25 +0100 Subject: [PATCH] Create cmake-single-platform.yml --- .github/workflows/cmake-single-platform.yml | 50 +++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 .github/workflows/cmake-single-platform.yml diff --git a/.github/workflows/cmake-single-platform.yml b/.github/workflows/cmake-single-platform.yml new file mode 100644 index 0000000..b3dbaaf --- /dev/null +++ b/.github/workflows/cmake-single-platform.yml @@ -0,0 +1,50 @@ +# This starter workflow is for a CMake project running on a single platform. There is a different starter workflow if you need cross-platform coverage. +# See: https://github.com/actions/starter-workflows/blob/main/ci/cmake-multi-platform.yml +name: CMake on a single platform + +on: + push: + branches: [ "master" ] + pull_request: + branches: [ "master" ] + +env: + # Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.) + BUILD_TYPE: Release + TOOLCHAIN_PATH: ${{ github.workspace }}/gcc-arm-none-eabi.cmake + +jobs: + build: + # The CMake configure and build commands are platform agnostic and should work equally well on Windows or Mac. + # You can convert this to a matrix build if you need cross-platform coverage. + # 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 + + steps: + - uses: actions/checkout@v3 + + - name: Install ARM GCC toolchain + run: | + sudo apt update + sudo apt install -y gcc-arm-none-eabi + + - name: Download gcc-arm-none-eabi.cmake from another repository + run: | + mkdir -p ${{ github.workspace }} + curl -sSL "https://raw.githubusercontent.com/jobroe/cmake-arm-embedded/blob/35a969878d3e6a979a0c61f0bf07327bac3aad1e/toolchain-arm-none-eabi.cmake" > "${TOOLCHAIN_PATH}" + + - name: Configure CMake + # Configure CMake in a 'build' subdirectory. `CMAKE_BUILD_TYPE` is only required if you are using a single-configuration generator such as make. + # See https://cmake.org/cmake/help/latest/variable/CMAKE_BUILD_TYPE.html?highlight=cmake_build_type + run: cmake -B ${{github.workspace}}/build -DCMAKE_BUILD_TYPE=${{env.BUILD_TYPE}} -DCMAKE_TOOLCHAIN_FILE=${TOOLCHAIN_PATH} + + - name: Build + # Build your program with the given configuration + run: cmake --build ${{github.workspace}}/build --config ${{env.BUILD_TYPE}} + + - name: Test + working-directory: ${{github.workspace}}/build + # Execute tests defined by the CMake configuration. + # See https://cmake.org/cmake/help/latest/manual/ctest.1.html for more detail + run: ctest -C ${{env.BUILD_TYPE}} +