diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 1df5176d..aaabaa71 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -391,15 +391,22 @@ jobs: [ -d "$cmake_test_folder" ] || cmake_test_folder="$BOOST_ROOT/libs/$SELF/test/cmake_subdir_test" cd "$cmake_test_folder" mkdir __build_cmake_subdir_test__ && cd __build_cmake_subdir_test__ - cmake -G "${{matrix.generator}}" -DBOOST_CI_INSTALL_TEST=OFF -DCMAKE_BUILD_TYPE=${{matrix.build_type}} -DBUILD_SHARED_LIBS=${{matrix.build_shared}} .. + extra_args="" + # On Windows DLLs need to be either in PATH or in the same folder as the executable, so put all binaries into the same folder + if [[ "$RUNNER_OS" == "Windows" ]] && [[ "${{matrix.build_shared}}" == "ON" ]]; then + extra_args="-DCMAKE_RUNTIME_OUTPUT_DIRECTORY='$(pwd)/bin'" + fi + cmake -G "${{matrix.generator}}" -DBOOST_CI_INSTALL_TEST=OFF -DCMAKE_BUILD_TYPE=${{matrix.build_type}} -DBUILD_SHARED_LIBS=${{matrix.build_shared}} $extra_args .. cmake --build . --config ${{matrix.build_type}} -j$B2_JOBS ctest --output-on-failure --build-config ${{matrix.build_type}} - name: Install Library run: | + BCM_INSTALL_PATH=/tmp/boost_install + echo "BCM_INSTALL_PATH=$BCM_INSTALL_PATH" >> $GITHUB_ENV cd "$BOOST_ROOT" mkdir __build_cmake_install_test__ && cd __build_cmake_install_test__ - cmake -G "${{matrix.generator}}" -DCMAKE_BUILD_TYPE=${{matrix.build_type}} -DBOOST_INCLUDE_LIBRARIES=$SELF -DBUILD_SHARED_LIBS=${{matrix.build_shared}} -DCMAKE_INSTALL_PREFIX=~/.local -DBoost_VERBOSE=ON -DBoost_DEBUG=ON .. + cmake -G "${{matrix.generator}}" -DCMAKE_BUILD_TYPE=${{matrix.build_type}} -DBOOST_INCLUDE_LIBRARIES=$SELF -DBUILD_SHARED_LIBS=${{matrix.build_shared}} -DCMAKE_INSTALL_PREFIX="$BCM_INSTALL_PATH" -DBoost_VERBOSE=ON -DBoost_DEBUG=ON .. cmake --build . --target install --config ${{matrix.build_type}} -j$B2_JOBS - name: Run CMake install tests run: | @@ -407,6 +414,14 @@ jobs: [ -d "$cmake_test_folder" ] || cmake_test_folder="$BOOST_ROOT/libs/$SELF/test/cmake_install_test" cd "$cmake_test_folder" mkdir __build_cmake_install_test__ && cd __build_cmake_install_test__ - cmake -G "${{matrix.generator}}" -DBOOST_CI_INSTALL_TEST=ON -DCMAKE_BUILD_TYPE=${{matrix.build_type}} -DBUILD_SHARED_LIBS=${{matrix.build_shared}} -DCMAKE_PREFIX_PATH=~/.local .. + cmake -G "${{matrix.generator}}" -DBOOST_CI_INSTALL_TEST=ON -DCMAKE_BUILD_TYPE=${{matrix.build_type}} -DBUILD_SHARED_LIBS=${{matrix.build_shared}} -DCMAKE_PREFIX_PATH="$BCM_INSTALL_PATH" .. cmake --build . --config ${{matrix.build_type}} -j$B2_JOBS + if [[ "${{matrix.build_shared}}" == "ON" ]]; then + # Make sure shared libs can be found at runtime + if [ "$RUNNER_OS" == "Windows" ]; then + export PATH="$BCM_INSTALL_PATH/bin:$PATH" + else + export LD_LIBRARY_PATH="$BCM_INSTALL_PATH/lib:$LD_LIBRARY_PATH" + fi + fi ctest --output-on-failure --build-config ${{matrix.build_type}} diff --git a/CMakeLists.txt b/CMakeLists.txt index 2c1630d4..09f5ec45 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -7,16 +7,22 @@ cmake_minimum_required(VERSION 3.5...3.16) project(boost_ci VERSION "${BOOST_SUPERPROJECT_VERSION}" LANGUAGES CXX) -add_library(boost_boost_ci INTERFACE) +add_library(boost_boost_ci src/boost_ci.cpp) add_library(Boost::boost_ci ALIAS boost_boost_ci) -target_include_directories(boost_boost_ci INTERFACE include) +target_include_directories(boost_boost_ci PUBLIC include) target_link_libraries(boost_boost_ci - INTERFACE + PUBLIC Boost::config + PRIVATE + Boost::atomic ) +if(BUILD_SHARED_LIBS) + target_compile_definitions(boost_boost_ci PUBLIC BOOST_BOOST_CI_DYN_LINK) +endif() + if(BUILD_TESTING) add_subdirectory(test) endif() diff --git a/build/Jamfile.v2 b/build/Jamfile.v2 new file mode 100644 index 00000000..40239514 --- /dev/null +++ b/build/Jamfile.v2 @@ -0,0 +1,25 @@ +# Boost CI Test Build Jamfile + +# Copyright (c) 2022 Alexander Grund +# +# Distributed under the Boost Software License, Version 1.0. +# (See accompanying file LICENSE or www.boost.org/LICENSE_1_0.txt) + +import configure ; + +local requirements = + shared:BOOST_BOOST_CI_DYN_LINK=1 + /boost/atomic//boost_atomic + ; + +project boost/ci + : source-location ../src + : requirements $(requirements) + : usage-requirements $(requirements) + ; + +lib boost_ci + : boost_ci.cpp + ; + +boost-install boost_ci ; diff --git a/include/boost/boost-ci/boost_ci.hpp b/include/boost/boost-ci/boost_ci.hpp index b2d5f407..b5817fbb 100644 --- a/include/boost/boost-ci/boost_ci.hpp +++ b/include/boost/boost-ci/boost_ci.hpp @@ -11,6 +11,17 @@ #include #endif +// This define is usually set in boost//config.hpp +#if defined(BOOST_ALL_DYN_LINK) || defined(BOOST_BOOST_CI_DYN_LINK) +#ifdef BOOST_BOOST_CI_SOURCE +#define BOOST_BOOST_CI_DECL BOOST_SYMBOL_EXPORT +#else +#define BOOST_BOOST_CI_DECL BOOST_SYMBOL_IMPORT +#endif +#else +#define BOOST_BOOST_CI_DECL +#endif + namespace boost { namespace boost_ci @@ -21,25 +32,7 @@ namespace boost #define MSVC_VALUE false #endif - // Some function to test - BOOST_NOINLINE int get_answer(const bool isMsvc = MSVC_VALUE) - { - int answer; - // Specifically crafted condition to check for coverage from MSVC and non MSVC builds - if(isMsvc) - { - answer = 21; - } else - { - answer = 42; - } -#ifdef BOOST_NO_CXX11_SMART_PTR - return answer; -#else - // Just use some stdlib feature combined with a Boost.Config feature as demonstration - auto ptr = std::unique_ptr(new int(answer)); - return *ptr; -#endif - } + // Some function to test. Returns 41 for true, 42 otherwise + BOOST_BOOST_CI_DECL int get_answer(bool isMsvc = MSVC_VALUE); } } diff --git a/src/boost_ci.cpp b/src/boost_ci.cpp new file mode 100644 index 00000000..1c3a43cf --- /dev/null +++ b/src/boost_ci.cpp @@ -0,0 +1,47 @@ +// +// Copyright (c) 2022 Alexander Grund +// +// Use, modification and distribution is subject to the Boost Software License, +// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at +// http://www.boost.org/LICENSE_1_0.txt) + +#define BOOST_BOOST_CI_SOURCE + +#include +// Just some dependency on another Boost library +#include + +// Some simple struct big enough so that the atomic is forced to use a lock +// forcing it to call into the library +struct X +{ + double x, y, z; + explicit X(int value = 0): x(value), y(value), z(value) {} +}; + +namespace boost +{ + namespace boost_ci + { + // Some function to test + int get_answer(const bool isMsvc) + { + boost::atomic answer; + // Specifically crafted condition to check for coverage from MSVC and non MSVC builds + if(isMsvc) + { + answer = X(21); + } else + { + answer = X(42); + } +#ifdef BOOST_NO_CXX11_SMART_PTR + return answer.load().x; +#else + // Just use some stdlib feature combined with a Boost.Config feature as demonstration + auto ptr = std::unique_ptr(new int(answer.load().x)); + return *ptr; +#endif + } + } +} diff --git a/test/Jamfile b/test/Jamfile index fdbbeaba..db979644 100644 --- a/test/Jamfile +++ b/test/Jamfile @@ -8,9 +8,8 @@ import os ; import testing ; -project boost/ci/test - : requirements - . +project : requirements + /boost/ci//boost_ci ; local B2_ADDRESS_MODEL = [ os.environ B2_ADDRESS_MODEL ] ; diff --git a/test/cmake_test/CMakeLists.txt b/test/cmake_test/CMakeLists.txt index 01efe823..429ada16 100644 --- a/test/cmake_test/CMakeLists.txt +++ b/test/cmake_test/CMakeLists.txt @@ -11,8 +11,27 @@ project(cmake_subdir_test LANGUAGES CXX) if(BOOST_CI_INSTALL_TEST) find_package(boost_boost_ci REQUIRED) else() - add_subdirectory(../.. boostorg/ci) - add_subdirectory(../../../config boostorg/config) + add_subdirectory(../.. boostorg/boost-ci) + + set(deps + # Primary dependencies + atomic + config + core + # Secondary dependencies + align + assert + predef + preprocessor + static_assert + throw_exception + type_traits + winapi + ) + + foreach(dep IN LISTS deps) + add_subdirectory(../../../${dep} boostorg/${dep}) + endforeach() endif() add_executable(main main.cpp)