From a43d6569b8d9076c56ec9d497944419679128637 Mon Sep 17 00:00:00 2001 From: Peter Dimov Date: Fri, 20 Nov 2020 03:28:46 +0200 Subject: [PATCH] Squash-merge feature/gh-actions into develop (#15) * Add .github/workflows * Fix typo * GITHUB_BASE_REF is only for PRs * Compute BOOST_BRANCH * Split into lines; fix cd * Revert "Split into lines; fix cd" * Fix cd * We don't want fail-fast * Add os to matrix * Use bash on Windows * Split Windows setup * Quote if expressions * Install GCC if needed * sudo make me a sandwich * Use matrix.install for the apt package * Use GITHUB_BASE_REF on Windows as well * Use a LIBRARY environment variable * Rename ci.yml to posix.yml * Split ci.yml into posix.yml and windows.yml * Use cmd for Run tests * Remove ./, try clang-win * Remove clang-win, not present --- .github/workflows/posix.yml | 84 +++++++++++++++++++++++++++++++++++ .github/workflows/windows.yml | 51 +++++++++++++++++++++ 2 files changed, 135 insertions(+) create mode 100644 .github/workflows/posix.yml create mode 100644 .github/workflows/windows.yml diff --git a/.github/workflows/posix.yml b/.github/workflows/posix.yml new file mode 100644 index 0000000..f301f95 --- /dev/null +++ b/.github/workflows/posix.yml @@ -0,0 +1,84 @@ +name: POSIX + +on: + pull_request: + push: + branches: + - master + - develop + - feature/** + +env: + LIBRARY: assert + UBSAN_OPTIONS: print_stacktrace=1 + +jobs: + CI: + strategy: + fail-fast: false + matrix: + include: + - toolset: gcc-4.7 + cxxstd: "03,11" + os: ubuntu-16.04 + install: g++-4.7 + - toolset: gcc-4.8 + cxxstd: "03,11" + os: ubuntu-16.04 + install: g++-4.8 + - toolset: gcc-4.9 + cxxstd: "03,11" + os: ubuntu-16.04 + install: g++-4.9 + - toolset: gcc-5 + cxxstd: "03,11,14,1z" + os: ubuntu-16.04 + - toolset: gcc-6 + cxxstd: "03,11,14,1z" + os: ubuntu-16.04 + install: g++-6 + - toolset: gcc-7 + cxxstd: "03,11,14,17" + os: ubuntu-18.04 + - toolset: gcc-8 + cxxstd: "03,11,14,17,2a" + os: ubuntu-18.04 + - toolset: gcc-9 + cxxstd: "03,11,14,17,2a" + os: ubuntu-18.04 + - toolset: gcc-10 + cxxstd: "03,11,14,17,2a" + os: ubuntu-18.04 + - toolset: clang + cxxstd: "03,11,14,17,2a" + os: ubuntu-18.04 + - toolset: clang + cxxstd: "03,11,14,17,2a" + os: macos-10.15 + + runs-on: ${{matrix.os}} + + steps: + - uses: actions/checkout@v2 + + - name: Install packages + if: matrix.install + run: sudo apt install ${{matrix.install}} + + - name: Setup Boost + run: | + REF=${GITHUB_BASE_REF:-$GITHUB_REF} + BOOST_BRANCH=develop && [ "$REF" == "master" ] && BOOST_BRANCH=master || true + cd .. + git clone -b $BOOST_BRANCH --depth 1 https://github.com/boostorg/boost.git boost-root + cd boost-root + cp -r $GITHUB_WORKSPACE/* libs/$LIBRARY + git submodule update --init tools/boostdep + python tools/boostdep/depinst/depinst.py --git_args "--jobs 3" $LIBRARY + ./bootstrap.sh + ./b2 -d0 headers + + - name: Run tests + run: | + cd ../boost-root + ./b2 -j3 libs/$LIBRARY/test toolset=${{matrix.toolset}} cxxstd=${{matrix.cxxstd}} diff --git a/.github/workflows/windows.yml b/.github/workflows/windows.yml new file mode 100644 index 0000000..f3b7143 --- /dev/null +++ b/.github/workflows/windows.yml @@ -0,0 +1,51 @@ +name: Windows + +on: + pull_request: + push: + branches: + - master + - develop + - feature/** + +env: + LIBRARY: assert + +jobs: + CI: + strategy: + fail-fast: false + matrix: + include: + - toolset: msvc-14.1 + cxxstd: "14,17,latest" + os: windows-2016 + - toolset: msvc-14.2 + cxxstd: "14,17,latest" + os: windows-2019 + + runs-on: ${{matrix.os}} + + steps: + - uses: actions/checkout@v2 + + - name: Setup Boost + shell: cmd + run: | + if "%GITHUB_BASE_REF%" == "" set GITHUB_BASE_REF=%GITHUB_REF% + set BOOST_BRANCH=develop + if "%GITHUB_BASE_REF%" == "master" set BOOST_BRANCH=master + cd .. + git clone -b %BOOST_BRANCH% --depth 1 https://github.com/boostorg/boost.git boost-root + cd boost-root + xcopy /s /e /q %GITHUB_WORKSPACE% libs\%LIBRARY%\ + git submodule update --init tools/boostdep + python tools/boostdep/depinst/depinst.py --git_args "--jobs 3" %LIBRARY% + cmd /c bootstrap + b2 -d0 headers + + - name: Run tests + shell: cmd + run: | + cd ../boost-root + b2 -j3 libs/%LIBRARY%/test toolset=${{matrix.toolset}} cxxstd=${{matrix.cxxstd}}