Fix PGO Build for clang
[stockfish] / .travis.yml
1 language: cpp
2 sudo: required
3 dist: trusty
4
5 matrix:
6   include:
7     - os: linux
8       compiler: gcc
9       addons:
10         apt:
11           sources: ['ubuntu-toolchain-r-test']
12           packages: ['g++-6', 'g++-6-multilib', 'g++-multilib', 'valgrind', 'expect']
13       env:
14         - COMPILER=g++-6
15         - COMP=gcc
16
17     - os: linux
18       compiler: clang
19       addons:
20         apt:
21           sources: ['ubuntu-toolchain-r-test']
22           packages: ['clang', 'g++-multilib', 'valgrind', 'expect']
23       env:
24         - COMPILER=clang++
25         - COMP=clang
26
27     - os: osx
28       compiler: gcc
29       env:
30         - COMPILER=g++
31         - COMP=gcc
32
33     - os: osx
34       compiler: clang
35       env:
36         - COMPILER=clang++ V='Apple LLVM 6.0' # Apple LLVM version 6.0 (clang-600.0.54) (based on LLVM 3.5svn)
37         - COMP=clang
38
39 branches:
40   only:
41    - master
42
43 before_script:
44   - cd src
45
46 script:
47   - make clean && make build ARCH=x86-64 && ./stockfish bench 2>&1 >/dev/null | grep 'Nodes searched' | tee bench1
48   - make clean && make build ARCH=x86-32 && ./stockfish bench 2>&1 >/dev/null | grep 'Nodes searched' | tee bench2
49   - echo "Checking for same bench numbers..."
50   - diff bench1 bench2 > result
51   - test ! -s result
52   # verify perft numbers (positions from https://chessprogramming.wikispaces.com/Perft+Results)
53   - printf ' set timeout 10\n lassign $argv pos depth result\n spawn ./stockfish\n send "position $pos\\n perft $depth\\n"\n expect "Nodes searched  ? $result" {} timeout {exit 1} \n send "quit\\n"\n expect eof\n' > perft.exp
54   - expect perft.exp startpos 5 4865609 > /dev/null
55   - expect perft.exp "fen r3k2r/p1ppqpb1/bn2pnp1/3PN3/1p2P3/2N2Q1p/PPPBBPPP/R3K2R w KQkq -" 5 193690690 > /dev/null
56   - expect perft.exp "fen 8/2p5/3p4/KP5r/1R3p1k/8/4P1P1/8 w - -" 6 11030083 > /dev/null
57   - expect perft.exp "fen r3k2r/Pppp1ppp/1b3nbN/nP6/BBP1P3/q4N2/Pp1P2PP/R2Q1RK1 w kq - 0 1" 5 15833292 > /dev/null
58   - expect perft.exp "fen rnbq1k1r/pp1Pbppp/2p5/8/2B5/8/PPP1NnPP/RNBQK2R w KQ - 1 8" 5 89941194 > /dev/null
59   - expect perft.exp "fen r4rk1/1pp1qppp/p1np1n2/2b1p1B1/2B1P1b1/P1NP1N2/1PP1QPPP/R4RK1 w - - 0 10" 5 164075551 > /dev/null
60   # if valgrind is available check the build is without error, reduce depth to speedup testing, but not too shallow to catch more cases.
61   - if [ -x "$(command -v valgrind )" ] ; then make clean && make ARCH=x86-64 debug=yes build && valgrind --error-exitcode=42 ./stockfish bench 128 1 10 default depth 1>/dev/null ; fi
62   # use g++-6 as a proxy for having sanitizers ... might need revision as they become available for more recent versions of clang/gcc than trusty provides
63   - if [[ "$COMPILER" == "g++-6" ]]; then make clean && make ARCH=x86-64 sanitize=yes build && ! ./stockfish bench 2>&1 | grep "runtime error:" ; fi