From dce10e4d8c9829eeb0135d9f5269c63e88f75cbb Mon Sep 17 00:00:00 2001 From: Peter Thoman Date: Mon, 11 Dec 2023 16:25:49 +0100 Subject: [PATCH] Add github CI workflow and multi-platform/config CMake --- .github/workflows/simsycl_ci.yml | 77 ++++++++++++++++++++++++++++++++ CMakeLists.txt | 30 ++++++++----- README.md | 1 + test/CMakeLists.txt | 13 +++--- 4 files changed, 102 insertions(+), 19 deletions(-) create mode 100644 .github/workflows/simsycl_ci.yml diff --git a/.github/workflows/simsycl_ci.yml b/.github/workflows/simsycl_ci.yml new file mode 100644 index 0000000..b980c90 --- /dev/null +++ b/.github/workflows/simsycl_ci.yml @@ -0,0 +1,77 @@ +name: SimSYCL CI + +on: + push: + pull_request: + +jobs: + build: + runs-on: ${{ matrix.os }} + + strategy: + # Set fail-fast to false to ensure that feedback is delivered for all matrix combinations. Consider changing this to true when your workflow is stable. + fail-fast: false + + matrix: + os: [ubuntu-latest, windows-latest] + build_type: [Release, Debug] + c_compiler: [gcc, clang, cl] + include: + - os: windows-latest + c_compiler: cl + cpp_compiler: cl + - os: ubuntu-latest + c_compiler: gcc + cpp_compiler: g++ + - os: ubuntu-latest + c_compiler: clang + cpp_compiler: clang++ + exclude: + - os: windows-latest + c_compiler: gcc + - os: windows-latest + c_compiler: clang + - os: ubuntu-latest + c_compiler: cl + + steps: + - uses: actions/checkout@v3 + + - name: Set reusable strings + # Turn repeated input strings (such as the build output directory) into step outputs. These step outputs can be used throughout the workflow file. + id: strings + shell: bash + run: | + echo "build-output-dir=${{ github.workspace }}/build" >> "$GITHUB_OUTPUT" + + - name: Build Boost + id: boost + uses: egor-tensin/build-boost@v1 + with: + version: 1.78.0 + libraries: context + platform: x64 + configuration: Release + + - 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 + -D "BOOST_ROOT=${{ steps.boost.outputs.root }}" + -D "BOOST_LIBRARYDIR=${{ steps.boost.outputs.librarydir }}" + -B ${{ steps.strings.outputs.build-output-dir }} + -DCMAKE_CXX_COMPILER=${{ matrix.cpp_compiler }} + -DCMAKE_C_COMPILER=${{ matrix.c_compiler }} + -DCMAKE_BUILD_TYPE=${{ matrix.build_type }} + -S ${{ github.workspace }} + + - name: Build + # Build your program with the given configuration. Note that --config is needed because the default Windows generator is a multi-config generator (Visual Studio generator). + run: cmake --build ${{ steps.strings.outputs.build-output-dir }} --config ${{ matrix.build_type }} + + - name: Test + working-directory: ${{ steps.strings.outputs.build-output-dir }} + # Execute tests defined by the CMake configuration. Note that --build-config is needed because the default Windows generator is a multi-config generator (Visual Studio generator). + # See https://cmake.org/cmake/help/latest/manual/ctest.1.html for more detail + run: ctest --build-config ${{ matrix.build_type }} diff --git a/CMakeLists.txt b/CMakeLists.txt index 1d7de21..b385dd6 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -3,7 +3,21 @@ project(SimSYCL VERSION 0.1 LANGUAGES CXX) set(CMAKE_EXPORT_COMPILE_COMMANDS ON) -find_package(Boost 1.60 COMPONENTS context REQUIRED) +find_package(Boost 1.78 COMPONENTS context REQUIRED) + +# Function to set properties, compile options, and link options for all simsycl targets +function(set_simsycl_target_options target) + set_target_properties(${target} PROPERTIES CXX_STANDARD 20) + set_target_properties(${target} PROPERTIES CXX_STANDARD_REQUIRED ON) + target_compile_options(${target} PRIVATE + $<$:/W4 /WX $<$:/fsanitize=address>> + $<$>:-Wall -Wextra -Wpedantic $<$:-fsanitize=address>> + ) + target_link_options(${target} PRIVATE + $<$:$<$:/fsanitize=address>> + $<$>:$<$:-fsanitize=address>> + ) +endfunction() add_library(simsycl include/sycl/sycl.hpp @@ -46,20 +60,12 @@ add_library(simsycl src/simsycl/dummy.cc ) target_link_libraries(simsycl Boost::context) - target_include_directories(simsycl PUBLIC include) -set_target_properties(simsycl PROPERTIES CXX_STANDARD 20) -set_target_properties(simsycl PROPERTIES CXX_STANDARD_REQUIRED ON) -target_compile_options(simsycl PRIVATE -Wall -Wextra -Wpedantic) -target_compile_options(simsycl PRIVATE -fsanitize=address) -target_link_options(simsycl PRIVATE -fsanitize=address) +set_simsycl_target_options(simsycl) add_executable(main src/test/main.cc) target_link_libraries(main simsycl) -set_target_properties(main PROPERTIES CXX_STANDARD 20) -set_target_properties(main PROPERTIES CXX_STANDARD_REQUIRED ON) -target_compile_options(main PRIVATE -Wall -Wextra -Wpedantic) -target_compile_options(main PRIVATE -fsanitize=address) -target_link_options(main PRIVATE -fsanitize=address) +set_simsycl_target_options(main) +enable_testing() add_subdirectory(test) diff --git a/README.md b/README.md index 6bfd900..db209ed 100644 --- a/README.md +++ b/README.md @@ -3,4 +3,5 @@ # Acknowlegments - Fabian Knorr +- Peter Thoman - Luigi Crisci \ No newline at end of file diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt index 3cbf22d..9fc9b3b 100644 --- a/test/CMakeLists.txt +++ b/test/CMakeLists.txt @@ -9,11 +9,10 @@ FetchContent_Declare( FetchContent_MakeAvailable(Catch2) add_executable(tests group_op_tests.cc) - -set_target_properties(tests PROPERTIES CXX_STANDARD 20) -set_target_properties(tests PROPERTIES CXX_STANDARD_REQUIRED ON) -target_compile_options(tests PRIVATE -Wall -Wextra -Wpedantic) -target_compile_options(tests PRIVATE -fsanitize=address) - target_link_libraries(tests PRIVATE Catch2::Catch2WithMain simsycl) -target_link_options(tests PRIVATE -fsanitize=address) +set_simsycl_target_options(tests) + +list(APPEND CMAKE_MODULE_PATH ${catch2_SOURCE_DIR}/extras) +include(CTest) +include(Catch) +catch_discover_tests(tests)