# This script executes the script step when running under travis-ci
+#if cygwin, check path
+case ${MACHTYPE} in
+ *cygwin*) OPJ_CI_IS_CYGWIN=1;;
+ *) ;;
+esac
+
+if [ "${OPJ_CI_IS_CYGWIN:-}" == "1" ]; then
+ # Hack for appveyor
+ if ! which wget; then
+ # PATH is not yet set up
+ export PATH=$PATH:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin
+ fi
+fi
+
# Set-up some bash options
set -o nounset ## set -u : exit the script if you try to use an uninitialised variable
set -o errexit ## set -e : exit the script if any statement returns a non-true return value
set -o pipefail ## Fail on error in pipe
+# ABI check is done by abi-check.sh
+if [ "${OPJ_CI_ABI_CHECK:-}" == "1" ]; then
+ exit 0
+fi
+
# Set-up some variables
+if [ "${OPJ_CI_BUILD_CONFIGURATION:-}" == "" ]; then
+ export OPJ_CI_BUILD_CONFIGURATION=Release #default
+fi
OPJ_SOURCE_DIR=$(cd $(dirname $0)/../.. && pwd)
-OPJ_DO_SUBMIT=0 # Do not flood cdash
+if [ "${OPJ_DO_SUBMIT:-}" == "" ]; then
+ OPJ_DO_SUBMIT=0 # Do not flood cdash by default
+fi
if [ "${TRAVIS_REPO_SLUG:-}" != "" ]; then
OPJ_OWNER=$(echo "${TRAVIS_REPO_SLUG}" | sed 's/\(^.*\)\/.*/\1/')
OPJ_SITE="${OPJ_OWNER}.travis-ci.org"
# default to gcc
export CC=gcc
fi
+ elif uname -s | grep -i CYGWIN &> /dev/null; then
+ TRAVIS_OS_NAME=windows
else
echo "Failed to guess OS"; exit 1
fi
if which lsb_release > /dev/null; then
OPJ_OS_NAME=$(lsb_release -si)$(lsb_release -sr | sed 's/\([^0-9]*\.[0-9]*\).*/\1/')
fi
- if [ "${CC}" == "gcc" ]; then
- OPJ_CC_VERSION=gcc$(${CC} --version | head -1 | sed 's/.*\ \([0-9.]*[0-9]\)/\1/')
- elif [ "${CC}" == "clang" ]; then
+ if [ -z "${CC##*gcc*}" ]; then
+ OPJ_CC_VERSION=$(${CC} --version | head -1 | sed 's/.*\ \([0-9.]*[0-9]\)/\1/')
+ if [ -z "${CC##*mingw*}" ]; then
+ OPJ_CC_VERSION=mingw${OPJ_CC_VERSION}
+ # disable testing for now
+ export OPJ_CI_SKIP_TESTS=1
+ else
+ OPJ_CC_VERSION=gcc${OPJ_CC_VERSION}
+ fi
+ elif [ -z "${CC##*clang*}" ]; then
OPJ_CC_VERSION=clang$(${CC} --version | grep version | sed 's/.*version \([^0-9.]*[0-9.]*\).*/\1/')
else
- echo "Compiler not supported: ${CC}"
+ echo "Compiler not supported: ${CC}"; exit 1
fi
+elif [ "${TRAVIS_OS_NAME}" == "windows" ]; then
+ OPJ_OS_NAME=windows
+ OPJ_CC_VERSION=vs2015
else
- echo "OS not supported: ${TRAVIS_OS_NAME}"
+ echo "OS not supported: ${TRAVIS_OS_NAME}"; exit 1
+fi
+
+if [ "${OPJ_CI_ARCH:-}" == "" ]; then
+ echo "Guessing build architecture"
+ MACHINE_ARCH=$(uname -m)
+ if [ "${MACHINE_ARCH}" == "x86_64" ]; then
+ export OPJ_CI_ARCH=x86_64
+ fi
+ echo "${OPJ_CI_ARCH}"
fi
if [ "${TRAVIS_BRANCH:-}" == "" ]; then
- echo "Guessing branch"
- TRAVIS_BRANCH=$(git -C ../openjpeg branch | grep '*' | tr -d '*[[:blank:]]') #default to master
+ if [ "${APPVEYOR_REPO_BRANCH:-}" != "" ]; then
+ TRAVIS_BRANCH=${APPVEYOR_REPO_BRANCH}
+ else
+ echo "Guessing branch"
+ TRAVIS_BRANCH=$(git -C ${OPJ_SOURCE_DIR} branch | grep '*' | tr -d '*[[:blank:]]')
+ fi
fi
-OPJ_BUILDNAME=${OPJ_OS_NAME}-${OPJ_CC_VERSION}-${TRAVIS_BRANCH}
+OPJ_BUILDNAME=${OPJ_OS_NAME}-${OPJ_CC_VERSION}-${OPJ_CI_ARCH}-${TRAVIS_BRANCH}
+OPJ_BUILDNAME_TEST=${OPJ_OS_NAME}-${OPJ_CC_VERSION}-${OPJ_CI_ARCH}
if [ "${TRAVIS_PULL_REQUEST:-}" != "false" ] && [ "${TRAVIS_PULL_REQUEST:-}" != "" ]; then
OPJ_BUILDNAME=${OPJ_BUILDNAME}-pr${TRAVIS_PULL_REQUEST}
+elif [ "${APPVEYOR_PULL_REQUEST_NUMBER:-}" != "" ]; then
+ OPJ_BUILDNAME=${OPJ_BUILDNAME}-pr${APPVEYOR_PULL_REQUEST_NUMBER}
+fi
+OPJ_BUILDNAME=${OPJ_BUILDNAME}-${OPJ_CI_BUILD_CONFIGURATION}-3rdP
+OPJ_BUILDNAME_TEST=${OPJ_BUILDNAME_TEST}-${OPJ_CI_BUILD_CONFIGURATION}-3rdP
+if [ "${OPJ_CI_ASAN:-}" == "1" ]; then
+ OPJ_BUILDNAME=${OPJ_BUILDNAME}-ASan
+ OPJ_BUILDNAME_TEST=${OPJ_BUILDNAME_TEST}-ASan
fi
-OPJ_BUILDNAME=${OPJ_BUILDNAME}-Release-3rdP
-if [ "${OPJ_NONCOMMERCIAL:-}" == "1" ] && [ -d kdu ]; then
+if [ "${OPJ_NONCOMMERCIAL:-}" == "1" ] && [ "${OPJ_CI_SKIP_TESTS:-}" != "1" ] && [ -d kdu ]; then
echo "
Testing will use Kakadu trial binaries. Here's the copyright notice from kakadu:
Copyright is owned by NewSouth Innovations Pty Limited, commercial arm of the UNSW Australia in Sydney.
"
fi
+if [ -d cmake-install ]; then
+ export PATH=${PWD}/cmake-install/bin:${PATH}
+fi
+
set -x
-if [ "${OPJ_NONCOMMERCIAL:-}" == "1" ] && [ -d kdu ]; then
- if [ "${TRAVIS_OS_NAME}" == "linux" ]; then
- export LD_LIBRARY_PATH=${PWD}/kdu:${LD_LIBRARY_PATH}
+# This will print configuration
+# travis-ci doesn't dump cmake version in system info, let's print it
+cmake --version
+
+export OPJ_SITE=${OPJ_SITE}
+export OPJ_BUILDNAME=${OPJ_BUILDNAME}
+export OPJ_SOURCE_DIR=${OPJ_SOURCE_DIR}
+export OPJ_BUILD_CONFIGURATION=${OPJ_CI_BUILD_CONFIGURATION}
+export OPJ_DO_SUBMIT=${OPJ_DO_SUBMIT}
+
+ctest -S ${OPJ_SOURCE_DIR}/tools/ctest_scripts/travis-ci.cmake -V || true
+# ctest will exit with various error codes depending on version.
+# ignore ctest exit code & parse this ourselves
+set +x
+
+# let's parse configure/build/tests for failure
+
+echo "
+Parsing logs for failures
+"
+OPJ_CI_RESULT=0
+
+# 1st configure step
+OPJ_CONFIGURE_XML=$(find build -path 'build/Testing/*' -name 'Configure.xml')
+if [ ! -f "${OPJ_CONFIGURE_XML}" ]; then
+ echo "No configure log found"
+ OPJ_CI_RESULT=1
+else
+ if ! grep '<ConfigureStatus>0</ConfigureStatus>' ${OPJ_CONFIGURE_XML} &> /dev/null; then
+ echo "Errors were found in configure log"
+ OPJ_CI_RESULT=1
+ fi
+fi
+
+# 2nd build step
+# We must have one Build.xml file
+OPJ_BUILD_XML=$(find build -path 'build/Testing/*' -name 'Build.xml')
+if [ ! -f "${OPJ_BUILD_XML}" ]; then
+ echo "No build log found"
+ OPJ_CI_RESULT=1
+else
+ if grep '<Error>' ${OPJ_BUILD_XML} &> /dev/null; then
+ echo "Errors were found in build log"
+ OPJ_CI_RESULT=1
+ fi
+fi
+
+if [ ${OPJ_CI_RESULT} -ne 0 ]; then
+ # Don't trash output with failing tests when there are configure/build errors
+ exit ${OPJ_CI_RESULT}
+fi
+
+if [ "${OPJ_CI_SKIP_TESTS:-}" != "1" ]; then
+ OPJ_TEST_XML=$(find build -path 'build/Testing/*' -name 'Test.xml')
+ if [ ! -f "${OPJ_TEST_XML}" ]; then
+ echo "No test log found"
+ OPJ_CI_RESULT=1
+ else
+ echo "Parsing tests for new/unknown failures"
+ # 3rd test step
+ OPJ_FAILEDTEST_LOG=$(find build -path 'build/Testing/Temporary/*' -name 'LastTestsFailed_*.log')
+ if [ -f "${OPJ_FAILEDTEST_LOG}" ]; then
+ awk -F: '{ print $2 }' ${OPJ_FAILEDTEST_LOG} > failures.txt
+ while read FAILEDTEST; do
+ # Start with common errors
+ if grep -x "${FAILEDTEST}" ${OPJ_SOURCE_DIR}/tools/travis-ci/knownfailures-all.txt > /dev/null; then
+ continue
+ fi
+ if [ -f ${OPJ_SOURCE_DIR}/tools/travis-ci/knownfailures-${OPJ_BUILDNAME_TEST}.txt ]; then
+ if grep -x "${FAILEDTEST}" ${OPJ_SOURCE_DIR}/tools/travis-ci/knownfailures-${OPJ_BUILDNAME_TEST}.txt > /dev/null; then
+ continue
+ fi
+ fi
+ echo "${FAILEDTEST}"
+ OPJ_CI_RESULT=1
+ done < failures.txt
+ fi
+ fi
+
+ if [ ${OPJ_CI_RESULT} -eq 0 ]; then
+ echo "No new/unknown test failure found
+ "
+ else
+ echo "
+New/unknown test failure found!!!
+ "
+ fi
+
+ # 4th memcheck step
+ OPJ_MEMCHECK_XML=$(find build -path 'build/Testing/*' -name 'DynamicAnalysis.xml')
+ if [ -f "${OPJ_MEMCHECK_XML}" ]; then
+ if grep '<Defect Type' ${OPJ_MEMCHECK_XML} 2> /dev/null; then
+ echo "Errors were found in dynamic analysis log"
+ OPJ_CI_RESULT=1
+ fi
fi
- export PATH=${PWD}/kdu:${PATH}
fi
-mkdir build
-cd build
-cmake -G "Unix Makefiles" -DCMAKE_BUILD_TYPE=Release -DBUILD_CODEC=ON -DBUILD_THIRDPARTY=ON -DBUILD_TESTING=ON -DOPJ_DATA_ROOT=${PWD}/../data -DJPYLYZER_EXECUTABLE=${PWD}/../jpylyzer/jpylyzer/jpylyzer.py -DSITE=${OPJ_SITE} -DBUILDNAME=${OPJ_BUILDNAME} ${OPJ_SOURCE_DIR}
-ctest -D ExperimentalStart
-ctest -D ExperimentalBuild -V
-ctest -D ExperimentalTest -j2 || true
-ctest -D ExperimentalSubmit || true
+exit ${OPJ_CI_RESULT}