Update workflow with windows + clang

This commit is contained in:
Ion Gaztañaga
2021-12-28 18:31:01 +01:00
parent 3f76f9fdf7
commit f2b2fbd7f8

View File

@@ -1,4 +1,4 @@
name: GitHub Actions CI name: CI
on: on:
pull_request: pull_request:
@@ -6,10 +6,10 @@ on:
branches: branches:
- master - master
- develop - develop
- githubactions*
- feature/** - feature/**
- fix/**
- pr/** env:
UBSAN_OPTIONS: print_stacktrace=1
jobs: jobs:
posix: posix:
@@ -17,200 +17,182 @@ jobs:
fail-fast: false fail-fast: false
matrix: matrix:
include: include:
- name: "TOOLSET=gcc CXXSTD=03,11 Job 0" - toolset: gcc-4.8
buildtype: "boost"
packages: ""
packages_to_remove: ""
os: "ubuntu-20.04"
container: "ubuntu:16.04"
cxx: "g++"
sources: ""
llvm_os: ""
llvm_ver: ""
toolset: "gcc"
cxxstd: "03,11" cxxstd: "03,11"
- name: "TOOLSET=clang CXXSTD=03,11,14,1z Job 1" os: ubuntu-18.04
buildtype: "boost" install: g++-4.8
packages: "libstdc++-4.9-dev clang" - toolset: gcc-5
packages_to_remove: ""
os: "ubuntu-20.04"
container: "ubuntu:16.04"
cxx: "clang++"
sources: ""
llvm_os: ""
llvm_ver: ""
toolset: "clang"
cxxstd: "03,11,14,1z" cxxstd: "03,11,14,1z"
os: ubuntu-18.04
install: g++-5
- toolset: gcc-6
cxxstd: "03,11,14,1z"
os: ubuntu-18.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
install: g++-8
- toolset: gcc-9
cxxstd: "03,11,14,17,2a"
os: ubuntu-20.04
- toolset: gcc-10
cxxstd: "03,11,14,17,2a"
os: ubuntu-20.04
install: g++-10
- toolset: gcc-11
cxxstd: "03,11,14,17,2a"
os: ubuntu-20.04
install: g++-11
- toolset: clang
compiler: clang++-3.9
cxxstd: "03,11,14"
os: ubuntu-18.04
install: clang-3.9
- toolset: clang
compiler: clang++-4.0
cxxstd: "03,11,14"
os: ubuntu-18.04
install: clang-4.0
- toolset: clang
compiler: clang++-5.0
cxxstd: "03,11,14,1z"
os: ubuntu-18.04
install: clang-5.0
- toolset: clang
compiler: clang++-6.0
cxxstd: "03,11,14,17"
os: ubuntu-18.04
install: clang-6.0
- toolset: clang
compiler: clang++-7
cxxstd: "03,11,14,17"
os: ubuntu-18.04
install: clang-7
- toolset: clang
compiler: clang++-8
cxxstd: "03,11,14,17"
os: ubuntu-20.04
install: clang-8
- toolset: clang
compiler: clang++-9
cxxstd: "03,11,14,17,2a"
os: ubuntu-20.04
install: clang-9
- toolset: clang
compiler: clang++-10
cxxstd: "03,11,14,17,2a"
os: ubuntu-20.04
install: clang-10
- toolset: clang
compiler: clang++-11
cxxstd: "03,11,14,17,2a"
os: ubuntu-20.04
install: clang-11
- toolset: clang
compiler: clang++-12
cxxstd: "03,11,14,17,2a"
os: ubuntu-20.04
install: clang-12
- toolset: clang
cxxstd: "03,11,14,17,2a"
os: macos-10.15
runs-on: ${{ matrix.os }} runs-on: ${{matrix.os}}
container: ${{ matrix.container }}
steps: steps:
- name: Check if running in container
if: matrix.container != ''
run: echo "GHA_CONTAINER=${{ matrix.container }}" >> $GITHUB_ENV
- name: If running in container, upgrade packages
if: matrix.container != ''
run: |
apt-get -o Acquire::Retries=3 update && DEBIAN_FRONTEND=noninteractive apt-get -y install tzdata && apt-get -o Acquire::Retries=3 install -y sudo software-properties-common wget curl apt-transport-https make apt-file sudo unzip libssl-dev build-essential autotools-dev autoconf automake g++ libc++-helpers python ruby cpio gcc-multilib g++-multilib pkgconf python3 ccache libpython-dev
sudo apt-add-repository ppa:git-core/ppa
sudo apt-get -o Acquire::Retries=3 update && apt-get -o Acquire::Retries=3 -y install git
python_version=$(python3 -c 'import sys; print("{0.major}.{0.minor}".format(sys.version_info))')
sudo wget https://bootstrap.pypa.io/pip/$python_version/get-pip.py
sudo python3 get-pip.py
sudo /usr/local/bin/pip install cmake
- uses: actions/checkout@v2 - uses: actions/checkout@v2
- name: linux - name: Install packages
shell: bash if: matrix.install
env: run: sudo apt install ${{matrix.install}}
CXX: ${{ matrix.cxx }}
SOURCES: ${{ matrix.sources }} - name: Setup Boost
LLVM_OS: ${{ matrix.llvm_os }}
LLVM_VER: ${{ matrix.llvm_ver }}
PACKAGES: ${{ matrix.packages }}
PACKAGES_TO_REMOVE: ${{ matrix.packages_to_remove }}
JOB_BUILDTYPE: ${{ matrix.buildtype }}
TOOLSET: ${{ matrix.toolset }}
CXXSTD: ${{ matrix.cxxstd }}
TRAVIS_BRANCH: ${{ github.base_ref }}
TRAVIS_OS_NAME: "linux"
run: | run: |
echo '==================================> SETUP' echo GITHUB_REPOSITORY: $GITHUB_REPOSITORY
echo '==================================> PACKAGES' LIBRARY=${GITHUB_REPOSITORY#*/}
set -e echo LIBRARY: $LIBRARY
if [ -n "$PACKAGES_TO_REMOVE" ]; then sudo apt-get purge -y $PACKAGES_TO_REMOVE; fi echo "LIBRARY=$LIBRARY" >> $GITHUB_ENV
echo ">>>>> APT: REPO.." echo GITHUB_BASE_REF: $GITHUB_BASE_REF
for i in {1..3}; do sudo -E apt-add-repository -y "ppa:ubuntu-toolchain-r/test" && break || sleep 2; done echo GITHUB_REF: $GITHUB_REF
REF=${GITHUB_BASE_REF:-$GITHUB_REF}
if test -n "${LLVM_OS}" ; then REF=${REF#refs/heads/}
wget -O - https://apt.llvm.org/llvm-snapshot.gpg.key | sudo apt-key add - echo REF: $REF
if test -n "${LLVM_VER}" ; then BOOST_BRANCH=develop && [ "$REF" == "master" ] && BOOST_BRANCH=master || true
sudo -E apt-add-repository "deb http://apt.llvm.org/${LLVM_OS}/ llvm-toolchain-${LLVM_OS}-${LLVM_VER} main" echo BOOST_BRANCH: $BOOST_BRANCH
else
# Snapshot (i.e. trunk) build of clang
sudo -E apt-add-repository "deb http://apt.llvm.org/${LLVM_OS}/ llvm-toolchain-${LLVM_OS} main"
fi
fi
echo ">>>>> APT: UPDATE.."
sudo -E apt-get -o Acquire::Retries=3 update
if test -n "${SOURCES}" ; then
echo ">>>>> APT: INSTALL SOURCES.."
for SOURCE in $SOURCES; do
sudo -E apt-add-repository ppa:$SOURCE
done
fi
echo ">>>>> APT: INSTALL ${PACKAGES}.."
sudo -E DEBIAN_FRONTEND=noninteractive apt-get -o Acquire::Retries=3 -y --no-install-suggests --no-install-recommends install ${PACKAGES}
echo '==================================> INSTALL AND COMPILE'
set -e
export TRAVIS_BUILD_DIR=$(pwd)
export TRAVIS_BRANCH=${TRAVIS_BRANCH:-$(echo $GITHUB_REF | awk 'BEGIN { FS = "/" } ; { print $3 }')}
export VCS_COMMIT_ID=$GITHUB_SHA
export GIT_COMMIT=$GITHUB_SHA
export REPO_NAME=$(basename $GITHUB_REPOSITORY)
export USER=$(whoami)
export CC=${CC:-gcc}
export PATH=~/.local/bin:/usr/local/bin:$PATH
if [ "$JOB_BUILDTYPE" == "boost" ]; then
echo '==================================> INSTALL'
BOOST_BRANCH=develop && [ "$TRAVIS_BRANCH" == "master" ] && BOOST_BRANCH=master || true
cd .. cd ..
git clone -b $BOOST_BRANCH https://github.com/boostorg/boost.git boost-root git clone -b $BOOST_BRANCH --depth 1 https://github.com/boostorg/boost.git boost-root
cd boost-root cd boost-root
git submodule update --init tools/build cp -r $GITHUB_WORKSPACE/* libs/$LIBRARY
git submodule update --init libs/config
git submodule update --init tools/boostdep git submodule update --init tools/boostdep
cp -r $TRAVIS_BUILD_DIR/* libs/container python tools/boostdep/depinst/depinst.py --git_args "--jobs 3" $LIBRARY
python tools/boostdep/depinst/depinst.py container
./bootstrap.sh ./bootstrap.sh
./b2 headers ./b2 -d0 headers
echo '==================================> SCRIPT' - name: Create user-config.jam
if: matrix.compiler
run: |
echo "using ${{matrix.toolset}} : : ${{matrix.compiler}} ;" > ~/user-config.jam
./b2 libs/container/test toolset=$TOOLSET cxxstd=$CXXSTD - name: Run tests
run: |
cd ../boost-root
./b2 -j3 libs/$LIBRARY/test toolset=${{matrix.toolset}} cxxstd=${{matrix.cxxstd}} variant=debug,release
fi windows:
osx:
strategy: strategy:
fail-fast: false fail-fast: false
matrix: matrix:
include: include:
- name: "TOOLSET=clang CXXSTD=03,11,14,1z Job 2" - toolset: msvc-14.1
buildtype: "boost" cxxstd: "14,17,latest"
packages: "" addrmd: 32,64
os: "macos-10.15" os: windows-2016
cxx: "clang++" - toolset: msvc-14.2
sources: "" cxxstd: "14,17,latest"
llvm_os: "" addrmd: 32,64
llvm_ver: "" os: windows-2019
xcode_version: 11.7 - toolset: msvc-14.3
toolset: "clang" cxxstd: "14,17,latest"
cxxstd: "03,11,14,1z" addrmd: 32,64
os: windows-2022
- toolset: gcc
cxxstd: "03,11,14,17,2a"
addrmd: 64
os: windows-2019
runs-on: ${{ matrix.os }} runs-on: ${{matrix.os}}
steps: steps:
- uses: actions/checkout@v2 - uses: actions/checkout@v2
- name: Set DEVELOPER_DIR - name: Setup Boost
if: matrix.xcode_version != '' shell: cmd
run: echo "DEVELOPER_DIR=/Applications/Xcode_${{ matrix.xcode_version }}.app/Contents/Developer" >> $GITHUB_ENV
- name: Test DEVELOPER_DIR
run: echo $DEVELOPER_DIR
- name: "osx"
shell: bash
env:
CXX: ${{ matrix.cxx }}
SOURCES: ${{ matrix.sources }}
LLVM_OS: ${{ matrix.llvm_os }}
LLVM_VER: ${{ matrix.llvm_ver }}
PACKAGES: ${{ matrix.packages }}
JOB_BUILDTYPE: ${{ matrix.buildtype }}
TOOLSET: ${{ matrix.toolset }}
CXXSTD: ${{ matrix.cxxstd }}
TRAVIS_BRANCH: ${{ github.base_ref }}
TRAVIS_OS_NAME: "osx"
run: | run: |
echo '==================================> SETUP' echo GITHUB_REPOSITORY: %GITHUB_REPOSITORY%
set -e for /f %%i in ("%GITHUB_REPOSITORY%") do set LIBRARY=%%~nxi
sudo mv /Library/Developer/CommandLineTools /Library/Developer/CommandLineTools.bck echo LIBRARY: %LIBRARY%
echo '==================================> PACKAGES' echo LIBRARY=%LIBRARY%>>%GITHUB_ENV%
echo '==================================> INSTALL AND COMPILE' echo GITHUB_BASE_REF: %GITHUB_BASE_REF%
set -e echo GITHUB_REF: %GITHUB_REF%
export TRAVIS_BUILD_DIR=$(pwd) if "%GITHUB_BASE_REF%" == "" set GITHUB_BASE_REF=%GITHUB_REF%
export TRAVIS_BRANCH=${TRAVIS_BRANCH:-$(echo $GITHUB_REF | awk 'BEGIN { FS = "/" } ; { print $3 }')} set BOOST_BRANCH=develop
export VCS_COMMIT_ID=$GITHUB_SHA for /f %%i in ("%GITHUB_BASE_REF%") do if "%%~nxi" == "master" set BOOST_BRANCH=master
export GIT_COMMIT=$GITHUB_SHA echo BOOST_BRANCH: %BOOST_BRANCH%
export REPO_NAME=$(basename $GITHUB_REPOSITORY)
export USER=$(whoami)
export CC=${CC:-gcc}
export PATH=~/.local/bin:/usr/local/bin:$PATH
if [ "$JOB_BUILDTYPE" == "boost" ]; then
echo '==================================> INSTALL'
BOOST_BRANCH=develop && [ "$TRAVIS_BRANCH" == "master" ] && BOOST_BRANCH=master || true
cd .. cd ..
git clone -b $BOOST_BRANCH https://github.com/boostorg/boost.git boost-root git clone -b %BOOST_BRANCH% --depth 1 https://github.com/boostorg/boost.git boost-root
cd boost-root cd boost-root
git submodule update --init tools/build xcopy /s /e /q %GITHUB_WORKSPACE% libs\%LIBRARY%\
git submodule update --init libs/config
git submodule update --init tools/boostdep git submodule update --init tools/boostdep
cp -r $TRAVIS_BUILD_DIR/* libs/container python tools/boostdep/depinst/depinst.py --git_args "--jobs 3" %LIBRARY%
python tools/boostdep/depinst/depinst.py container cmd /c bootstrap
./bootstrap.sh b2 -d0 headers
./b2 headers
echo '==================================> SCRIPT' - name: Run tests
shell: cmd
./b2 libs/container/test toolset=$TOOLSET cxxstd=$CXXSTD run: |
cd ../boost-root
fi b2 -j3 libs/%LIBRARY%/test toolset=${{matrix.toolset}} cxxstd=${{matrix.cxxstd}} address-model=${{matrix.addrmd}} variant=debug,release