Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 1 | language: c |
| 2 | dist: trusty |
| 3 | sudo: false |
| 4 | group: beta |
| 5 | |
Christian Heimes | 8adc73c | 2017-09-05 01:48:54 +0200 | [diff] [blame] | 6 | # To cache doc-building dependencies and C compiler output. |
| 7 | cache: |
| 8 | - pip |
| 9 | - ccache |
Christian Heimes | ced9cb5 | 2018-01-16 21:02:26 +0100 | [diff] [blame] | 10 | - directories: |
| 11 | - $HOME/multissl |
| 12 | |
| 13 | env: |
| 14 | global: |
| 15 | - OPENSSL=1.1.0g |
| 16 | - OPENSSL_DIR="$HOME/multissl/openssl/${OPENSSL}" |
| 17 | - PATH="${OPENSSL_DIR}/bin:$PATH" |
INADA Naoki | 8ff5356 | 2018-02-10 20:35:17 +0900 | [diff] [blame] | 18 | # Use -O3 because we don't use debugger on Travis-CI |
| 19 | - CFLAGS="-I${OPENSSL_DIR}/include -O3" |
Christian Heimes | ced9cb5 | 2018-01-16 21:02:26 +0100 | [diff] [blame] | 20 | - LDFLAGS="-L${OPENSSL_DIR}/lib" |
| 21 | # Set rpath with env var instead of -Wl,-rpath linker flag |
| 22 | # OpenSSL ignores LDFLAGS when linking bin/openssl |
| 23 | - LD_RUN_PATH="${OPENSSL_DIR}/lib" |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 24 | |
Donald Stufft | 984eef7 | 2017-02-14 20:21:32 -0500 | [diff] [blame] | 25 | branches: |
| 26 | only: |
| 27 | - master |
| 28 | - /^\d\.\d$/ |
| 29 | |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 30 | matrix: |
Brett Cannon | b52260d | 2017-02-14 16:37:15 -0800 | [diff] [blame] | 31 | fast_finish: true |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 32 | allow_failures: |
Brett Cannon | 21c2dd7 | 2017-06-03 10:24:17 -0700 | [diff] [blame] | 33 | - env: OPTIONAL=true |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 34 | include: |
| 35 | - os: linux |
Hiro Asari | a5aa72a | 2017-05-31 18:34:00 -0400 | [diff] [blame] | 36 | language: c |
| 37 | compiler: clang |
| 38 | # gcc also works, but to keep the # of concurrent builds down, we use one C |
Brett Cannon | 21c2dd7 | 2017-06-03 10:24:17 -0700 | [diff] [blame] | 39 | # compiler here and the other to run the coverage build. Clang is preferred |
| 40 | # in this instance for its better error messages. |
| 41 | env: TESTING=cpython |
Hiro Asari | a5aa72a | 2017-05-31 18:34:00 -0400 | [diff] [blame] | 42 | - os: linux |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 43 | language: python |
Brett Cannon | 31b3901 | 2017-05-11 10:45:34 -0700 | [diff] [blame] | 44 | # Build the docs against a stable version of Python so code bugs don't hold up doc-related PRs. |
Brett Cannon | ad2f9e2 | 2017-03-27 16:39:54 -0700 | [diff] [blame] | 45 | python: 3.6 |
Brett Cannon | 21c2dd7 | 2017-06-03 10:24:17 -0700 | [diff] [blame] | 46 | env: TESTING=docs |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 47 | before_script: |
Zachary Ware | 5325197 | 2017-02-15 16:18:03 -0600 | [diff] [blame] | 48 | - cd Doc |
Mariatta | fca224f | 2017-05-16 13:48:25 -0700 | [diff] [blame] | 49 | # Sphinx is pinned so that new versions that introduce new warnings won't suddenly cause build failures. |
| 50 | # (Updating the version is fine as long as no warnings are raised by doing so.) |
Ned Deily | fcd97d4 | 2017-09-05 00:10:31 -0700 | [diff] [blame] | 51 | - python -m pip install sphinx~=1.6.1 blurb |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 52 | script: |
Ned Deily | 122fc13 | 2017-11-27 17:07:32 -0500 | [diff] [blame] | 53 | - make check suspicious html SPHINXOPTS="-q -W -j4" |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 54 | - os: linux |
| 55 | language: c |
Brett Cannon | ad2f9e2 | 2017-03-27 16:39:54 -0700 | [diff] [blame] | 56 | compiler: gcc |
Brett Cannon | 21c2dd7 | 2017-06-03 10:24:17 -0700 | [diff] [blame] | 57 | env: OPTIONAL=true |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 58 | before_script: |
Berker Peksag | 157c0b8 | 2017-02-14 12:57:26 +0300 | [diff] [blame] | 59 | - | |
Zachary Ware | c53b13b | 2017-06-05 18:42:17 -0500 | [diff] [blame] | 60 | if ! git diff --name-only $TRAVIS_COMMIT_RANGE | grep -qvE '(\.rst$)|(^Doc)|(^Misc)' |
Berker Peksag | 157c0b8 | 2017-02-14 12:57:26 +0300 | [diff] [blame] | 61 | then |
| 62 | echo "Only docs were updated, stopping build process." |
| 63 | exit |
| 64 | fi |
Christian Heimes | ced9cb5 | 2018-01-16 21:02:26 +0100 | [diff] [blame] | 65 | python3 Tools/ssl/multissltests.py --steps=library \ |
| 66 | --base-directory ${HOME}/multissl \ |
| 67 | --openssl ${OPENSSL} >/dev/null |
| 68 | openssl version |
Berker Peksag | 157c0b8 | 2017-02-14 12:57:26 +0300 | [diff] [blame] | 69 | ./configure |
| 70 | make -s -j4 |
| 71 | # Need a venv that can parse covered code. |
| 72 | ./python -m venv venv |
| 73 | ./venv/bin/python -m pip install -U coverage |
Victor Stinner | b907abc | 2017-08-17 16:40:51 +0200 | [diff] [blame] | 74 | ./venv/bin/python -m test.pythoninfo |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 75 | script: |
| 76 | # Skip tests that re-run the entire test suite. |
Thomas Moreau | e8c368d | 2017-10-03 11:53:17 +0200 | [diff] [blame] | 77 | - ./venv/bin/python -m coverage run --pylib -m test --fail-env-changed -uall,-cpu -x test_multiprocessing_fork -x test_multiprocessing_forkserver -x test_multiprocessing_spawn -x test_concurrent_futures |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 78 | after_script: # Probably should be after_success once test suite updated to run under coverage.py. |
| 79 | # Make the `coverage` command available to Codecov w/ a version of Python that can parse all source files. |
| 80 | - source ./venv/bin/activate |
| 81 | - bash <(curl -s https://codecov.io/bash) |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 82 | |
Zachary Ware | c53b13b | 2017-06-05 18:42:17 -0500 | [diff] [blame] | 83 | # Travis provides only 2 cores, so don't overdo the parallelism and waste memory. |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 84 | before_script: |
Berker Peksag | 157c0b8 | 2017-02-14 12:57:26 +0300 | [diff] [blame] | 85 | - | |
Zachary Ware | 0afbabe | 2017-06-10 21:37:40 -0500 | [diff] [blame] | 86 | set -e |
Ammar Askar | b2ec361 | 2018-01-27 15:53:56 -0500 | [diff] [blame] | 87 | if [ "$TRAVIS_PULL_REQUEST" = "false" ]; then |
| 88 | files_changed=$(git diff --name-only $TRAVIS_COMMIT_RANGE) |
| 89 | else |
| 90 | # Pull requests are slightly complicated because merging the PR commit without |
| 91 | # rebasing causes it to retain its old commit date. Meaning in history if any |
| 92 | # commits have been made on master that post-date it, they will be accidentally |
| 93 | # included in the diff if we use the TRAVIS_COMMIT_RANGE variable. |
| 94 | files_changed=$(git diff --name-only HEAD $(git merge-base HEAD $TRAVIS_BRANCH)) |
| 95 | fi |
| 96 | |
| 97 | # Prints changed files in this commit to help debug doc-only build issues. |
| 98 | echo "Files changed: " |
| 99 | echo $files_changed |
| 100 | |
Stéphane Wirtel | 32921f9 | 2018-02-08 20:14:59 +0100 | [diff] [blame] | 101 | if ! echo "$files_changed" | grep -qvE '(\.rst$)|(^Doc)|(^Misc)' |
Berker Peksag | 157c0b8 | 2017-02-14 12:57:26 +0300 | [diff] [blame] | 102 | then |
| 103 | echo "Only docs were updated, stopping build process." |
| 104 | exit |
| 105 | fi |
Christian Heimes | ced9cb5 | 2018-01-16 21:02:26 +0100 | [diff] [blame] | 106 | if [ "${TESTING}" != "docs" ]; then |
| 107 | # clang complains about unused-parameter a lot, redirect stderr |
| 108 | python3 Tools/ssl/multissltests.py --steps=library \ |
| 109 | --base-directory ${HOME}/multissl \ |
| 110 | --openssl ${OPENSSL} >/dev/null 2>&1 |
| 111 | fi |
| 112 | openssl version |
Berker Peksag | 157c0b8 | 2017-02-14 12:57:26 +0300 | [diff] [blame] | 113 | ./configure --with-pydebug |
| 114 | make -j4 |
Zachary Ware | 0afbabe | 2017-06-10 21:37:40 -0500 | [diff] [blame] | 115 | make -j4 regen-all clinic |
Zachary Ware | 3f8f16d | 2017-06-10 23:04:36 -0500 | [diff] [blame] | 116 | changes=`git status --porcelain` |
| 117 | if ! test -z "$changes" |
Zachary Ware | 0afbabe | 2017-06-10 21:37:40 -0500 | [diff] [blame] | 118 | then |
| 119 | echo "Generated files not up to date" |
Zachary Ware | 3f8f16d | 2017-06-10 23:04:36 -0500 | [diff] [blame] | 120 | echo "$changes" |
Zachary Ware | 0afbabe | 2017-06-10 21:37:40 -0500 | [diff] [blame] | 121 | exit 1 |
| 122 | fi |
Victor Stinner | 92b1f90 | 2017-08-18 17:30:51 +0200 | [diff] [blame] | 123 | make pythoninfo |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 124 | |
| 125 | script: |
Brett Cannon | 70cb187 | 2017-06-24 16:51:23 -0700 | [diff] [blame] | 126 | # Using the built Python as patchcheck.py is built around the idea of using |
| 127 | # a checkout-build of CPython to know things like what base branch the changes |
| 128 | # should be compared against. |
| 129 | # Only run on Linux as the check only needs to be run once. |
| 130 | - if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then ./python Tools/scripts/patchcheck.py --travis $TRAVIS_PULL_REQUEST; fi |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 131 | # `-r -w` implicitly provided through `make buildbottest`. |
Victor Stinner | 5b392bb | 2017-07-20 15:46:32 +0200 | [diff] [blame] | 132 | - make buildbottest TESTOPTS="-j4 -uall,-cpu" |
Victor Stinner | 87d332d | 2017-10-24 01:29:53 -0700 | [diff] [blame] | 133 | # Check that all symbols exported by libpython start with "Py" or "_Py" |
| 134 | - make smelly |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 135 | |
| 136 | notifications: |
| 137 | email: false |
| 138 | irc: |
| 139 | channels: |
Donald Stufft | 4538ddc | 2017-02-10 19:58:34 -0500 | [diff] [blame] | 140 | # This is set to a secure variable to prevent forks from notifying the |
| 141 | # IRC channel whenever they fail a build. This can be removed when travis |
| 142 | # implements https://github.com/travis-ci/travis-ci/issues/1094. |
| 143 | # The actual value here is: irc.freenode.net#python-dev |
| 144 | - secure: "s7kAkpcom2yUJ8XqyjFI0obJmhAGrn1xmoivdaPdgBIA++X47TBp1x4pgDsbEsoalef7bEwa4l07KdT4qa+DOd/c4QxaWom7fbN3BuLVsZuVfODnl79+gYq/TAbGfyH+yDs18DXrUfPgwD7C5aW32ugsqAOd4iWzfGJQ5OrOZzqzGjYdYQUEkJFXgxDEIb4aHvxNDWGO3Po9uKISrhb5saQ0l776yLo1Ur7M4oxl8RTbCdgX0vf5TzPg52BgvZpOgt3DHOUYPeiJLKNjAE6ibg0U95sEvMfHX77nz4aFY4/3UI6FFaRla34rZ+mYKrn0TdxOhera1QOgPmM6HzdO4K44FpfK1DS0Xxk9U9/uApq+cG0bU3W+cVUHDBe5+90lpRBAXHeHCgT7TI8gec614aiT8lEr3+yH8OBRYGzkjNK8E2LJZ/SxnVxDe7aLF6AWcoWLfS6/ziAIBFQ5Nc4U72CT8fGVSkl8ywPiRlvixKdvTODMSZo0jMqlfZSNaAPTsNRx4wu5Uis4qekwe32Fz4aB6KGpsuuVjBi+H6v0RKxNJNGY3JKDiEH2TK0UE2auJ5GvLW48aUVFcQMB7euCWYXlSWVRHh3WLU8QXF29Dw4JduRZqUpOdRgMHU79UHRq+mkE0jAS/nBcS6CvsmxCpTSrfVYuMOu32yt18QQoTyU=" |
Brett Cannon | bb09c86 | 2017-02-10 14:21:15 -0800 | [diff] [blame] | 145 | on_success: change |
| 146 | on_failure: always |
| 147 | skip_join: true |