From: Marco Costalba Date: Wed, 16 Aug 2017 09:28:54 +0000 (-0700) Subject: Speed up Trevis CI X-Git-Url: https://git.sesse.net/?p=stockfish;a=commitdiff_plain;h=4d511512d2a74d60917bc1a749c3b35eb143118b Speed up Trevis CI Avoid a couple of redundant rebuilds and compile with 2 threads since travis gives 2vCPUs. Also enable -O1 optimization for valgrind and sanitizers, it should be safe withouth false positives and it gives a very sensible speed up, especially with valgrind. The spee dup allow us to increase testing to depth 10, useful for thread sanitizer. No functional change. --- diff --git a/.travis.yml b/.travis.yml index ba20fdc8..c42badd4 100644 --- a/.travis.yml +++ b/.travis.yml @@ -44,33 +44,28 @@ before_script: - cd src script: - # - # checking bench for various build types - # - # obtain reference from git log + # Obtain bench reference from git log - git log HEAD | grep "\b[Bb]ench[ :]\+[0-9]\{7\}" | head -n 1 | sed "s/[^0-9]*\([0-9][0-9]*\)/\1/g" > git_sig - export benchref=$(cat git_sig) - echo "Reference bench:" $benchref - # verify against reference - - make clean && make ARCH=x86-64 build > /dev/null && ../tests/signature.sh $benchref - - make clean && make ARCH=x86-32 build > /dev/null && ../tests/signature.sh $benchref - - make clean && make ARCH=x86-64 optimize=no debug=yes build > /dev/null && ../tests/signature.sh $benchref - - make clean && make ARCH=x86-32 optimize=no debug=yes build > /dev/null && ../tests/signature.sh $benchref - # - # perft - # - - make clean && make ARCH=x86-64 build > /dev/null && ../tests/perft.sh # - # reproducible search + # Verify bench number against various builds + - make clean && make -j2 ARCH=x86-64 optimize=no debug=yes build > /dev/null && ../tests/signature.sh $benchref + - make clean && make -j2 ARCH=x86-32 optimize=no debug=yes build > /dev/null && ../tests/signature.sh $benchref + - make clean && make -j2 ARCH=x86-32 build > /dev/null && ../tests/signature.sh $benchref + - make clean && make -j2 ARCH=x86-64 build > /dev/null && ../tests/signature.sh $benchref # - - make clean && make ARCH=x86-64 build > /dev/null && ../tests/reprosearch.sh + # Check perft and reproducible search + - ../tests/perft.sh + - ../tests/reprosearch.sh # - # valgrind + # Valgrind # - - if [ -x "$(command -v valgrind )" ]; then make clean && make ARCH=x86-64 debug=yes optimize=no build > /dev/null && ../tests/instrumented.sh --valgrind; fi + - export CXXFLAGS=-O1 + - if [ -x "$(command -v valgrind )" ]; then make clean && make -j2 ARCH=x86-64 debug=yes optimize=no build > /dev/null && ../tests/instrumented.sh --valgrind; fi # - # sanitizer + # Sanitizer # - # use g++-6 as a proxy for having sanitizers, might need revision as they become available for more recent versions of clang/gcc - - if [[ "$COMPILER" == "g++-6" ]]; then make clean && make ARCH=x86-64 sanitize=undefined optimize=no debug=yes build > /dev/null && ../tests/instrumented.sh --sanitizer-undefined; fi - - if [[ "$COMPILER" == "g++-6" ]]; then make clean && make ARCH=x86-64 sanitize=thread optimize=no debug=yes build > /dev/null && ../tests/instrumented.sh --sanitizer-thread; fi + # Use g++-6 as a proxy for having sanitizers, might need revision as they become available for more recent versions of clang/gcc + - if [[ "$COMPILER" == "g++-6" ]]; then make clean && make -j2 ARCH=x86-64 sanitize=undefined optimize=no debug=yes build > /dev/null && ../tests/instrumented.sh --sanitizer-undefined; fi + - if [[ "$COMPILER" == "g++-6" ]]; then make clean && make -j2 ARCH=x86-64 sanitize=thread optimize=no debug=yes build > /dev/null && ../tests/instrumented.sh --sanitizer-thread; fi diff --git a/tests/instrumented.sh b/tests/instrumented.sh index 7eaa2160..878d6cb0 100755 --- a/tests/instrumented.sh +++ b/tests/instrumented.sh @@ -62,7 +62,7 @@ for args in "eval" \ "go depth 10" \ "go movetime 1000" \ "go wtime 8000 btime 8000 winc 500 binc 500" \ - "bench 128 $threads 9 default depth" + "bench 128 $threads 10 default depth" do echo "$prefix $exeprefix ./stockfish $args $postfix"