11language : cpp
2- dist : trusty
3- sudo : false
42matrix :
53 include :
64 # This config does a few things:
@@ -11,14 +9,14 @@ matrix:
119 # also tests the automatic discovery functions in CMake (Python version, C++ standard).
1210 - os : linux
1311 dist : xenial # Necessary to run doxygen 1.8.15
14- env : STYLE DOCS PIP
12+ name : Style, docs, and pip
1513 cache : false
1614 before_install :
1715 - pyenv global $(pyenv whence 2to3) # activate all python versions
1816 - PY_CMD=python3
1917 - $PY_CMD -m pip install --user --upgrade pip wheel setuptools
20- install :
21- - $PY_CMD -m pip install --user --upgrade sphinx sphinx_rtd_theme breathe flake8 pep8-naming pytest
18+ install : # Breathe does not yet support Sphinx 2
19+ - $PY_CMD -m pip install --user --upgrade " sphinx<2" sphinx_rtd_theme breathe flake8 pep8-naming pytest
2220 - curl -fsSL https://sourceforge.net/projects/doxygen/files/rel-1.8.15/doxygen-1.8.15.linux.bin.tar.gz/download | tar xz
2321 - export PATH="$PWD/doxygen-1.8.15/bin:$PATH"
2422 script :
@@ -33,62 +31,119 @@ matrix:
3331 diff -rq $installed ./include/pybind11
3432 - |
3533 # Barebones build
36- cmake -DCMAKE_BUILD_TYPE=Debug -DPYBIND11_WERROR=ON -DDOWNLOAD_CATCH=ON -DPYTHON_EXECUTABLE=$(which $PY_CMD)
34+ cmake -DCMAKE_BUILD_TYPE=Debug -DPYBIND11_WERROR=ON -DDOWNLOAD_CATCH=ON -DPYTHON_EXECUTABLE=$(which $PY_CMD) .
3735 make pytest -j 2
3836 make cpptest -j 2
3937 # The following are regular test configurations, including optional dependencies.
4038 # With regard to each other they differ in Python version, C++ standard and compiler.
4139 - os : linux
40+ dist : trusty
41+ name : Python 2.7, c++11, gcc 4.8
4242 env : PYTHON=2.7 CPP=11 GCC=4.8
4343 addons :
4444 apt :
45- packages : [cmake=2.\*, cmake-data=2.\*]
45+ packages :
46+ - cmake=2.\*
47+ - cmake-data=2.\*
4648 - os : linux
49+ dist : trusty
50+ name : Python 3.6, c++11, gcc 4.8
4751 env : PYTHON=3.6 CPP=11 GCC=4.8
4852 addons :
4953 apt :
50- sources : [deadsnakes]
51- packages : [python3.6-dev python3.6-venv, cmake=2.\*, cmake-data=2.\*]
52- - sudo : true
53- services : docker
54+ sources :
55+ - deadsnakes
56+ packages :
57+ - python3.6-dev
58+ - python3.6-venv
59+ - cmake=2.\*
60+ - cmake-data=2.\*
61+ - os : linux
62+ dist : trusty
5463 env : PYTHON=2.7 CPP=14 GCC=6 CMAKE=1
55- - sudo : true
56- services : docker
57- env : PYTHON=3.5 CPP=14 GCC=6 DEBUG=1
58- - sudo : true
64+ name : Python 2.7, c++14, gcc 4.8, CMake test
65+ addons :
66+ apt :
67+ sources :
68+ - ubuntu-toolchain-r-test
69+ packages :
70+ - g++-6
71+ - os : linux
72+ dist : trusty
73+ name : Python 3.5, c++14, gcc 6, Debug build
74+ # N.B. `ensurepip` could be installed transitively by `python3.5-venv`, but
75+ # seems to have apt conflicts (at least for Trusty). Use Docker instead.
5976 services : docker
77+ env : DOCKER=debian:stretch PYTHON=3.5 CPP=14 GCC=6 DEBUG=1
78+ - os : linux
79+ dist : xenial
6080 env : PYTHON=3.6 CPP=17 GCC=7
81+ name : Python 3.6, c++17, gcc 7
82+ addons :
83+ apt :
84+ sources :
85+ - deadsnakes
86+ - ubuntu-toolchain-r-test
87+ packages :
88+ - g++-7
89+ - python3.6-dev
90+ - python3.6-venv
6191 - os : linux
62- env : PYTHON=3.6 CPP=17 CLANG=5.0
92+ dist : xenial
93+ env : PYTHON=3.6 CPP=17 CLANG=7
94+ name : Python 3.6, c++17, Clang 7
6395 addons :
6496 apt :
65- sources : [deadsnakes, llvm-toolchain-trusty-5.0, ubuntu-toolchain-r-test]
66- packages : [python3.6-dev python3.6-venv clang-5.0 llvm-5.0-dev, lld-5.0]
97+ sources :
98+ - deadsnakes
99+ - llvm-toolchain-xenial-7
100+ packages :
101+ - python3.6-dev
102+ - python3.6-venv
103+ - clang-7
104+ - libclang-7-dev
105+ - llvm-7-dev
106+ - lld-7
107+ - libc++-7-dev
108+ - libc++abi-7-dev # Why is this necessary???
67109 - os : osx
110+ name : Python 2.7, c++14, AppleClang 7.3, CMake test
68111 osx_image : xcode7.3
69112 env : PYTHON=2.7 CPP=14 CLANG CMAKE=1
70113 - os : osx
114+ name : Python 3.7, c++14, AppleClang 9, Debug build
71115 osx_image : xcode9
72116 env : PYTHON=3.7 CPP=14 CLANG DEBUG=1
73117 # Test a PyPy 2.7 build
74118 - os : linux
119+ dist : trusty
75120 env : PYPY=5.8 PYTHON=2.7 CPP=11 GCC=4.8
121+ name : PyPy 5.8, Python 2.7, c++11, gcc 4.8
76122 addons :
77123 apt :
78- packages : [libblas-dev, liblapack-dev, gfortran]
124+ packages :
125+ - libblas-dev
126+ - liblapack-dev
127+ - gfortran
79128 # Build in 32-bit mode and tests against the CMake-installed version
80- - sudo : true
129+ - os : linux
130+ dist : trusty
81131 services : docker
82- env : ARCH=i386 PYTHON=3.5 CPP=14 GCC=6 INSTALL=1
132+ env : DOCKER=i386/debian:stretch PYTHON=3.5 CPP=14 GCC=6 INSTALL=1
133+ name : Python 3.4, c++14, gcc 6, 32-bit
83134 script :
84135 - |
85- $SCRIPT_RUN_PREFIX sh -c "set -e
86- cmake ${CMAKE_EXTRA_ARGS} -DPYBIND11_INSTALL=1 -DPYBIND11_TEST=0
87- make install
88- cp -a tests /pybind11-tests
89- mkdir /build-tests && cd /build-tests
90- cmake ../pybind11-tests ${CMAKE_EXTRA_ARGS} -DPYBIND11_WERROR=ON
91- make pytest -j 2"
136+ # Consolidated 32-bit Docker Build + Install
137+ set -ex
138+ $SCRIPT_RUN_PREFIX sh -c "
139+ set -ex
140+ cmake ${CMAKE_EXTRA_ARGS} -DPYBIND11_INSTALL=1 -DPYBIND11_TEST=0 .
141+ make install
142+ cp -a tests /pybind11-tests
143+ mkdir /build-tests && cd /build-tests
144+ cmake ../pybind11-tests ${CMAKE_EXTRA_ARGS} -DPYBIND11_WERROR=ON
145+ make pytest -j 2"
146+ set +ex
92147cache :
93148 directories :
94149 - $HOME/.local/bin
@@ -98,6 +153,7 @@ cache:
98153before_install :
99154- |
100155 # Configure build variables
156+ set -ex
101157 if [ "$TRAVIS_OS_NAME" = "linux" ]; then
102158 if [ -n "$CLANG" ]; then
103159 export CXX=clang++-$CLANG CC=clang-$CLANG
@@ -108,18 +164,16 @@ before_install:
108164 fi
109165 export CXX=g++-$GCC CC=gcc-$GCC
110166 fi
111- if [ "$GCC" = "6" ]; then DOCKER=${ARCH:+$ARCH/}debian:stretch
112- elif [ "$GCC" = "7" ]; then DOCKER=debian:buster EXTRA_PACKAGES+=" catch python3-distutils" DOWNLOAD_CATCH=OFF
113- fi
114167 elif [ "$TRAVIS_OS_NAME" = "osx" ]; then
115168 export CXX=clang++ CC=clang;
116169 fi
117170 if [ -n "$CPP" ]; then CPP=-std=c++$CPP; fi
118171 if [ "${PYTHON:0:1}" = "3" ]; then PY=3; fi
119172 if [ -n "$DEBUG" ]; then CMAKE_EXTRA_ARGS+=" -DCMAKE_BUILD_TYPE=Debug"; fi
173+ set +ex
120174 - |
121175 # Initialize environment
122- set -e
176+ set -ex
123177 if [ -n "$DOCKER" ]; then
124178 docker pull $DOCKER
125179
@@ -148,13 +202,15 @@ before_install:
148202 if [ "$PY" = 3 ] || [ -n "$PYPY" ]; then
149203 $PY_CMD -m ensurepip --user
150204 fi
205+ $PY_CMD --version
151206 $PY_CMD -m pip install --user --upgrade pip wheel
152207 fi
153- set +e
208+ set +ex
154209install :
155210- |
156211 # Install dependencies
157- set -e
212+ set -ex
213+ cmake --version
158214 if [ -n "$DOCKER" ]; then
159215 if [ -n "$DEBUG" ]; then
160216 PY_DEBUG="python$PYTHON-dbg python$PY-scipy-dbg"
@@ -166,49 +222,59 @@ install:
166222 libeigen3-dev libboost-dev cmake make ${EXTRA_PACKAGES} && break; done"
167223 else
168224
169- if [ "$CLANG" = "5.0" ]; then
170- if ! [ -d ~/.local/include/c++/v1 ]; then
171- # Neither debian nor llvm provide a libc++ 5.0 deb; luckily it's fairly quick
172- # to build, install (and cache), so do it ourselves:
173- git clone --depth=1 https://github.com/llvm-mirror/llvm.git llvm-source
174- git clone https://github.com/llvm-mirror/libcxx.git llvm-source/projects/libcxx -b release_50
175- git clone https://github.com/llvm-mirror/libcxxabi.git llvm-source/projects/libcxxabi -b release_50
176- mkdir llvm-build && cd llvm-build
177- # Building llvm requires a newer cmake than is provided by the trusty container:
178- CMAKE_VER=cmake-3.8.0-Linux-x86_64
179- curl https://cmake.org/files/v3.8/$CMAKE_VER.tar.gz | tar xz
180- ./$CMAKE_VER/bin/cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=~/.local ../llvm-source
181- make -j2 install-cxxabi install-cxx
182- cp -a include/c++/v1/*cxxabi*.h ~/.local/include/c++/v1
183- cd ..
184- fi
185- export CXXFLAGS="-isystem $HOME/.local/include/c++/v1 -stdlib=libc++"
186- export LDFLAGS="-L$HOME/.local/lib -fuse-ld=lld-$CLANG"
187- export LD_LIBRARY_PATH="$HOME/.local/lib${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}"
188- if [ "$CPP" = "-std=c++17" ]; then CPP="-std=c++1z"; fi
225+ if [ "$CLANG" = "7" ]; then
226+ export CXXFLAGS="-stdlib=libc++"
189227 fi
190228
191229 export NPY_NUM_BUILD_JOBS=2
192230 echo "Installing pytest, numpy, scipy..."
193- ${PYPY:+travis_wait 30} $PY_CMD -m pip install --user --upgrade pytest numpy scipy \
194- ${PYPY:+--extra-index-url https://imaginary.ca/trusty-pypi}
231+ local PIP_CMD=""
232+ if [ -n $PYPY ]; then
233+ # For expediency, install only versions that are available on the extra index.
234+ travis_wait 30 \
235+ $PY_CMD -m pip install --user --upgrade --extra-index-url https://imaginary.ca/trusty-pypi \
236+ pytest numpy==1.15.4 scipy==1.2.0
237+ else
238+ $PY_CMD -m pip install --user --upgrade pytest numpy scipy
239+ fi
195240 echo "done."
196241
197242 mkdir eigen
198243 curl -fsSL https://bitbucket.org/eigen/eigen/get/3.3.4.tar.bz2 | \
199244 tar --extract -j --directory=eigen --strip-components=1
200245 export CMAKE_INCLUDE_PATH="${CMAKE_INCLUDE_PATH:+$CMAKE_INCLUDE_PATH:}$PWD/eigen"
201246 fi
202- set +e
247+ set +ex
203248script :
204- - $SCRIPT_RUN_PREFIX cmake ${CMAKE_EXTRA_ARGS}
205- -DPYBIND11_PYTHON_VERSION=$PYTHON
206- -DPYBIND11_CPP_STANDARD=$CPP
207- -DPYBIND11_WERROR=${WERROR:-ON}
208- -DDOWNLOAD_CATCH=${DOWNLOAD_CATCH:-ON}
209- - $SCRIPT_RUN_PREFIX make pytest -j 2
210- - $SCRIPT_RUN_PREFIX make cpptest -j 2
211- - if [ -n "$CMAKE" ]; then $SCRIPT_RUN_PREFIX make test_cmake_build; fi
249+ - |
250+ # CMake Configuration
251+ set -ex
252+ $SCRIPT_RUN_PREFIX cmake ${CMAKE_EXTRA_ARGS} \
253+ -DPYBIND11_PYTHON_VERSION=$PYTHON \
254+ -DPYBIND11_CPP_STANDARD=$CPP \
255+ -DPYBIND11_WERROR=${WERROR:-ON} \
256+ -DDOWNLOAD_CATCH=${DOWNLOAD_CATCH:-ON} \
257+ .
258+ set +ex
259+ - |
260+ # pytest
261+ set -ex
262+ $SCRIPT_RUN_PREFIX make pytest -j 2 VERBOSE=1
263+ set +ex
264+ - |
265+ # cpptest
266+ set -ex
267+ $SCRIPT_RUN_PREFIX make cpptest -j 2
268+ set +ex
269+ - |
270+ # CMake Build Interface
271+ set -ex
272+ if [ -n "$CMAKE" ]; then $SCRIPT_RUN_PREFIX make test_cmake_build; fi
273+ set +ex
212274after_failure : cat tests/test_cmake_build/*.log*
213275after_script :
214- - if [ -n "$DOCKER" ]; then docker stop "$containerid"; docker rm "$containerid"; fi
276+ - |
277+ # Cleanup (Docker)
278+ set -ex
279+ if [ -n "$DOCKER" ]; then docker stop "$containerid"; docker rm "$containerid"; fi
280+ set +ex
0 commit comments