X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=scripts%2Fci%2Frun-jenkins.sh;h=4eeedc730de5cb9b01d36713c73f501d2a5ff564;hb=ef684b2041bfc73c16802ad017304963d7c9038a;hp=13890c1051ff1b880ce6379ee7180651d6b73eb0;hpb=9281d4a7e6a644a73c87819139a5d3047052c1bb;p=mono.git diff --git a/scripts/ci/run-jenkins.sh b/scripts/ci/run-jenkins.sh index 13890c1051f..4eeedc730de 100755 --- a/scripts/ci/run-jenkins.sh +++ b/scripts/ci/run-jenkins.sh @@ -5,7 +5,13 @@ export TESTCMD=${MONO_REPO_ROOT}/scripts/ci/run-step.sh export TEST_HARNESS_VERBOSE=1 -if [[ ${label} == w* ]]; then +if [[ $CI_TAGS == *'collect-coverage'* ]]; then + # Collect coverage for further use by lcov and similar tools. + # Coverage must be collected with -O0 and debug information. + export CFLAGS="-ggdb3 --coverage -O0" + # Collect coverage on all optimizations + export MONO_ENV_OPTIONS="$MONO_ENV_OPTIONS -O=all" +elif [[ ${label} == w* ]]; then # Passing -ggdb3 on Cygwin breaks linking against libmonosgen-x.y.dll export CFLAGS="-g -O2" else @@ -19,10 +25,11 @@ if [[ ${label} == 'w64' ]]; then PLATFORM=x64; EXTRA_CONF_FLAGS="${EXTRA_CONF_FL if [[ ${CI_TAGS} == *'coop-gc'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --with-cooperative-gc=yes"; fi -if [[ ${CI_TAGS} == *'checked-coop'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --enable-checked-build=gc,thread"; export MONO_CHECK_MODE=gc,thread; fi -if [[ ${CI_TAGS} == *'checked-all'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --enable-checked-build=all"; export MONO_CHECK_MODE=all; fi +if [[ ${CI_TAGS} == *'checked-coop'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --enable-checked-build=gc,thread"; fi +if [[ ${CI_TAGS} == *'checked-all'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --enable-checked-build=all"; fi if [[ ${CI_TAGS} == *'mcs-compiler'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --with-csc=mcs"; fi +if [[ ${CI_TAGS} == *'disable-mcs-build'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --disable-mcs-build"; fi if [[ ${CI_TAGS} == *'fullaot_llvm'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --enable-llvm=yes --with-runtime_preset=fullaot "; elif [[ ${CI_TAGS} == *'hybridaot_llvm'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --enable-llvm=yes --with-runtime_preset=hybridaot"; @@ -32,7 +39,7 @@ elif [[ ${CI_TAGS} == *'hybridaot'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_ elif [[ ${CI_TAGS} == *'winaot'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --with-runtime_preset=winaot"; elif [[ ${CI_TAGS} == *'aot'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --with-runtime_preset=aot"; elif [[ ${CI_TAGS} == *'bitcode'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --with-runtime_preset=bitcode"; -elif [[ ${CI_TAGS} == *'interpreter'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --with-interpreter=yes"; +elif [[ ${CI_TAGS} == *'interpreter'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --enable-interpreter"; elif [[ ${CI_TAGS} == *'acceptance-tests'* ]]; then EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --prefix=${MONO_REPO_ROOT}/tmp/mono-acceptance-tests --with-sgen-default-concurrent=yes"; elif [[ ${label} != w* ]] && [[ ${label} != 'debian-8-ppc64el' ]] && [[ ${label} != 'centos-s390x' ]] && [[ ${CI_TAGS} != *'monolite'* ]]; then @@ -42,6 +49,10 @@ elif [[ ${label} != w* ]] && [[ ${label} != 'debian-8-ppc64el' ]] && [[ ${label} if [[ ${label} == 'ubuntu-1404-amd64' ]]; then # only enable build of the additional profiles on one architecture to save time EXTRA_CONF_FLAGS="${EXTRA_CONF_FLAGS} --with-runtime_preset=all" + # when building profiles like monotouch/monodroid which don't build System.Drawing.dll in the Mono repo we need + # to build the facades against _something_ to satisfy the typeforwards. In CI we can cheat a little and pass + # them System.Drawing.dll from the 'build' profile since we don't test those profiles here (we just ensure they compile). + export EXTERNAL_FACADE_DRAWING_REFERENCE=${MONO_REPO_ROOT}/mcs/class/lib/build/System.Drawing.dll fi fi @@ -50,7 +61,7 @@ if [ -x "/usr/bin/dpkg-architecture" ]; EXTRA_CONF_FLAGS="$EXTRA_CONF_FLAGS --host=`/usr/bin/dpkg-architecture -qDEB_HOST_GNU_TYPE`" #force build arch = dpkg arch, sometimes misdetected mkdir -p ~/.config/.mono/ - wget -qO- http://download.mono-project.com/test/new-certs.tgz| tar zx -C ~/.config/.mono/ + wget -qO- https://download.mono-project.com/test/new-certs.tgz| tar zx -C ~/.config/.mono/ fi ${TESTCMD} --label=configure --timeout=60m --fatal ./autogen.sh $EXTRA_CONF_FLAGS @@ -79,12 +90,18 @@ if [[ ${label} == 'debian-8-ppc64el' ]]; then make_parallelism=-j1; fi ${TESTCMD} --label=make --timeout=300m --fatal make ${make_parallelism} -w V=1 +if [[ ${CI_TAGS} == *'checked-coop'* ]]; then export MONO_CHECK_MODE=gc,thread; fi +if [[ ${CI_TAGS} == *'checked-all'* ]]; then export MONO_CHECK_MODE=all; fi + if [[ ${CI_TAGS} == *'acceptance-tests'* ]]; then $(dirname "${BASH_SOURCE[0]}")/run-test-acceptance-tests.sh elif [[ ${CI_TAGS} == *'profiler-stress-tests'* ]]; then - $(dirname "${BASH_SOURCE[0]}")/run-test-profiler-stress-tests.sh + $(dirname "${BASH_SOURCE[0]}")/run-test-profiler-stress-tests.sh +elif [[ ${CI_TAGS} == *'stress-tests'* ]]; + then + $(dirname "${BASH_SOURCE[0]}")/run-test-stress-tests.sh elif [[ ${CI_TAGS} == *'interpreter'* ]]; then $(dirname "${BASH_SOURCE[0]}")/run-test-interpreter.sh